[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.112 and 1.116

version 1.112, 2003/10/18 13:05:45 version 1.116, 2004/03/24 15:34:54
Line 282  udp_input(m, va_alist)
Line 282  udp_input(m, va_alist)
                         if (m->m_pkthdr.csum_flags & M_CSUM_NO_PSEUDOHDR)                          if (m->m_pkthdr.csum_flags & M_CSUM_NO_PSEUDOHDR)
                                 hw_csum = in_cksum_phdr(ip->ip_src.s_addr,                                  hw_csum = in_cksum_phdr(ip->ip_src.s_addr,
                                     ip->ip_dst.s_addr,                                      ip->ip_dst.s_addr,
                                     htonl(hw_csum + ntohs(ip->ip_len) +                                      htons(hw_csum + len + IPPROTO_UDP));
                                     IPPROTO_UDP));  
                         if ((hw_csum ^ 0xffff) != 0)                          if ((hw_csum ^ 0xffff) != 0)
                                 goto badcsum;                                  goto badcsum;
                         break;                          break;
Line 1024  udp_usrreq(so, req, m, nam, control, p)
Line 1023  udp_usrreq(so, req, m, nam, control, p)
                 so->so_state &= ~SS_ISCONNECTED;        /* XXX */                  so->so_state &= ~SS_ISCONNECTED;        /* XXX */
                 in_pcbdisconnect(inp);                  in_pcbdisconnect(inp);
                 inp->inp_laddr = zeroin_addr;           /* XXX */                  inp->inp_laddr = zeroin_addr;           /* XXX */
                 if (inp->inp_ia != NULL) {  
                         LIST_REMOVE(inp, inp_ialink);  
                         IFAFREE(&inp->inp_ia->ia_ifa);  
                         inp->inp_ia = NULL;  
                 }  
                 in_pcbstate(inp, INP_BOUND);            /* XXX */                  in_pcbstate(inp, INP_BOUND);            /* XXX */
                 break;                  break;
   
Line 1073  udp_usrreq(so, req, m, nam, control, p)
Line 1067  udp_usrreq(so, req, m, nam, control, p)
                         in_pcbstate(inp, INP_BOUND);    /* XXX */                          in_pcbstate(inp, INP_BOUND);    /* XXX */
                 }                  }
           die:            die:
                 if (inp->inp_ia != NULL && in_nullhost(inp->inp_laddr)) {  
                         LIST_REMOVE(inp, inp_ialink);  
                         IFAFREE(&inp->inp_ia->ia_ifa);  
                         inp->inp_ia = NULL;  
                 }  
                 if (m)                  if (m)
                         m_freem(m);                          m_freem(m);
         }          }
Line 1120  release:
Line 1109  release:
 /*  /*
  * Sysctl for udp variables.   * Sysctl for udp variables.
  */   */
 int  SYSCTL_SETUP(sysctl_net_inet_udp_setup, "sysctl net.inet.udp subtree setup")
 udp_sysctl(name, namelen, oldp, oldlenp, newp, newlen)  
         int *name;  
         u_int namelen;  
         void *oldp;  
         size_t *oldlenp;  
         void *newp;  
         size_t newlen;  
 {  {
         /* All sysctl names at this level are terminal. */  
         if (namelen != 1)          sysctl_createv(clog, 0, NULL, NULL,
                 return (ENOTDIR);                         CTLFLAG_PERMANENT,
                          CTLTYPE_NODE, "net", NULL,
         switch (name[0]) {                         NULL, 0, NULL, 0,
         case UDPCTL_CHECKSUM:                         CTL_NET, CTL_EOL);
                 return (sysctl_int(oldp, oldlenp, newp, newlen, &udpcksum));          sysctl_createv(clog, 0, NULL, NULL,
         case UDPCTL_SENDSPACE:                         CTLFLAG_PERMANENT,
                 return (sysctl_int(oldp, oldlenp, newp, newlen,                         CTLTYPE_NODE, "inet", NULL,
                     &udp_sendspace));                         NULL, 0, NULL, 0,
         case UDPCTL_RECVSPACE:                         CTL_NET, PF_INET, CTL_EOL);
                 return (sysctl_int(oldp, oldlenp, newp, newlen,          sysctl_createv(clog, 0, NULL, NULL,
                     &udp_recvspace));                         CTLFLAG_PERMANENT,
         default:                         CTLTYPE_NODE, "udp", NULL,
                 return (ENOPROTOOPT);                         NULL, 0, NULL, 0,
         }                         CTL_NET, PF_INET, IPPROTO_UDP, CTL_EOL);
         /* NOTREACHED */  
           sysctl_createv(clog, 0, NULL, NULL,
                          CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
                          CTLTYPE_INT, "checksum", NULL,
                          NULL, 0, &udpcksum, 0,
                          CTL_NET, PF_INET, IPPROTO_UDP, UDPCTL_CHECKSUM,
                          CTL_EOL);
           sysctl_createv(clog, 0, NULL, NULL,
                          CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
                          CTLTYPE_INT, "sendspace", NULL,
                          NULL, 0, &udp_sendspace, 0,
                          CTL_NET, PF_INET, IPPROTO_UDP, UDPCTL_SENDSPACE,
                          CTL_EOL);
           sysctl_createv(clog, 0, NULL, NULL,
                          CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
                          CTLTYPE_INT, "recvspace", NULL,
                          NULL, 0, &udp_recvspace, 0,
                          CTL_NET, PF_INET, IPPROTO_UDP, UDPCTL_RECVSPACE,
                          CTL_EOL);
 }  }
 #endif  #endif

Legend:
Removed from v.1.112  
changed lines
  Added in v.1.116

CVSweb <webmaster@jp.NetBSD.org>