blob: 22012246d68b64fac99535e94025da07ab86514c [file] [log] [blame] [raw]
/*
* Copyright (C) 2002-2005 by Darren Reed.
*
* See the IPFILTER.LICENCE file for details on licencing.
*
* $Id$
*/
#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 == 1)
return -1;
if (nbits == 0) {
mask = 0;
} else {
mask = 0xffffffff;
mask <<= (32 - nbits);
}
*ap = htonl(mask);
break;
case 0 :
case 6 :
if ((nbits > 128) || (use_inet6 == -1))
return -1;
fill6bits(nbits, ap);
break;
default :
return -1;
}
return 0;
}