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

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

Diff for /src/sys/netinet/ip_input.c between version 1.219.2.1 and 1.232

version 1.219.2.1, 2005/10/26 08:32:51 version 1.232, 2006/09/19 21:42:30
Line 121  __KERNEL_RCSID(0, "$NetBSD$");
Line 121  __KERNEL_RCSID(0, "$NetBSD$");
 #include <sys/kernel.h>  #include <sys/kernel.h>
 #include <sys/pool.h>  #include <sys/pool.h>
 #include <sys/sysctl.h>  #include <sys/sysctl.h>
   #include <sys/kauth.h>
   
 #include <net/if.h>  #include <net/if.h>
 #include <net/if_dl.h>  #include <net/if_dl.h>
Line 279  static u_int ip_reass_ttl_decr(u_int tic
Line 280  static u_int ip_reass_ttl_decr(u_int tic
 static void     ip_reass_drophalf(void);  static void     ip_reass_drophalf(void);
   
   
 static __inline int ipq_lock_try(void);  static inline int ipq_lock_try(void);
 static __inline void ipq_unlock(void);  static inline void ipq_unlock(void);
   
 static __inline int  static inline int
 ipq_lock_try(void)  ipq_lock_try(void)
 {  {
         int s;          int s;
Line 301  ipq_lock_try(void)
Line 302  ipq_lock_try(void)
         return (1);          return (1);
 }  }
   
 static __inline void  static inline void
 ipq_unlock(void)  ipq_unlock(void)
 {  {
         int s;          int s;
Line 414  ip_init(void)
Line 415  ip_init(void)
         for (i = 0; i < IPREASS_NHASH; i++)          for (i = 0; i < IPREASS_NHASH; i++)
                 LIST_INIT(&ipq[i]);                  LIST_INIT(&ipq[i]);
   
         ip_id = time.tv_sec & 0xfffff;          ip_id = time_second & 0xfffff;
   
         ipintrq.ifq_maxlen = ipqmaxlen;          ipintrq.ifq_maxlen = ipqmaxlen;
         ip_nmbclusters_changed();          ip_nmbclusters_changed();
Line 445  ip_init(void)
Line 446  ip_init(void)
 #endif /* MBUFTRACE */  #endif /* MBUFTRACE */
 }  }
   
 struct  sockaddr_in ipaddr = { sizeof(ipaddr), AF_INET };  struct  sockaddr_in ipaddr = {
           .sin_len = sizeof(ipaddr),
           .sin_family = AF_INET,
   };
 struct  route ipforward_rt;  struct  route ipforward_rt;
   
 /*  /*
Line 732  ip_input(struct mbuf *m)
Line 736  ip_input(struct mbuf *m)
         }          }
         if (ia != NULL)          if (ia != NULL)
                 goto ours;                  goto ours;
         if (m->m_pkthdr.rcvif->if_flags & IFF_BROADCAST) {          if (m->m_pkthdr.rcvif && m->m_pkthdr.rcvif->if_flags & IFF_BROADCAST) {
                 IFADDR_FOREACH(ifa, m->m_pkthdr.rcvif) {                  IFADDR_FOREACH(ifa, m->m_pkthdr.rcvif) {
                         if (ifa->ifa_addr->sa_family != AF_INET)                          if (ifa->ifa_addr->sa_family != AF_INET)
                                 continue;                                  continue;
Line 974  found:
Line 978  found:
                 goto bad;                  goto bad;
         }          }
 #endif  #endif
 #if FAST_IPSEC  #ifdef FAST_IPSEC
         /*          /*
          * enforce IPsec policy checking if we are seeing last header.           * enforce IPsec policy checking if we are seeing last header.
          * note that we do not visit this with protocols with pcb layer           * note that we do not visit this with protocols with pcb layer
Line 1839  ip_forward(struct mbuf *m, int srcrt)
Line 1843  ip_forward(struct mbuf *m, int srcrt)
   
         dest = 0;          dest = 0;
 #ifdef DIAGNOSTIC  #ifdef DIAGNOSTIC
         if (ipprintfs)          if (ipprintfs) {
                 printf("forward: src %2.2x dst %2.2x ttl %x\n",                  printf("forward: src %s ", inet_ntoa(ip->ip_src));
                     ntohl(ip->ip_src.s_addr),                  printf("dst %s ttl %x\n", inet_ntoa(ip->ip_dst), ip->ip_ttl);
                     ntohl(ip->ip_dst.s_addr), ip->ip_ttl);          }
 #endif  #endif
         if (m->m_flags & (M_BCAST|M_MCAST) || in_canforward(ip->ip_dst) == 0) {          if (m->m_flags & (M_BCAST|M_MCAST) || in_canforward(ip->ip_dst) == 0) {
                 ipstat.ips_cantforward++;                  ipstat.ips_cantforward++;
Line 1853  ip_forward(struct mbuf *m, int srcrt)
Line 1857  ip_forward(struct mbuf *m, int srcrt)
                 icmp_error(m, ICMP_TIMXCEED, ICMP_TIMXCEED_INTRANS, dest, 0);                  icmp_error(m, ICMP_TIMXCEED, ICMP_TIMXCEED_INTRANS, dest, 0);
                 return;                  return;
         }          }
         ip->ip_ttl -= IPTTLDEC;  
   
         sin = satosin(&ipforward_rt.ro_dst);          sin = satosin(&ipforward_rt.ro_dst);
         if ((rt = ipforward_rt.ro_rt) == 0 ||          if ((rt = ipforward_rt.ro_rt) == 0 ||
Line 1883  ip_forward(struct mbuf *m, int srcrt)
Line 1886  ip_forward(struct mbuf *m, int srcrt)
         if (mcopy)          if (mcopy)
                 mcopy = m_pullup(mcopy, ip->ip_hl << 2);                  mcopy = m_pullup(mcopy, ip->ip_hl << 2);
   
           ip->ip_ttl -= IPTTLDEC;
   
         /*          /*
          * If forwarding packet using same interface that it came in on,           * If forwarding packet using same interface that it came in on,
          * perhaps should send a redirect to sender to shortcut a hop.           * perhaps should send a redirect to sender to shortcut a hop.
Line 2092  ip_savecontrol(struct inpcb *inp, struct
Line 2097  ip_savecontrol(struct inpcb *inp, struct
 }  }
   
 /*  /*
    * sysctl helper routine for net.inet.ip.forwsrcrt.
    */
   static int
   sysctl_net_inet_ip_forwsrcrt(SYSCTLFN_ARGS)
   {
           int error, tmp;
           struct sysctlnode node;
   
           node = *rnode;
           tmp = ip_forwsrcrt;
           node.sysctl_data = &tmp;
           error = sysctl_lookup(SYSCTLFN_CALL(&node));
           if (error || newp == NULL)
                   return (error);
   
           if (kauth_authorize_network(l->l_cred, KAUTH_NETWORK_FORWSRCRT,
               0, NULL, NULL, NULL))
                   return (EPERM);
   
           ip_forwsrcrt = tmp;
   
           return (0);
   }
   
   /*
  * sysctl helper routine for net.inet.ip.mtudisctimeout.  checks the   * sysctl helper routine for net.inet.ip.mtudisctimeout.  checks the
  * range of the new value and tweaks timers if it changes.   * range of the new value and tweaks timers if it changes.
  */   */
Line 2192  SYSCTL_SETUP(sysctl_net_inet_ip_setup, "
Line 2222  SYSCTL_SETUP(sysctl_net_inet_ip_setup, "
                        IPCTL_DEFMTU, CTL_EOL);                         IPCTL_DEFMTU, CTL_EOL);
 #endif /* IPCTL_DEFMTU */  #endif /* IPCTL_DEFMTU */
         sysctl_createv(clog, 0, NULL, NULL,          sysctl_createv(clog, 0, NULL, NULL,
                        CTLFLAG_PERMANENT|CTLFLAG_READONLY1,                         CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
                        CTLTYPE_INT, "forwsrcrt",                         CTLTYPE_INT, "forwsrcrt",
                        SYSCTL_DESCR("Enable forwarding of source-routed "                         SYSCTL_DESCR("Enable forwarding of source-routed "
                                     "datagrams"),                                      "datagrams"),
                        NULL, 0, &ip_forwsrcrt, 0,                         sysctl_net_inet_ip_forwsrcrt, 0, &ip_forwsrcrt, 0,
                        CTL_NET, PF_INET, IPPROTO_IP,                         CTL_NET, PF_INET, IPPROTO_IP,
                        IPCTL_FORWSRCRT, CTL_EOL);                         IPCTL_FORWSRCRT, CTL_EOL);
         sysctl_createv(clog, 0, NULL, NULL,          sysctl_createv(clog, 0, NULL, NULL,

Legend:
Removed from v.1.219.2.1  
changed lines
  Added in v.1.232

CVSweb <webmaster@jp.NetBSD.org>