From patchwork Fri Jan 7 03:32:13 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: yaboot does not compile against new e2fsprogs release Date: Thu, 06 Jan 2011 17:32:13 -0000 From: Tony Breeds X-Patchwork-Id: 77840 Message-Id: <20110107033213.GX19615@ozlabs.org> To: acrux Cc: yaboot-devel@lists.ozlabs.org On Wed, Dec 29, 2010 at 03:59:21PM +0100, acrux wrote: > > hi all, > it seems that yaboot (1.3.16) does not compile against e2fsprogs > 1.41.12 > It could be the new (from e2fsprogs-1.41.13): > Added a new function to the ext2fs library, ext2fs_get_memalign(). > > but i've not yet investigated... Please try this compile d but otherwise untested patch. Yours Tony diff --git a/lib/malloc.c b/lib/malloc.c index 81d7717..0121112 100644 --- a/lib/malloc.c +++ b/lib/malloc.c @@ -23,6 +23,10 @@ #include "stddef.h" #include "string.h" +/* Copied from asm-generic/errno-base.h */ +#define ENOMEM 12 /* Out of memory */ +#define EINVAL 22 /* Invalid argument */ + /* Imported functions */ extern void prom_printf (char *fmt, ...); @@ -60,6 +64,49 @@ void *malloc (unsigned int size) return caddr; } +/* Do not fall back to the malloc above as posix_memalign is needed by + * external libraries not yaboot */ +int posix_memalign(void **memptr, size_t alignment, size_t size) +{ + char *caddr; + /* size of allocation including the alignment */ + size_t alloc_size; + + if (!malloc_ptr) + return EINVAL; + + /* Minimal aligment is sizeof(void *) */ + if (alignment < sizeof(void*)) + alignment = sizeof(void*); + + /* Check for valid alignment and power of 2 */ + if ((alignment % sizeof(void*) != 0) || ((alignment-1)&alignment)) + return EINVAL; + + if (size == 0) { + *memptr=NULL; + return 0; + } + + caddr = (char*)( + (size_t)((malloc_ptr + sizeof(int))+(alignment-1)) & + (~(alignment-1)) + ); + + alloc_size = size + (caddr - (malloc_ptr+sizeof(int))); + + if ((malloc_ptr + alloc_size + sizeof(int)) > malloc_top) + return ENOMEM; + + *(int *)(caddr - sizeof(int)) = size; + malloc_ptr += alloc_size + sizeof(int); + last_alloc = caddr; + malloc_ptr = (char *) ((((unsigned int) malloc_ptr) + 3) & (~3)); + *memptr=(void*)caddr; + + return 0; +} + void *realloc(void *ptr, unsigned int size) { char *caddr, *oaddr = ptr;