[BACK]Return to ip6_input.c CVS log [TXT][DIR] Up to [cvs.NetBSD.org] / src / sys / netinet6

Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.

Diff for /src/sys/netinet6/ip6_input.c between version 1.145.2.1 and 1.146

version 1.145.2.1, 2014/08/10 06:56:30 version 1.146, 2014/05/30 01:39:03
Line 90  __KERNEL_RCSID(0, "$NetBSD$");
Line 90  __KERNEL_RCSID(0, "$NetBSD$");
 #include <net/if_types.h>  #include <net/if_types.h>
 #include <net/if_dl.h>  #include <net/if_dl.h>
 #include <net/route.h>  #include <net/route.h>
 #include <net/pktqueue.h>  #include <net/netisr.h>
 #include <net/pfil.h>  #include <net/pfil.h>
   
 #include <netinet/in.h>  #include <netinet/in.h>
 #include <netinet/in_systm.h>  #include <netinet/in_systm.h>
 #ifdef INET  #ifdef INET
 #include <netinet/ip.h>  #include <netinet/ip.h>
 #include <netinet/ip_var.h>  
 #include <netinet/ip_icmp.h>  #include <netinet/ip_icmp.h>
 #endif /* INET */  #endif /* INET */
 #include <netinet/ip6.h>  #include <netinet/ip6.h>
Line 136  __KERNEL_RCSID(0, "$NetBSD$");
Line 135  __KERNEL_RCSID(0, "$NetBSD$");
 extern struct domain inet6domain;  extern struct domain inet6domain;
   
 u_char ip6_protox[IPPROTO_MAX];  u_char ip6_protox[IPPROTO_MAX];
   static int ip6qmaxlen = IFQ_MAXLEN;
 struct in6_ifaddr *in6_ifaddr;  struct in6_ifaddr *in6_ifaddr;
 pktqueue_t *ip6_pktq __read_mostly;  struct ifqueue ip6intrq;
   
 extern callout_t in6_tmpaddrtimer_ch;  extern callout_t in6_tmpaddrtimer_ch;
   
Line 150  pfil_head_t *inet6_pfil_hook;
Line 150  pfil_head_t *inet6_pfil_hook;
 percpu_t *ip6stat_percpu;  percpu_t *ip6stat_percpu;
   
 static void ip6_init2(void *);  static void ip6_init2(void *);
 static void ip6intr(void *);  
 static struct m_tag *ip6_setdstifaddr(struct mbuf *, const struct in6_ifaddr *);  static struct m_tag *ip6_setdstifaddr(struct mbuf *, const struct in6_ifaddr *);
   
 static int ip6_process_hopopts(struct mbuf *, u_int8_t *, int, u_int32_t *,  static int ip6_process_hopopts(struct mbuf *, u_int8_t *, int, u_int32_t *,
Line 179  ip6_init(void)
Line 178  ip6_init(void)
                 if (pr->pr_domain->dom_family == PF_INET6 &&                  if (pr->pr_domain->dom_family == PF_INET6 &&
                     pr->pr_protocol && pr->pr_protocol != IPPROTO_RAW)                      pr->pr_protocol && pr->pr_protocol != IPPROTO_RAW)
                         ip6_protox[pr->pr_protocol] = pr - inet6sw;                          ip6_protox[pr->pr_protocol] = pr - inet6sw;
           ip6intrq.ifq_maxlen = ip6qmaxlen;
         ip6_pktq = pktq_create(IFQ_MAXLEN, ip6intr, NULL);  
         KASSERT(ip6_pktq != NULL);  
   
         scope6_init();          scope6_init();
         addrsel_policy_init();          addrsel_policy_init();
         nd6_init();          nd6_init();
Line 219  ip6_init2(void *dummy)
Line 215  ip6_init2(void *dummy)
 /*  /*
  * IP6 input interrupt handling. Just pass the packet to ip6_input.   * IP6 input interrupt handling. Just pass the packet to ip6_input.
  */   */
 static void  void
 ip6intr(void *arg __unused)  ip6intr(void)
 {  {
           int s;
         struct mbuf *m;          struct mbuf *m;
   
         mutex_enter(softnet_lock);          mutex_enter(softnet_lock);
         while ((m = pktq_dequeue(ip6_pktq)) != NULL) {          KERNEL_LOCK(1, NULL);
                 const ifnet_t *ifp = m->m_pkthdr.rcvif;          for (;;) {
                   s = splnet();
                 /*                  IF_DEQUEUE(&ip6intrq, m);
                  * Drop the packet if IPv6 is disabled on the interface.                  splx(s);
                  */                  if (m == 0)
                 if ((ND_IFINFO(ifp)->flags & ND6_IFF_IFDISABLED)) {                          break;
                   /* drop the packet if IPv6 operation is disabled on the IF */
                   if ((ND_IFINFO(m->m_pkthdr.rcvif)->flags & ND6_IFF_IFDISABLED)) {
                         m_freem(m);                          m_freem(m);
                         continue;                          break;
                 }                  }
                 ip6_input(m);                  ip6_input(m);
         }          }
           KERNEL_UNLOCK_ONE(NULL);
         mutex_exit(softnet_lock);          mutex_exit(softnet_lock);
 }  }
   
Line 1854  sysctl_net_inet6_ip6_setup(struct sysctl
Line 1854  sysctl_net_inet6_ip6_setup(struct sysctl
                        IPV6CTL_V6ONLY, CTL_EOL);                         IPV6CTL_V6ONLY, CTL_EOL);
         sysctl_createv(clog, 0, NULL, NULL,          sysctl_createv(clog, 0, NULL, NULL,
                        CTLFLAG_PERMANENT|CTLFLAG_READWRITE,                         CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
                        CTLTYPE_INT, "auto_linklocal",  
                        SYSCTL_DESCR("Default value of per-interface flag for "  
                                     "adding an IPv6 link-local address to "  
                                     "interfaces when attached"),  
                        NULL, 0, &ip6_auto_linklocal, 0,  
                        CTL_NET, PF_INET6, IPPROTO_IPV6,  
                        IPV6CTL_AUTO_LINKLOCAL, CTL_EOL);  
         sysctl_createv(clog, 0, NULL, NULL,  
                        CTLFLAG_PERMANENT|CTLFLAG_READWRITE,  
                        CTLTYPE_INT, "anonportmin",                         CTLTYPE_INT, "anonportmin",
                        SYSCTL_DESCR("Lowest ephemeral port number to assign"),                         SYSCTL_DESCR("Lowest ephemeral port number to assign"),
                        sysctl_net_inet_ip_ports, 0, &ip6_anonportmin, 0,                         sysctl_net_inet_ip_ports, 0, &ip6_anonportmin, 0,

Legend:
Removed from v.1.145.2.1  
changed lines
  Added in v.1.146

CVSweb <webmaster@jp.NetBSD.org>