Commit d3c0caa9 authored by marko's avatar marko

branches/zip: Simplify the interface to mem0pool.c.

mem_heap_create_block(): Compute len and call mem_area_alloc() only once.

mem_heap_block_free(): Call mem_area_free() only once.

Approved by Heikki.
parent 76dea7ad
...@@ -330,40 +330,33 @@ mem_heap_create_block( ...@@ -330,40 +330,33 @@ mem_heap_create_block(
} }
/* In dynamic allocation, calculate the size: block header + data. */ /* In dynamic allocation, calculate the size: block header + data. */
len = MEM_BLOCK_HEADER_SIZE + MEM_SPACE_NEEDED(n);
if (type == MEM_HEAP_DYNAMIC) { if (type == MEM_HEAP_DYNAMIC || len < UNIV_PAGE_SIZE / 2) {
ut_ad(type == MEM_HEAP_DYNAMIC || n <= MEM_MAX_ALLOC_IN_BUF);
len = MEM_BLOCK_HEADER_SIZE + MEM_SPACE_NEEDED(n);
block = mem_area_alloc(&len, mem_comm_pool); block = mem_area_alloc(&len, mem_comm_pool);
} else { } else {
ut_ad(n <= MEM_MAX_ALLOC_IN_BUF); len = UNIV_PAGE_SIZE;
len = MEM_BLOCK_HEADER_SIZE + MEM_SPACE_NEEDED(n);
if (len < UNIV_PAGE_SIZE / 2) {
block = mem_area_alloc(&len, mem_comm_pool); if ((type & MEM_HEAP_BTR_SEARCH) && heap) {
} else { /* We cannot allocate the block from the
len = UNIV_PAGE_SIZE; buffer pool, but must get the free block from
the heap header free block field */
if ((type & MEM_HEAP_BTR_SEARCH) && heap) {
/* We cannot allocate the block from the
buffer pool, but must get the free block from
the heap header free block field */
buf_block = heap->free_block; buf_block = heap->free_block;
heap->free_block = NULL; heap->free_block = NULL;
if (UNIV_UNLIKELY(!buf_block)) { if (UNIV_UNLIKELY(!buf_block)) {
return(NULL); return(NULL);
}
} else {
buf_block = buf_block_alloc(0);
} }
} else {
block = (mem_block_t*) buf_block->frame; buf_block = buf_block_alloc(0);
} }
block = (mem_block_t*) buf_block->frame;
} }
ut_ad(block); ut_ad(block);
...@@ -492,19 +485,14 @@ mem_heap_block_free( ...@@ -492,19 +485,14 @@ mem_heap_block_free(
UNIV_MEM_ASSERT_AND_FREE(block, len); UNIV_MEM_ASSERT_AND_FREE(block, len);
#endif /* UNIV_MEM_DEBUG */ #endif /* UNIV_MEM_DEBUG */
if (type == MEM_HEAP_DYNAMIC) { if (type == MEM_HEAP_DYNAMIC || len < UNIV_PAGE_SIZE / 2) {
ut_ad(!buf_block); ut_ad(!buf_block);
mem_area_free(block, mem_comm_pool); mem_area_free(block, mem_comm_pool);
} else { } else {
ut_ad(type & MEM_HEAP_BUFFER); ut_ad(type & MEM_HEAP_BUFFER);
if (len >= UNIV_PAGE_SIZE / 2) { buf_block_free(buf_block);
buf_block_free(buf_block);
} else {
ut_ad(!buf_block);
mem_area_free(block, mem_comm_pool);
}
} }
} }
......
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