--- libelwix/inc/elwix/anet.h 2013/05/30 09:07:33 1.2 +++ libelwix/inc/elwix/anet.h 2013/06/20 14:54:34 1.4.6.1 @@ -3,7 +3,7 @@ * by Michael Pounov * * $Author: misho $ -* $Id: anet.h,v 1.2 2013/05/30 09:07:33 misho Exp $ +* $Id: anet.h,v 1.4.6.1 2013/06/20 14:54:34 misho Exp $ * ************************************************************************** The ELWIX and AITNET software is distributed under the following @@ -62,7 +62,21 @@ 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 * @@ -71,6 +85,13 @@ typedef union { */ int e_usleep(unsigned int usec); /* + * e_link_ntoa() - String ethernet address from link address + * + * @sdl = link address + * return: =NULL error or !=NULL ethernet address, should be e_free() + */ +char *e_link_ntoa(const struct sockaddr_dl *sdl); +/* * e_ether_ntoa() - Convert ethernet address to string * * @n = ethernet address structure, like struct ether_addr @@ -121,6 +142,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