o wl3501: clarify arp type checking in wl3501_md_ind_interrupt

Information collected from another driver source found on the net
for this hardware, written by magyver@zcom.com.tw, that I'm
reading to find more information about this hardware, coalescing
several efforts to have a driver for this card.
parent afa0e56e
...@@ -1171,15 +1171,17 @@ static inline void wl3501_md_ind_interrupt(struct net_device *dev, ...@@ -1171,15 +1171,17 @@ static inline void wl3501_md_ind_interrupt(struct net_device *dev,
this->rssi = rssi <= 63 ? (rssi * 100) / 64 : 255; this->rssi = rssi <= 63 ? (rssi * 100) / 64 : 255;
if (this->llc_type == 1) { if (this->llc_type == 1) {
u16 tmp; unsigned char addr4[ETH_ALEN];
wl3501_get_from_wla(this, wl3501_get_from_wla(this,
sig.data + sizeof(struct wl3501_rx_hdr) - 6, sig.data +
&tmp, sizeof(tmp)); offsetof(struct wl3501_rx_hdr, addr4),
if (tmp == 0xaaaa) { &addr4, sizeof(addr4));
if (addr4[0] == 0xAA && addr4[1] == 0xAA &&
addr4[2] == 0x03 && addr4[4] == 0x00) {
pkt_len = sig.size + 12 - 24 - 4 - 6; pkt_len = sig.size + 12 - 24 - 4 - 6;
this->ether_type = ARPHRD_ETHER; this->ether_type = ARPHRD_ETHER;
} else if (tmp == 0xe0e0) { } else if (addr4[0] == 0xE0 && addr4[1] == 0xE0) {
pkt_len = sig.size + 12 - 24 - 4 + 2; pkt_len = sig.size + 12 - 24 - 4 + 2;
this->ether_type = ARPHRD_IEEE80211; /* FIXME */ this->ether_type = ARPHRD_IEEE80211; /* FIXME */
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment