File:  [ELWIX - Embedded LightWeight unIX -] / libelwix / inc / elwix.h
Revision 1.26: download - view: text, annotated - select for diffs - revision graph
Thu Aug 21 15:43:00 2025 UTC (3 weeks, 4 days ago) by misho
Branches: MAIN
CVS tags: elwix6_9, elwix6_8, HEAD, ELWIX6_8, ELWIX6_7
Version 6.7

    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>