1 /* ialloc.h -- malloc with idx_t rather than size_t
3 Copyright 2021-2024 Free Software Foundation, Inc.
5 This file is free software: you can redistribute it and/or modify
6 it under the terms of the GNU Lesser General Public License as
7 published by the Free Software Foundation; either version 2.1 of the
8 License, or (at your option) any later version.
10 This file is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License
16 along with this program. If not, see <https://www.gnu.org/licenses/>. */
21 /* This file uses _GL_INLINE_HEADER_BEGIN, _GL_INLINE, _GL_ATTRIBUTE_COLD,
22 _GL_ATTRIBUTE_MALLOC. */
23 #if !_GL_CONFIG_H_INCLUDED
24 #error "Please include config.h first."
32 #if defined __CHERI_PURE_CAPABILITY__
36 _GL_INLINE_HEADER_BEGIN
38 # define IALLOC_INLINE _GL_INLINE
45 IALLOC_INLINE
void * _GL_ATTRIBUTE_COLD
46 _gl_alloc_nomem (void)
52 /* imalloc (size) is like malloc (size).
53 It returns a non-NULL pointer to size bytes of memory.
54 Upon failure, it returns NULL with errno set. */
56 _GL_ATTRIBUTE_MALLOC
/*_GL_ATTRIBUTE_DEALLOC_FREE*/
60 return s
<= SIZE_MAX
? malloc (s
) : _gl_alloc_nomem ();
63 /* irealloc (ptr, size) is like realloc (ptr, size).
64 It returns a non-NULL pointer to size bytes of memory.
65 Upon failure, it returns NULL with errno set. */
67 /*_GL_ATTRIBUTE_DEALLOC_FREE*/
69 irealloc (void *p
, idx_t s
)
73 /* Work around GNU realloc glitch by treating a zero size as if it
74 were 1, so that returning NULL is equivalent to failing. */
75 p
= realloc (p
, s
| !s
);
76 #if defined __CHERI_PURE_CAPABILITY__
78 p
= cheri_bounds_set (p
, s
);
83 return _gl_alloc_nomem ();
86 /* icalloc (num, size) is like calloc (num, size).
87 It returns a non-NULL pointer to num * size bytes of memory.
88 Upon failure, it returns NULL with errno set. */
90 _GL_ATTRIBUTE_MALLOC
/*_GL_ATTRIBUTE_DEALLOC_FREE*/
92 icalloc (idx_t n
, idx_t s
)
97 return _gl_alloc_nomem ();
103 return _gl_alloc_nomem ();
106 return calloc (n
, s
);
109 /* ireallocarray (ptr, num, size) is like reallocarray (ptr, num, size).
110 It returns a non-NULL pointer to num * size bytes of memory.
111 Upon failure, it returns NULL with errno set. */
113 ireallocarray (void *p
, idx_t n
, idx_t s
)
115 if (n
<= SIZE_MAX
&& s
<= SIZE_MAX
)
117 /* Work around GNU reallocarray glitch by treating a zero size as if
118 it were 1, so that returning NULL is equivalent to failing. */
121 if (n
== 0 || s
== 0)
123 p
= reallocarray (p
, nx
, sx
);
124 #if defined __CHERI_PURE_CAPABILITY__
125 if (p
!= NULL
&& (n
== 0 || s
== 0))
126 p
= cheri_bounds_set (p
, 0);
131 return _gl_alloc_nomem ();
138 _GL_INLINE_HEADER_END