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