mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	Fix memory leak when shared libxml.dll is unloaded
When a multiple modules (process/plugins) all link to libxml2.dll they will in fact share a single loaded instance of it. It is unsafe for any of them to call xmlCleanupParser, as this would deinitialize the shared state and break others that might still have ongoing use. However, on windows atexit is per-module (rather process-wide), so if used *within* libxml2 it is possible to register a clean up when all users are done and libxml2.dll is about to actually unload. This allows multiple plugins to link with and share libxml2 without a premature cleanup if one is unloaded, while still cleaning up if *all* such callers are themselves unloaded.
This commit is contained in:
		
				
					committed by
					
						 Nick Wellnhofer
						Nick Wellnhofer
					
				
			
			
				
	
			
			
			
						parent
						
							453bdfb95e
						
					
				
				
					commit
					c7c526d6d0
				
			
							
								
								
									
										4
									
								
								parser.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								parser.c
									
									
									
									
									
								
							| @@ -14741,6 +14741,10 @@ xmlInitParser(void) { | ||||
|     if (xmlParserInitialized != 0) | ||||
| 	return; | ||||
|  | ||||
| #if defined(WIN32) && (!defined(LIBXML_STATIC) || defined(LIBXML_STATIC_FOR_DLL)) | ||||
| 	atexit(xmlCleanupParser); | ||||
| #endif | ||||
|  | ||||
| #ifdef LIBXML_THREAD_ENABLED | ||||
|     __xmlGlobalInitMutexLock(); | ||||
|     if (xmlParserInitialized == 0) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user