mirror of
				https://github.com/mozilla/gecko-dev.git
				synced 2025-10-31 16:28:05 +02:00 
			
		
		
		
	 11ee6d0d0c
			
		
	
	
		11ee6d0d0c
		
	
	
	
	
		
			
			Check for double-free, use-after-free and offset problems involving C++ delete. There are currently no clang-analyzer-cplusplus.NewDelete warnings in mozilla-central! https://clang-analyzer.llvm.org/available_checks.html MozReview-Commit-ID: 9sVp4fc4JTj --HG-- extra : rebase_source : 733974ff07b873f6e5cd1e83104f82eafbf7f3c7 extra : source : 778684b276e6658fb9f3fa125aaec984cca8760a
		
			
				
	
	
		
			50 lines
		
	
	
	
		
			1,019 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
	
		
			1,019 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| // https://clang-analyzer.llvm.org/available_checks.html
 | |
| 
 | |
| void use(int *p);
 | |
| 
 | |
| void test_use_parameter_after_delete(int *p)
 | |
| {
 | |
|   delete p;
 | |
|   use(p); // warning: use after free
 | |
| }
 | |
| 
 | |
| class SomeClass {
 | |
| public:
 | |
|   void f();
 | |
| };
 | |
| 
 | |
| void test_use_local_after_delete()
 | |
| {
 | |
|   SomeClass *c = new SomeClass;
 | |
|   delete c;
 | |
|   c->f(); // warning: use after free
 | |
| }
 | |
| 
 | |
| // XXX clang documentation says this should cause a warning but it doesn't!
 | |
| void test_delete_alloca()
 | |
| {
 | |
|   int *p = (int *)__builtin_alloca(sizeof(int));
 | |
|   delete p; // NO warning: deleting memory allocated by alloca
 | |
| }
 | |
| 
 | |
| void test_double_free()
 | |
| {
 | |
|   int *p = new int;
 | |
|   delete p;
 | |
|   delete p; // warning: attempt to free released
 | |
| }
 | |
| 
 | |
| void test_delete_local()
 | |
| {
 | |
|   int i;
 | |
|   delete &i; // warning: delete address of local
 | |
| }
 | |
| 
 | |
| // XXX clang documentation says this should cause a warning but it doesn't!
 | |
| void test_delete_offset()
 | |
| {
 | |
|   int *p = new int[1];
 | |
|   delete[] (++p);
 | |
|     // NO warning: argument to 'delete[]' is offset by 4 bytes
 | |
|     // from the start of memory allocated by 'new[]'
 | |
| }
 |