blob: 4a50ef8045786fb9201d256e737273be1964e46a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
/*
* Copyright (C) 2002-2005 by Darren Reed.
*
* See the IPFILTER.LICENCE file for details on licencing.
*
* $Id: ntomask.c,v 1.6.2.1 2006/06/16 17:21:07 darrenr Exp $
*/
#include "ipf.h"
int ntomask(v, nbits, ap)
int v, nbits;
u_32_t *ap;
{
u_32_t mask;
if (nbits < 0)
return -1;
switch (v)
{
case 4 :
if (nbits > 32 || use_inet6 != 0)
return -1;
if (nbits == 0) {
mask = 0;
} else {
mask = 0xffffffff;
mask <<= (32 - nbits);
}
*ap = htonl(mask);
break;
case 6 :
if ((nbits > 128) || (use_inet6 == 0))
return -1;
fill6bits(nbits, ap);
break;
default :
return -1;
}
return 0;
}
|