goto out_neigh_release;
        }
 
-       n->confirmed = jiffies - (n->parms->base_reachable_time << 1);
+       n->confirmed = jiffies - (NEIGH_VAR(n->parms, BASE_REACHABLE_TIME) << 1);
 
        write_lock_bh(&tbl->lock);
        nht = rcu_dereference_protected(tbl->nht,
                tbl->last_rand = jiffies;
                for (p = &tbl->parms; p; p = p->next)
                        p->reachable_time =
-                               neigh_rand_reach_time(p->base_reachable_time);
+                               neigh_rand_reach_time(NEIGH_VAR(p, BASE_REACHABLE_TIME));
        }
 
        for (i = 0 ; i < (1 << nht->hash_shift); i++) {
 
                        if (atomic_read(&n->refcnt) == 1 &&
                            (state == NUD_FAILED ||
-                            time_after(jiffies, n->used + n->parms->gc_staletime))) {
+                            time_after(jiffies, n->used + NEIGH_VAR(n->parms, GC_STALETIME)))) {
                                *np = n->next;
                                n->dead = 1;
                                write_unlock(&n->lock);
                                                lockdep_is_held(&tbl->lock));
        }
 out:
-       /* Cycle through all hash buckets every base_reachable_time/2 ticks.
-        * ARP entry timeouts range from 1/2 base_reachable_time to 3/2
-        * base_reachable_time.
+       /* Cycle through all hash buckets every BASE_REACHABLE_TIME/2 ticks.
+        * ARP entry timeouts range from 1/2 BASE_REACHABLE_TIME to 3/2
+        * BASE_REACHABLE_TIME.
         */
        schedule_delayed_work(&tbl->gc_work,
-                             tbl->parms.base_reachable_time >> 1);
+                             NEIGH_VAR(&tbl->parms, BASE_REACHABLE_TIME) >> 1);
        write_unlock_bh(&tbl->lock);
 }
 
 {
        struct neigh_parms *p = n->parms;
        return (n->nud_state & NUD_PROBE) ?
-               p->ucast_probes :
-               p->ucast_probes + p->app_probes + p->mcast_probes;
+               NEIGH_VAR(p, UCAST_PROBES) :
+               NEIGH_VAR(p, UCAST_PROBES) + NEIGH_VAR(p, APP_PROBES) +
+               NEIGH_VAR(p, MCAST_PROBES);
 }
 
 static void neigh_invalidate(struct neighbour *neigh)
                        neigh_dbg(2, "neigh %p is still alive\n", neigh);
                        next = neigh->confirmed + neigh->parms->reachable_time;
                } else if (time_before_eq(now,
-                                         neigh->used + neigh->parms->delay_probe_time)) {
+                                         neigh->used +
+                                         NEIGH_VAR(neigh->parms, DELAY_PROBE_TIME))) {
                        neigh_dbg(2, "neigh %p is delayed\n", neigh);
                        neigh->nud_state = NUD_DELAY;
                        neigh->updated = jiffies;
                        neigh_suspect(neigh);
-                       next = now + neigh->parms->delay_probe_time;
+                       next = now + NEIGH_VAR(neigh->parms, DELAY_PROBE_TIME);
                } else {
                        neigh_dbg(2, "neigh %p is suspected\n", neigh);
                        neigh->nud_state = NUD_STALE;
                }
        } else if (state & NUD_DELAY) {
                if (time_before_eq(now,
-                                  neigh->confirmed + neigh->parms->delay_probe_time)) {
+                                  neigh->confirmed +
+                                  NEIGH_VAR(neigh->parms, DELAY_PROBE_TIME))) {
                        neigh_dbg(2, "neigh %p is now reachable\n", neigh);
                        neigh->nud_state = NUD_REACHABLE;
                        neigh->updated = jiffies;
                        neigh->nud_state = NUD_PROBE;
                        neigh->updated = jiffies;
                        atomic_set(&neigh->probes, 0);
-                       next = now + neigh->parms->retrans_time;
+                       next = now + NEIGH_VAR(neigh->parms, RETRANS_TIME);
                }
        } else {
                /* NUD_PROBE|NUD_INCOMPLETE */
-               next = now + neigh->parms->retrans_time;
+               next = now + NEIGH_VAR(neigh->parms, RETRANS_TIME);
        }
 
        if ((neigh->nud_state & (NUD_INCOMPLETE | NUD_PROBE)) &&
                goto out_unlock_bh;
 
        if (!(neigh->nud_state & (NUD_STALE | NUD_INCOMPLETE))) {
-               if (neigh->parms->mcast_probes + neigh->parms->app_probes) {
+               if (NEIGH_VAR(neigh->parms, MCAST_PROBES) +
+                   NEIGH_VAR(neigh->parms, APP_PROBES)) {
                        unsigned long next, now = jiffies;
 
-                       atomic_set(&neigh->probes, neigh->parms->ucast_probes);
+                       atomic_set(&neigh->probes,
+                                  NEIGH_VAR(neigh->parms, UCAST_PROBES));
                        neigh->nud_state     = NUD_INCOMPLETE;
                        neigh->updated = now;
-                       next = now + max(neigh->parms->retrans_time, HZ/2);
+                       next = now + max(NEIGH_VAR(neigh->parms, RETRANS_TIME),
+                                        HZ/2);
                        neigh_add_timer(neigh, next);
                        immediate_probe = true;
                } else {
                neigh_dbg(2, "neigh %p is delayed\n", neigh);
                neigh->nud_state = NUD_DELAY;
                neigh->updated = jiffies;
-               neigh_add_timer(neigh,
-                               jiffies + neigh->parms->delay_probe_time);
+               neigh_add_timer(neigh, jiffies +
+                               NEIGH_VAR(neigh->parms, DELAY_PROBE_TIME));
        }
 
        if (neigh->nud_state == NUD_INCOMPLETE) {
                if (skb) {
                        while (neigh->arp_queue_len_bytes + skb->truesize >
-                              neigh->parms->queue_len_bytes) {
+                              NEIGH_VAR(neigh->parms, QUEUE_LEN_BYTES)) {
                                struct sk_buff *buff;
 
                                buff = __skb_dequeue(&neigh->arp_queue);
                neigh_update_hhs(neigh);
                if (!(new & NUD_CONNECTED))
                        neigh->confirmed = jiffies -
-                                     (neigh->parms->base_reachable_time << 1);
+                                     (NEIGH_VAR(neigh->parms, BASE_REACHABLE_TIME) << 1);
                notify = 1;
        }
        if (new == old)
                    struct sk_buff *skb)
 {
        unsigned long now = jiffies;
-       unsigned long sched_next = now + (net_random() % p->proxy_delay);
+       unsigned long sched_next = now + (net_random() %
+                                         NEIGH_VAR(p, PROXY_DELAY));
 
-       if (tbl->proxy_queue.qlen > p->proxy_qlen) {
+       if (tbl->proxy_queue.qlen > NEIGH_VAR(p, PROXY_QLEN)) {
                kfree_skb(skb);
                return;
        }
                p->tbl            = tbl;
                atomic_set(&p->refcnt, 1);
                p->reachable_time =
-                               neigh_rand_reach_time(p->base_reachable_time);
+                               neigh_rand_reach_time(NEIGH_VAR(p, BASE_REACHABLE_TIME));
                dev_hold(dev);
                p->dev = dev;
                write_pnet(&p->net, hold_net(net));
        write_pnet(&tbl->parms.net, &init_net);
        atomic_set(&tbl->parms.refcnt, 1);
        tbl->parms.reachable_time =
-                         neigh_rand_reach_time(tbl->parms.base_reachable_time);
+                         neigh_rand_reach_time(NEIGH_VAR(&tbl->parms, BASE_REACHABLE_TIME));
 
        tbl->stats = alloc_percpu(struct neigh_statistics);
        if (!tbl->stats)
        if ((parms->dev &&
             nla_put_u32(skb, NDTPA_IFINDEX, parms->dev->ifindex)) ||
            nla_put_u32(skb, NDTPA_REFCNT, atomic_read(&parms->refcnt)) ||
-           nla_put_u32(skb, NDTPA_QUEUE_LENBYTES, parms->queue_len_bytes) ||
+           nla_put_u32(skb, NDTPA_QUEUE_LENBYTES,
+                       NEIGH_VAR(parms, QUEUE_LEN_BYTES)) ||
            /* approximative value for deprecated QUEUE_LEN (in packets) */
            nla_put_u32(skb, NDTPA_QUEUE_LEN,
-                       parms->queue_len_bytes / SKB_TRUESIZE(ETH_FRAME_LEN)) ||
-           nla_put_u32(skb, NDTPA_PROXY_QLEN, parms->proxy_qlen) ||
-           nla_put_u32(skb, NDTPA_APP_PROBES, parms->app_probes) ||
-           nla_put_u32(skb, NDTPA_UCAST_PROBES, parms->ucast_probes) ||
-           nla_put_u32(skb, NDTPA_MCAST_PROBES, parms->mcast_probes) ||
+                       NEIGH_VAR(parms, QUEUE_LEN_BYTES) / SKB_TRUESIZE(ETH_FRAME_LEN)) ||
+           nla_put_u32(skb, NDTPA_PROXY_QLEN, NEIGH_VAR(parms, PROXY_QLEN)) ||
+           nla_put_u32(skb, NDTPA_APP_PROBES, NEIGH_VAR(parms, APP_PROBES)) ||
+           nla_put_u32(skb, NDTPA_UCAST_PROBES,
+                       NEIGH_VAR(parms, UCAST_PROBES)) ||
+           nla_put_u32(skb, NDTPA_MCAST_PROBES,
+                       NEIGH_VAR(parms, MCAST_PROBES)) ||
            nla_put_msecs(skb, NDTPA_REACHABLE_TIME, parms->reachable_time) ||
            nla_put_msecs(skb, NDTPA_BASE_REACHABLE_TIME,
-                         parms->base_reachable_time) ||
-           nla_put_msecs(skb, NDTPA_GC_STALETIME, parms->gc_staletime) ||
+                         NEIGH_VAR(parms, BASE_REACHABLE_TIME)) ||
+           nla_put_msecs(skb, NDTPA_GC_STALETIME,
+                         NEIGH_VAR(parms, GC_STALETIME)) ||
            nla_put_msecs(skb, NDTPA_DELAY_PROBE_TIME,
-                         parms->delay_probe_time) ||
-           nla_put_msecs(skb, NDTPA_RETRANS_TIME, parms->retrans_time) ||
-           nla_put_msecs(skb, NDTPA_ANYCAST_DELAY, parms->anycast_delay) ||
-           nla_put_msecs(skb, NDTPA_PROXY_DELAY, parms->proxy_delay) ||
-           nla_put_msecs(skb, NDTPA_LOCKTIME, parms->locktime))
+                         NEIGH_VAR(parms, DELAY_PROBE_TIME)) ||
+           nla_put_msecs(skb, NDTPA_RETRANS_TIME,
+                         NEIGH_VAR(parms, RETRANS_TIME)) ||
+           nla_put_msecs(skb, NDTPA_ANYCAST_DELAY,
+                         NEIGH_VAR(parms, ANYCAST_DELAY)) ||
+           nla_put_msecs(skb, NDTPA_PROXY_DELAY,
+                         NEIGH_VAR(parms, PROXY_DELAY)) ||
+           nla_put_msecs(skb, NDTPA_LOCKTIME,
+                         NEIGH_VAR(parms, LOCKTIME)))
                goto nla_put_failure;
        return nla_nest_end(skb, nest);
 
 
                        switch (i) {
                        case NDTPA_QUEUE_LEN:
-                               p->queue_len_bytes = nla_get_u32(tbp[i]) *
-                                                    SKB_TRUESIZE(ETH_FRAME_LEN);
+                               NEIGH_VAR_SET(p, QUEUE_LEN_BYTES,
+                                             nla_get_u32(tbp[i]) *
+                                             SKB_TRUESIZE(ETH_FRAME_LEN));
                                break;
                        case NDTPA_QUEUE_LENBYTES:
-                               p->queue_len_bytes = nla_get_u32(tbp[i]);
+                               NEIGH_VAR_SET(p, QUEUE_LEN_BYTES,
+                                             nla_get_u32(tbp[i]));
                                break;
                        case NDTPA_PROXY_QLEN:
-                               p->proxy_qlen = nla_get_u32(tbp[i]);
+                               NEIGH_VAR_SET(p, PROXY_QLEN,
+                                             nla_get_u32(tbp[i]));
                                break;
                        case NDTPA_APP_PROBES:
-                               p->app_probes = nla_get_u32(tbp[i]);
+                               NEIGH_VAR_SET(p, APP_PROBES,
+                                             nla_get_u32(tbp[i]));
                                break;
                        case NDTPA_UCAST_PROBES:
-                               p->ucast_probes = nla_get_u32(tbp[i]);
+                               NEIGH_VAR_SET(p, UCAST_PROBES,
+                                             nla_get_u32(tbp[i]));
                                break;
                        case NDTPA_MCAST_PROBES:
-                               p->mcast_probes = nla_get_u32(tbp[i]);
+                               NEIGH_VAR_SET(p, MCAST_PROBES,
+                                             nla_get_u32(tbp[i]));
                                break;
                        case NDTPA_BASE_REACHABLE_TIME:
-                               p->base_reachable_time = nla_get_msecs(tbp[i]);
+                               NEIGH_VAR_SET(p, BASE_REACHABLE_TIME,
+                                             nla_get_msecs(tbp[i]));
                                break;
                        case NDTPA_GC_STALETIME:
-                               p->gc_staletime = nla_get_msecs(tbp[i]);
+                               NEIGH_VAR_SET(p, GC_STALETIME,
+                                             nla_get_msecs(tbp[i]));
                                break;
                        case NDTPA_DELAY_PROBE_TIME:
-                               p->delay_probe_time = nla_get_msecs(tbp[i]);
+                               NEIGH_VAR_SET(p, DELAY_PROBE_TIME,
+                                             nla_get_msecs(tbp[i]));
                                break;
                        case NDTPA_RETRANS_TIME:
-                               p->retrans_time = nla_get_msecs(tbp[i]);
+                               NEIGH_VAR_SET(p, RETRANS_TIME,
+                                             nla_get_msecs(tbp[i]));
                                break;
                        case NDTPA_ANYCAST_DELAY:
-                               p->anycast_delay = nla_get_msecs(tbp[i]);
+                               NEIGH_VAR_SET(p, ANYCAST_DELAY, nla_get_msecs(tbp[i]));
                                break;
                        case NDTPA_PROXY_DELAY:
-                               p->proxy_delay = nla_get_msecs(tbp[i]);
+                               NEIGH_VAR_SET(p, PROXY_DELAY, nla_get_msecs(tbp[i]));
                                break;
                        case NDTPA_LOCKTIME:
-                               p->locktime = nla_get_msecs(tbp[i]);
+                               NEIGH_VAR_SET(p, LOCKTIME, nla_get_msecs(tbp[i]));
                                break;
                        }
                }
        return ret;
 }
 
-enum {
-       NEIGH_VAR_MCAST_PROBE,
-       NEIGH_VAR_UCAST_PROBE,
-       NEIGH_VAR_APP_PROBE,
-       NEIGH_VAR_RETRANS_TIME,
-       NEIGH_VAR_BASE_REACHABLE_TIME,
-       NEIGH_VAR_DELAY_PROBE_TIME,
-       NEIGH_VAR_GC_STALETIME,
-       NEIGH_VAR_QUEUE_LEN,
-       NEIGH_VAR_QUEUE_LEN_BYTES,
-       NEIGH_VAR_PROXY_QLEN,
-       NEIGH_VAR_ANYCAST_DELAY,
-       NEIGH_VAR_PROXY_DELAY,
-       NEIGH_VAR_LOCKTIME,
-       NEIGH_VAR_RETRANS_TIME_MS,
-       NEIGH_VAR_BASE_REACHABLE_TIME_MS,
-       NEIGH_VAR_GC_INTERVAL,
-       NEIGH_VAR_GC_THRESH1,
-       NEIGH_VAR_GC_THRESH2,
-       NEIGH_VAR_GC_THRESH3,
-       NEIGH_VAR_MAX
-};
+static int neigh_proc_dointvec_zero_intmax(struct ctl_table *ctl, int write,
+                                          void __user *buffer,
+                                          size_t *lenp, loff_t *ppos)
+{
+       struct ctl_table tmp = *ctl;
+
+       tmp.extra1 = &zero;
+       tmp.extra2 = &int_max;
+
+       return proc_dointvec_minmax(&tmp, write, buffer, lenp, ppos);
+}
+
+#define NEIGH_PARMS_DATA_OFFSET(index) \
+       (&((struct neigh_parms *) 0)->data[index])
+
+#define NEIGH_SYSCTL_ENTRY(attr, data_attr, name, mval, proc) \
+       [NEIGH_VAR_ ## attr] = { \
+               .procname       = name, \
+               .data           = NEIGH_PARMS_DATA_OFFSET(NEIGH_VAR_ ## data_attr), \
+               .maxlen         = sizeof(int), \
+               .mode           = mval, \
+               .proc_handler   = proc, \
+       }
+
+#define NEIGH_SYSCTL_ZERO_INTMAX_ENTRY(attr, name) \
+       NEIGH_SYSCTL_ENTRY(attr, attr, name, 0644, neigh_proc_dointvec_zero_intmax)
+
+#define NEIGH_SYSCTL_JIFFIES_ENTRY(attr, name) \
+       NEIGH_SYSCTL_ENTRY(attr, attr, name, 0644, proc_dointvec_jiffies)
+
+#define NEIGH_SYSCTL_USERHZ_JIFFIES_ENTRY(attr, name) \
+       NEIGH_SYSCTL_ENTRY(attr, attr, name, 0644, proc_dointvec_userhz_jiffies)
+
+#define NEIGH_SYSCTL_MS_JIFFIES_ENTRY(attr, name) \
+       NEIGH_SYSCTL_ENTRY(attr, attr, name, 0644, proc_dointvec_ms_jiffies)
+
+#define NEIGH_SYSCTL_MS_JIFFIES_REUSED_ENTRY(attr, data_attr, name) \
+       NEIGH_SYSCTL_ENTRY(attr, data_attr, name, 0644, proc_dointvec_ms_jiffies)
+
+#define NEIGH_SYSCTL_UNRES_QLEN_REUSED_ENTRY(attr, data_attr, name) \
+       NEIGH_SYSCTL_ENTRY(attr, data_attr, name, 0644, proc_unres_qlen)
 
 static struct neigh_sysctl_table {
        struct ctl_table_header *sysctl_header;
        struct ctl_table neigh_vars[NEIGH_VAR_MAX + 1];
 } neigh_sysctl_template __read_mostly = {
        .neigh_vars = {
-               [NEIGH_VAR_MCAST_PROBE] = {
-                       .procname       = "mcast_solicit",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .extra1         = &zero,
-                       .extra2         = &int_max,
-                       .proc_handler   = proc_dointvec_minmax,
-               },
-               [NEIGH_VAR_UCAST_PROBE] = {
-                       .procname       = "ucast_solicit",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .extra1         = &zero,
-                       .extra2         = &int_max,
-                       .proc_handler   = proc_dointvec_minmax,
-               },
-               [NEIGH_VAR_APP_PROBE] = {
-                       .procname       = "app_solicit",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .extra1         = &zero,
-                       .extra2         = &int_max,
-                       .proc_handler   = proc_dointvec_minmax,
-               },
-               [NEIGH_VAR_RETRANS_TIME] = {
-                       .procname       = "retrans_time",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_userhz_jiffies,
-               },
-               [NEIGH_VAR_BASE_REACHABLE_TIME] = {
-                       .procname       = "base_reachable_time",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_jiffies,
-               },
-               [NEIGH_VAR_DELAY_PROBE_TIME] = {
-                       .procname       = "delay_first_probe_time",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_jiffies,
-               },
-               [NEIGH_VAR_GC_STALETIME] = {
-                       .procname       = "gc_stale_time",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_jiffies,
-               },
-               [NEIGH_VAR_QUEUE_LEN] = {
-                       .procname       = "unres_qlen",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_unres_qlen,
-               },
-               [NEIGH_VAR_QUEUE_LEN_BYTES] = {
-                       .procname       = "unres_qlen_bytes",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .extra1         = &zero,
-                       .proc_handler   = proc_dointvec_minmax,
-               },
-               [NEIGH_VAR_PROXY_QLEN] = {
-                       .procname       = "proxy_qlen",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .extra1         = &zero,
-                       .extra2         = &int_max,
-                       .proc_handler   = proc_dointvec_minmax,
-               },
-               [NEIGH_VAR_ANYCAST_DELAY] = {
-                       .procname       = "anycast_delay",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_userhz_jiffies,
-               },
-               [NEIGH_VAR_PROXY_DELAY] = {
-                       .procname       = "proxy_delay",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_userhz_jiffies,
-               },
-               [NEIGH_VAR_LOCKTIME] = {
-                       .procname       = "locktime",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_userhz_jiffies,
-               },
-               [NEIGH_VAR_RETRANS_TIME_MS] = {
-                       .procname       = "retrans_time_ms",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_ms_jiffies,
-               },
-               [NEIGH_VAR_BASE_REACHABLE_TIME_MS] = {
-                       .procname       = "base_reachable_time_ms",
-                       .maxlen         = sizeof(int),
-                       .mode           = 0644,
-                       .proc_handler   = proc_dointvec_ms_jiffies,
-               },
+               NEIGH_SYSCTL_ZERO_INTMAX_ENTRY(MCAST_PROBES, "mcast_solicit"),
+               NEIGH_SYSCTL_ZERO_INTMAX_ENTRY(UCAST_PROBES, "ucast_solicit"),
+               NEIGH_SYSCTL_ZERO_INTMAX_ENTRY(APP_PROBES, "app_solicit"),
+               NEIGH_SYSCTL_USERHZ_JIFFIES_ENTRY(RETRANS_TIME, "retrans_time"),
+               NEIGH_SYSCTL_JIFFIES_ENTRY(BASE_REACHABLE_TIME, "base_reachable_time"),
+               NEIGH_SYSCTL_JIFFIES_ENTRY(DELAY_PROBE_TIME, "delay_first_probe_time"),
+               NEIGH_SYSCTL_JIFFIES_ENTRY(GC_STALETIME, "gc_stale_time"),
+               NEIGH_SYSCTL_ZERO_INTMAX_ENTRY(QUEUE_LEN_BYTES, "unres_qlen_bytes"),
+               NEIGH_SYSCTL_ZERO_INTMAX_ENTRY(PROXY_QLEN, "proxy_qlen"),
+               NEIGH_SYSCTL_USERHZ_JIFFIES_ENTRY(ANYCAST_DELAY, "anycast_delay"),
+               NEIGH_SYSCTL_USERHZ_JIFFIES_ENTRY(PROXY_DELAY, "proxy_delay"),
+               NEIGH_SYSCTL_USERHZ_JIFFIES_ENTRY(LOCKTIME, "locktime"),
+               NEIGH_SYSCTL_UNRES_QLEN_REUSED_ENTRY(QUEUE_LEN, QUEUE_LEN_BYTES, "unres_qlen"),
+               NEIGH_SYSCTL_MS_JIFFIES_REUSED_ENTRY(RETRANS_TIME_MS, RETRANS_TIME, "retrans_time_ms"),
+               NEIGH_SYSCTL_MS_JIFFIES_REUSED_ENTRY(BASE_REACHABLE_TIME_MS, BASE_REACHABLE_TIME, "base_reachable_time_ms"),
                [NEIGH_VAR_GC_INTERVAL] = {
                        .procname       = "gc_interval",
                        .maxlen         = sizeof(int),
 int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p,
                          char *p_name, proc_handler *handler)
 {
+       int i;
        struct neigh_sysctl_table *t;
-       const char *dev_name_source = NULL;
+       const char *dev_name_source;
        char neigh_path[ sizeof("net//neigh/") + IFNAMSIZ + IFNAMSIZ ];
 
        t = kmemdup(&neigh_sysctl_template, sizeof(*t), GFP_KERNEL);
        if (!t)
                goto err;
 
-       t->neigh_vars[NEIGH_VAR_MCAST_PROBE].data  = &p->mcast_probes;
-       t->neigh_vars[NEIGH_VAR_UCAST_PROBE].data  = &p->ucast_probes;
-       t->neigh_vars[NEIGH_VAR_APP_PROBE].data  = &p->app_probes;
-       t->neigh_vars[NEIGH_VAR_RETRANS_TIME].data  = &p->retrans_time;
-       t->neigh_vars[NEIGH_VAR_BASE_REACHABLE_TIME].data  = &p->base_reachable_time;
-       t->neigh_vars[NEIGH_VAR_DELAY_PROBE_TIME].data  = &p->delay_probe_time;
-       t->neigh_vars[NEIGH_VAR_GC_STALETIME].data  = &p->gc_staletime;
-       t->neigh_vars[NEIGH_VAR_QUEUE_LEN].data  = &p->queue_len_bytes;
-       t->neigh_vars[NEIGH_VAR_QUEUE_LEN_BYTES].data  = &p->queue_len_bytes;
-       t->neigh_vars[NEIGH_VAR_PROXY_QLEN].data  = &p->proxy_qlen;
-       t->neigh_vars[NEIGH_VAR_ANYCAST_DELAY].data  = &p->anycast_delay;
-       t->neigh_vars[NEIGH_VAR_PROXY_DELAY].data = &p->proxy_delay;
-       t->neigh_vars[NEIGH_VAR_LOCKTIME].data = &p->locktime;
-       t->neigh_vars[NEIGH_VAR_RETRANS_TIME_MS].data  = &p->retrans_time;
-       t->neigh_vars[NEIGH_VAR_BASE_REACHABLE_TIME_MS].data  = &p->base_reachable_time;
+       for (i = 0; i < ARRAY_SIZE(t->neigh_vars); i++)
+               t->neigh_vars[i].data += (long) p;
 
        if (dev) {
                dev_name_source = dev->name;
                t->neigh_vars[NEIGH_VAR_GC_THRESH3].data = (int *)(p + 1) + 3;
        }
 
-
        if (handler) {
                /* RetransTime */
                t->neigh_vars[NEIGH_VAR_RETRANS_TIME].proc_handler = handler;