1 /* 2 * Copyright (c) 1998-2001 Proofpoint, Inc. and its suppliers. 3 * All rights reserved. 4 * Copyright (c) 1983, 1995-1997 Eric P. Allman. All rights reserved. 5 * Copyright (c) 1988, 1993 6 * The Regents of the University of California. All rights reserved. 7 * 8 * By using this file, you agree to the terms and conditions set 9 * forth in the LICENSE file which can be found at the top level of 10 * the sendmail distribution. 11 * 12 * 13 * $Id: bitops.h,v 1.3 2013-11-22 20:51:31 ca Exp $ 14 */ 15 16 #ifndef SM_BITOPS_H 17 # define SM_BITOPS_H 18 19 /* 20 ** Data structure for bit maps. 21 ** 22 ** Each bit in this map can be referenced by an ascii character. 23 ** This is 256 possible bits, or 32 8-bit bytes. 24 */ 25 26 # define BITMAPBITS 256 /* number of bits in a bit map */ 27 # define BYTEBITS 8 /* number of bits in a byte */ 28 # define BITMAPBYTES (BITMAPBITS / BYTEBITS) /* number of bytes in bit map */ 29 # define BITMAPMAX ((BITMAPBYTES / sizeof (int)) - 1) 30 31 /* internal macros */ 32 33 /* make sure this index never leaves the allowed range: 0 to BITMAPMAX */ 34 # define _BITWORD(bit) (((unsigned char)(bit) / (BYTEBITS * sizeof (int))) & BITMAPMAX) 35 # define _BITBIT(bit) ((unsigned int)1 << ((unsigned char)(bit) % (BYTEBITS * sizeof (int)))) 36 37 typedef unsigned int BITMAP256[BITMAPBYTES / sizeof (int)]; 38 39 /* properly case and truncate bit */ 40 # define bitidx(bit) ((unsigned int) (bit) & 0xff) 41 42 /* test bit number N */ 43 # define bitnset(bit, map) ((map)[_BITWORD(bit)] & _BITBIT(bit)) 44 45 /* set bit number N */ 46 # define setbitn(bit, map) (map)[_BITWORD(bit)] |= _BITBIT(bit) 47 48 /* clear bit number N */ 49 # define clrbitn(bit, map) (map)[_BITWORD(bit)] &= ~_BITBIT(bit) 50 51 /* clear an entire bit map */ 52 # define clrbitmap(map) memset((char *) map, '\0', BITMAPBYTES) 53 54 /* bit hacking */ 55 # define bitset(bit, word) (((word) & (bit)) != 0) 56 57 #endif /* ! SM_BITOPS_H */ 58