Add sc_allocarray() util

Add a function to allocate an array, which fails safely in the case
where the multiplication would overflow.
This commit is contained in:
Romain Vimont 2023-02-28 21:48:18 +01:00
parent 7e725ae55f
commit 0b39c613a8
3 changed files with 27 additions and 0 deletions

View file

@ -37,6 +37,7 @@ src = [
'src/util/intmap.c',
'src/util/intr.c',
'src/util/log.c',
'src/util/memory.c',
'src/util/net.c',
'src/util/net_intr.c',
'src/util/process.c',

14
app/src/util/memory.c Normal file
View file

@ -0,0 +1,14 @@
#include "memory.h"
#include <stdlib.h>
#include <errno.h>
void *
sc_allocarray(size_t nmemb, size_t size) {
size_t bytes;
if (__builtin_mul_overflow(nmemb, size, &bytes)) {
errno = ENOMEM;
return NULL;
}
return malloc(bytes);
}

12
app/src/util/memory.h Normal file
View file

@ -0,0 +1,12 @@
#ifndef SC_MEMORY_H
#define SC_MEMORY_H
#include <stddef.h>
/* Like calloc(), but without initialization.
* Like reallocarray(), but without reallocation.
*/
void *
sc_allocarray(size_t nmemb, size_t size);
#endif