summaryrefslogtreecommitdiffstats
path: root/src/core/malloc.c
diff options
context:
space:
mode:
authorMichael Brown2006-04-25 23:48:16 +0200
committerMichael Brown2006-04-25 23:48:16 +0200
commitcfae86f6c8f9103422abb62d23d33e44b06e1906 (patch)
treef45e12aa8062e74d01d9b76b084859dfec3754df /src/core/malloc.c
parentD'oh (diff)
downloadipxe-cfae86f6c8f9103422abb62d23d33e44b06e1906.tar.gz
ipxe-cfae86f6c8f9103422abb62d23d33e44b06e1906.tar.xz
ipxe-cfae86f6c8f9103422abb62d23d33e44b06e1906.zip
Glenn managed to shrink .text by 5 more bytes.
Diffstat (limited to 'src/core/malloc.c')
-rw-r--r--src/core/malloc.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/src/core/malloc.c b/src/core/malloc.c
index bead02ed..f6d0ffde 100644
--- a/src/core/malloc.c
+++ b/src/core/malloc.c
@@ -66,19 +66,22 @@ static LIST_HEAD ( free_blocks );
*/
void * alloc_memblock ( size_t size, size_t align ) {
struct memory_block *block;
+ size_t align_mask;
size_t pre_size;
ssize_t post_size;
struct memory_block *pre;
struct memory_block *post;
- /* Round up alignment and size to multiples of MIN_MEMBLOCK_SIZE */
- align = ( align + MIN_MEMBLOCK_SIZE - 1 ) & ~( MIN_MEMBLOCK_SIZE - 1 );
+ /* Round up size to multiple of MIN_MEMBLOCK_SIZE and
+ * calculate alignment mask.
+ */
size = ( size + MIN_MEMBLOCK_SIZE - 1 ) & ~( MIN_MEMBLOCK_SIZE - 1 );
+ align_mask = ( align - 1 ) | ( MIN_MEMBLOCK_SIZE - 1 );
DBG ( "Allocating %zx (aligned %zx)\n", size, align );
/* Search through blocks for the first one with enough space */
list_for_each_entry ( block, &free_blocks, list ) {
- pre_size = ( - virt_to_phys ( block ) ) & ( align - 1 );
+ pre_size = ( - virt_to_phys ( block ) ) & align_mask;
post_size = block->size - pre_size - size;
if ( post_size >= 0 ) {
/* Split block into pre-block, block, and