genmask.c revision 253468
1/*
2 * Copyright (C) 1993-2001 by Darren Reed.
3 *
4 * See the IPFILTER.LICENCE file for details on licencing.
5 *
6 * $Id: genmask.c,v 1.7 2003/11/11 13:40:15 darrenr Exp $
7 */
8
9#include "ipf.h"
10
11
12int genmask(msk, mskp)
13char *msk;
14u_32_t *mskp;
15{
16	char *endptr = 0L;
17	int bits;
18
19	if (strchr(msk, '.') || strchr(msk, 'x') || strchr(msk, ':')) {
20		/* possibly of the form xxx.xxx.xxx.xxx
21		 * or 0xYYYYYYYY */
22#ifdef	USE_INET6
23		if (use_inet6) {
24			if (inet_pton(AF_INET6, msk, mskp) != 1)
25				return -1;
26		} else
27#endif
28		if (inet_aton(msk, (struct in_addr *)mskp) == 0)
29			return -1;
30	} else {
31		/*
32		 * set x most significant bits
33		 */
34		bits = (int)strtol(msk, &endptr, 0);
35#ifdef	USE_INET6
36		if ((*endptr != '\0') ||
37		    ((bits > 32) && !use_inet6) || (bits < 0) ||
38		    ((bits > 128) && use_inet6))
39#else
40		if (*endptr != '\0' || bits > 32 || bits < 0)
41#endif
42			return -1;
43#ifdef	USE_INET6
44		if (use_inet6)
45			fill6bits(bits, mskp);
46		else
47#endif
48		if (bits == 0)
49			*mskp = 0;
50		else
51			*mskp = htonl(0xffffffff << (32 - bits));
52	}
53	return 0;
54}
55