Convert to if_foreach_llmaddr() KPI.
This commit is contained in:
parent
7c12abe654
commit
226158378d
@ -606,11 +606,20 @@ xl_rxfilter(struct xl_softc *sc)
|
||||
* NICs older than the 3c905B have only one multicast option, which
|
||||
* is to enable reception of all multicast frames.
|
||||
*/
|
||||
static u_int
|
||||
xl_check_maddr_90x(void *arg, struct sockaddr_dl *sdl, u_int cnt)
|
||||
{
|
||||
uint8_t *rxfilt = arg;
|
||||
|
||||
*rxfilt |= XL_RXFILTER_ALLMULTI;
|
||||
|
||||
return (1);
|
||||
}
|
||||
|
||||
static void
|
||||
xl_rxfilter_90x(struct xl_softc *sc)
|
||||
{
|
||||
struct ifnet *ifp;
|
||||
struct ifmultiaddr *ifma;
|
||||
u_int8_t rxfilt;
|
||||
|
||||
XL_LOCK_ASSERT(sc);
|
||||
@ -634,16 +643,8 @@ xl_rxfilter_90x(struct xl_softc *sc)
|
||||
rxfilt |= XL_RXFILTER_ALLFRAMES;
|
||||
if (ifp->if_flags & IFF_ALLMULTI)
|
||||
rxfilt |= XL_RXFILTER_ALLMULTI;
|
||||
} else {
|
||||
if_maddr_rlock(ifp);
|
||||
CK_STAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) {
|
||||
if (ifma->ifma_addr->sa_family != AF_LINK)
|
||||
continue;
|
||||
rxfilt |= XL_RXFILTER_ALLMULTI;
|
||||
break;
|
||||
}
|
||||
if_maddr_runlock(ifp);
|
||||
}
|
||||
} else
|
||||
if_foreach_llmaddr(sc->xl_ifp, xl_check_maddr_90x, &rxfilt);
|
||||
|
||||
CSR_WRITE_2(sc, XL_COMMAND, rxfilt | XL_CMD_RX_SET_FILT);
|
||||
XL_SEL_WIN(7);
|
||||
@ -651,14 +652,34 @@ xl_rxfilter_90x(struct xl_softc *sc)
|
||||
|
||||
/*
|
||||
* 3c905B adapters have a hash filter that we can program.
|
||||
* Note: the 3c905B currently only supports a 64-bit
|
||||
* hash table, which means we really only need 6 bits,
|
||||
* but the manual indicates that future chip revisions
|
||||
* will have a 256-bit hash table, hence the routine
|
||||
* is set up to calculate 8 bits of position info in
|
||||
* case we need it some day.
|
||||
* Note II, The Sequel: _CURRENT_ versions of the
|
||||
* 3c905B have a 256 bit hash table. This means we have
|
||||
* to use all 8 bits regardless. On older cards, the
|
||||
* upper 2 bits will be ignored. Grrrr....
|
||||
*/
|
||||
static u_int
|
||||
xl_check_maddr_90xB(void *arg, struct sockaddr_dl *sdl, u_int count)
|
||||
{
|
||||
struct xl_softc *sc = arg;
|
||||
uint16_t h;
|
||||
|
||||
h = ether_crc32_be(LLADDR(sdl), ETHER_ADDR_LEN) & 0xFF;
|
||||
CSR_WRITE_2(sc, XL_COMMAND, h | XL_CMD_RX_SET_HASH | XL_HASH_SET);
|
||||
|
||||
return (1);
|
||||
}
|
||||
|
||||
static void
|
||||
xl_rxfilter_90xB(struct xl_softc *sc)
|
||||
{
|
||||
struct ifnet *ifp;
|
||||
struct ifmultiaddr *ifma;
|
||||
int i, mcnt;
|
||||
u_int16_t h;
|
||||
int i;
|
||||
u_int8_t rxfilt;
|
||||
|
||||
XL_LOCK_ASSERT(sc);
|
||||
@ -689,31 +710,7 @@ xl_rxfilter_90xB(struct xl_softc *sc)
|
||||
CSR_WRITE_2(sc, XL_COMMAND, XL_CMD_RX_SET_HASH | i);
|
||||
|
||||
/* Now program new ones. */
|
||||
mcnt = 0;
|
||||
if_maddr_rlock(ifp);
|
||||
CK_STAILQ_FOREACH(ifma, &ifp->if_multiaddrs, ifma_link) {
|
||||
if (ifma->ifma_addr->sa_family != AF_LINK)
|
||||
continue;
|
||||
/*
|
||||
* Note: the 3c905B currently only supports a 64-bit
|
||||
* hash table, which means we really only need 6 bits,
|
||||
* but the manual indicates that future chip revisions
|
||||
* will have a 256-bit hash table, hence the routine
|
||||
* is set up to calculate 8 bits of position info in
|
||||
* case we need it some day.
|
||||
* Note II, The Sequel: _CURRENT_ versions of the
|
||||
* 3c905B have a 256 bit hash table. This means we have
|
||||
* to use all 8 bits regardless. On older cards, the
|
||||
* upper 2 bits will be ignored. Grrrr....
|
||||
*/
|
||||
h = ether_crc32_be(LLADDR((struct sockaddr_dl *)
|
||||
ifma->ifma_addr), ETHER_ADDR_LEN) & 0xFF;
|
||||
CSR_WRITE_2(sc, XL_COMMAND,
|
||||
h | XL_CMD_RX_SET_HASH | XL_HASH_SET);
|
||||
mcnt++;
|
||||
}
|
||||
if_maddr_runlock(ifp);
|
||||
if (mcnt > 0)
|
||||
if (if_foreach_llmaddr(sc->xl_ifp, xl_check_maddr_90xB, sc) > 0)
|
||||
rxfilt |= XL_RXFILTER_MULTIHASH;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user