[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.17 and 1.18

version 1.17, 1995/05/15 02:09:58 version 1.18, 1995/06/01 21:36:27
Line 248  next:
Line 248  next:
                     ia->ia_ifp == m->m_pkthdr.rcvif &&                      ia->ia_ifp == m->m_pkthdr.rcvif &&
 #endif  #endif
                     (ia->ia_ifp->if_flags & IFF_BROADCAST)) {                      (ia->ia_ifp->if_flags & IFF_BROADCAST)) {
                         u_int32_t t;                          if (ip->ip_dst.s_addr ==
                               satosin(&ia->ia_broadaddr)->sin_addr.s_addr)
                         if (satosin(&ia->ia_broadaddr)->sin_addr.s_addr ==  
                             ip->ip_dst.s_addr)  
                                 goto ours;                                  goto ours;
                         if (ip->ip_dst.s_addr == ia->ia_netbroadcast.s_addr)                          if (ip->ip_dst.s_addr == ia->ia_netbroadcast.s_addr)
                                 goto ours;                                  goto ours;
Line 259  next:
Line 257  next:
                          * Look for all-0's host part (old broadcast addr),                           * Look for all-0's host part (old broadcast addr),
                          * either for subnet or net.                           * either for subnet or net.
                          */                           */
                         t = ntohl(ip->ip_dst.s_addr);                          if (ip->ip_dst.s_addr == ia->ia_subnet ||
                         if (t == ia->ia_subnet)                              ip->ip_dst.s_addr == ia->ia_net)
                                 goto ours;  
                         if (t == ia->ia_net)  
                                 goto ours;                                  goto ours;
                 }                  }
         }          }
         if (IN_MULTICAST(ntohl(ip->ip_dst.s_addr))) {          if (IN_MULTICAST(ip->ip_dst.s_addr)) {
                 struct in_multi *inm;                  struct in_multi *inm;
 #ifdef MROUTING  #ifdef MROUTING
                 extern struct socket *ip_mrouter;                  extern struct socket *ip_mrouter;
Line 322  next:
Line 318  next:
                 }                  }
                 goto ours;                  goto ours;
         }          }
         if (ip->ip_dst.s_addr == (u_int32_t)INADDR_BROADCAST)          if (ip->ip_dst.s_addr == INADDR_BROADCAST)
                 goto ours;                  goto ours;
         if (ip->ip_dst.s_addr == INADDR_ANY)          if (ip->ip_dst.s_addr == INADDR_ANY)
                 goto ours;                  goto ours;
Line 746  ip_dooptions(m)
Line 742  ip_dooptions(m)
                         /*                          /*
                          * Let ip_intr's mcast routing check handle mcast pkts                           * Let ip_intr's mcast routing check handle mcast pkts
                          */                           */
                         forward = !IN_MULTICAST(ntohl(ip->ip_dst.s_addr));                          forward = !IN_MULTICAST(ip->ip_dst.s_addr);
                         break;                          break;
   
                 case IPOPT_RR:                  case IPOPT_RR:
Line 1083  ip_forward(m, srcrt)
Line 1079  ip_forward(m, srcrt)
             satosin(rt_key(rt))->sin_addr.s_addr != 0 &&              satosin(rt_key(rt))->sin_addr.s_addr != 0 &&
             ipsendredirects && !srcrt) {              ipsendredirects && !srcrt) {
 #define RTA(rt) ((struct in_ifaddr *)(rt->rt_ifa))  #define RTA(rt) ((struct in_ifaddr *)(rt->rt_ifa))
                 u_int32_t src = ntohl(ip->ip_src.s_addr);  
   
                 if (RTA(rt) &&                  if (RTA(rt) &&
                     (src & RTA(rt)->ia_subnetmask) == RTA(rt)->ia_subnet) {                      (ip->ip_src.s_addr & RTA(rt)->ia_subnetmask) ==
                       RTA(rt)->ia_subnet) {
                     if (rt->rt_flags & RTF_GATEWAY)                      if (rt->rt_flags & RTF_GATEWAY)
                         dest = satosin(rt->rt_gateway)->sin_addr.s_addr;                          dest = satosin(rt->rt_gateway)->sin_addr.s_addr;
                     else                      else

Legend:
Removed from v.1.17  
changed lines
  Added in v.1.18

CVSweb <webmaster@jp.NetBSD.org>