xref: /freebsd-src/sys/contrib/openzfs/module/lua/lmem.h (revision c03c5b1c80914ec656fbee84539355d1fad68bf9)
1*eda14cbcSMatt Macy /*
2*eda14cbcSMatt Macy ** $Id: lmem.h,v 1.40.1.1 2013/04/12 18:48:47 roberto Exp $
3*eda14cbcSMatt Macy ** Interface to Memory Manager
4*eda14cbcSMatt Macy ** See Copyright Notice in lua.h
5*eda14cbcSMatt Macy */
6*eda14cbcSMatt Macy 
7*eda14cbcSMatt Macy #ifndef lmem_h
8*eda14cbcSMatt Macy #define lmem_h
9*eda14cbcSMatt Macy 
10*eda14cbcSMatt Macy 
11*eda14cbcSMatt Macy #include "llimits.h"
12*eda14cbcSMatt Macy #include <sys/lua/lua.h>
13*eda14cbcSMatt Macy 
14*eda14cbcSMatt Macy 
15*eda14cbcSMatt Macy /*
16*eda14cbcSMatt Macy ** This macro avoids the runtime division MAX_SIZET/(e), as 'e' is
17*eda14cbcSMatt Macy ** always constant.
18*eda14cbcSMatt Macy ** The macro is somewhat complex to avoid warnings:
19*eda14cbcSMatt Macy ** +1 avoids warnings of "comparison has constant result";
20*eda14cbcSMatt Macy ** cast to 'void' avoids warnings of "value unused".
21*eda14cbcSMatt Macy */
22*eda14cbcSMatt Macy #define luaM_reallocv(L,b,on,n,e) \
23*eda14cbcSMatt Macy   (cast(void, \
24*eda14cbcSMatt Macy      (cast(size_t, (n)+1) > MAX_SIZET/(e)) ? (luaM_toobig(L), 0) : 0), \
25*eda14cbcSMatt Macy    luaM_realloc_(L, (b), (on)*(e), (n)*(e)))
26*eda14cbcSMatt Macy 
27*eda14cbcSMatt Macy #define luaM_freemem(L, b, s)	luaM_realloc_(L, (b), (s), 0)
28*eda14cbcSMatt Macy #define luaM_free(L, b)		luaM_realloc_(L, (b), sizeof(*(b)), 0)
29*eda14cbcSMatt Macy #define luaM_freearray(L, b, n)   luaM_reallocv(L, (b), n, 0, sizeof((b)[0]))
30*eda14cbcSMatt Macy 
31*eda14cbcSMatt Macy #define luaM_malloc(L,s)	luaM_realloc_(L, NULL, 0, (s))
32*eda14cbcSMatt Macy #define luaM_new(L,t)		cast(t *, luaM_malloc(L, sizeof(t)))
33*eda14cbcSMatt Macy #define luaM_newvector(L,n,t) \
34*eda14cbcSMatt Macy 		cast(t *, luaM_reallocv(L, NULL, 0, n, sizeof(t)))
35*eda14cbcSMatt Macy 
36*eda14cbcSMatt Macy #define luaM_newobject(L,tag,s)	luaM_realloc_(L, NULL, tag, (s))
37*eda14cbcSMatt Macy 
38*eda14cbcSMatt Macy #define luaM_growvector(L,v,nelems,size,t,limit,e) \
39*eda14cbcSMatt Macy           if ((nelems)+1 > (size)) \
40*eda14cbcSMatt Macy             ((v)=cast(t *, luaM_growaux_(L,v,&(size),sizeof(t),limit,e)))
41*eda14cbcSMatt Macy 
42*eda14cbcSMatt Macy #define luaM_reallocvector(L, v,oldn,n,t) \
43*eda14cbcSMatt Macy    ((v)=cast(t *, luaM_reallocv(L, v, oldn, n, sizeof(t))))
44*eda14cbcSMatt Macy 
45*eda14cbcSMatt Macy LUAI_FUNC l_noret luaM_toobig (lua_State *L);
46*eda14cbcSMatt Macy 
47*eda14cbcSMatt Macy /* not to be called directly */
48*eda14cbcSMatt Macy LUAI_FUNC void *luaM_realloc_ (lua_State *L, void *block, size_t oldsize,
49*eda14cbcSMatt Macy                                                           size_t size);
50*eda14cbcSMatt Macy LUAI_FUNC void *luaM_growaux_ (lua_State *L, void *block, int *size,
51*eda14cbcSMatt Macy                                size_t size_elem, int limit,
52*eda14cbcSMatt Macy                                const char *what);
53*eda14cbcSMatt Macy 
54*eda14cbcSMatt Macy #endif
55