Commit f2a6c169 authored by Rémi Bernon's avatar Rémi Bernon Committed by Alexandre Julliard

ntdll: Use block helpers in create_free_block.

parent b4655f24
...@@ -691,45 +691,40 @@ static inline BOOL HEAP_Decommit( SUBHEAP *subheap, void *ptr ) ...@@ -691,45 +691,40 @@ static inline BOOL HEAP_Decommit( SUBHEAP *subheap, void *ptr )
static void create_free_block( SUBHEAP *subheap, struct block *block, SIZE_T block_size ) static void create_free_block( SUBHEAP *subheap, struct block *block, SIZE_T block_size )
{ {
const char *end = (char *)block + block_size, *commit_end = subheap_commit_end( subheap );
struct entry *entry = (struct entry *)block; struct entry *entry = (struct entry *)block;
HEAP *heap = subheap->heap; HEAP *heap = subheap->heap;
DWORD flags = heap->flags; DWORD flags = heap->flags;
char *end; struct block *next;
BOOL last;
mark_block_uninitialized( block, sizeof(*entry) ); mark_block_uninitialized( block, sizeof(*entry) );
block_set_type( block, ARENA_FREE_MAGIC ); block_set_type( block, ARENA_FREE_MAGIC );
block_set_size( block, ARENA_FLAG_FREE, block_size );
/* If debugging, erase the freed block content */ /* If debugging, erase the freed block content */
end = (char *)block + block_size; if (end > commit_end) end = commit_end;
if (end > (char *)subheap->base + subheap->commitSize)
end = (char *)subheap->base + subheap->commitSize;
if (end > (char *)(entry + 1)) mark_block_free( entry + 1, end - (char *)(entry + 1), flags ); if (end > (char *)(entry + 1)) mark_block_free( entry + 1, end - (char *)(entry + 1), flags );
if (((char *)block + block_size < (char *)subheap->base + subheap->size) && if ((next = next_block( subheap, block )) && (block_get_flags( next ) & ARENA_FLAG_FREE))
(*(DWORD *)((char *)block + block_size) & ARENA_FLAG_FREE))
{ {
/* merge with the next block if it is free */ /* merge with the next block if it is free */
struct entry *next_entry = (struct entry *)((char *)block + block_size); struct entry *next_entry = (struct entry *)next;
list_remove( &next_entry->entry ); list_remove( &next_entry->entry );
block_size += (next_entry->size & ARENA_SIZE_MASK) + sizeof(*next_entry); block_size += block_get_size( next );
mark_block_free( next_entry, sizeof(struct entry), flags ); block_set_size( block, ARENA_FLAG_FREE, block_size );
mark_block_free( next_entry, sizeof(*next_entry), flags );
} }
if ((next = next_block( subheap, block )))
last = ((char *)block + block_size >= (char *)subheap->base + subheap->size);
if (!last)
{ {
/* set the next block PREV_FREE flag and back pointer */ /* set the next block PREV_FREE flag and back pointer */
DWORD *next = (DWORD *)((char *)block + block_size); block_set_size( next, ARENA_FLAG_PREV_FREE, block_get_size( next ) );
*next |= ARENA_FLAG_PREV_FREE;
mark_block_initialized( (struct block **)next - 1, sizeof(struct block *) ); mark_block_initialized( (struct block **)next - 1, sizeof(struct block *) );
*((struct block **)next - 1) = block; *((struct block **)next - 1) = block;
} }
entry->size = (block_size - sizeof(*entry)) | ARENA_FLAG_FREE; HEAP_InsertFreeBlock( heap, entry, !next );
HEAP_InsertFreeBlock( subheap->heap, entry, last );
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment