提交 caefe526 编写于 作者: M Michael Chan 提交者: David S. Miller

bnxt_en: Change bp->state to bitmap.

This allows multiple independent bits to be set for various states.
Subsequent patches to implement tx timeout reset will require this.
Signed-off-by: NMichael Chan <mchan@broadcom.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 de68f5de
...@@ -4602,7 +4602,7 @@ static int __bnxt_open_nic(struct bnxt *bp, bool irq_re_init, bool link_re_init) ...@@ -4602,7 +4602,7 @@ static int __bnxt_open_nic(struct bnxt *bp, bool irq_re_init, bool link_re_init)
bp->nge_port_cnt = 1; bp->nge_port_cnt = 1;
} }
bp->state = BNXT_STATE_OPEN; set_bit(BNXT_STATE_OPEN, &bp->state);
bnxt_enable_int(bp); bnxt_enable_int(bp);
/* Enable TX queues */ /* Enable TX queues */
bnxt_tx_enable(bp); bnxt_tx_enable(bp);
...@@ -4678,7 +4678,7 @@ int bnxt_close_nic(struct bnxt *bp, bool irq_re_init, bool link_re_init) ...@@ -4678,7 +4678,7 @@ int bnxt_close_nic(struct bnxt *bp, bool irq_re_init, bool link_re_init)
/* Change device state to avoid TX queue wake up's */ /* Change device state to avoid TX queue wake up's */
bnxt_tx_disable(bp); bnxt_tx_disable(bp);
bp->state = BNXT_STATE_CLOSED; clear_bit(BNXT_STATE_OPEN, &bp->state);
cancel_work_sync(&bp->sp_task); cancel_work_sync(&bp->sp_task);
/* Flush rings before disabling interrupts */ /* Flush rings before disabling interrupts */
...@@ -5080,7 +5080,7 @@ static void bnxt_sp_task(struct work_struct *work) ...@@ -5080,7 +5080,7 @@ static void bnxt_sp_task(struct work_struct *work)
struct bnxt *bp = container_of(work, struct bnxt, sp_task); struct bnxt *bp = container_of(work, struct bnxt, sp_task);
int rc; int rc;
if (bp->state != BNXT_STATE_OPEN) if (!test_bit(BNXT_STATE_OPEN, &bp->state))
return; return;
if (test_and_clear_bit(BNXT_RX_MASK_SP_EVENT, &bp->sp_event)) if (test_and_clear_bit(BNXT_RX_MASK_SP_EVENT, &bp->sp_event))
...@@ -5185,7 +5185,7 @@ static int bnxt_init_board(struct pci_dev *pdev, struct net_device *dev) ...@@ -5185,7 +5185,7 @@ static int bnxt_init_board(struct pci_dev *pdev, struct net_device *dev)
bp->timer.function = bnxt_timer; bp->timer.function = bnxt_timer;
bp->current_interval = BNXT_TIMER_INTERVAL; bp->current_interval = BNXT_TIMER_INTERVAL;
bp->state = BNXT_STATE_CLOSED; clear_bit(BNXT_STATE_OPEN, &bp->state);
return 0; return 0;
......
...@@ -925,9 +925,8 @@ struct bnxt { ...@@ -925,9 +925,8 @@ struct bnxt {
struct timer_list timer; struct timer_list timer;
int state; unsigned long state;
#define BNXT_STATE_CLOSED 0 #define BNXT_STATE_OPEN 0
#define BNXT_STATE_OPEN 1
struct bnxt_irq *irq_tbl; struct bnxt_irq *irq_tbl;
u8 mac_addr[ETH_ALEN]; u8 mac_addr[ETH_ALEN];
......
...@@ -21,7 +21,7 @@ ...@@ -21,7 +21,7 @@
#ifdef CONFIG_BNXT_SRIOV #ifdef CONFIG_BNXT_SRIOV
static int bnxt_vf_ndo_prep(struct bnxt *bp, int vf_id) static int bnxt_vf_ndo_prep(struct bnxt *bp, int vf_id)
{ {
if (bp->state != BNXT_STATE_OPEN) { if (!test_bit(BNXT_STATE_OPEN, &bp->state)) {
netdev_err(bp->dev, "vf ndo called though PF is down\n"); netdev_err(bp->dev, "vf ndo called though PF is down\n");
return -EINVAL; return -EINVAL;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册