[BACK]Return to raw_ip.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/raw_ip.c between version 1.46.2.1 and 1.55.2.3

version 1.46.2.1, 2000/11/20 18:10:34 version 1.55.2.3, 2002/01/08 00:34:11
Line 64 
Line 64 
  *      @(#)raw_ip.c    8.7 (Berkeley) 5/15/95   *      @(#)raw_ip.c    8.7 (Berkeley) 5/15/95
  */   */
   
   #include <sys/cdefs.h>
   __KERNEL_RCSID(0, "$NetBSD$");
   
 #include "opt_ipsec.h"  #include "opt_ipsec.h"
 #include "opt_mrouting.h"  #include "opt_mrouting.h"
   
Line 97 
Line 100 
   
 struct inpcbtable rawcbtable;  struct inpcbtable rawcbtable;
   
   int      rip_pcbnotify __P((struct inpcbtable *, struct in_addr,
       struct in_addr, int, int, void (*) __P((struct inpcb *, int))));
 int      rip_bind __P((struct inpcb *, struct mbuf *));  int      rip_bind __P((struct inpcb *, struct mbuf *));
 int      rip_connect __P((struct inpcb *, struct mbuf *));  int      rip_connect __P((struct inpcb *, struct mbuf *));
 void     rip_disconnect __P((struct inpcb *));  void     rip_disconnect __P((struct inpcb *));
Line 162  rip_input(m, va_alist)
Line 167  rip_input(m, va_alist)
          */           */
         ip->ip_len -= ip->ip_hl << 2;          ip->ip_len -= ip->ip_hl << 2;
   
         for (inp = rawcbtable.inpt_queue.cqh_first;          CIRCLEQ_FOREACH(inp, &rawcbtable.inpt_queue, inp_queue) {
             inp != (struct inpcb *)&rawcbtable.inpt_queue;  
             inp = inp->inp_queue.cqe_next) {  
                 if (inp->inp_ip.ip_p && inp->inp_ip.ip_p != proto)                  if (inp->inp_ip.ip_p && inp->inp_ip.ip_p != proto)
                         continue;                          continue;
                 if (!in_nullhost(inp->inp_laddr) &&                  if (!in_nullhost(inp->inp_laddr) &&
Line 175  rip_input(m, va_alist)
Line 178  rip_input(m, va_alist)
                         continue;                          continue;
                 if (last) {                  if (last) {
                         struct mbuf *n;                          struct mbuf *n;
   
   #ifdef IPSEC
                           /* check AH/ESP integrity. */
                           if (ipsec4_in_reject_so(m, last->inp_socket)) {
                                   ipsecstat.in_polvio++;
                                   /* do not inject data to pcb */
                           } else
   #endif /*IPSEC*/
                         if ((n = m_copy(m, 0, (int)M_COPYALL)) != NULL) {                          if ((n = m_copy(m, 0, (int)M_COPYALL)) != NULL) {
                                 if (last->inp_flags & INP_CONTROLOPTS ||                                  if (last->inp_flags & INP_CONTROLOPTS ||
                                     last->inp_socket->so_options & SO_TIMESTAMP)                                      last->inp_socket->so_options & SO_TIMESTAMP)
Line 192  rip_input(m, va_alist)
Line 203  rip_input(m, va_alist)
                 }                  }
                 last = inp;                  last = inp;
         }          }
   #ifdef IPSEC
           /* check AH/ESP integrity. */
           if (last && ipsec4_in_reject_so(m, last->inp_socket)) {
                   m_freem(m);
                   ipsecstat.in_polvio++;
                   ipstat.ips_delivered--;
                   /* do not inject data to pcb */
           } else
   #endif /*IPSEC*/
         if (last) {          if (last) {
                 if (last->inp_flags & INP_CONTROLOPTS ||                  if (last->inp_flags & INP_CONTROLOPTS ||
                     last->inp_socket->so_options & SO_TIMESTAMP)                      last->inp_socket->so_options & SO_TIMESTAMP)
Line 215  rip_input(m, va_alist)
Line 235  rip_input(m, va_alist)
         return;          return;
 }  }
   
   int
   rip_pcbnotify(table, faddr, laddr, proto, errno, notify)
           struct inpcbtable *table;
           struct in_addr faddr, laddr;
           int proto;
           int errno;
           void (*notify) __P((struct inpcb *, int));
   {
           struct inpcb *inp, *ninp;
           int nmatch;
   
           nmatch = 0;
           for (inp = CIRCLEQ_FIRST(&table->inpt_queue);
               inp != (struct inpcb *)&table->inpt_queue;
               inp = ninp) {
                   ninp = inp->inp_queue.cqe_next;
                   if (inp->inp_ip.ip_p && inp->inp_ip.ip_p != proto)
                           continue;
                   if (in_hosteq(inp->inp_faddr, faddr) &&
                       in_hosteq(inp->inp_laddr, laddr)) {
                           (*notify)(inp, errno);
                           nmatch++;
                   }
           }
   
           return nmatch;
   }
   
   void *
   rip_ctlinput(cmd, sa, v)
           int cmd;
           struct sockaddr *sa;
           void *v;
   {
           struct ip *ip = v;
           void (*notify) __P((struct inpcb *, int)) = in_rtchange;
           int errno;
   
           if (sa->sa_family != AF_INET ||
               sa->sa_len != sizeof(struct sockaddr_in))
                   return NULL;
           if ((unsigned)cmd >= PRC_NCMDS)
                   return NULL;
           errno = inetctlerrmap[cmd];
           if (PRC_IS_REDIRECT(cmd))
                   notify = in_rtchange, ip = 0;
           else if (cmd == PRC_HOSTDEAD)
                   ip = 0;
           else if (errno == 0)
                   return NULL;
           if (ip) {
                   rip_pcbnotify(&rawcbtable, satosin(sa)->sin_addr,
                       ip->ip_src, ip->ip_p, errno, notify);
   
                   /* XXX mapped address case */
           } else
                   in_pcbnotifyall(&rawcbtable, satosin(sa)->sin_addr, errno,
                       notify);
           return NULL;
   }
   
 /*  /*
  * Generate IP header and pass packet to ip_output.   * Generate IP header and pass packet to ip_output.
  * Tack on options user may have setup with control call.   * Tack on options user may have setup with control call.
Line 279  rip_output(m, va_alist)
Line 360  rip_output(m, va_alist)
                 ipstat.ips_rawout++;                  ipstat.ips_rawout++;
         }          }
 #ifdef IPSEC  #ifdef IPSEC
         ipsec_setsocket(m, inp->inp_socket);          if (ipsec_setsocket(m, inp->inp_socket) != 0) {
                   m_freem(m);
                   return ENOBUFS;
           }
 #endif /*IPSEC*/  #endif /*IPSEC*/
         return (ip_output(m, opts, &inp->inp_route, flags, inp->inp_moptions, &inp->inp_errormtu));          return (ip_output(m, opts, &inp->inp_route, flags, inp->inp_moptions, &inp->inp_errormtu));
 }  }
Line 369  rip_bind(inp, nam)
Line 453  rip_bind(inp, nam)
   
         if (nam->m_len != sizeof(*addr))          if (nam->m_len != sizeof(*addr))
                 return (EINVAL);                  return (EINVAL);
         if (ifnet.tqh_first == 0)          if (TAILQ_FIRST(&ifnet) == 0)
                 return (EADDRNOTAVAIL);                  return (EADDRNOTAVAIL);
         if (addr->sin_family != AF_INET &&          if (addr->sin_family != AF_INET &&
             addr->sin_family != AF_IMPLINK)              addr->sin_family != AF_IMPLINK)
Line 390  rip_connect(inp, nam)
Line 474  rip_connect(inp, nam)
   
         if (nam->m_len != sizeof(*addr))          if (nam->m_len != sizeof(*addr))
                 return (EINVAL);                  return (EINVAL);
         if (ifnet.tqh_first == 0)          if (TAILQ_FIRST(&ifnet) == 0)
                 return (EADDRNOTAVAIL);                  return (EADDRNOTAVAIL);
         if (addr->sin_family != AF_INET &&          if (addr->sin_family != AF_INET &&
             addr->sin_family != AF_IMPLINK)              addr->sin_family != AF_IMPLINK)
Line 430  rip_usrreq(so, req, m, nam, control, p)
Line 514  rip_usrreq(so, req, m, nam, control, p)
                     (struct ifnet *)control, p));                      (struct ifnet *)control, p));
   
         if (req == PRU_PURGEIF) {          if (req == PRU_PURGEIF) {
                   in_pcbpurgeif0(&rawcbtable, (struct ifnet *)control);
                 in_purgeif((struct ifnet *)control);                  in_purgeif((struct ifnet *)control);
                 in_pcbpurgeif(&rawcbtable, (struct ifnet *)control);                  in_pcbpurgeif(&rawcbtable, (struct ifnet *)control);
                 return (0);                  return (0);
Line 467  rip_usrreq(so, req, m, nam, control, p)
Line 552  rip_usrreq(so, req, m, nam, control, p)
                         break;                          break;
                 inp = sotoinpcb(so);                  inp = sotoinpcb(so);
                 inp->inp_ip.ip_p = (long)nam;                  inp->inp_ip.ip_p = (long)nam;
 #ifdef IPSEC  
                 error = ipsec_init_policy(so, &inp->inp_sp);  
                 if (error != 0) {  
                         in_pcbdetach(inp);  
                         break;  
                 }  
 #endif /*IPSEC*/  
                 break;                  break;
   
         case PRU_DETACH:          case PRU_DETACH:

Legend:
Removed from v.1.46.2.1  
changed lines
  Added in v.1.55.2.3

CVSweb <webmaster@jp.NetBSD.org>