提交 5bc3eb7e 编写于 作者: S Stephen Hemminger 提交者: David S. Miller

ip: convert to net_device_ops for ioctl

Convert to net_device_ops function table pointer for ioctl.
Signed-off-by: NStephen Hemminger <shemminger@vyatta.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 54a30c97
...@@ -124,8 +124,8 @@ static void ipmr_del_tunnel(struct net_device *dev, struct vifctl *v) ...@@ -124,8 +124,8 @@ static void ipmr_del_tunnel(struct net_device *dev, struct vifctl *v)
dev = __dev_get_by_name(&init_net, "tunl0"); dev = __dev_get_by_name(&init_net, "tunl0");
if (dev) { if (dev) {
const struct net_device_ops *ops = dev->netdev_ops;
struct ifreq ifr; struct ifreq ifr;
mm_segment_t oldfs;
struct ip_tunnel_parm p; struct ip_tunnel_parm p;
memset(&p, 0, sizeof(p)); memset(&p, 0, sizeof(p));
...@@ -137,9 +137,13 @@ static void ipmr_del_tunnel(struct net_device *dev, struct vifctl *v) ...@@ -137,9 +137,13 @@ static void ipmr_del_tunnel(struct net_device *dev, struct vifctl *v)
sprintf(p.name, "dvmrp%d", v->vifc_vifi); sprintf(p.name, "dvmrp%d", v->vifc_vifi);
ifr.ifr_ifru.ifru_data = (__force void __user *)&p; ifr.ifr_ifru.ifru_data = (__force void __user *)&p;
oldfs = get_fs(); set_fs(KERNEL_DS); if (ops->ndo_do_ioctl) {
dev->do_ioctl(dev, &ifr, SIOCDELTUNNEL); mm_segment_t oldfs = get_fs();
set_fs(oldfs);
set_fs(KERNEL_DS);
ops->ndo_do_ioctl(dev, &ifr, SIOCDELTUNNEL);
set_fs(oldfs);
}
} }
} }
...@@ -151,9 +155,9 @@ struct net_device *ipmr_new_tunnel(struct vifctl *v) ...@@ -151,9 +155,9 @@ struct net_device *ipmr_new_tunnel(struct vifctl *v)
dev = __dev_get_by_name(&init_net, "tunl0"); dev = __dev_get_by_name(&init_net, "tunl0");
if (dev) { if (dev) {
const struct net_device_ops *ops = dev->netdev_ops;
int err; int err;
struct ifreq ifr; struct ifreq ifr;
mm_segment_t oldfs;
struct ip_tunnel_parm p; struct ip_tunnel_parm p;
struct in_device *in_dev; struct in_device *in_dev;
...@@ -166,9 +170,14 @@ struct net_device *ipmr_new_tunnel(struct vifctl *v) ...@@ -166,9 +170,14 @@ struct net_device *ipmr_new_tunnel(struct vifctl *v)
sprintf(p.name, "dvmrp%d", v->vifc_vifi); sprintf(p.name, "dvmrp%d", v->vifc_vifi);
ifr.ifr_ifru.ifru_data = (__force void __user *)&p; ifr.ifr_ifru.ifru_data = (__force void __user *)&p;
oldfs = get_fs(); set_fs(KERNEL_DS); if (ops->ndo_do_ioctl) {
err = dev->do_ioctl(dev, &ifr, SIOCADDTUNNEL); mm_segment_t oldfs = get_fs();
set_fs(oldfs);
set_fs(KERNEL_DS);
err = ops->ndo_do_ioctl(dev, &ifr, SIOCADDTUNNEL);
set_fs(oldfs);
} else
err = -EOPNOTSUPP;
dev = NULL; dev = NULL;
......
...@@ -2031,8 +2031,8 @@ int addrconf_set_dstaddr(struct net *net, void __user *arg) ...@@ -2031,8 +2031,8 @@ int addrconf_set_dstaddr(struct net *net, void __user *arg)
#if defined(CONFIG_IPV6_SIT) || defined(CONFIG_IPV6_SIT_MODULE) #if defined(CONFIG_IPV6_SIT) || defined(CONFIG_IPV6_SIT_MODULE)
if (dev->type == ARPHRD_SIT) { if (dev->type == ARPHRD_SIT) {
const struct net_device_ops *ops = dev->netdev_ops;
struct ifreq ifr; struct ifreq ifr;
mm_segment_t oldfs;
struct ip_tunnel_parm p; struct ip_tunnel_parm p;
err = -EADDRNOTAVAIL; err = -EADDRNOTAVAIL;
...@@ -2048,9 +2048,14 @@ int addrconf_set_dstaddr(struct net *net, void __user *arg) ...@@ -2048,9 +2048,14 @@ int addrconf_set_dstaddr(struct net *net, void __user *arg)
p.iph.ttl = 64; p.iph.ttl = 64;
ifr.ifr_ifru.ifru_data = (__force void __user *)&p; ifr.ifr_ifru.ifru_data = (__force void __user *)&p;
oldfs = get_fs(); set_fs(KERNEL_DS); if (ops->ndo_do_ioctl) {
err = dev->do_ioctl(dev, &ifr, SIOCADDTUNNEL); mm_segment_t oldfs = get_fs();
set_fs(oldfs);
set_fs(KERNEL_DS);
err = ops->ndo_do_ioctl(dev, &ifr, SIOCADDTUNNEL);
set_fs(oldfs);
} else
err = -EOPNOTSUPP;
if (err == 0) { if (err == 0) {
err = -ENOBUFS; err = -ENOBUFS;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册