Annotation of libelwix/inc/elwix.h, revision 1.31.4.1

1.1       misho       1: /*************************************************************************
                      2: * (C) 2013 AITNET ltd - Sofia/Bulgaria - <misho@aitnet.org>
                      3: *  by Michael Pounov <misho@elwix.org>
                      4: *
                      5: * $Author: misho $
1.31.4.1! misho       6: * $Id: elwix.h,v 1.31 2026/03/31 15:29:12 misho Exp $
1.1       misho       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: 
1.30      misho      15: Copyright 2004 - 2026
1.1       misho      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: 
1.25      misho      50: #include <stdio.h>
1.1       misho      51: #include <assert.h>
                     52: #include <syslog.h>
1.14      misho      53: #include <stdarg.h>
1.27      misho      54: #include <stdalign.h>
1.1       misho      55: #include <sys/types.h>
1.6       misho      56: #include <sys/param.h>
1.14      misho      57: #include <sys/socket.h>
                     58: #include <sys/un.h>
1.31.4.1! misho      59: #ifndef __cplusplus
        !            60:         #include <stdatomic.h>
        !            61: #else
        !            62:         #include <atomic>
        !            63:         #define _Atomic(X) std::atomic<X>
        !            64: #endif
1.14      misho      65: #ifndef __linux__
1.6       misho      66: #include <sys/limits.h>
1.8       misho      67: #include <sys/endian.h>
1.1       misho      68: #include <net/if_dl.h>
1.15      misho      69: #else
                     70: #include <linux/if_packet.h>
1.14      misho      71: #endif
1.1       misho      72: #include <netinet/in.h>
                     73: #include <arpa/inet.h>
                     74: 
1.14      misho      75: #include <elwix/aqueue.h>
1.1       misho      76: #include <elwix/atree.h>
                     77: #include <elwix/ampool.h>
                     78: #include <elwix/acrc.h>
                     79: #include <elwix/aarray.h>
                     80: #include <elwix/asarr.h>
                     81: #include <elwix/avar.h>
                     82: #include <elwix/astr.h>
                     83: #include <elwix/aregex.h>
1.2       misho      84: #include <elwix/aav.h>
1.1       misho      85: #include <elwix/anet.h>
1.2       misho      86: #include <elwix/atime.h>
1.7       misho      87: #include <elwix/apack.h>
1.9       misho      88: #include <elwix/apio.h>
1.16      misho      89: #include <elwix/ajson.h>
1.19      misho      90: #include <elwix/aiov.h>
1.20      misho      91: #include <elwix/aindex.h>
1.27      misho      92: #include <elwix/aring.h>
1.29      misho      93: #include <elwix/auuid.h>
1.1       misho      94: 
                     95: 
                     96: #ifndef STRSIZ
                     97: #define STRSIZ         256
                     98: #endif
                     99: 
1.6       misho     100: #ifndef NBBY
                    101: #define        NBBY            8               /* number of bits in a byte */
                    102: #endif
                    103: 
1.11      misho     104: #ifndef BYTE_ORDER
                    105:        #ifndef LITTLE_ENDIAN
                    106:                #define LITTLE_ENDIAN   1234
                    107:        #endif /* LITTLE_ENDIAN */
                    108:        #ifndef BIG_ENDIAN
                    109:                #define BIG_ENDIAN      4321
                    110:        #endif /* BIG_ENDIAN */
                    111:        #ifdef WORDS_BIGENDIAN
                    112:                #define BYTE_ORDER BIG_ENDIAN
                    113:        #else /* WORDS_BIGENDIAN */
                    114:                #define BYTE_ORDER LITTLE_ENDIAN
                    115:        #endif /* WORDS_BIGENDIAN */
                    116: #endif /* BYTE_ORDER */
                    117: 
1.1       misho     118: #ifndef be16toh
                    119: #define be16toh                betoh16
                    120: #endif
                    121: #ifndef be32toh
                    122: #define be32toh                betoh32
                    123: #endif
                    124: #ifndef be64toh
                    125: #define be64toh                betoh64
                    126: #endif
                    127: #ifndef le16toh
                    128: #define le16toh                letoh16
                    129: #endif
                    130: #ifndef le32toh
                    131: #define le32toh                letoh32
                    132: #endif
                    133: #ifndef le64toh
                    134: #define le64toh                letoh64
                    135: #endif
                    136: 
1.6       misho     137: /* Bit map related macros. */
                    138: #ifndef setbit
                    139: #define        setbit(a, i)            (((unsigned char *)(a))[(i) / NBBY] |= 1 << ((i) % NBBY))
                    140: #endif
                    141: #ifndef clrbit
                    142: #define        clrbit(a, i)            (((unsigned char *)(a))[(i) / NBBY] &= ~(1 << ((i) % NBBY)))
                    143: #endif
                    144: #ifndef isset
                    145: #define        isset(a, i)             (((const unsigned char *)(a))[(i) / NBBY] & (1 << ((i) % NBBY)))
                    146: #endif
                    147: #ifndef isclr
                    148: #define        isclr(a, i)             ((((const unsigned char *)(a))[(i) / NBBY] & (1 << ((i) % NBBY))) == 0)
                    149: #endif
                    150: 
                    151: /* Macros for counting and rounding. */
                    152: #ifndef howmany
                    153: #define        howmany(x, y)           (((x) + ((y) - 1)) / (y))
                    154: #endif
                    155: #ifndef nitems
                    156: #define        nitems(x)               (sizeof((x)) / sizeof((x)[0]))
                    157: #endif
                    158: #ifndef rounddown
                    159: #define        rounddown(x, y)         (((x) / (y)) * (y))
                    160: #endif
                    161: #ifndef rounddown2
                    162: #define        rounddown2(x, y)        ((x) & (~((y) - 1))) /* if y is power of two */
                    163: #endif
                    164: #ifndef roundup
                    165: #define        roundup(x, y)           ((((x) + ((y) - 1)) / (y)) * (y)) /* to any y */
                    166: #endif
                    167: #ifndef roundup2
                    168: #define        roundup2(x, y)          (((x) + ((y) - 1)) & (~((y) - 1))) /* if y is powers of two */
                    169: #endif
                    170: #ifndef powerof2
                    171: #define powerof2(x)            ((((x) - 1) & (x)) == 0)
                    172: #endif
                    173: 
                    174: /* Macros for min/max. */
                    175: #ifndef MIN
                    176: #define        MIN(a, b)               (((a) < (b)) ? (a) : (b))
                    177: #endif
                    178: #ifndef MAX
                    179: #define        MAX(a, b)               (((a) > (b)) ? (a) : (b))
                    180: #endif
                    181: 
                    182: #define E_ALIGN(x, a)          (((x) + ((a) - 1)) & ~((a) - 1))
1.1       misho     183: 
                    184: 
1.6       misho     185: #define ELWIX_SYSM             0
                    186: #define ELWIX_MPOOL            1
1.1       misho     187: 
1.6       misho     188: #define VACUUM_LEFT            1
                    189: #define VACUUM_BETWEEN         2
1.1       misho     190: 
                    191: 
1.28      misho     192: typedef struct {
                    193:        E_ATOMIC_ALIGN int      value;
                    194: } e_atomic_int;
1.9       misho     195: 
1.26      misho     196: #ifdef __cplusplus
                    197: extern "C" {
                    198: #endif
1.9       misho     199: 
1.28      misho     200: extern int __isthreaded;
                    201: 
1.1       misho     202: // elwix_SetProg() Set program memory pool name
1.3       misho     203: void elwix_SetProg(const char *csProgName);
1.1       misho     204: // elwix_GetProg() Get program memory pool name
1.3       misho     205: const char *elwix_GetProg();
1.1       misho     206: 
                    207: // elwix_GetErrno() Get error code of last operation
1.3       misho     208: int elwix_GetErrno();
1.1       misho     209: // elwix_GetError() Get error text of last operation
1.3       misho     210: const char *elwix_GetError();
1.1       misho     211: 
                    212: 
                    213: // elwix_mm_inuse() Check for memory management model
1.3       misho     214: int elwix_mm_inuse();
1.1       misho     215: 
                    216: 
                    217: /*
                    218:  * elwixInit() - Init libelwix library memory management
                    219:  *
                    220:  * @mm = memory management (IO_SYSM or IO_MPOOL)
                    221:  * @maxmem = memory limit
                    222:  * return: -1 error or !=-1 used memory management model
                    223:  */
1.3       misho     224: int elwixInit(int mm, unsigned long maxmem);
1.1       misho     225: /*
                    226:  * elwixFini() - Finish libelwix library memory management
                    227:  *
                    228:  * return: none
                    229:  */
1.3       misho     230: void elwixFini();
1.1       misho     231: 
1.11      misho     232: /*
                    233:  * elwix_byteOrder() - Detect platform byte order
                    234:  *
                    235:  * return: 1 = little endian or 0 big endian
                    236:  */
                    237: int elwix_byteOrder();
1.14      misho     238: 
                    239: #ifndef strlcpy
                    240: /*
                    241:  * Copy src to string dst of size siz.  At most siz-1 characters
                    242:  * will be copied.  Always NUL terminates (unless siz == 0).
                    243:  * Returns strlen(src); if retval >= siz, truncation occurred.
                    244:  */
                    245: size_t strlcpy(char *dst, const char *src, size_t siz);
                    246: #endif
                    247: #ifndef strlcat
                    248: /*
                    249:  * Appends src to string dst of size siz (unlike strncat, siz is the
                    250:  * full size of dst, not space left).  At most siz-1 characters
                    251:  * will be copied.  Always NUL terminates (unless siz <= strlen(dst)).
                    252:  * Returns strlen(src) + MIN(siz, strlen(initial dst)).
                    253:  * If retval >= siz, truncation occurred.
                    254:  */
                    255: size_t strlcat(char *dst, const char *src, size_t siz);
                    256: #endif
1.11      misho     257: 
1.1       misho     258: /* memory management hooks */
                    259: extern void *(*e_malloc)(size_t);
                    260: extern void *(*e_calloc)(size_t, size_t);
                    261: extern void *(*e_realloc)(void*, size_t);
                    262: extern char *(*e_strdup)(const char*);
                    263: extern void (*e_free)(void*);
                    264: 
                    265: 
                    266: /* Debug helper macros */
                    267: 
                    268: /* Verbose macros */
                    269: extern int elwix_Verbose;
1.21      misho     270: #define e_Verbose              elwix_Verbose
1.1       misho     271: #define e_initVerbose(x)       (elwix_Verbose = (x))
                    272: #define e_incVerbose           (elwix_Verbose++)
                    273: #define e_decVerbose           (elwix_Verbose--)
                    274: 
1.2       misho     275: #define EVERBS(x)              if ((x) <= elwix_Verbose)
                    276: #define EVERBOSE(x, fmt, ...)  do { assert((fmt)); \
                    277:                                        if ((x) <= elwix_Verbose) { \
1.26      misho     278:                                                char __str[BUFSIZ] = { 0 }; \
1.18      misho     279:                                                snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
                    280:                                                syslog(LOG_INFO, "Verbose(%d):%s(%d): %s\n", \
                    281:                                                                (x), __func__, __LINE__, __str); \
                    282:                                        } \
                    283:                                } while (0)
                    284: #define EVERBOSE2(x, fmt, ...) do { assert((fmt)); \
                    285:                                        if ((x) <= elwix_Verbose) { \
1.26      misho     286:                                                char __str[0x10000] = { 0 }; \
1.8       misho     287:                                                snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
1.16      misho     288:                                                syslog(LOG_INFO, "Verbose(%d):%s(%d): %s\n", \
1.8       misho     289:                                                                (x), __func__, __LINE__, __str); \
1.2       misho     290:                                        } \
                    291:                                } while (0)
1.1       misho     292: 
                    293: /* Debug macros */
                    294: extern int elwix_Debug;
1.16      misho     295: #define e_Debug                        elwix_Debug
                    296: 
1.1       misho     297: #define ELWIX_DEBUG_OFF                0x0
                    298: #define ELWIX_DEBUG_TRACE      0x1
                    299: #define ELWIX_DEBUG_LOG                0x2
1.22      misho     300: #define ELWIX_DEBUG_MEM                0x4
                    301: #define ELWIX_DEBUG_MEMORY     ELWIX_DEBUG_MEM
                    302: #define ELWIX_DEBUG_IO         0x8
                    303: #define ELWIX_DEBUG_IPC                0x10
                    304: #define ELWIX_DEBUG_LOCK       0x20
                    305: #define ELWIX_DEBUG_SYS                0x40
                    306: #define ELWIX_DEBUG_NET                0x80
1.31      misho     307: #define ELWIX_DEBUG_1          0x100
                    308: #define ELWIX_DEBUG_2          0x200
                    309: #define ELWIX_DEBUG_3          0x400
                    310: #define ELWIX_DEBUG_4          0x800
1.1       misho     311: #define ELWIX_DEBUG_ANY                0xFFFFFFFF
                    312: 
1.24      misho     313: #define EDBG(x)                        (elwix_Debug & (x))
                    314: #define EDBGS(x)               if (EDBG(x))
1.5       misho     315: #define ETRACE()               if (elwix_Debug & ELWIX_DEBUG_TRACE) \
1.4       misho     316:                                           syslog(LOG_DEBUG, "I'm in %s(%d)\n", __func__, __LINE__)
1.1       misho     317: #define EDEBUG(x, fmt, ...)    do { assert((fmt)); \
                    318:                                        if ((x) & elwix_Debug) { \
1.26      misho     319:                                                char __str[BUFSIZ] = { 0 }; \
1.8       misho     320:                                                snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
1.1       misho     321:                                                syslog(LOG_DEBUG, "Debug(%d):%s(%d): %s\n", \
1.8       misho     322:                                                                (x), __func__, __LINE__, __str); \
1.1       misho     323:                                        } \
                    324:                                } while (0)
                    325: 
                    326: /* Logger macro */
                    327: #define ELOGGER(x, fmt, ...)   do { assert((fmt)); \
1.26      misho     328:                                        char __str[BUFSIZ] = { 0 }; \
1.8       misho     329:                                        snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
1.26      misho     330:                                        syslog((x), "Log:%s(%d): %s\n", \
1.8       misho     331:                                                                __func__, __LINE__, __str); \
1.1       misho     332:                                } while (0)
                    333: 
1.12      misho     334: #define EWARNING(x, fmt, ...)  do { assert((fmt)); \
1.26      misho     335:                                        char __str[BUFSIZ] = { 0 }; \
1.12      misho     336:                                        snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
                    337:                                        syslog(LOG_WARNING, "Warning:%s(%d): #%d - %s\n", \
                    338:                                                         __func__, __LINE__, (x), __str); \
                    339:                                } while (0)
1.1       misho     340: /* Error state macros */
                    341: #define EERROR(x, fmt, ...)    do { assert((fmt)); \
1.26      misho     342:                                        char __str[BUFSIZ] = { 0 }; \
1.8       misho     343:                                        snprintf(__str, sizeof __str, (fmt), ##__VA_ARGS__); \
1.1       misho     344:                                        syslog(LOG_ERR, "Error:%s(%d): #%d - %s\n", \
1.8       misho     345:                                                         __func__, __LINE__, (x), __str); \
1.1       misho     346:                                } while (0)
                    347: #define ESYSERR(x)             do { \
1.17      misho     348:                                        if (x > 0 || errno) { \
                    349:                                                int _ern = errno; \
1.1       misho     350:                                                syslog(LOG_ERR, "Error(sys):%s(%d): #%d - %s\n", \
                    351:                                                                __func__, __LINE__, x > 0 ? x : errno, \
                    352:                                                                strerror(x > 0 ? x : errno)); \
1.17      misho     353:                                                errno = _ern; \
                    354:                                        } \
1.1       misho     355:                                } while (0)
                    356: #define ELIBERR(ait)           do { \
                    357:                                        if (ait##_GetErrno()) \
                    358:                                                syslog(LOG_ERR, "Error(lib):%s(%d): #%d - %s\n", \
                    359:                                                                __func__, __LINE__, ait##_GetErrno(), \
                    360:                                                                ait##_GetError()); \
                    361:                                } while (0)
                    362: 
                    363: 
1.26      misho     364: #ifdef __cplusplus
                    365: }
                    366: #endif
                    367: 
1.1       misho     368: #endif

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>