2  *      NET3    IP device support routines.
 
   4  *              This program is free software; you can redistribute it and/or
 
   5  *              modify it under the terms of the GNU General Public License
 
   6  *              as published by the Free Software Foundation; either version
 
   7  *              2 of the License, or (at your option) any later version.
 
   9  *      Derived from the IP parts of dev.c 1.0.19
 
  11  *                              Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
 
  12  *                              Mark Evans, <evansmp@uhura.aston.ac.uk>
 
  15  *              Alan Cox, <gw4pts@gw4pts.ampr.org>
 
  16  *              Alexey Kuznetsov, <kuznet@ms2.inr.ac.ru>
 
  19  *              Alexey Kuznetsov:       pa_* fields are replaced with ifaddr
 
  21  *              Cyrus Durgin:           updated for kmod
 
  22  *              Matthias Andree:        in devinet_ioctl, compare label and
 
  23  *                                      address (4.4BSD alias style support),
 
  24  *                                      fall back to comparing just the label
 
  29 #include <asm/uaccess.h>
 
  30 #include <asm/system.h>
 
  31 #include <linux/bitops.h>
 
  32 #include <linux/capability.h>
 
  33 #include <linux/module.h>
 
  34 #include <linux/types.h>
 
  35 #include <linux/kernel.h>
 
  36 #include <linux/string.h>
 
  38 #include <linux/socket.h>
 
  39 #include <linux/sockios.h>
 
  41 #include <linux/errno.h>
 
  42 #include <linux/interrupt.h>
 
  43 #include <linux/if_addr.h>
 
  44 #include <linux/if_ether.h>
 
  45 #include <linux/inet.h>
 
  46 #include <linux/netdevice.h>
 
  47 #include <linux/etherdevice.h>
 
  48 #include <linux/skbuff.h>
 
  49 #include <linux/init.h>
 
  50 #include <linux/notifier.h>
 
  51 #include <linux/inetdevice.h>
 
  52 #include <linux/igmp.h>
 
  54 #include <linux/sysctl.h>
 
  56 #include <linux/kmod.h>
 
  60 #include <net/route.h>
 
  61 #include <net/ip_fib.h>
 
  62 #include <net/rtnetlink.h>
 
  63 #include <net/net_namespace.h>
 
  65 static struct ipv4_devconf ipv4_devconf = {
 
  67                 [NET_IPV4_CONF_ACCEPT_REDIRECTS - 1] = 1,
 
  68                 [NET_IPV4_CONF_SEND_REDIRECTS - 1] = 1,
 
  69                 [NET_IPV4_CONF_SECURE_REDIRECTS - 1] = 1,
 
  70                 [NET_IPV4_CONF_SHARED_MEDIA - 1] = 1,
 
  74 static struct ipv4_devconf ipv4_devconf_dflt = {
 
  76                 [NET_IPV4_CONF_ACCEPT_REDIRECTS - 1] = 1,
 
  77                 [NET_IPV4_CONF_SEND_REDIRECTS - 1] = 1,
 
  78                 [NET_IPV4_CONF_SECURE_REDIRECTS - 1] = 1,
 
  79                 [NET_IPV4_CONF_SHARED_MEDIA - 1] = 1,
 
  80                 [NET_IPV4_CONF_ACCEPT_SOURCE_ROUTE - 1] = 1,
 
  84 #define IPV4_DEVCONF_DFLT(net, attr) \
 
  85         IPV4_DEVCONF((*net->ipv4.devconf_dflt), attr)
 
  87 static const struct nla_policy ifa_ipv4_policy[IFA_MAX+1] = {
 
  88         [IFA_LOCAL]             = { .type = NLA_U32 },
 
  89         [IFA_ADDRESS]           = { .type = NLA_U32 },
 
  90         [IFA_BROADCAST]         = { .type = NLA_U32 },
 
  91         [IFA_LABEL]             = { .type = NLA_STRING, .len = IFNAMSIZ - 1 },
 
  94 static void rtmsg_ifa(int event, struct in_ifaddr *, struct nlmsghdr *, u32);
 
  96 static BLOCKING_NOTIFIER_HEAD(inetaddr_chain);
 
  97 static void inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
 
 100 static void devinet_sysctl_register(struct in_device *idev);
 
 101 static void devinet_sysctl_unregister(struct in_device *idev);
 
 103 static inline void devinet_sysctl_register(struct in_device *idev)
 
 106 static inline void devinet_sysctl_unregister(struct in_device *idev)
 
 111 /* Locks all the inet devices. */
 
 113 static struct in_ifaddr *inet_alloc_ifa(void)
 
 115         struct in_ifaddr *ifa = kzalloc(sizeof(*ifa), GFP_KERNEL);
 
 118                 INIT_RCU_HEAD(&ifa->rcu_head);
 
 124 static void inet_rcu_free_ifa(struct rcu_head *head)
 
 126         struct in_ifaddr *ifa = container_of(head, struct in_ifaddr, rcu_head);
 
 128                 in_dev_put(ifa->ifa_dev);
 
 132 static inline void inet_free_ifa(struct in_ifaddr *ifa)
 
 134         call_rcu(&ifa->rcu_head, inet_rcu_free_ifa);
 
 137 void in_dev_finish_destroy(struct in_device *idev)
 
 139         struct net_device *dev = idev->dev;
 
 141         WARN_ON(idev->ifa_list);
 
 142         WARN_ON(idev->mc_list);
 
 143 #ifdef NET_REFCNT_DEBUG
 
 144         printk(KERN_DEBUG "in_dev_finish_destroy: %p=%s\n",
 
 145                idev, dev ? dev->name : "NIL");
 
 149                 printk("Freeing alive in_device %p\n", idev);
 
 155 static struct in_device *inetdev_init(struct net_device *dev)
 
 157         struct in_device *in_dev;
 
 161         in_dev = kzalloc(sizeof(*in_dev), GFP_KERNEL);
 
 164         INIT_RCU_HEAD(&in_dev->rcu_head);
 
 165         memcpy(&in_dev->cnf, dev_net(dev)->ipv4.devconf_dflt,
 
 166                         sizeof(in_dev->cnf));
 
 167         in_dev->cnf.sysctl = NULL;
 
 169         if ((in_dev->arp_parms = neigh_parms_alloc(dev, &arp_tbl)) == NULL)
 
 171         if (IPV4_DEVCONF(in_dev->cnf, FORWARDING))
 
 172                 dev_disable_lro(dev);
 
 173         /* Reference in_dev->dev */
 
 175         /* Account for reference dev->ip_ptr (below) */
 
 178         devinet_sysctl_register(in_dev);
 
 179         ip_mc_init_dev(in_dev);
 
 180         if (dev->flags & IFF_UP)
 
 183         /* we can receive as soon as ip_ptr is set -- do this last */
 
 184         rcu_assign_pointer(dev->ip_ptr, in_dev);
 
 193 static void in_dev_rcu_put(struct rcu_head *head)
 
 195         struct in_device *idev = container_of(head, struct in_device, rcu_head);
 
 199 static void inetdev_destroy(struct in_device *in_dev)
 
 201         struct in_ifaddr *ifa;
 
 202         struct net_device *dev;
 
 210         ip_mc_destroy_dev(in_dev);
 
 212         while ((ifa = in_dev->ifa_list) != NULL) {
 
 213                 inet_del_ifa(in_dev, &in_dev->ifa_list, 0);
 
 219         devinet_sysctl_unregister(in_dev);
 
 220         neigh_parms_release(&arp_tbl, in_dev->arp_parms);
 
 223         call_rcu(&in_dev->rcu_head, in_dev_rcu_put);
 
 226 int inet_addr_onlink(struct in_device *in_dev, __be32 a, __be32 b)
 
 229         for_primary_ifa(in_dev) {
 
 230                 if (inet_ifa_match(a, ifa)) {
 
 231                         if (!b || inet_ifa_match(b, ifa)) {
 
 236         } endfor_ifa(in_dev);
 
 241 static void __inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
 
 242                          int destroy, struct nlmsghdr *nlh, u32 pid)
 
 244         struct in_ifaddr *promote = NULL;
 
 245         struct in_ifaddr *ifa, *ifa1 = *ifap;
 
 246         struct in_ifaddr *last_prim = in_dev->ifa_list;
 
 247         struct in_ifaddr *prev_prom = NULL;
 
 248         int do_promote = IN_DEV_PROMOTE_SECONDARIES(in_dev);
 
 252         /* 1. Deleting primary ifaddr forces deletion all secondaries
 
 253          * unless alias promotion is set
 
 256         if (!(ifa1->ifa_flags & IFA_F_SECONDARY)) {
 
 257                 struct in_ifaddr **ifap1 = &ifa1->ifa_next;
 
 259                 while ((ifa = *ifap1) != NULL) {
 
 260                         if (!(ifa->ifa_flags & IFA_F_SECONDARY) &&
 
 261                             ifa1->ifa_scope <= ifa->ifa_scope)
 
 264                         if (!(ifa->ifa_flags & IFA_F_SECONDARY) ||
 
 265                             ifa1->ifa_mask != ifa->ifa_mask ||
 
 266                             !inet_ifa_match(ifa1->ifa_address, ifa)) {
 
 267                                 ifap1 = &ifa->ifa_next;
 
 273                                 *ifap1 = ifa->ifa_next;
 
 275                                 rtmsg_ifa(RTM_DELADDR, ifa, nlh, pid);
 
 276                                 blocking_notifier_call_chain(&inetaddr_chain,
 
 288         *ifap = ifa1->ifa_next;
 
 290         /* 3. Announce address deletion */
 
 292         /* Send message first, then call notifier.
 
 293            At first sight, FIB update triggered by notifier
 
 294            will refer to already deleted ifaddr, that could confuse
 
 295            netlink listeners. It is not true: look, gated sees
 
 296            that route deleted and if it still thinks that ifaddr
 
 297            is valid, it will try to restore deleted routes... Grr.
 
 298            So that, this order is correct.
 
 300         rtmsg_ifa(RTM_DELADDR, ifa1, nlh, pid);
 
 301         blocking_notifier_call_chain(&inetaddr_chain, NETDEV_DOWN, ifa1);
 
 306                         prev_prom->ifa_next = promote->ifa_next;
 
 307                         promote->ifa_next = last_prim->ifa_next;
 
 308                         last_prim->ifa_next = promote;
 
 311                 promote->ifa_flags &= ~IFA_F_SECONDARY;
 
 312                 rtmsg_ifa(RTM_NEWADDR, promote, nlh, pid);
 
 313                 blocking_notifier_call_chain(&inetaddr_chain,
 
 315                 for (ifa = promote->ifa_next; ifa; ifa = ifa->ifa_next) {
 
 316                         if (ifa1->ifa_mask != ifa->ifa_mask ||
 
 317                             !inet_ifa_match(ifa1->ifa_address, ifa))
 
 327 static void inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
 
 330         __inet_del_ifa(in_dev, ifap, destroy, NULL, 0);
 
 333 static int __inet_insert_ifa(struct in_ifaddr *ifa, struct nlmsghdr *nlh,
 
 336         struct in_device *in_dev = ifa->ifa_dev;
 
 337         struct in_ifaddr *ifa1, **ifap, **last_primary;
 
 341         if (!ifa->ifa_local) {
 
 346         ifa->ifa_flags &= ~IFA_F_SECONDARY;
 
 347         last_primary = &in_dev->ifa_list;
 
 349         for (ifap = &in_dev->ifa_list; (ifa1 = *ifap) != NULL;
 
 350              ifap = &ifa1->ifa_next) {
 
 351                 if (!(ifa1->ifa_flags & IFA_F_SECONDARY) &&
 
 352                     ifa->ifa_scope <= ifa1->ifa_scope)
 
 353                         last_primary = &ifa1->ifa_next;
 
 354                 if (ifa1->ifa_mask == ifa->ifa_mask &&
 
 355                     inet_ifa_match(ifa1->ifa_address, ifa)) {
 
 356                         if (ifa1->ifa_local == ifa->ifa_local) {
 
 360                         if (ifa1->ifa_scope != ifa->ifa_scope) {
 
 364                         ifa->ifa_flags |= IFA_F_SECONDARY;
 
 368         if (!(ifa->ifa_flags & IFA_F_SECONDARY)) {
 
 369                 net_srandom(ifa->ifa_local);
 
 373         ifa->ifa_next = *ifap;
 
 376         /* Send message first, then call notifier.
 
 377            Notifier will trigger FIB update, so that
 
 378            listeners of netlink will know about new ifaddr */
 
 379         rtmsg_ifa(RTM_NEWADDR, ifa, nlh, pid);
 
 380         blocking_notifier_call_chain(&inetaddr_chain, NETDEV_UP, ifa);
 
 385 static int inet_insert_ifa(struct in_ifaddr *ifa)
 
 387         return __inet_insert_ifa(ifa, NULL, 0);
 
 390 static int inet_set_ifa(struct net_device *dev, struct in_ifaddr *ifa)
 
 392         struct in_device *in_dev = __in_dev_get_rtnl(dev);
 
 400         ipv4_devconf_setall(in_dev);
 
 401         if (ifa->ifa_dev != in_dev) {
 
 402                 WARN_ON(ifa->ifa_dev);
 
 404                 ifa->ifa_dev = in_dev;
 
 406         if (ipv4_is_loopback(ifa->ifa_local))
 
 407                 ifa->ifa_scope = RT_SCOPE_HOST;
 
 408         return inet_insert_ifa(ifa);
 
 411 struct in_device *inetdev_by_index(struct net *net, int ifindex)
 
 413         struct net_device *dev;
 
 414         struct in_device *in_dev = NULL;
 
 415         read_lock(&dev_base_lock);
 
 416         dev = __dev_get_by_index(net, ifindex);
 
 418                 in_dev = in_dev_get(dev);
 
 419         read_unlock(&dev_base_lock);
 
 423 /* Called only from RTNL semaphored context. No locks. */
 
 425 struct in_ifaddr *inet_ifa_byprefix(struct in_device *in_dev, __be32 prefix,
 
 430         for_primary_ifa(in_dev) {
 
 431                 if (ifa->ifa_mask == mask && inet_ifa_match(prefix, ifa))
 
 433         } endfor_ifa(in_dev);
 
 437 static int inet_rtm_deladdr(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
 
 439         struct net *net = sock_net(skb->sk);
 
 440         struct nlattr *tb[IFA_MAX+1];
 
 441         struct in_device *in_dev;
 
 442         struct ifaddrmsg *ifm;
 
 443         struct in_ifaddr *ifa, **ifap;
 
 448         err = nlmsg_parse(nlh, sizeof(*ifm), tb, IFA_MAX, ifa_ipv4_policy);
 
 452         ifm = nlmsg_data(nlh);
 
 453         in_dev = inetdev_by_index(net, ifm->ifa_index);
 
 454         if (in_dev == NULL) {
 
 459         __in_dev_put(in_dev);
 
 461         for (ifap = &in_dev->ifa_list; (ifa = *ifap) != NULL;
 
 462              ifap = &ifa->ifa_next) {
 
 464                     ifa->ifa_local != nla_get_be32(tb[IFA_LOCAL]))
 
 467                 if (tb[IFA_LABEL] && nla_strcmp(tb[IFA_LABEL], ifa->ifa_label))
 
 470                 if (tb[IFA_ADDRESS] &&
 
 471                     (ifm->ifa_prefixlen != ifa->ifa_prefixlen ||
 
 472                     !inet_ifa_match(nla_get_be32(tb[IFA_ADDRESS]), ifa)))
 
 475                 __inet_del_ifa(in_dev, ifap, 1, nlh, NETLINK_CB(skb).pid);
 
 479         err = -EADDRNOTAVAIL;
 
 484 static struct in_ifaddr *rtm_to_ifaddr(struct net *net, struct nlmsghdr *nlh)
 
 486         struct nlattr *tb[IFA_MAX+1];
 
 487         struct in_ifaddr *ifa;
 
 488         struct ifaddrmsg *ifm;
 
 489         struct net_device *dev;
 
 490         struct in_device *in_dev;
 
 493         err = nlmsg_parse(nlh, sizeof(*ifm), tb, IFA_MAX, ifa_ipv4_policy);
 
 497         ifm = nlmsg_data(nlh);
 
 499         if (ifm->ifa_prefixlen > 32 || tb[IFA_LOCAL] == NULL)
 
 502         dev = __dev_get_by_index(net, ifm->ifa_index);
 
 507         in_dev = __in_dev_get_rtnl(dev);
 
 512         ifa = inet_alloc_ifa();
 
 515                  * A potential indev allocation can be left alive, it stays
 
 516                  * assigned to its device and is destroy with it.
 
 520         ipv4_devconf_setall(in_dev);
 
 523         if (tb[IFA_ADDRESS] == NULL)
 
 524                 tb[IFA_ADDRESS] = tb[IFA_LOCAL];
 
 526         ifa->ifa_prefixlen = ifm->ifa_prefixlen;
 
 527         ifa->ifa_mask = inet_make_mask(ifm->ifa_prefixlen);
 
 528         ifa->ifa_flags = ifm->ifa_flags;
 
 529         ifa->ifa_scope = ifm->ifa_scope;
 
 530         ifa->ifa_dev = in_dev;
 
 532         ifa->ifa_local = nla_get_be32(tb[IFA_LOCAL]);
 
 533         ifa->ifa_address = nla_get_be32(tb[IFA_ADDRESS]);
 
 535         if (tb[IFA_BROADCAST])
 
 536                 ifa->ifa_broadcast = nla_get_be32(tb[IFA_BROADCAST]);
 
 539                 nla_strlcpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);
 
 541                 memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);
 
 549 static int inet_rtm_newaddr(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
 
 551         struct net *net = sock_net(skb->sk);
 
 552         struct in_ifaddr *ifa;
 
 556         ifa = rtm_to_ifaddr(net, nlh);
 
 560         return __inet_insert_ifa(ifa, nlh, NETLINK_CB(skb).pid);
 
 564  *      Determine a default network mask, based on the IP address.
 
 567 static __inline__ int inet_abc_len(__be32 addr)
 
 569         int rc = -1;    /* Something else, probably a multicast. */
 
 571         if (ipv4_is_zeronet(addr))
 
 574                 __u32 haddr = ntohl(addr);
 
 576                 if (IN_CLASSA(haddr))
 
 578                 else if (IN_CLASSB(haddr))
 
 580                 else if (IN_CLASSC(haddr))
 
 588 int devinet_ioctl(struct net *net, unsigned int cmd, void __user *arg)
 
 591         struct sockaddr_in sin_orig;
 
 592         struct sockaddr_in *sin = (struct sockaddr_in *)&ifr.ifr_addr;
 
 593         struct in_device *in_dev;
 
 594         struct in_ifaddr **ifap = NULL;
 
 595         struct in_ifaddr *ifa = NULL;
 
 596         struct net_device *dev;
 
 599         int tryaddrmatch = 0;
 
 602          *      Fetch the caller's info block into kernel space
 
 605         if (copy_from_user(&ifr, arg, sizeof(struct ifreq)))
 
 607         ifr.ifr_name[IFNAMSIZ - 1] = 0;
 
 609         /* save original address for comparison */
 
 610         memcpy(&sin_orig, sin, sizeof(*sin));
 
 612         colon = strchr(ifr.ifr_name, ':');
 
 617         dev_load(net, ifr.ifr_name);
 
 621         case SIOCGIFADDR:       /* Get interface address */
 
 622         case SIOCGIFBRDADDR:    /* Get the broadcast address */
 
 623         case SIOCGIFDSTADDR:    /* Get the destination address */
 
 624         case SIOCGIFNETMASK:    /* Get the netmask for the interface */
 
 625                 /* Note that these ioctls will not sleep,
 
 626                    so that we do not impose a lock.
 
 627                    One day we will be forced to put shlock here (I mean SMP)
 
 629                 tryaddrmatch = (sin_orig.sin_family == AF_INET);
 
 630                 memset(sin, 0, sizeof(*sin));
 
 631                 sin->sin_family = AF_INET;
 
 636                 if (!capable(CAP_NET_ADMIN))
 
 639         case SIOCSIFADDR:       /* Set interface address (and family) */
 
 640         case SIOCSIFBRDADDR:    /* Set the broadcast address */
 
 641         case SIOCSIFDSTADDR:    /* Set the destination address */
 
 642         case SIOCSIFNETMASK:    /* Set the netmask for the interface */
 
 644                 if (!capable(CAP_NET_ADMIN))
 
 647                 if (sin->sin_family != AF_INET)
 
 658         if ((dev = __dev_get_by_name(net, ifr.ifr_name)) == NULL)
 
 664         if ((in_dev = __in_dev_get_rtnl(dev)) != NULL) {
 
 666                         /* Matthias Andree */
 
 667                         /* compare label and address (4.4BSD style) */
 
 668                         /* note: we only do this for a limited set of ioctls
 
 669                            and only if the original address family was AF_INET.
 
 670                            This is checked above. */
 
 671                         for (ifap = &in_dev->ifa_list; (ifa = *ifap) != NULL;
 
 672                              ifap = &ifa->ifa_next) {
 
 673                                 if (!strcmp(ifr.ifr_name, ifa->ifa_label) &&
 
 674                                     sin_orig.sin_addr.s_addr ==
 
 680                 /* we didn't get a match, maybe the application is
 
 681                    4.3BSD-style and passed in junk so we fall back to
 
 682                    comparing just the label */
 
 684                         for (ifap = &in_dev->ifa_list; (ifa = *ifap) != NULL;
 
 685                              ifap = &ifa->ifa_next)
 
 686                                 if (!strcmp(ifr.ifr_name, ifa->ifa_label))
 
 691         ret = -EADDRNOTAVAIL;
 
 692         if (!ifa && cmd != SIOCSIFADDR && cmd != SIOCSIFFLAGS)
 
 696         case SIOCGIFADDR:       /* Get interface address */
 
 697                 sin->sin_addr.s_addr = ifa->ifa_local;
 
 700         case SIOCGIFBRDADDR:    /* Get the broadcast address */
 
 701                 sin->sin_addr.s_addr = ifa->ifa_broadcast;
 
 704         case SIOCGIFDSTADDR:    /* Get the destination address */
 
 705                 sin->sin_addr.s_addr = ifa->ifa_address;
 
 708         case SIOCGIFNETMASK:    /* Get the netmask for the interface */
 
 709                 sin->sin_addr.s_addr = ifa->ifa_mask;
 
 714                         ret = -EADDRNOTAVAIL;
 
 718                         if (!(ifr.ifr_flags & IFF_UP))
 
 719                                 inet_del_ifa(in_dev, ifap, 1);
 
 722                 ret = dev_change_flags(dev, ifr.ifr_flags);
 
 725         case SIOCSIFADDR:       /* Set interface address (and family) */
 
 727                 if (inet_abc_len(sin->sin_addr.s_addr) < 0)
 
 732                         if ((ifa = inet_alloc_ifa()) == NULL)
 
 735                                 memcpy(ifa->ifa_label, ifr.ifr_name, IFNAMSIZ);
 
 737                                 memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);
 
 740                         if (ifa->ifa_local == sin->sin_addr.s_addr)
 
 742                         inet_del_ifa(in_dev, ifap, 0);
 
 743                         ifa->ifa_broadcast = 0;
 
 747                 ifa->ifa_address = ifa->ifa_local = sin->sin_addr.s_addr;
 
 749                 if (!(dev->flags & IFF_POINTOPOINT)) {
 
 750                         ifa->ifa_prefixlen = inet_abc_len(ifa->ifa_address);
 
 751                         ifa->ifa_mask = inet_make_mask(ifa->ifa_prefixlen);
 
 752                         if ((dev->flags & IFF_BROADCAST) &&
 
 753                             ifa->ifa_prefixlen < 31)
 
 754                                 ifa->ifa_broadcast = ifa->ifa_address |
 
 757                         ifa->ifa_prefixlen = 32;
 
 758                         ifa->ifa_mask = inet_make_mask(32);
 
 760                 ret = inet_set_ifa(dev, ifa);
 
 763         case SIOCSIFBRDADDR:    /* Set the broadcast address */
 
 765                 if (ifa->ifa_broadcast != sin->sin_addr.s_addr) {
 
 766                         inet_del_ifa(in_dev, ifap, 0);
 
 767                         ifa->ifa_broadcast = sin->sin_addr.s_addr;
 
 768                         inet_insert_ifa(ifa);
 
 772         case SIOCSIFDSTADDR:    /* Set the destination address */
 
 774                 if (ifa->ifa_address == sin->sin_addr.s_addr)
 
 777                 if (inet_abc_len(sin->sin_addr.s_addr) < 0)
 
 780                 inet_del_ifa(in_dev, ifap, 0);
 
 781                 ifa->ifa_address = sin->sin_addr.s_addr;
 
 782                 inet_insert_ifa(ifa);
 
 785         case SIOCSIFNETMASK:    /* Set the netmask for the interface */
 
 788                  *      The mask we set must be legal.
 
 791                 if (bad_mask(sin->sin_addr.s_addr, 0))
 
 794                 if (ifa->ifa_mask != sin->sin_addr.s_addr) {
 
 795                         __be32 old_mask = ifa->ifa_mask;
 
 796                         inet_del_ifa(in_dev, ifap, 0);
 
 797                         ifa->ifa_mask = sin->sin_addr.s_addr;
 
 798                         ifa->ifa_prefixlen = inet_mask_len(ifa->ifa_mask);
 
 800                         /* See if current broadcast address matches
 
 801                          * with current netmask, then recalculate
 
 802                          * the broadcast address. Otherwise it's a
 
 803                          * funny address, so don't touch it since
 
 804                          * the user seems to know what (s)he's doing...
 
 806                         if ((dev->flags & IFF_BROADCAST) &&
 
 807                             (ifa->ifa_prefixlen < 31) &&
 
 808                             (ifa->ifa_broadcast ==
 
 809                              (ifa->ifa_local|~old_mask))) {
 
 810                                 ifa->ifa_broadcast = (ifa->ifa_local |
 
 811                                                       ~sin->sin_addr.s_addr);
 
 813                         inet_insert_ifa(ifa);
 
 823         ret = copy_to_user(arg, &ifr, sizeof(struct ifreq)) ? -EFAULT : 0;
 
 827 static int inet_gifconf(struct net_device *dev, char __user *buf, int len)
 
 829         struct in_device *in_dev = __in_dev_get_rtnl(dev);
 
 830         struct in_ifaddr *ifa;
 
 834         if (!in_dev || (ifa = in_dev->ifa_list) == NULL)
 
 837         for (; ifa; ifa = ifa->ifa_next) {
 
 842                 if (len < (int) sizeof(ifr))
 
 844                 memset(&ifr, 0, sizeof(struct ifreq));
 
 846                         strcpy(ifr.ifr_name, ifa->ifa_label);
 
 848                         strcpy(ifr.ifr_name, dev->name);
 
 850                 (*(struct sockaddr_in *)&ifr.ifr_addr).sin_family = AF_INET;
 
 851                 (*(struct sockaddr_in *)&ifr.ifr_addr).sin_addr.s_addr =
 
 854                 if (copy_to_user(buf, &ifr, sizeof(struct ifreq))) {
 
 858                 buf  += sizeof(struct ifreq);
 
 859                 len  -= sizeof(struct ifreq);
 
 860                 done += sizeof(struct ifreq);
 
 866 __be32 inet_select_addr(const struct net_device *dev, __be32 dst, int scope)
 
 869         struct in_device *in_dev;
 
 870         struct net *net = dev_net(dev);
 
 873         in_dev = __in_dev_get_rcu(dev);
 
 877         for_primary_ifa(in_dev) {
 
 878                 if (ifa->ifa_scope > scope)
 
 880                 if (!dst || inet_ifa_match(dst, ifa)) {
 
 881                         addr = ifa->ifa_local;
 
 885                         addr = ifa->ifa_local;
 
 886         } endfor_ifa(in_dev);
 
 893         /* Not loopback addresses on loopback should be preferred
 
 894            in this case. It is importnat that lo is the first interface
 
 897         read_lock(&dev_base_lock);
 
 899         for_each_netdev(net, dev) {
 
 900                 if ((in_dev = __in_dev_get_rcu(dev)) == NULL)
 
 903                 for_primary_ifa(in_dev) {
 
 904                         if (ifa->ifa_scope != RT_SCOPE_LINK &&
 
 905                             ifa->ifa_scope <= scope) {
 
 906                                 addr = ifa->ifa_local;
 
 907                                 goto out_unlock_both;
 
 909                 } endfor_ifa(in_dev);
 
 912         read_unlock(&dev_base_lock);
 
 918 static __be32 confirm_addr_indev(struct in_device *in_dev, __be32 dst,
 
 919                               __be32 local, int scope)
 
 926                     (local == ifa->ifa_local || !local) &&
 
 927                     ifa->ifa_scope <= scope) {
 
 928                         addr = ifa->ifa_local;
 
 933                         same = (!local || inet_ifa_match(local, ifa)) &&
 
 934                                 (!dst || inet_ifa_match(dst, ifa));
 
 938                                 /* Is the selected addr into dst subnet? */
 
 939                                 if (inet_ifa_match(addr, ifa))
 
 941                                 /* No, then can we use new local src? */
 
 942                                 if (ifa->ifa_scope <= scope) {
 
 943                                         addr = ifa->ifa_local;
 
 946                                 /* search for large dst subnet for addr */
 
 950         } endfor_ifa(in_dev);
 
 952         return same? addr : 0;
 
 956  * Confirm that local IP address exists using wildcards:
 
 957  * - in_dev: only on this interface, 0=any interface
 
 958  * - dst: only in the same subnet as dst, 0=any dst
 
 959  * - local: address, 0=autoselect the local address
 
 960  * - scope: maximum allowed scope value for the local address
 
 962 __be32 inet_confirm_addr(struct in_device *in_dev,
 
 963                          __be32 dst, __be32 local, int scope)
 
 966         struct net_device *dev;
 
 969         if (scope != RT_SCOPE_LINK)
 
 970                 return confirm_addr_indev(in_dev, dst, local, scope);
 
 972         net = dev_net(in_dev->dev);
 
 973         read_lock(&dev_base_lock);
 
 975         for_each_netdev(net, dev) {
 
 976                 if ((in_dev = __in_dev_get_rcu(dev))) {
 
 977                         addr = confirm_addr_indev(in_dev, dst, local, scope);
 
 983         read_unlock(&dev_base_lock);
 
 992 int register_inetaddr_notifier(struct notifier_block *nb)
 
 994         return blocking_notifier_chain_register(&inetaddr_chain, nb);
 
 997 int unregister_inetaddr_notifier(struct notifier_block *nb)
 
 999         return blocking_notifier_chain_unregister(&inetaddr_chain, nb);
 
1002 /* Rename ifa_labels for a device name change. Make some effort to preserve existing
 
1003  * alias numbering and to create unique labels if possible.
 
1005 static void inetdev_changename(struct net_device *dev, struct in_device *in_dev)
 
1007         struct in_ifaddr *ifa;
 
1010         for (ifa = in_dev->ifa_list; ifa; ifa = ifa->ifa_next) {
 
1011                 char old[IFNAMSIZ], *dot;
 
1013                 memcpy(old, ifa->ifa_label, IFNAMSIZ);
 
1014                 memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);
 
1017                 dot = strchr(old, ':');
 
1019                         sprintf(old, ":%d", named);
 
1022                 if (strlen(dot) + strlen(dev->name) < IFNAMSIZ) {
 
1023                         strcat(ifa->ifa_label, dot);
 
1025                         strcpy(ifa->ifa_label + (IFNAMSIZ - strlen(dot) - 1), dot);
 
1028                 rtmsg_ifa(RTM_NEWADDR, ifa, NULL, 0);
 
1032 static inline bool inetdev_valid_mtu(unsigned mtu)
 
1037 /* Called only under RTNL semaphore */
 
1039 static int inetdev_event(struct notifier_block *this, unsigned long event,
 
1042         struct net_device *dev = ptr;
 
1043         struct in_device *in_dev = __in_dev_get_rtnl(dev);
 
1048                 if (event == NETDEV_REGISTER) {
 
1049                         in_dev = inetdev_init(dev);
 
1051                                 return notifier_from_errno(-ENOMEM);
 
1052                         if (dev->flags & IFF_LOOPBACK) {
 
1053                                 IN_DEV_CONF_SET(in_dev, NOXFRM, 1);
 
1054                                 IN_DEV_CONF_SET(in_dev, NOPOLICY, 1);
 
1056                 } else if (event == NETDEV_CHANGEMTU) {
 
1057                         /* Re-enabling IP */
 
1058                         if (inetdev_valid_mtu(dev->mtu))
 
1059                                 in_dev = inetdev_init(dev);
 
1065         case NETDEV_REGISTER:
 
1066                 printk(KERN_DEBUG "inetdev_event: bug\n");
 
1070                 if (!inetdev_valid_mtu(dev->mtu))
 
1072                 if (dev->flags & IFF_LOOPBACK) {
 
1073                         struct in_ifaddr *ifa;
 
1074                         if ((ifa = inet_alloc_ifa()) != NULL) {
 
1076                                   ifa->ifa_address = htonl(INADDR_LOOPBACK);
 
1077                                 ifa->ifa_prefixlen = 8;
 
1078                                 ifa->ifa_mask = inet_make_mask(8);
 
1079                                 in_dev_hold(in_dev);
 
1080                                 ifa->ifa_dev = in_dev;
 
1081                                 ifa->ifa_scope = RT_SCOPE_HOST;
 
1082                                 memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);
 
1083                                 inet_insert_ifa(ifa);
 
1091         case NETDEV_CHANGEMTU:
 
1092                 if (inetdev_valid_mtu(dev->mtu))
 
1094                 /* disable IP when MTU is not enough */
 
1095         case NETDEV_UNREGISTER:
 
1096                 inetdev_destroy(in_dev);
 
1098         case NETDEV_CHANGENAME:
 
1099                 /* Do not notify about label change, this event is
 
1100                  * not interesting to applications using netlink.
 
1102                 inetdev_changename(dev, in_dev);
 
1104                 devinet_sysctl_unregister(in_dev);
 
1105                 devinet_sysctl_register(in_dev);
 
1112 static struct notifier_block ip_netdev_notifier = {
 
1113         .notifier_call =inetdev_event,
 
1116 static inline size_t inet_nlmsg_size(void)
 
1118         return NLMSG_ALIGN(sizeof(struct ifaddrmsg))
 
1119                + nla_total_size(4) /* IFA_ADDRESS */
 
1120                + nla_total_size(4) /* IFA_LOCAL */
 
1121                + nla_total_size(4) /* IFA_BROADCAST */
 
1122                + nla_total_size(IFNAMSIZ); /* IFA_LABEL */
 
1125 static int inet_fill_ifaddr(struct sk_buff *skb, struct in_ifaddr *ifa,
 
1126                             u32 pid, u32 seq, int event, unsigned int flags)
 
1128         struct ifaddrmsg *ifm;
 
1129         struct nlmsghdr  *nlh;
 
1131         nlh = nlmsg_put(skb, pid, seq, event, sizeof(*ifm), flags);
 
1135         ifm = nlmsg_data(nlh);
 
1136         ifm->ifa_family = AF_INET;
 
1137         ifm->ifa_prefixlen = ifa->ifa_prefixlen;
 
1138         ifm->ifa_flags = ifa->ifa_flags|IFA_F_PERMANENT;
 
1139         ifm->ifa_scope = ifa->ifa_scope;
 
1140         ifm->ifa_index = ifa->ifa_dev->dev->ifindex;
 
1142         if (ifa->ifa_address)
 
1143                 NLA_PUT_BE32(skb, IFA_ADDRESS, ifa->ifa_address);
 
1146                 NLA_PUT_BE32(skb, IFA_LOCAL, ifa->ifa_local);
 
1148         if (ifa->ifa_broadcast)
 
1149                 NLA_PUT_BE32(skb, IFA_BROADCAST, ifa->ifa_broadcast);
 
1151         if (ifa->ifa_label[0])
 
1152                 NLA_PUT_STRING(skb, IFA_LABEL, ifa->ifa_label);
 
1154         return nlmsg_end(skb, nlh);
 
1157         nlmsg_cancel(skb, nlh);
 
1161 static int inet_dump_ifaddr(struct sk_buff *skb, struct netlink_callback *cb)
 
1163         struct net *net = sock_net(skb->sk);
 
1165         struct net_device *dev;
 
1166         struct in_device *in_dev;
 
1167         struct in_ifaddr *ifa;
 
1168         int s_ip_idx, s_idx = cb->args[0];
 
1170         s_ip_idx = ip_idx = cb->args[1];
 
1172         for_each_netdev(net, dev) {
 
1177                 if ((in_dev = __in_dev_get_rtnl(dev)) == NULL)
 
1180                 for (ifa = in_dev->ifa_list, ip_idx = 0; ifa;
 
1181                      ifa = ifa->ifa_next, ip_idx++) {
 
1182                         if (ip_idx < s_ip_idx)
 
1184                         if (inet_fill_ifaddr(skb, ifa, NETLINK_CB(cb->skb).pid,
 
1186                                              RTM_NEWADDR, NLM_F_MULTI) <= 0)
 
1195         cb->args[1] = ip_idx;
 
1200 static void rtmsg_ifa(int event, struct in_ifaddr* ifa, struct nlmsghdr *nlh,
 
1203         struct sk_buff *skb;
 
1204         u32 seq = nlh ? nlh->nlmsg_seq : 0;
 
1208         net = dev_net(ifa->ifa_dev->dev);
 
1209         skb = nlmsg_new(inet_nlmsg_size(), GFP_KERNEL);
 
1213         err = inet_fill_ifaddr(skb, ifa, pid, seq, event, 0);
 
1215                 /* -EMSGSIZE implies BUG in inet_nlmsg_size() */
 
1216                 WARN_ON(err == -EMSGSIZE);
 
1220         err = rtnl_notify(skb, net, pid, RTNLGRP_IPV4_IFADDR, nlh, GFP_KERNEL);
 
1223                 rtnl_set_sk_err(net, RTNLGRP_IPV4_IFADDR, err);
 
1226 #ifdef CONFIG_SYSCTL
 
1228 static void devinet_copy_dflt_conf(struct net *net, int i)
 
1230         struct net_device *dev;
 
1232         read_lock(&dev_base_lock);
 
1233         for_each_netdev(net, dev) {
 
1234                 struct in_device *in_dev;
 
1236                 in_dev = __in_dev_get_rcu(dev);
 
1237                 if (in_dev && !test_bit(i, in_dev->cnf.state))
 
1238                         in_dev->cnf.data[i] = net->ipv4.devconf_dflt->data[i];
 
1241         read_unlock(&dev_base_lock);
 
1244 static void inet_forward_change(struct net *net)
 
1246         struct net_device *dev;
 
1247         int on = IPV4_DEVCONF_ALL(net, FORWARDING);
 
1249         IPV4_DEVCONF_ALL(net, ACCEPT_REDIRECTS) = !on;
 
1250         IPV4_DEVCONF_DFLT(net, FORWARDING) = on;
 
1252         read_lock(&dev_base_lock);
 
1253         for_each_netdev(net, dev) {
 
1254                 struct in_device *in_dev;
 
1256                         dev_disable_lro(dev);
 
1258                 in_dev = __in_dev_get_rcu(dev);
 
1260                         IN_DEV_CONF_SET(in_dev, FORWARDING, on);
 
1263         read_unlock(&dev_base_lock);
 
1266 static int devinet_conf_proc(ctl_table *ctl, int write,
 
1267                              struct file* filp, void __user *buffer,
 
1268                              size_t *lenp, loff_t *ppos)
 
1270         int ret = proc_dointvec(ctl, write, filp, buffer, lenp, ppos);
 
1273                 struct ipv4_devconf *cnf = ctl->extra1;
 
1274                 struct net *net = ctl->extra2;
 
1275                 int i = (int *)ctl->data - cnf->data;
 
1277                 set_bit(i, cnf->state);
 
1279                 if (cnf == net->ipv4.devconf_dflt)
 
1280                         devinet_copy_dflt_conf(net, i);
 
1286 static int devinet_conf_sysctl(ctl_table *table, int __user *name, int nlen,
 
1287                                void __user *oldval, size_t __user *oldlenp,
 
1288                                void __user *newval, size_t newlen)
 
1290         struct ipv4_devconf *cnf;
 
1292         int *valp = table->data;
 
1296         if (!newval || !newlen)
 
1299         if (newlen != sizeof(int))
 
1302         if (get_user(new, (int __user *)newval))
 
1308         if (oldval && oldlenp) {
 
1311                 if (get_user(len, oldlenp))
 
1315                         if (len > table->maxlen)
 
1316                                 len = table->maxlen;
 
1317                         if (copy_to_user(oldval, valp, len))
 
1319                         if (put_user(len, oldlenp))
 
1326         cnf = table->extra1;
 
1327         net = table->extra2;
 
1328         i = (int *)table->data - cnf->data;
 
1330         set_bit(i, cnf->state);
 
1332         if (cnf == net->ipv4.devconf_dflt)
 
1333                 devinet_copy_dflt_conf(net, i);
 
1338 static int devinet_sysctl_forward(ctl_table *ctl, int write,
 
1339                                   struct file* filp, void __user *buffer,
 
1340                                   size_t *lenp, loff_t *ppos)
 
1342         int *valp = ctl->data;
 
1344         int ret = proc_dointvec(ctl, write, filp, buffer, lenp, ppos);
 
1346         if (write && *valp != val) {
 
1347                 struct net *net = ctl->extra2;
 
1349                 if (valp != &IPV4_DEVCONF_DFLT(net, FORWARDING)) {
 
1351                         if (valp == &IPV4_DEVCONF_ALL(net, FORWARDING)) {
 
1352                                 inet_forward_change(net);
 
1354                                 struct ipv4_devconf *cnf = ctl->extra1;
 
1355                                 struct in_device *idev =
 
1356                                         container_of(cnf, struct in_device, cnf);
 
1357                                 dev_disable_lro(idev->dev);
 
1360                         rt_cache_flush(net, 0);
 
1367 int ipv4_doint_and_flush(ctl_table *ctl, int write,
 
1368                          struct file* filp, void __user *buffer,
 
1369                          size_t *lenp, loff_t *ppos)
 
1371         int *valp = ctl->data;
 
1373         int ret = proc_dointvec(ctl, write, filp, buffer, lenp, ppos);
 
1374         struct net *net = ctl->extra2;
 
1376         if (write && *valp != val)
 
1377                 rt_cache_flush(net, 0);
 
1382 int ipv4_doint_and_flush_strategy(ctl_table *table, int __user *name, int nlen,
 
1383                                   void __user *oldval, size_t __user *oldlenp,
 
1384                                   void __user *newval, size_t newlen)
 
1386         int ret = devinet_conf_sysctl(table, name, nlen, oldval, oldlenp,
 
1388         struct net *net = table->extra2;
 
1391                 rt_cache_flush(net, 0);
 
1397 #define DEVINET_SYSCTL_ENTRY(attr, name, mval, proc, sysctl) \
 
1399                 .ctl_name       = NET_IPV4_CONF_ ## attr, \
 
1401                 .data           = ipv4_devconf.data + \
 
1402                                   NET_IPV4_CONF_ ## attr - 1, \
 
1403                 .maxlen         = sizeof(int), \
 
1405                 .proc_handler   = proc, \
 
1406                 .strategy       = sysctl, \
 
1407                 .extra1         = &ipv4_devconf, \
 
1410 #define DEVINET_SYSCTL_RW_ENTRY(attr, name) \
 
1411         DEVINET_SYSCTL_ENTRY(attr, name, 0644, devinet_conf_proc, \
 
1412                              devinet_conf_sysctl)
 
1414 #define DEVINET_SYSCTL_RO_ENTRY(attr, name) \
 
1415         DEVINET_SYSCTL_ENTRY(attr, name, 0444, devinet_conf_proc, \
 
1416                              devinet_conf_sysctl)
 
1418 #define DEVINET_SYSCTL_COMPLEX_ENTRY(attr, name, proc, sysctl) \
 
1419         DEVINET_SYSCTL_ENTRY(attr, name, 0644, proc, sysctl)
 
1421 #define DEVINET_SYSCTL_FLUSHING_ENTRY(attr, name) \
 
1422         DEVINET_SYSCTL_COMPLEX_ENTRY(attr, name, ipv4_doint_and_flush, \
 
1423                                      ipv4_doint_and_flush_strategy)
 
1425 static struct devinet_sysctl_table {
 
1426         struct ctl_table_header *sysctl_header;
 
1427         struct ctl_table devinet_vars[__NET_IPV4_CONF_MAX];
 
1429 } devinet_sysctl = {
 
1431                 DEVINET_SYSCTL_COMPLEX_ENTRY(FORWARDING, "forwarding",
 
1432                                              devinet_sysctl_forward,
 
1433                                              devinet_conf_sysctl),
 
1434                 DEVINET_SYSCTL_RO_ENTRY(MC_FORWARDING, "mc_forwarding"),
 
1436                 DEVINET_SYSCTL_RW_ENTRY(ACCEPT_REDIRECTS, "accept_redirects"),
 
1437                 DEVINET_SYSCTL_RW_ENTRY(SECURE_REDIRECTS, "secure_redirects"),
 
1438                 DEVINET_SYSCTL_RW_ENTRY(SHARED_MEDIA, "shared_media"),
 
1439                 DEVINET_SYSCTL_RW_ENTRY(RP_FILTER, "rp_filter"),
 
1440                 DEVINET_SYSCTL_RW_ENTRY(SEND_REDIRECTS, "send_redirects"),
 
1441                 DEVINET_SYSCTL_RW_ENTRY(ACCEPT_SOURCE_ROUTE,
 
1442                                         "accept_source_route"),
 
1443                 DEVINET_SYSCTL_RW_ENTRY(PROXY_ARP, "proxy_arp"),
 
1444                 DEVINET_SYSCTL_RW_ENTRY(MEDIUM_ID, "medium_id"),
 
1445                 DEVINET_SYSCTL_RW_ENTRY(BOOTP_RELAY, "bootp_relay"),
 
1446                 DEVINET_SYSCTL_RW_ENTRY(LOG_MARTIANS, "log_martians"),
 
1447                 DEVINET_SYSCTL_RW_ENTRY(TAG, "tag"),
 
1448                 DEVINET_SYSCTL_RW_ENTRY(ARPFILTER, "arp_filter"),
 
1449                 DEVINET_SYSCTL_RW_ENTRY(ARP_ANNOUNCE, "arp_announce"),
 
1450                 DEVINET_SYSCTL_RW_ENTRY(ARP_IGNORE, "arp_ignore"),
 
1451                 DEVINET_SYSCTL_RW_ENTRY(ARP_ACCEPT, "arp_accept"),
 
1453                 DEVINET_SYSCTL_FLUSHING_ENTRY(NOXFRM, "disable_xfrm"),
 
1454                 DEVINET_SYSCTL_FLUSHING_ENTRY(NOPOLICY, "disable_policy"),
 
1455                 DEVINET_SYSCTL_FLUSHING_ENTRY(FORCE_IGMP_VERSION,
 
1456                                               "force_igmp_version"),
 
1457                 DEVINET_SYSCTL_FLUSHING_ENTRY(PROMOTE_SECONDARIES,
 
1458                                               "promote_secondaries"),
 
1462 static int __devinet_sysctl_register(struct net *net, char *dev_name,
 
1463                 int ctl_name, struct ipv4_devconf *p)
 
1466         struct devinet_sysctl_table *t;
 
1468 #define DEVINET_CTL_PATH_DEV    3
 
1470         struct ctl_path devinet_ctl_path[] = {
 
1471                 { .procname = "net", .ctl_name = CTL_NET, },
 
1472                 { .procname = "ipv4", .ctl_name = NET_IPV4, },
 
1473                 { .procname = "conf", .ctl_name = NET_IPV4_CONF, },
 
1474                 { /* to be set */ },
 
1478         t = kmemdup(&devinet_sysctl, sizeof(*t), GFP_KERNEL);
 
1482         for (i = 0; i < ARRAY_SIZE(t->devinet_vars) - 1; i++) {
 
1483                 t->devinet_vars[i].data += (char *)p - (char *)&ipv4_devconf;
 
1484                 t->devinet_vars[i].extra1 = p;
 
1485                 t->devinet_vars[i].extra2 = net;
 
1489          * Make a copy of dev_name, because '.procname' is regarded as const
 
1490          * by sysctl and we wouldn't want anyone to change it under our feet
 
1491          * (see SIOCSIFNAME).
 
1493         t->dev_name = kstrdup(dev_name, GFP_KERNEL);
 
1497         devinet_ctl_path[DEVINET_CTL_PATH_DEV].procname = t->dev_name;
 
1498         devinet_ctl_path[DEVINET_CTL_PATH_DEV].ctl_name = ctl_name;
 
1500         t->sysctl_header = register_net_sysctl_table(net, devinet_ctl_path,
 
1502         if (!t->sysctl_header)
 
1516 static void __devinet_sysctl_unregister(struct ipv4_devconf *cnf)
 
1518         struct devinet_sysctl_table *t = cnf->sysctl;
 
1524         unregister_sysctl_table(t->sysctl_header);
 
1529 static void devinet_sysctl_register(struct in_device *idev)
 
1531         neigh_sysctl_register(idev->dev, idev->arp_parms, NET_IPV4,
 
1532                         NET_IPV4_NEIGH, "ipv4", NULL, NULL);
 
1533         __devinet_sysctl_register(dev_net(idev->dev), idev->dev->name,
 
1534                         idev->dev->ifindex, &idev->cnf);
 
1537 static void devinet_sysctl_unregister(struct in_device *idev)
 
1539         __devinet_sysctl_unregister(&idev->cnf);
 
1540         neigh_sysctl_unregister(idev->arp_parms);
 
1543 static struct ctl_table ctl_forward_entry[] = {
 
1545                 .ctl_name       = NET_IPV4_FORWARD,
 
1546                 .procname       = "ip_forward",
 
1547                 .data           = &ipv4_devconf.data[
 
1548                                         NET_IPV4_CONF_FORWARDING - 1],
 
1549                 .maxlen         = sizeof(int),
 
1551                 .proc_handler   = devinet_sysctl_forward,
 
1552                 .strategy       = devinet_conf_sysctl,
 
1553                 .extra1         = &ipv4_devconf,
 
1554                 .extra2         = &init_net,
 
1559 static __net_initdata struct ctl_path net_ipv4_path[] = {
 
1560         { .procname = "net", .ctl_name = CTL_NET, },
 
1561         { .procname = "ipv4", .ctl_name = NET_IPV4, },
 
1566 static __net_init int devinet_init_net(struct net *net)
 
1569         struct ipv4_devconf *all, *dflt;
 
1570 #ifdef CONFIG_SYSCTL
 
1571         struct ctl_table *tbl = ctl_forward_entry;
 
1572         struct ctl_table_header *forw_hdr;
 
1576         all = &ipv4_devconf;
 
1577         dflt = &ipv4_devconf_dflt;
 
1579         if (net != &init_net) {
 
1580                 all = kmemdup(all, sizeof(ipv4_devconf), GFP_KERNEL);
 
1584                 dflt = kmemdup(dflt, sizeof(ipv4_devconf_dflt), GFP_KERNEL);
 
1586                         goto err_alloc_dflt;
 
1588 #ifdef CONFIG_SYSCTL
 
1589                 tbl = kmemdup(tbl, sizeof(ctl_forward_entry), GFP_KERNEL);
 
1593                 tbl[0].data = &all->data[NET_IPV4_CONF_FORWARDING - 1];
 
1594                 tbl[0].extra1 = all;
 
1595                 tbl[0].extra2 = net;
 
1599 #ifdef CONFIG_SYSCTL
 
1600         err = __devinet_sysctl_register(net, "all",
 
1601                         NET_PROTO_CONF_ALL, all);
 
1605         err = __devinet_sysctl_register(net, "default",
 
1606                         NET_PROTO_CONF_DEFAULT, dflt);
 
1611         forw_hdr = register_net_sysctl_table(net, net_ipv4_path, tbl);
 
1612         if (forw_hdr == NULL)
 
1614         net->ipv4.forw_hdr = forw_hdr;
 
1617         net->ipv4.devconf_all = all;
 
1618         net->ipv4.devconf_dflt = dflt;
 
1621 #ifdef CONFIG_SYSCTL
 
1623         __devinet_sysctl_unregister(dflt);
 
1625         __devinet_sysctl_unregister(all);
 
1627         if (tbl != ctl_forward_entry)
 
1631         if (dflt != &ipv4_devconf_dflt)
 
1634         if (all != &ipv4_devconf)
 
1640 static __net_exit void devinet_exit_net(struct net *net)
 
1642 #ifdef CONFIG_SYSCTL
 
1643         struct ctl_table *tbl;
 
1645         tbl = net->ipv4.forw_hdr->ctl_table_arg;
 
1646         unregister_net_sysctl_table(net->ipv4.forw_hdr);
 
1647         __devinet_sysctl_unregister(net->ipv4.devconf_dflt);
 
1648         __devinet_sysctl_unregister(net->ipv4.devconf_all);
 
1651         kfree(net->ipv4.devconf_dflt);
 
1652         kfree(net->ipv4.devconf_all);
 
1655 static __net_initdata struct pernet_operations devinet_ops = {
 
1656         .init = devinet_init_net,
 
1657         .exit = devinet_exit_net,
 
1660 void __init devinet_init(void)
 
1662         register_pernet_subsys(&devinet_ops);
 
1664         register_gifconf(PF_INET, inet_gifconf);
 
1665         register_netdevice_notifier(&ip_netdev_notifier);
 
1667         rtnl_register(PF_INET, RTM_NEWADDR, inet_rtm_newaddr, NULL);
 
1668         rtnl_register(PF_INET, RTM_DELADDR, inet_rtm_deladdr, NULL);
 
1669         rtnl_register(PF_INET, RTM_GETADDR, NULL, inet_dump_ifaddr);
 
1672 EXPORT_SYMBOL(in_dev_finish_destroy);
 
1673 EXPORT_SYMBOL(inet_select_addr);
 
1674 EXPORT_SYMBOL(inetdev_by_index);
 
1675 EXPORT_SYMBOL(register_inetaddr_notifier);
 
1676 EXPORT_SYMBOL(unregister_inetaddr_notifier);