[BACK]Return to udp_usrreq.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/udp_usrreq.c between version 1.138.2.2 and 1.146.2.1

version 1.138.2.2, 2006/12/30 20:50:34 version 1.146.2.1, 2006/02/05 03:09:11
Line 95  __KERNEL_RCSID(0, "$NetBSD$");
Line 95  __KERNEL_RCSID(0, "$NetBSD$");
 #include <netinet/udp.h>  #include <netinet/udp.h>
 #include <netinet/udp_var.h>  #include <netinet/udp_var.h>
   
   #ifdef IPSEC_NAT_T
   #include <netinet6/ipsec.h>
   #include <netinet6/esp.h>
   #endif
   
 #ifdef INET6  #ifdef INET6
 #include <netinet/ip6.h>  #include <netinet/ip6.h>
 #include <netinet/icmp6.h>  #include <netinet/icmp6.h>
 #include <netinet6/ip6_var.h>  #include <netinet6/ip6_var.h>
 #include <netinet6/in6_pcb.h>  
 #include <netinet6/udp6_var.h>  #include <netinet6/udp6_var.h>
 #include <netinet6/scope6_var.h>  #include <netinet6/scope6_var.h>
 #endif  #endif
Line 119  __KERNEL_RCSID(0, "$NetBSD$");
Line 123  __KERNEL_RCSID(0, "$NetBSD$");
 #ifdef FAST_IPSEC  #ifdef FAST_IPSEC
 #include <netipsec/ipsec.h>  #include <netipsec/ipsec.h>
 #include <netipsec/ipsec_var.h>                 /* XXX ipsecstat namespace */  #include <netipsec/ipsec_var.h>                 /* XXX ipsecstat namespace */
 #include <netipsec/esp.h>  
 #ifdef INET6  #ifdef INET6
 #include <netipsec/ipsec6.h>  #include <netipsec/ipsec6.h>
 #endif  #endif
Line 127  __KERNEL_RCSID(0, "$NetBSD$");
Line 130  __KERNEL_RCSID(0, "$NetBSD$");
   
 #ifdef IPSEC  #ifdef IPSEC
 #include <netinet6/ipsec.h>  #include <netinet6/ipsec.h>
 #include <netinet6/esp.h>  
 #include <netkey/key.h>  #include <netkey/key.h>
 #endif /*IPSEC*/  #endif /*IPSEC*/
   
Line 139  __KERNEL_RCSID(0, "$NetBSD$");
Line 141  __KERNEL_RCSID(0, "$NetBSD$");
  * UDP protocol implementation.   * UDP protocol implementation.
  * Per RFC 768, August, 1980.   * Per RFC 768, August, 1980.
  */   */
   #ifndef COMPAT_42
 int     udpcksum = 1;  int     udpcksum = 1;
   #else
   int     udpcksum = 0;           /* XXX */
   #endif
 int     udp_do_loopback_cksum = 0;  int     udp_do_loopback_cksum = 0;
   
 struct  inpcbtable udbtable;  struct  inpcbtable udbtable;
Line 173  static void udp_notify (struct inpcb *, 
Line 179  static void udp_notify (struct inpcb *, 
 int     udbhashsize = UDBHASHSIZE;  int     udbhashsize = UDBHASHSIZE;
   
 #ifdef MBUFTRACE  #ifdef MBUFTRACE
 struct mowner udp_mowner = MOWNER_INIT("udp", "");  struct mowner udp_mowner = { "udp" };
 struct mowner udp_rx_mowner = MOWNER_INIT("udp", "rx");  struct mowner udp_rx_mowner = { "udp", "rx" };
 struct mowner udp_tx_mowner = MOWNER_INIT("udp", "tx");  struct mowner udp_tx_mowner = { "udp", "tx" };
 #endif  #endif
   
 #ifdef UDP_CSUM_COUNTERS  #ifdef UDP_CSUM_COUNTERS
Line 995  udp_ctlinput(int cmd, struct sockaddr *s
Line 1001  udp_ctlinput(int cmd, struct sockaddr *s
 }  }
   
 int  int
 udp_ctloutput(int op, struct socket *so, int level, int optname,  udp_ctloutput(op, so, level, optname, mp)
     struct mbuf **mp)          int op;
           struct socket *so;
           int level, optname;
           struct mbuf **mp;
 {  {
         int s;          int s;
         int error = 0;          int error = 0;
Line 1027  udp_ctloutput(int op, struct socket *so,
Line 1036  udp_ctloutput(int op, struct socket *so,
         default:          default:
                 error = EAFNOSUPPORT;                  error = EAFNOSUPPORT;
                 goto end;                  goto end;
                   break;
         }          }
   
   
Line 1039  udp_ctloutput(int op, struct socket *so,
Line 1049  udp_ctloutput(int op, struct socket *so,
                 case UDP_ENCAP:                  case UDP_ENCAP:
                         if (m == NULL || m->m_len < sizeof (int)) {                          if (m == NULL || m->m_len < sizeof (int)) {
                                 error = EINVAL;                                  error = EINVAL;
                                 break;                                  goto end;
                         }                          }
   
                         switch(*mtod(m, int *)) {                          switch(*mtod(m, int *)) {
Line 1060  udp_ctloutput(int op, struct socket *so,
Line 1070  udp_ctloutput(int op, struct socket *so,
 #endif  #endif
                         default:                          default:
                                 error = EINVAL;                                  error = EINVAL;
                                   goto end;
                                 break;                                  break;
                         }                          }
                         break;                          break;
   
                 default:                  default:
                         error = ENOPROTOOPT;                          error = ENOPROTOOPT;
                           goto end;
                         break;                          break;
                 }                  }
                 if (m != NULL) {  
                         m_free(m);  
                 }  
                 break;                  break;
   
         default:          default:
                 error = EINVAL;                  error = EINVAL;
                   goto end;
                 break;                  break;
         }          }
   
Line 1171  udp_usrreq(struct socket *so, int req, s
Line 1181  udp_usrreq(struct socket *so, int req, s
         struct mbuf *control, struct lwp *l)          struct mbuf *control, struct lwp *l)
 {  {
         struct inpcb *inp;          struct inpcb *inp;
           struct proc *p;
         int s;          int s;
         int error = 0;          int error = 0;
   
           p = l ? l->l_proc : NULL;
         if (req == PRU_CONTROL)          if (req == PRU_CONTROL)
                 return (in_control(so, (long)m, (caddr_t)nam,                  return (in_control(so, (long)m, (caddr_t)nam,
                     (struct ifnet *)control, l));                      (struct ifnet *)control, p));
   
         s = splsoftnet();  
   
         if (req == PRU_PURGEIF) {          if (req == PRU_PURGEIF) {
                 in_pcbpurgeif0(&udbtable, (struct ifnet *)control);                  in_pcbpurgeif0(&udbtable, (struct ifnet *)control);
                 in_purgeif((struct ifnet *)control);                  in_purgeif((struct ifnet *)control);
                 in_pcbpurgeif(&udbtable, (struct ifnet *)control);                  in_pcbpurgeif(&udbtable, (struct ifnet *)control);
                 splx(s);  
                 return (0);                  return (0);
         }          }
   
           s = splsoftnet();
         inp = sotoinpcb(so);          inp = sotoinpcb(so);
 #ifdef DIAGNOSTIC  #ifdef DIAGNOSTIC
         if (req != PRU_SEND && req != PRU_SENDOOB && control)          if (req != PRU_SEND && req != PRU_SENDOOB && control)
Line 1231  udp_usrreq(struct socket *so, int req, s
Line 1241  udp_usrreq(struct socket *so, int req, s
                 break;                  break;
   
         case PRU_BIND:          case PRU_BIND:
                 error = in_pcbbind(inp, nam, l);                  error = in_pcbbind(inp, nam, p);
                 break;                  break;
   
         case PRU_LISTEN:          case PRU_LISTEN:
Line 1239  udp_usrreq(struct socket *so, int req, s
Line 1249  udp_usrreq(struct socket *so, int req, s
                 break;                  break;
   
         case PRU_CONNECT:          case PRU_CONNECT:
                 error = in_pcbconnect(inp, nam, l);                  error = in_pcbconnect(inp, nam, p);
                 if (error)                  if (error)
                         break;                          break;
                 soisconnected(so);                  soisconnected(so);
Line 1281  udp_usrreq(struct socket *so, int req, s
Line 1291  udp_usrreq(struct socket *so, int req, s
                                 error = EISCONN;                                  error = EISCONN;
                                 goto die;                                  goto die;
                         }                          }
                         error = in_pcbconnect(inp, nam, l);                          error = in_pcbconnect(inp, nam, p);
                         if (error)                          if (error)
                                 goto die;                                  goto die;
                 } else {                  } else {
Line 1413  SYSCTL_SETUP(sysctl_net_inet_udp_setup, 
Line 1423  SYSCTL_SETUP(sysctl_net_inet_udp_setup, 
  * -1 if an error occurent and m was freed   * -1 if an error occurent and m was freed
  */   */
 static int  static int
 udp4_espinudp(struct mbuf **mp, int off, struct sockaddr *src,  udp4_espinudp(mp, off, src, so)
     struct socket *so)          struct mbuf **mp;
           int off;
           struct sockaddr *src;
           struct socket *so;
 {  {
         size_t len;          size_t len;
         caddr_t data;          caddr_t data;
Line 1535  udp4_espinudp(struct mbuf **mp, int off,
Line 1548  udp4_espinudp(struct mbuf **mp, int off,
         ((u_int16_t *)(tag + 1))[1] = dport;          ((u_int16_t *)(tag + 1))[1] = dport;
         m_tag_prepend(n, tag);          m_tag_prepend(n, tag);
   
 #ifdef FAST_IPSEC  
         ipsec4_common_input(n, iphdrlen);  
 #else  
         esp4_input(n, iphdrlen);          esp4_input(n, iphdrlen);
 #endif  
   
         /* We handled it, it shoudln't be handled by UDP */          /* We handled it, it shoudln't be handled by UDP */
         return 1;          return 1;

Legend:
Removed from v.1.138.2.2  
changed lines
  Added in v.1.146.2.1

CVSweb <webmaster@jp.NetBSD.org>