Commit 1f1332a3 authored by Michael Chan's avatar Michael Chan Committed by David S. Miller

cnic: Convert cnic_local_flags to atomic ops.

It is easier to expand the flags for other purposes because it does
not require a spin_lock.  The next bug fix patch needs a flag in
cnic_local_flags.
Signed-off-by: default avatarMichael Chan <mchan@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 57c8a456
...@@ -1143,12 +1143,12 @@ static int cnic_submit_bnx2_kwqes(struct cnic_dev *dev, struct kwqe *wqes[], ...@@ -1143,12 +1143,12 @@ static int cnic_submit_bnx2_kwqes(struct cnic_dev *dev, struct kwqe *wqes[],
spin_lock_bh(&cp->cnic_ulp_lock); spin_lock_bh(&cp->cnic_ulp_lock);
if (num_wqes > cnic_kwq_avail(cp) && if (num_wqes > cnic_kwq_avail(cp) &&
!(cp->cnic_local_flags & CNIC_LCL_FL_KWQ_INIT)) { !test_bit(CNIC_LCL_FL_KWQ_INIT, &cp->cnic_local_flags)) {
spin_unlock_bh(&cp->cnic_ulp_lock); spin_unlock_bh(&cp->cnic_ulp_lock);
return -EAGAIN; return -EAGAIN;
} }
cp->cnic_local_flags &= ~CNIC_LCL_FL_KWQ_INIT; clear_bit(CNIC_LCL_FL_KWQ_INIT, &cp->cnic_local_flags);
prod = cp->kwq_prod_idx; prod = cp->kwq_prod_idx;
sw_prod = prod & MAX_KWQ_IDX; sw_prod = prod & MAX_KWQ_IDX;
...@@ -3690,7 +3690,7 @@ static int cnic_start_bnx2_hw(struct cnic_dev *dev) ...@@ -3690,7 +3690,7 @@ static int cnic_start_bnx2_hw(struct cnic_dev *dev)
cp->max_kwq_idx = MAX_KWQ_IDX; cp->max_kwq_idx = MAX_KWQ_IDX;
cp->kwq_prod_idx = 0; cp->kwq_prod_idx = 0;
cp->kwq_con_idx = 0; cp->kwq_con_idx = 0;
cp->cnic_local_flags |= CNIC_LCL_FL_KWQ_INIT; set_bit(CNIC_LCL_FL_KWQ_INIT, &cp->cnic_local_flags);
if (CHIP_NUM(cp) == CHIP_NUM_5706 || CHIP_NUM(cp) == CHIP_NUM_5708) if (CHIP_NUM(cp) == CHIP_NUM_5706 || CHIP_NUM(cp) == CHIP_NUM_5708)
cp->kwq_con_idx_ptr = &sblk->status_rx_quick_consumer_index15; cp->kwq_con_idx_ptr = &sblk->status_rx_quick_consumer_index15;
......
...@@ -179,9 +179,8 @@ struct cnic_local { ...@@ -179,9 +179,8 @@ struct cnic_local {
#define ULP_F_CALL_PENDING 2 #define ULP_F_CALL_PENDING 2
struct cnic_ulp_ops *ulp_ops[MAX_CNIC_ULP_TYPE]; struct cnic_ulp_ops *ulp_ops[MAX_CNIC_ULP_TYPE];
/* protected by ulp_lock */ unsigned long cnic_local_flags;
u32 cnic_local_flags; #define CNIC_LCL_FL_KWQ_INIT 0x0
#define CNIC_LCL_FL_KWQ_INIT 0x00000001
struct cnic_dev *dev; struct cnic_dev *dev;
......
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