summaryrefslogtreecommitdiff
path: root/src/helper.c
blob: 6f4b6c205d65bdf9fe7e1bba2984df4be4cf8a96 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/**
 * Helper functions for libseccomp
 *
 * Copyright (c) 2017 Red Hat <pmoore@redhat.com>
 * Author: Paul Moore <paul@paul-moore.com>
 */

/*
 * This library is free software; you can redistribute it and/or modify it
 * under the terms of version 2.1 of the GNU Lesser General Public License as
 * published by the Free Software Foundation.
 *
 * This library is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this library; if not, see <http://www.gnu.org/licenses>.
 */

#include <stdlib.h>
#include <string.h>

#include "helper.h"

/**
 * Allocate memory
 * @param size the size of the buffer to allocate
 *
 * This function allocates a buffer of the given size, initializes it to zero,
 * and returns a pointer to buffer on success.  NULL is returned on failure.
 *
 */
void *zmalloc(size_t size)
{
	/* NOTE: unlike malloc() zero size allocations always return NULL */
	if (size == 0)
		return NULL;

	return calloc(1, size);
}

/**
 * Change the size of an allocated buffer
 * @param ptr pointer to the allocated buffer.  If NULL it is equivalent to zmalloc.
 * @param old_size the current size of the allocated buffer
 * @param size the new size of the buffer
 *
 * This function changes the size of an allocated memory buffer and return a pointer
 * to the buffer on success, the new buffer portion is initialized to zero.  NULL is
 * returned on failure.  The returned buffer could be different than the specified
 * ptr param.
 *
 */
void *zrealloc(void *ptr, size_t old_size, size_t size)
{
	/* NOTE: unlike malloc() zero size allocations always return NULL */
	if (size == 0)
		return NULL;

	ptr = realloc(ptr, size);
	if (!ptr)
		return NULL;
	memset(ptr + old_size, 0, size - old_size);
	return ptr;
}