ne2000: use inline net_crc32() and bitshift instead of compute_mcast_idx()
This makes it much easier to compare the multicast CRC calculation endian and bitshift against the Linux driver implementation. Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Signed-off-by: Jason Wang <jasowang@redhat.com>
This commit is contained in:
parent
4227be63f0
commit
084e2b111b
@ -23,6 +23,8 @@
|
|||||||
*/
|
*/
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "hw/pci/pci.h"
|
#include "hw/pci/pci.h"
|
||||||
|
#include "net/net.h"
|
||||||
|
#include "net/eth.h"
|
||||||
#include "ne2000.h"
|
#include "ne2000.h"
|
||||||
#include "hw/loader.h"
|
#include "hw/loader.h"
|
||||||
#include "sysemu/sysemu.h"
|
#include "sysemu/sysemu.h"
|
||||||
@ -199,7 +201,7 @@ ssize_t ne2000_receive(NetClientState *nc, const uint8_t *buf, size_t size_)
|
|||||||
/* multicast */
|
/* multicast */
|
||||||
if (!(s->rxcr & 0x08))
|
if (!(s->rxcr & 0x08))
|
||||||
return size;
|
return size;
|
||||||
mcast_idx = compute_mcast_idx(buf);
|
mcast_idx = net_crc32(buf, ETH_ALEN) >> 26;
|
||||||
if (!(s->mult[mcast_idx >> 3] & (1 << (mcast_idx & 7))))
|
if (!(s->mult[mcast_idx >> 3] & (1 << (mcast_idx & 7))))
|
||||||
return size;
|
return size;
|
||||||
} else if (s->mem[0] == buf[0] &&
|
} else if (s->mem[0] == buf[0] &&
|
||||||
|
Loading…
Reference in New Issue
Block a user