cnic: Fix interrupt logic
authorMichael Chan <mchan@broadcom.com>
Wed, 8 Jun 2011 19:29:32 +0000 (19:29 +0000)
committerGreg Kroah-Hartman <gregkh@suse.de>
Mon, 3 Oct 2011 18:41:04 +0000 (11:41 -0700)
commit 93736656138e6d2f39f19c1d68f9ef81cfc9dd66 upstream.

We need to keep looping until cnic_get_kcqes() returns 0.  cnic_get_kcqes()
returns a maximum of 64 entries.  If there are more entries in the queue
and we don't loop back, the remaining entries may not be serviced for a
long time.

Signed-off-by: Michael Chan <mchan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/net/cnic.c

index 11a92afdf982ef62be6a6097a88f768e9b3d599e..5c0a669dfa5f3ba803e873cf5058263a9d2be7b6 100644 (file)
@@ -2778,13 +2778,10 @@ static u32 cnic_service_bnx2_queues(struct cnic_dev *dev)
 
                /* Tell compiler that status_blk fields can change. */
                barrier();
-               if (status_idx != *cp->kcq1.status_idx_ptr) {
-                       status_idx = (u16) *cp->kcq1.status_idx_ptr;
-                       /* status block index must be read first */
-                       rmb();
-                       cp->kwq_con_idx = *cp->kwq_con_idx_ptr;
-               } else
-                       break;
+               status_idx = (u16) *cp->kcq1.status_idx_ptr;
+               /* status block index must be read first */
+               rmb();
+               cp->kwq_con_idx = *cp->kwq_con_idx_ptr;
        }
 
        CNIC_WR16(dev, cp->kcq1.io_addr, cp->kcq1.sw_prod_idx);
@@ -2908,8 +2905,6 @@ static u32 cnic_service_bnx2x_kcq(struct cnic_dev *dev, struct kcq_info *info)
 
                /* Tell compiler that sblk fields can change. */
                barrier();
-               if (last_status == *info->status_idx_ptr)
-                       break;
 
                last_status = *info->status_idx_ptr;
                /* status block index must be read before reading the KCQ */