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 <andrew.cooper3@citrix.com>
Acked-by: Ian Campbell <Ian.Campbell@citrix.com>
CC: Ian Jackson <Ian.Jackson@eu.citrix.com>
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);
_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.