--- libelwix/inc/elwix/anet.h 2013/01/17 10:05:35 1.1 +++ libelwix/inc/elwix/anet.h 2013/06/03 22:25:09 1.3.2.1 @@ -3,7 +3,7 @@ * by Michael Pounov * * $Author: misho $ -* $Id: anet.h,v 1.1 2013/01/17 10:05:35 misho Exp $ +* $Id: anet.h,v 1.3.2.1 2013/06/03 22:25:09 misho Exp $ * ************************************************************************** The ELWIX and AITNET software is distributed under the following @@ -62,14 +62,28 @@ typedef union { } sockaddr_t; #define E_SOCKADDR_INIT { .ss = { 0 } } +typedef union { + union { + in_addr_t s_addr; + u_char s4_addr[sizeof(in_addr_t)]; + } in; + struct in6_addr in6; +} inaddr_t; +typedef struct { + sockaddr_t addr; + inaddr_t mask; +} netaddr_t; +#define E_CIDRMASK(x) htonl((((1 << (x)) - 1) << (32 - (x))) & 0xFFFFFFFF) + + /* * e_usleep() - usleep() replacement for ELWIX * * @usec = microseconds for sleep * return: -1 interrupted by signal or 0 ok */ -inline int e_usleep(unsigned int usec); +int e_usleep(unsigned int usec); /* * e_ether_ntoa() - Convert ethernet address to string * @@ -78,7 +92,7 @@ inline int e_usleep(unsigned int usec); * @len = string length * return: NULL error or !=NULL string a */ -inline char *e_ether_ntoa(const struct e_ether_addr *n, char * __restrict a, int len); +char *e_ether_ntoa(const struct e_ether_addr *n, char * __restrict a, int len); /* * e_ether_aton() - Convert string to ethernet address * @@ -86,14 +100,14 @@ inline char *e_ether_ntoa(const struct e_ether_addr *n * @e = ethernet address structure, like struct ether_addr * return: NULL error or !=NULL ethernet address structure */ -inline struct e_ether_addr *e_ether_aton(const char *a, struct e_ether_addr *e); +struct e_ether_addr *e_ether_aton(const char *a, struct e_ether_addr *e); /* * e_n2port() - Extract port from network structure * * @addr = Address * return: 0 not supported family type or port number */ -inline unsigned short e_n2port(sockaddr_t * __restrict addr); +unsigned short e_n2port(sockaddr_t * __restrict addr); /* * e_n2addr() - Extract address from network structure * @@ -121,6 +135,21 @@ sockaddr_t *e_gethostbyname(const char *psHost, unsign * return: 0 is equal or !=0 is different */ int e_addrcmp(sockaddr_t * __restrict a, sockaddr_t * __restrict b, int p); +/* + * e_innet() - Test address match in network + * + * @net = network + * @addr = address + * return: -1 error, 0 match or 1 not match + */ +int e_innet(netaddr_t * __restrict net, inaddr_t * __restrict addr); +/* + * e_getnet() - Get network from string + * + * @net = Network string (format: ) + * return: NULL error or !=NULL network should be e_free() + */ +netaddr_t *e_getnet(const char *net); #endif