From: Andrew Cooper Date: Thu, 27 Mar 2014 17:41:55 +0000 (+0000) Subject: tools/libxl: Introduce libxl__malloc() X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~5321 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=e140001d755b80960342241e54566bcd545ddfd5;p=xen.git tools/libxl: Introduce libxl__malloc() For those large allocations which are going to be filled immediately, where redundantly clearing the memory would just be a waste of time. Signed-off-by: Andrew Cooper Acked-by: Ian Campbell CC: Ian Jackson --- diff --git a/tools/libxl/libxl_internal.c b/tools/libxl/libxl_internal.c index 6c105decbe..6c94d3ed29 100644 --- a/tools/libxl/libxl_internal.c +++ b/tools/libxl/libxl_internal.c @@ -78,6 +78,15 @@ void libxl__free_all(libxl__gc *gc) gc->alloc_maxsize = 0; } +void *libxl__malloc(libxl__gc *gc, size_t size) +{ + void *ptr = malloc(size); + if (!ptr) libxl__alloc_failed(CTX, __func__, size, 1); + + libxl__ptr_add(gc, ptr); + return ptr; +} + void *libxl__zalloc(libxl__gc *gc, size_t size) { void *ptr = calloc(size, 1); diff --git a/tools/libxl/libxl_internal.h b/tools/libxl/libxl_internal.h index be325bbcfe..c2b73c405b 100644 --- a/tools/libxl/libxl_internal.h +++ b/tools/libxl/libxl_internal.h @@ -504,6 +504,8 @@ static inline int libxl__gc_is_real(const libxl__gc *gc) _hidden void libxl__ptr_add(libxl__gc *gc_opt, void *ptr /* may be NULL */) NN1; /* if this is the outermost libxl callframe then free all pointers in @gc */ _hidden void libxl__free_all(libxl__gc *gc); +/* allocate @size bytes. (a gc'd malloc(3)) */ +_hidden void *libxl__malloc(libxl__gc *gc_opt, size_t size) NN1; /* allocate and zero @size. (similar to a gc'd malloc(3)+memzero()) */ _hidden void *libxl__zalloc(libxl__gc *gc_opt, size_t size) NN1; /* allocate and zero memory for an array of @nmemb members of @size each.