X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fsyscall_netremove-net.hc;h=a0ccc1df8ea9dab27c4e54e1590ea92afc27d0a6;hb=95e2774070e989fe9cf9f48dae5fa054e55e2a3e;hp=173ed468c15d2ad083921562ae3ff6fded6504f2;hpb=ec4370f7ebd7fb0ce7f002f5bf2c74f03acd3ec1;p=util-vserver.git diff --git a/lib/syscall_netremove-net.hc b/lib/syscall_netremove-net.hc index 173ed46..a0ccc1d 100644 --- a/lib/syscall_netremove-net.hc +++ b/lib/syscall_netremove-net.hc @@ -1,4 +1,4 @@ -// $Id: syscall_netremove-net.hc 2249 2006-01-18 23:40:15Z ensc $ --*- c -*-- +// $Id: syscall_netremove-net.hc 2578 2007-08-08 20:05:26Z dhozac $ --*- c -*-- // Copyright (C) 2004 Enrico Scholz // @@ -21,17 +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; - for (i = 0; i < sizeof(k_info.ip) / sizeof(*k_info.ip); i++) - k_info.ip[i] = info->ip[i]; - for (i = 0; i < sizeof(k_info.mask) / sizeof(*k_info.mask); i++) - k_info.mask[i] = info->mask[i]; - - 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); }