Add an option (controlled by an environment variable) perform extra
validations on mem_pool allocated cache entries. When set:
  1) Invalidate cache_entry memory when discarding cache_entry.
  2) When discarding index_state struct, verify that all cache_entries
     were allocated from expected mem_pool.
  3) When discarding mem_pools, invalidate mem_pool memory.
This should provide extra checks that mem_pools and their allocated
cache_entries are being used as expected.
Signed-off-by: Jameson Miller <jamill@microsoft.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
	
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef MEM_POOL_H
 | 
						|
#define MEM_POOL_H
 | 
						|
 | 
						|
struct mp_block {
 | 
						|
	struct mp_block *next_block;
 | 
						|
	char *next_free;
 | 
						|
	char *end;
 | 
						|
	uintmax_t space[FLEX_ARRAY]; /* more */
 | 
						|
};
 | 
						|
 | 
						|
struct mem_pool {
 | 
						|
	struct mp_block *mp_block;
 | 
						|
 | 
						|
	/*
 | 
						|
	 * The amount of available memory to grow the pool by.
 | 
						|
	 * This size does not include the overhead for the mp_block.
 | 
						|
	 */
 | 
						|
	size_t block_alloc;
 | 
						|
 | 
						|
	/* The total amount of memory allocated by the pool. */
 | 
						|
	size_t pool_alloc;
 | 
						|
};
 | 
						|
 | 
						|
/*
 | 
						|
 * Initialize mem_pool with specified initial size.
 | 
						|
 */
 | 
						|
void mem_pool_init(struct mem_pool **mem_pool, size_t initial_size);
 | 
						|
 | 
						|
/*
 | 
						|
 * Discard a memory pool and free all the memory it is responsible for.
 | 
						|
 */
 | 
						|
void mem_pool_discard(struct mem_pool *mem_pool, int invalidate_memory);
 | 
						|
 | 
						|
/*
 | 
						|
 * Alloc memory from the mem_pool.
 | 
						|
 */
 | 
						|
void *mem_pool_alloc(struct mem_pool *pool, size_t len);
 | 
						|
 | 
						|
/*
 | 
						|
 * Allocate and zero memory from the memory pool.
 | 
						|
 */
 | 
						|
void *mem_pool_calloc(struct mem_pool *pool, size_t count, size_t size);
 | 
						|
 | 
						|
/*
 | 
						|
 * Move the memory associated with the 'src' pool to the 'dst' pool. The 'src'
 | 
						|
 * pool will be empty and not contain any memory. It still needs to be free'd
 | 
						|
 * with a call to `mem_pool_discard`.
 | 
						|
 */
 | 
						|
void mem_pool_combine(struct mem_pool *dst, struct mem_pool *src);
 | 
						|
 | 
						|
/*
 | 
						|
 * Check if a memory pointed at by 'mem' is part of the range of
 | 
						|
 * memory managed by the specified mem_pool.
 | 
						|
 */
 | 
						|
int mem_pool_contains(struct mem_pool *mem_pool, void *mem);
 | 
						|
 | 
						|
#endif
 |