X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fsyscall_netremove-net.hc;h=a0ccc1df8ea9dab27c4e54e1590ea92afc27d0a6;hb=a741f6faf2baae1e823d334012f6a09e6a1bda51;hp=4018011a433474dd6a07aea582a21285bb7ed34a;hpb=2822ba293eb308225c50d346930c47bf98d9927b;p=util-vserver.git diff --git a/lib/syscall_netremove-net.hc b/lib/syscall_netremove-net.hc index 4018011..a0ccc1d 100644 --- a/lib/syscall_netremove-net.hc +++ b/lib/syscall_netremove-net.hc @@ -1,4 +1,4 @@ -// $Id: syscall_netremove-net.hc,v 1.2 2005/07/15 18:07:24 ensc Exp $ --*- c -*-- +// $Id: syscall_netremove-net.hc 2578 2007-08-08 20:05:26Z dhozac $ --*- c -*-- // Copyright (C) 2004 Enrico Scholz // @@ -21,12 +21,31 @@ #endif static inline ALWAYSINLINE int -vc_net_remove_net(nid_t nid, struct vc_net_nx const *info) +vc_net_remove_net(nid_t nid, struct vc_net_addr const *info) { struct vcmd_net_addr_v0 k_info; + size_t i; - k_info.type = NETTYPE_USER2KERNEL(info->type); - k_info.count = info->count; - - return vserver(VCMD_net_remove, NID_USER2KERNEL(nid), &k_info); + k_info.type = info->vna_type & (VC_NXA_TYPE_IPV4|VC_NXA_TYPE_IPV6); + k_info.count = 1; + switch (info->vna_type) { + case VC_NXA_TYPE_IPV4 | VC_NXA_TYPE_ADDR: + k_info.ip[0].s_addr = info->vna_v4_ip.s_addr; + k_info.mask[0].s_addr = info->vna_v4_mask.s_addr; + break; + case VC_NXA_TYPE_IPV6 | VC_NXA_TYPE_ADDR: + for (i = 0; i < 4; i++) + k_info.ip[i].s_addr = info->vna_v6_ip.s6_addr32[i]; + k_info.mask[0].s_addr = info->vna_prefix; + break; + case VC_NXA_TYPE_ANY: + k_info.type = (uint16_t) -1; + k_info.count = -1; + break; + default: + errno = EINVAL; + return -1; + } + + return vserver(VCMD_net_remove_v0, NID_USER2KERNEL(nid), &k_info); }