/**
  * ks8851_rx_pkts - receive packets from the host
  * @ks: The device information.
+ * @rxq: Queue of packets received in this function.
  *
  * This is called from the IRQ work queue when the system detects that there
  * are packets in the receive queue. Find out how many packets there are and
  * read them from the FIFO.
  */
-static void ks8851_rx_pkts(struct ks8851_net *ks)
+static void ks8851_rx_pkts(struct ks8851_net *ks, struct sk_buff_head *rxq)
 {
        struct sk_buff *skb;
        unsigned rxfc;
                                        ks8851_dbg_dumpkkt(ks, rxpkt);
 
                                skb->protocol = eth_type_trans(skb, ks->netdev);
-                               __netif_rx(skb);
+                               __skb_queue_tail(rxq, skb);
 
                                ks->netdev->stats.rx_packets++;
                                ks->netdev->stats.rx_bytes += rxlen;
 static irqreturn_t ks8851_irq(int irq, void *_ks)
 {
        struct ks8851_net *ks = _ks;
+       struct sk_buff_head rxq;
        unsigned handled = 0;
        unsigned long flags;
        unsigned int status;
-
-       local_bh_disable();
+       struct sk_buff *skb;
 
        ks8851_lock(ks, &flags);
 
                 * from the device so do not bother masking just the RX
                 * from the device. */
 
-               ks8851_rx_pkts(ks);
+               __skb_queue_head_init(&rxq);
+               ks8851_rx_pkts(ks, &rxq);
        }
 
        /* if something stopped the rx process, probably due to wanting
        if (status & IRQ_LCI)
                mii_check_link(&ks->mii);
 
-       local_bh_enable();
+       if (status & IRQ_RXI)
+               while ((skb = __skb_dequeue(&rxq)))
+                       netif_rx(skb);
 
        return IRQ_HANDLED;
 }