X-Git-Url: https://git.archive.openwrt.org/?p=openwrt.git;a=blobdiff_plain;f=target%2Flinux%2Fcns3xxx%2Ffiles%2Fdrivers%2Fnet%2Fethernet%2Fcavium%2Fcns3xxx_eth.c;fp=target%2Flinux%2Fcns3xxx%2Ffiles%2Fdrivers%2Fnet%2Fethernet%2Fcavium%2Fcns3xxx_eth.c;h=7309d9ea779cdc72d193a63b7d8c91d012721b0d;hp=7ffff684de337f524b9dd453a14a2187e1e2b5a8;hb=7b0d07de1c30c5f8f4030c296717c9f86872b190;hpb=c4cdde2483e667146a76fe3e743f82cafb5c3567 diff --git a/target/linux/cns3xxx/files/drivers/net/ethernet/cavium/cns3xxx_eth.c b/target/linux/cns3xxx/files/drivers/net/ethernet/cavium/cns3xxx_eth.c index 7ffff684de..7309d9ea77 100644 --- a/target/linux/cns3xxx/files/drivers/net/ethernet/cavium/cns3xxx_eth.c +++ b/target/linux/cns3xxx/files/drivers/net/ethernet/cavium/cns3xxx_eth.c @@ -706,15 +706,15 @@ static int eth_poll(struct napi_struct *napi, int budget) } } - cns3xxx_alloc_rx_buf(sw, received); - - rx_ring->cur_index = i; - - if (received != budget) { + if (!received) { napi_complete(napi); enable_irq(IRQ_CNS3XXX_SW_R0RXC); } + cns3xxx_alloc_rx_buf(sw, received); + + rx_ring->cur_index = i; + wmb(); enable_rx_dma(sw);