1: /*************************************************************************
2: * (C) 2013 AITNET ltd - Sofia/Bulgaria - <misho@aitnet.org>
3: * by Michael Pounov <misho@elwix.org>
4: *
5: * $Author: misho $
6: * $Id: elwix.h,v 1.26 2025/08/21 15:43:00 misho Exp $
7: *
8: **************************************************************************
9: The ELWIX and AITNET software is distributed under the following
10: terms:
11:
12: All of the documentation and software included in the ELWIX and AITNET
13: Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org>
14:
15: Copyright 2004 - 2025
16: by Michael Pounov <misho@elwix.org>. All rights reserved.
17:
18: Redistribution and use in source and binary forms, with or without
19: modification, are permitted provided that the following conditions
20: are met:
21: 1. Redistributions of source code must retain the above copyright
22: notice, this list of conditions and the following disclaimer.
23: 2. Redistributions in binary form must reproduce the above copyright
24: notice, this list of conditions and the following disclaimer in the
25: documentation and/or other materials provided with the distribution.
26: 3. All advertising materials mentioning features or use of this software
27: must display the following acknowledgement:
28: This product includes software developed by Michael Pounov <misho@elwix.org>
29: ELWIX - Embedded LightWeight unIX and its contributors.
30: 4. Neither the name of AITNET nor the names of its contributors
31: may be used to endorse or promote products derived from this software
32: without specific prior written permission.
33:
34: THIS SOFTWARE IS PROVIDED BY AITNET AND CONTRIBUTORS ``AS IS'' AND
35: ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
36: IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
37: ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
38: FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
39: DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
40: OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
41: HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
42: LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
43: OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
44: SUCH DAMAGE.
45: */
46: #ifndef __ELWIX_H
47: #define __ELWIX_H
48:
49:
50: #include <stdio.h>
51: #include <assert.h>
52: #include <syslog.h>
53: #include <stdarg.h>
54: #include <sys/types.h>
55: #include <sys/param.h>
56: #include <sys/socket.h>
57: #include <sys/un.h>
58: #ifndef __linux__
59: #include <sys/limits.h>
60: #include <sys/endian.h>
61: #include <net/if_dl.h>
62: #else
63: #include <linux/if_packet.h>
64: #endif
65: #include <netinet/in.h>
66: #include <arpa/inet.h>
67:
68: #include <elwix/aqueue.h>
69: #include <elwix/atree.h>
70: #include <elwix/ampool.h>
71: #include <elwix/acrc.h>
72: #include <elwix/aarray.h>
73: #include <elwix/asarr.h>
74: #include <elwix/avar.h>
75: #include <elwix/astr.h>
76: #include <elwix/aregex.h>
77: #include <elwix/aav.h>
78: #include <elwix/anet.h>
79: #include <elwix/atime.h>
80: #include <elwix/apack.h>
81: #include <elwix/apio.h>
82: #include <elwix/ajson.h>
83: #include <elwix/aiov.h>
84: #include <elwix/aindex.h>
85:
86:
87: #ifndef STRSIZ
88: #define STRSIZ 256
89: #endif
90:
91: #ifndef NBBY
92: #define NBBY 8 /* number of bits in a byte */
93: #endif
94:
95: #ifndef BYTE_ORDER
96: #ifndef LITTLE_ENDIAN
97: #define LITTLE_ENDIAN 1234
98: #endif /* LITTLE_ENDIAN */
99: #ifndef BIG_ENDIAN
100: #define BIG_ENDIAN 4321
101: #endif /* BIG_ENDIAN */
102: #ifdef WORDS_BIGENDIAN
103: #define BYTE_ORDER BIG_ENDIAN
104: #else /* WORDS_BIGENDIAN */
105: #define BYTE_ORDER LITTLE_ENDIAN
106: #endif /* WORDS_BIGENDIAN */
107: #endif /* BYTE_ORDER */
108:
109: #ifndef be16toh
110: #define be16toh betoh16
111: #endif
112: #ifndef be32toh
113: #define be32toh betoh32
114: #endif
115: #ifndef be64toh
116: #define be64toh betoh64
117: #endif
118: #ifndef le16toh
119: #define le16toh letoh16
120: #endif
121: #ifndef le32toh
122: #define le32toh letoh32
123: #endif
124: #ifndef le64toh
125: #define le64toh letoh64
126: #endif
127:
128: /* Bit map related macros. */
129: #ifndef setbit
130: #define setbit(a, i) (((unsigned char *)(a))[(i) / NBBY] |= 1 << ((i) % NBBY))
131: #endif
132: #ifndef clrbit
133: #define clrbit(a, i) (((unsigned char *)(a))[(i) / NBBY] &= ~(1 << ((i) % NBBY)))
134: #endif
135: #ifndef isset
136: #define isset(a, i) (((const unsigned char *)(a))[(i) / NBBY] & (1 << ((i) % NBBY)))
137: #endif
138: #ifndef isclr
139: #define isclr(a, i) ((((const unsigned char *)(a))[(i) / NBBY] & (1 << ((i) % NBBY))) == 0)
140: #endif
141:
142: /* Macros for counting and rounding. */
143: #ifndef howmany
144: #define howmany(x, y) (((x) + ((y) - 1)) / (y))
145: #endif
146: #ifndef nitems
147: #define nitems(x) (sizeof((x)) / sizeof((x)[0]))
148: #endif
149: #ifndef rounddown
150: #define rounddown(x, y) (((x) / (y)) * (y))
151: #endif
152: #ifndef rounddown2
153: #define rounddown2(x, y) ((x) & (~((y) - 1))) /* if y is power of two */
154: #endif
155: #ifndef roundup
156: #define roundup(x, y) ((((x) + ((y) - 1)) / (y)) * (y)) /* to any y */
157: #endif
158: #ifndef roundup2
159: #define roundup2(x, y) (((x) + ((y) - 1)) & (~((y) - 1))) /* if y is powers of two */
160: #endif
161: #ifndef powerof2
162: #define powerof2(x) ((((x) - 1) & (x)) == 0)
163: #endif
164:
165: /* Macros for min/max. */
166: #ifndef MIN
167: #define MIN(a, b) (((a) < (b)) ? (a) : (b))
168: #endif
169: #ifndef MAX
170: #define MAX(a, b) (((a) > (b)) ? (a) : (b))
171: #endif
172:
173: #define E_ALIGN(x, a) (((x) + ((a) - 1)) & ~((a) - 1))
174:
175:
176: #define ELWIX_SYSM 0
177: #define ELWIX_MPOOL 1
178:
179: #define VACUUM_LEFT 1
180: #define VACUUM_BETWEEN 2
181:
182:
183: extern int __isthreaded;
184:
185: #ifdef __cplusplus
186: extern "C" {
187: #endif
188:
189: // elwix_SetProg() Set program memory pool name
190: void elwix_SetProg(const char *csProgName);
191: // elwix_GetProg() Get program memory pool name
192: const char *elwix_GetProg();
193:
194: // elwix_GetErrno() Get error code of last operation
195: int elwix_GetErrno();
196: // elwix_GetError() Get error text of last operation
197: const char *elwix_GetError();
198:
199:
200: // elwix_mm_inuse() Check for memory management model
201: int elwix_mm_inuse();
202:
203:
204: /*
205: * elwixInit() - Init libelwix library memory management
206: *
207: * @mm = memory management (IO_SYSM or IO_MPOOL)
208: * @maxmem = memory limit
209: * return: -1 error or !=-1 used memory management model
210: */
211: int elwixInit(int mm, unsigned long maxmem);
212: /*
213: * elwixFini() - Finish libelwix library memory management
214: *
215: * return: none
216: */
217: void elwixFini();
218:
219: /*
220: * elwix_byteOrder() - Detect platform byte order
221: *
222: * return: 1 = little endian or 0 big endian
223: */
224: int elwix_byteOrder();
225:
226: #ifndef strlcpy
227: /*
228: * Copy src to string dst of size siz. At most siz-1 characters
229: * will be copied. Always NUL terminates (unless siz == 0).
230: * Returns strlen(src); if retval >= siz, truncation occurred.
231: */
232: size_t strlcpy(char *dst, const char *src, size_t siz);
233: #endif
234: #ifndef strlcat
235: /*
236: * Appends src to string dst of size siz (unlike strncat, siz is the
237: * full size of dst, not space left). At most siz-1 characters
238: * will be copied. Always NUL terminates (unless siz <= strlen(dst)).
239: * Returns strlen(src) + MIN(siz, strlen(initial dst)).
240: * If retval >= siz, truncation occurred.
241: */
242: size_t strlcat(char *dst, const char *src, size_t siz);
243: #endif
244:
245: /* memory management hooks */
246: extern void *(*e_malloc)(size_t);
247: extern void *(*e_calloc)(size_t, size_t);
248: extern void *(*e_realloc)(void*, size_t);
249: extern char *(*e_strdup)(const char*);
250: extern void (*e_free)(void*);
251:
252:
253: /* Debug helper macros */
254:
255: /* Verbose macros */
256: extern int elwix_Verbose;
257: #define e_Verbose elwix_Verbose
258: #define e_initVerbose(x) (elwix_Verbose = (x))
259: #define e_incVerbose (elwix_Verbose++)
260: #define e_decVerbose (elwix_Verbose--)
261:
262: #define EVERBS(x) if ((x) <= elwix_Verbose)
263: #define EVERBOSE(x, fmt, ...) do { assert((fmt)); \
264: if ((x) <= elwix_Verbose) { \
265: char __str[BUFSIZ] = { 0 }; \
266: snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
267: syslog(LOG_INFO, "Verbose(%d):%s(%d): %s\n", \
268: (x), __func__, __LINE__, __str); \
269: } \
270: } while (0)
271: #define EVERBOSE2(x, fmt, ...) do { assert((fmt)); \
272: if ((x) <= elwix_Verbose) { \
273: char __str[0x10000] = { 0 }; \
274: snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
275: syslog(LOG_INFO, "Verbose(%d):%s(%d): %s\n", \
276: (x), __func__, __LINE__, __str); \
277: } \
278: } while (0)
279:
280: /* Debug macros */
281: extern int elwix_Debug;
282: #define e_Debug elwix_Debug
283:
284: #define ELWIX_DEBUG_OFF 0x0
285: #define ELWIX_DEBUG_TRACE 0x1
286: #define ELWIX_DEBUG_LOG 0x2
287: #define ELWIX_DEBUG_MEM 0x4
288: #define ELWIX_DEBUG_MEMORY ELWIX_DEBUG_MEM
289: #define ELWIX_DEBUG_IO 0x8
290: #define ELWIX_DEBUG_IPC 0x10
291: #define ELWIX_DEBUG_LOCK 0x20
292: #define ELWIX_DEBUG_SYS 0x40
293: #define ELWIX_DEBUG_NET 0x80
294: #define ELWIX_DEBUG_ANY 0xFFFFFFFF
295:
296: #define EDBG(x) (elwix_Debug & (x))
297: #define EDBGS(x) if (EDBG(x))
298: #define ETRACE() if (elwix_Debug & ELWIX_DEBUG_TRACE) \
299: syslog(LOG_DEBUG, "I'm in %s(%d)\n", __func__, __LINE__)
300: #define EDEBUG(x, fmt, ...) do { assert((fmt)); \
301: if ((x) & elwix_Debug) { \
302: char __str[BUFSIZ] = { 0 }; \
303: snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
304: syslog(LOG_DEBUG, "Debug(%d):%s(%d): %s\n", \
305: (x), __func__, __LINE__, __str); \
306: } \
307: } while (0)
308:
309: /* Logger macro */
310: #define ELOGGER(x, fmt, ...) do { assert((fmt)); \
311: char __str[BUFSIZ] = { 0 }; \
312: snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
313: syslog((x), "Log:%s(%d): %s\n", \
314: __func__, __LINE__, __str); \
315: } while (0)
316:
317: #define EWARNING(x, fmt, ...) do { assert((fmt)); \
318: char __str[BUFSIZ] = { 0 }; \
319: snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
320: syslog(LOG_WARNING, "Warning:%s(%d): #%d - %s\n", \
321: __func__, __LINE__, (x), __str); \
322: } while (0)
323: /* Error state macros */
324: #define EERROR(x, fmt, ...) do { assert((fmt)); \
325: char __str[BUFSIZ] = { 0 }; \
326: snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
327: syslog(LOG_ERR, "Error:%s(%d): #%d - %s\n", \
328: __func__, __LINE__, (x), __str); \
329: } while (0)
330: #define ESYSERR(x) do { \
331: if (x > 0 || errno) { \
332: int _ern = errno; \
333: syslog(LOG_ERR, "Error(sys):%s(%d): #%d - %s\n", \
334: __func__, __LINE__, x > 0 ? x : errno, \
335: strerror(x > 0 ? x : errno)); \
336: errno = _ern; \
337: } \
338: } while (0)
339: #define ELIBERR(ait) do { \
340: if (ait##_GetErrno()) \
341: syslog(LOG_ERR, "Error(lib):%s(%d): #%d - %s\n", \
342: __func__, __LINE__, ait##_GetErrno(), \
343: ait##_GetError()); \
344: } while (0)
345:
346:
347: #ifdef __cplusplus
348: }
349: #endif
350:
351: #endif
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>