[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.75.2.1 and 1.75.2.2

version 1.75.2.1, 2001/06/21 20:08:46 version 1.75.2.2, 2001/08/24 00:12:33
Line 536  udp4_sendup(m, off, src, so)
Line 536  udp4_sendup(m, off, src, so)
                         m_freem(n);                          m_freem(n);
                         if (opts)                          if (opts)
                                 m_freem(opts);                                  m_freem(opts);
                           udpstat.udps_fullsock++;
                 } else                  } else
                         sorwakeup(so);                          sorwakeup(so);
         }          }
Line 669  udp4_realinput(src, dst, m, off)
Line 670  udp4_realinput(src, dst, m, off)
                             (SO_REUSEPORT|SO_REUSEADDR)) == 0)                              (SO_REUSEPORT|SO_REUSEADDR)) == 0)
                                 break;                                  break;
                 }                  }
   
 #if 0  
                 if (last == NULL) {  
                         /*  
                          * No matching pcb found; discard datagram.  
                          * (No need to send an ICMP Port Unreachable  
                          * for a broadcast or multicast datgram.)  
                          */  
                         udpstat.udps_noportbcast++;  
                         goto bad;  
                 }  
 #endif  
         } else {          } else {
                 /*                  /*
                  * Locate pcb for datagram.                   * Locate pcb for datagram.
Line 689  udp4_realinput(src, dst, m, off)
Line 678  udp4_realinput(src, dst, m, off)
                 if (inp == 0) {                  if (inp == 0) {
                         ++udpstat.udps_pcbhashmiss;                          ++udpstat.udps_pcbhashmiss;
                         inp = in_pcblookup_bind(&udbtable, *dst4, *dport);                          inp = in_pcblookup_bind(&udbtable, *dst4, *dport);
                         if (inp == 0) {                          if (inp == 0)
 #if 0  
                                 struct mbuf *n;  
   
                                 if (m->m_flags & (M_BCAST | M_MCAST)) {  
                                         udpstat.udps_noportbcast++;  
                                         goto bad;  
                                 }  
                                 udpstat.udps_noport++;  
 #ifdef IPKDB  
                                 if (checkipkdb(src4, *sport, *dport, m, off,  
                                                m->m_pkthdr.len - off)) {  
                                         /*  
                                          * It was a debugger connect packet,  
                                          * just drop it now  
                                          */  
                                         goto bad;  
                                 }  
 #endif  
                                 if ((n = m_copy(m, 0, M_COPYALL)) != NULL) {  
                                         icmp_error(n, ICMP_UNREACH,  
                                                 ICMP_UNREACH_PORT, 0, 0);  
                                 }  
 #endif  
                                 return rcvcnt;                                  return rcvcnt;
                         }  
                 }                  }
   
                 udp4_sendup(m, off, (struct sockaddr *)src, inp->inp_socket);                  udp4_sendup(m, off, (struct sockaddr *)src, inp->inp_socket);
Line 758  udp6_realinput(af, src, dst, m, off)
Line 723  udp6_realinput(af, src, dst, m, off)
         struct mbuf *m;          struct mbuf *m;
         int off;        /* offset of udphdr */          int off;        /* offset of udphdr */
 {  {
         u_int16_t *sport, *dport;          u_int16_t sport, dport;
         int rcvcnt;          int rcvcnt;
         struct in6_addr *src6, *dst6;          struct in6_addr src6, dst6;
         struct in_addr *dst4;          const struct in_addr *dst4;
         struct in6pcb *in6p;          struct in6pcb *in6p;
   
         rcvcnt = 0;          rcvcnt = 0;
Line 772  udp6_realinput(af, src, dst, m, off)
Line 737  udp6_realinput(af, src, dst, m, off)
         if (src->sin6_family != AF_INET6 || dst->sin6_family != AF_INET6)          if (src->sin6_family != AF_INET6 || dst->sin6_family != AF_INET6)
                 goto bad;                  goto bad;
   
         src6 = &src->sin6_addr;          in6_embedscope(&src6, src, NULL, NULL);
         sport = &src->sin6_port;          sport = src->sin6_port;
         dst6 = &dst->sin6_addr;          in6_embedscope(&dst6, dst, NULL, NULL);
         dport = &dst->sin6_port;          dport = dst->sin6_port;
         dst4 = (struct in_addr *)&dst->sin6_addr.s6_addr32[12];          dst4 = (struct in_addr *)&dst->sin6_addr.s6_addr32[12];
   
         if (IN6_IS_ADDR_MULTICAST(dst6)          if (IN6_IS_ADDR_MULTICAST(&dst6) ||
          || (af == AF_INET && IN_MULTICAST(dst4->s_addr))) {              (af == AF_INET && IN_MULTICAST(dst4->s_addr))) {
                 struct in6pcb *last;                  struct in6pcb *last;
                 /*                  /*
                  * Deliver a multicast or broadcast datagram to *all* sockets                   * Deliver a multicast or broadcast datagram to *all* sockets
Line 806  udp6_realinput(af, src, dst, m, off)
Line 771  udp6_realinput(af, src, dst, m, off)
                  */                   */
                 for (in6p = udb6.in6p_next; in6p != &udb6;                  for (in6p = udb6.in6p_next; in6p != &udb6;
                      in6p = in6p->in6p_next) {                       in6p = in6p->in6p_next) {
                         if (in6p->in6p_lport != *dport)                          if (in6p->in6p_lport != dport)
                                 continue;                                  continue;
                         if (!IN6_IS_ADDR_UNSPECIFIED(&in6p->in6p_laddr)) {                          if (!IN6_IS_ADDR_UNSPECIFIED(&in6p->in6p_laddr)) {
                                 if (!IN6_ARE_ADDR_EQUAL(&in6p->in6p_laddr, dst6)                                  if (!IN6_ARE_ADDR_EQUAL(&in6p->in6p_laddr, &dst6) &&
                                  && !in6_mcmatch(in6p, dst6, m->m_pkthdr.rcvif))                                      !in6_mcmatch(in6p, &dst6, m->m_pkthdr.rcvif))
                                         continue;                                          continue;
                         }                          }
 #ifndef INET6_BINDV6ONLY  #ifndef INET6_BINDV6ONLY
                         else {                          else {
                                 if (IN6_IS_ADDR_V4MAPPED(dst6)                                  if (IN6_IS_ADDR_V4MAPPED(&dst6) &&
                                  && (in6p->in6p_flags & IN6P_BINDV6ONLY))                                      (in6p->in6p_flags & IN6P_BINDV6ONLY))
                                         continue;                                          continue;
                         }                          }
 #endif  #endif
                         if (!IN6_IS_ADDR_UNSPECIFIED(&in6p->in6p_faddr)) {                          if (!IN6_IS_ADDR_UNSPECIFIED(&in6p->in6p_faddr)) {
                                 if (!IN6_ARE_ADDR_EQUAL(&in6p->in6p_faddr, src6)                                  if (!IN6_ARE_ADDR_EQUAL(&in6p->in6p_faddr,
                                  || in6p->in6p_fport != *sport)                                      &src6) || in6p->in6p_fport != sport)
                                         continue;                                          continue;
                         }                          }
 #ifndef INET6_BINDV6ONLY  #ifndef INET6_BINDV6ONLY
                         else {                          else {
                                 if (IN6_IS_ADDR_V4MAPPED(src6)                                  if (IN6_IS_ADDR_V4MAPPED(&src6) &&
                                  && (in6p->in6p_flags & IN6P_BINDV6ONLY))                                      (in6p->in6p_flags & IN6P_BINDV6ONLY))
                                         continue;                                          continue;
                         }                          }
 #endif  #endif
Line 850  udp6_realinput(af, src, dst, m, off)
Line 815  udp6_realinput(af, src, dst, m, off)
                             (SO_REUSEPORT|SO_REUSEADDR)) == 0)                              (SO_REUSEPORT|SO_REUSEADDR)) == 0)
                                 break;                                  break;
                 }                  }
   
 #if 0  
                 if (last == NULL) {  
                         /*  
                          * No matching pcb found; discard datagram.  
                          * (No need to send an ICMP Port Unreachable  
                          * for a broadcast or multicast datgram.)  
                          */  
                         switch (af) {  
                         case AF_INET:  
                                 udpstat.udps_noportbcast++;  
                                 break;  
                         case AF_INET6:  
                                 udp6stat.udp6s_noportmcast++;  
                                 break;  
                         }  
                         goto bad;  
                 }  
 #endif  
         } else {          } else {
                 /*                  /*
                  * Locate pcb for datagram.                   * Locate pcb for datagram.
                  */                   */
                 in6p = in6_pcblookup_connect(&udb6, src6, *sport,                  in6p = in6_pcblookup_connect(&udb6, &src6, sport,
                         dst6, *dport, 0);                      &dst6, dport, 0);
                 if (in6p == 0) {                  if (in6p == 0) {
                         ++udpstat.udps_pcbhashmiss;                          ++udpstat.udps_pcbhashmiss;
                         in6p = in6_pcblookup_bind(&udb6, dst6, *dport, 0);                          in6p = in6_pcblookup_bind(&udb6, &dst6, dport, 0);
                         if (in6p == 0) {                          if (in6p == 0)
 #if 0  
                                 struct mbuf *n;  
                                 n = m_copy(m, 0, M_COPYALL);  
                                 switch (af) {  
                                 case AF_INET:  
                                         if (m->m_flags & (M_BCAST | M_MCAST)) {  
                                                 udpstat.udps_noportbcast++;  
                                                 goto bad;  
                                         }  
                                         udpstat.udps_noport++;  
                                         if (n != NULL)  
                                                 icmp_error(n, ICMP_UNREACH,  
                                                     ICMP_UNREACH_PORT, 0, 0);  
                                         break;  
                                 case AF_INET6:  
                                         if (m->m_flags & M_MCAST) {  
                                                 udp6stat.udp6s_noportmcast++;  
                                                 goto bad;  
                                         }  
                                         udp6stat.udp6s_noport++;  
                                         if (n != NULL)  
                                                 icmp6_error(n, ICMP6_DST_UNREACH,  
                                                     ICMP6_DST_UNREACH_NOPORT, 0);  
                                         break;  
                                 }  
 #endif  
   
                                 return rcvcnt;                                  return rcvcnt;
                         }  
                 }                  }
   
                 udp6_sendup(m, off, (struct sockaddr *)src, in6p->in6p_socket);                  udp6_sendup(m, off, (struct sockaddr *)src, in6p->in6p_socket);
Line 1107  udp_input(m, va_alist)
Line 1025  udp_input(m, va_alist)
                                                 m_freem(n);                                                  m_freem(n);
                                                 if (opts)                                                  if (opts)
                                                         m_freem(opts);                                                          m_freem(opts);
                                                   udpstat.udps_fullsock++;
                                         } else                                          } else
                                                 sorwakeup(last->inp_socket);                                                  sorwakeup(last->inp_socket);
                                         opts = 0;                                          opts = 0;
Line 1379  udp_usrreq(so, req, m, nam, control, p)
Line 1298  udp_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(&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);
                 return (0);                  return (0);
Line 1416  udp_usrreq(so, req, m, nam, control, p)
Line 1336  udp_usrreq(so, req, m, nam, control, p)
                         break;                          break;
                 inp = sotoinpcb(so);                  inp = sotoinpcb(so);
                 inp->inp_ip.ip_ttl = ip_defttl;                  inp->inp_ip.ip_ttl = ip_defttl;
 #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.75.2.1  
changed lines
  Added in v.1.75.2.2

CVSweb <webmaster@jp.NetBSD.org>