diff options
author | jhay <jhay@FreeBSD.org> | 1997-05-10 10:01:32 +0000 |
---|---|---|
committer | jhay <jhay@FreeBSD.org> | 1997-05-10 10:01:32 +0000 |
commit | 4f2a5d896ef4c868add74c88150f6cc2bbe07aae (patch) | |
tree | 5cf75145176ed4da63c9515fd20b38394fd52177 /sys | |
parent | 0993d64164c5645de9b918e293cd3ae73cc6eeab (diff) | |
download | FreeBSD-src-4f2a5d896ef4c868add74c88150f6cc2bbe07aae.zip FreeBSD-src-4f2a5d896ef4c868add74c88150f6cc2bbe07aae.tar.gz |
Use the MAC address of an interface for the host part of an IPX address
and not the MAC address of the first interface for every IPX address.
This is more inline with the way others like Novell do it.
Originally Submitted by: "Serge A. Babkin" <babkin@hq.icb.chel.su>
Diffstat (limited to 'sys')
-rw-r--r-- | sys/net/if_ethersubr.c | 18 | ||||
-rw-r--r-- | sys/net/if_fddisubr.c | 18 |
2 files changed, 30 insertions, 6 deletions
diff --git a/sys/net/if_ethersubr.c b/sys/net/if_ethersubr.c index ae17b35..48295ae 100644 --- a/sys/net/if_ethersubr.c +++ b/sys/net/if_ethersubr.c @@ -31,7 +31,7 @@ * SUCH DAMAGE. * * @(#)if_ethersubr.c 8.1 (Berkeley) 6/10/93 - * $Id: if_ethersubr.c,v 1.33 1997/02/22 09:41:00 peter Exp $ + * $Id: if_ethersubr.c,v 1.34 1997/03/24 11:33:11 bde Exp $ */ #include <sys/param.h> @@ -176,15 +176,27 @@ ether_output(ifp, m0, dst, rt0) #endif #ifdef IPX case AF_IPX: + { + struct ifaddr *ia; + type = htons(ETHERTYPE_IPX); bcopy((caddr_t)&(((struct sockaddr_ipx *)dst)->sipx_addr.x_host), (caddr_t)edst, sizeof (edst)); - if (!bcmp((caddr_t)edst, (caddr_t)&ipx_thishost, sizeof(edst))) - return (looutput(ifp, m, dst, rt)); + + for(ia = ifp->if_addrhead.tqh_first; ia != 0; + ia = ia->ifa_link.tqe_next) { + if(ia->ifa_addr->sa_family == AF_IPX && + !bcmp((caddr_t)edst, + (caddr_t)&((struct ipx_ifaddr *)ia)->ia_addr.sipx_addr.x_host, + sizeof(edst)) ) + return (looutput(ifp, m, dst, rt)); + } + /* If broadcasting on a simplex interface, loopback a copy */ if ((m->m_flags & M_BCAST) && (ifp->if_flags & IFF_SIMPLEX)) mcopy = m_copy(m, 0, (int)M_COPYALL); break; + } #endif #ifdef NETATALK case AF_APPLETALK: diff --git a/sys/net/if_fddisubr.c b/sys/net/if_fddisubr.c index d2f480e..3a22669 100644 --- a/sys/net/if_fddisubr.c +++ b/sys/net/if_fddisubr.c @@ -33,7 +33,7 @@ * SUCH DAMAGE. * * from: if_ethersubr.c,v 1.5 1994/12/13 22:31:45 wollman Exp - * $Id: if_fddisubr.c,v 1.17 1997/03/15 19:58:43 joerg Exp $ + * $Id: if_fddisubr.c,v 1.18 1997/03/24 11:24:46 bde Exp $ */ #include <sys/param.h> @@ -197,15 +197,27 @@ fddi_output(ifp, m0, dst, rt0) #endif #ifdef IPX case AF_IPX: + { + struct ifaddr *ia; + type = htons(ETHERTYPE_IPX); bcopy((caddr_t)&(((struct sockaddr_ipx *)dst)->sipx_addr.x_host), (caddr_t)edst, sizeof (edst)); - if (!bcmp((caddr_t)edst, (caddr_t)&ipx_thishost, sizeof(edst))) - return (looutput(ifp, m, dst, rt)); + + for(ia = ifp->if_addrhead.tqh_first; ia != 0; + ia = ia->ifa_link.tqe_next) { + if(ia->ifa_addr->sa_family == AF_IPX && + !bcmp((caddr_t)edst, + (caddr_t)&((struct ipx_ifaddr *)ia)->ia_addr.sipx_addr.x_host, + sizeof(edst)) ) + return (looutput(ifp, m, dst, rt)); + } + /* If broadcasting on a simplex interface, loopback a copy */ if ((m->m_flags & M_BCAST) && (ifp->if_flags & IFF_SIMPLEX)) mcopy = m_copy(m, 0, (int)M_COPYALL); break; + } #endif #ifdef NETATALK case AF_APPLETALK: { |