mirror of
https://gitlab.com/procps-ng/procps.git
synced 2024-11-27 20:14:05 +08:00
f5f843e257
* ps/parser.c:parse_list(): Regression (2c933ecb
): node->u is uninitialized at free(node->u) when reached before node->u=xcalloc(). * ps/parser.c:parse_list(): When "arg" is very long, CVE-2023-4016 is triggered.2c933ecb
handles the multiplication issue, but there is still the possibility of int overflow when incrementing "items".
61 lines
1.2 KiB
C
61 lines
1.2 KiB
C
/*
|
|
* This header was copied from util-linux at fall 2011.
|
|
*/
|
|
|
|
/*
|
|
* General memory allocation wrappers for malloc, realloc, calloc
|
|
* and strdup.
|
|
*/
|
|
|
|
#ifndef PROCPS_NG_XALLOC_H
|
|
#define PROCPS_NG_XALLOC_H
|
|
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include "c.h"
|
|
|
|
#ifndef XALLOC_EXIT_CODE
|
|
# define XALLOC_EXIT_CODE EXIT_FAILURE
|
|
#endif
|
|
|
|
static inline __ul_alloc_size(1)
|
|
void *xmalloc(const size_t size)
|
|
{
|
|
void *ret = malloc(size);
|
|
if (!ret && size)
|
|
xerrx(XALLOC_EXIT_CODE, "cannot allocate %zu bytes", size);
|
|
return ret;
|
|
}
|
|
|
|
static inline __ul_alloc_size(2)
|
|
void *xrealloc(void *ptr, const size_t size)
|
|
{
|
|
void *ret = realloc(ptr, size);
|
|
if (!ret && size)
|
|
xerrx(XALLOC_EXIT_CODE, "cannot allocate %zu bytes", size);
|
|
return ret;
|
|
}
|
|
|
|
static inline __ul_calloc_size(1, 2)
|
|
void *xcalloc(const size_t nelems, const size_t size)
|
|
{
|
|
void *ret = calloc(nelems, size);
|
|
if (!ret && size && nelems)
|
|
xerrx(XALLOC_EXIT_CODE, "cannot allocate %zu bytes", nelems*size);
|
|
return ret;
|
|
}
|
|
|
|
static inline char *xstrdup(const char *str)
|
|
{
|
|
char *ret;
|
|
if (!str)
|
|
return NULL;
|
|
ret = strdup(str);
|
|
if (!ret)
|
|
xerrx(XALLOC_EXIT_CODE, "cannot duplicate string");
|
|
return ret;
|
|
}
|
|
|
|
#endif /* PROCPS_NG_XALLOC_H */
|