1145519Sdarrenr/*	$FreeBSD$	*/
2145510Sdarrenr
3145510Sdarrenr/*
4255332Scy * Copyright (C) 2012 by Darren Reed.
5145510Sdarrenr *
6145510Sdarrenr * See the IPFILTER.LICENCE file for details on licencing.
7145510Sdarrenr *
8255332Scy * $Id$
9145510Sdarrenr */
10145510Sdarrenr
11145510Sdarrenr#include <fcntl.h>
12145510Sdarrenr#include <sys/ioctl.h>
13145510Sdarrenr#include "ipf.h"
14145510Sdarrenr#include "netinet/ip_lookup.h"
15145510Sdarrenr#include "netinet/ip_pool.h"
16145510Sdarrenr
17145510Sdarrenr
18255332Scyint
19255332Scyremove_poolnode(unit, name, node, iocfunc)
20255332Scy	int unit;
21255332Scy	char *name;
22255332Scy	ip_pool_node_t *node;
23255332Scy	ioctlfunc_t iocfunc;
24145510Sdarrenr{
25145510Sdarrenr	ip_pool_node_t pn;
26145510Sdarrenr	iplookupop_t op;
27145510Sdarrenr
28255332Scy	if (pool_open() == -1)
29145510Sdarrenr		return -1;
30145510Sdarrenr
31145510Sdarrenr	op.iplo_unit = unit;
32145510Sdarrenr	op.iplo_type = IPLT_POOL;
33145510Sdarrenr	op.iplo_arg = 0;
34145510Sdarrenr	strncpy(op.iplo_name, name, sizeof(op.iplo_name));
35145510Sdarrenr	op.iplo_struct = &pn;
36145510Sdarrenr	op.iplo_size = sizeof(pn);
37145510Sdarrenr
38145510Sdarrenr	bzero((char *)&pn, sizeof(pn));
39145510Sdarrenr	bcopy((char *)&node->ipn_addr, (char *)&pn.ipn_addr,
40145510Sdarrenr	      sizeof(pn.ipn_addr));
41145510Sdarrenr	bcopy((char *)&node->ipn_mask, (char *)&pn.ipn_mask,
42145510Sdarrenr	      sizeof(pn.ipn_mask));
43145510Sdarrenr	pn.ipn_info = node->ipn_info;
44145510Sdarrenr	strncpy(pn.ipn_name, node->ipn_name, sizeof(pn.ipn_name));
45145510Sdarrenr
46255332Scy	if (pool_ioctl(iocfunc, SIOCLOOKUPDELNODE, &op)) {
47145510Sdarrenr		if ((opts & OPT_DONOTHING) == 0) {
48255332Scy			return ipf_perror_fd(pool_fd(), iocfunc,
49255332Scy					     "remove lookup pool node");
50145510Sdarrenr		}
51145510Sdarrenr	}
52145510Sdarrenr
53145510Sdarrenr	return 0;
54145510Sdarrenr}
55