aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Chan <mchan@broadcom.com>2010-02-24 09:42:08 -0500
committerDavid S. Miller <davem@davemloft.net>2010-02-26 05:10:14 -0500
commita4dde3abbf87a495154a876576e1ab34b17b5ef1 (patch)
tree0a1faff1e54932ebb616fc5f0e412b187a433e94
parentc76284af9ec8a010c502a70249cb74b3bb69ec6f (diff)
cnic: Use union for the status blocks of different devices.
We only need to assign the status block address once and it also saves space in the structure. Signed-off-by: Michael Chan <mchan@broadcom.com> Signed-off-by: Benjamin Li <benli@broadcom.com> Signed-off-by: Eddie Wai <waie@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/cnic.c35
-rw-r--r--drivers/net/cnic.h9
2 files changed, 23 insertions, 21 deletions
diff --git a/drivers/net/cnic.c b/drivers/net/cnic.c
index 0defe61d5bf3..463408f46ba6 100644
--- a/drivers/net/cnic.c
+++ b/drivers/net/cnic.c
@@ -900,7 +900,8 @@ static int cnic_alloc_uio(struct cnic_dev *dev) {
900 uinfo->mem[0].memtype = UIO_MEM_PHYS; 900 uinfo->mem[0].memtype = UIO_MEM_PHYS;
901 901
902 if (test_bit(CNIC_F_BNX2_CLASS, &dev->flags)) { 902 if (test_bit(CNIC_F_BNX2_CLASS, &dev->flags)) {
903 uinfo->mem[1].addr = (unsigned long) cp->status_blk & PAGE_MASK; 903 uinfo->mem[1].addr = (unsigned long) cp->status_blk.gen &
904 PAGE_MASK;
904 if (cp->ethdev->drv_state & CNIC_DRV_STATE_USING_MSIX) 905 if (cp->ethdev->drv_state & CNIC_DRV_STATE_USING_MSIX)
905 uinfo->mem[1].size = BNX2_SBLK_MSIX_ALIGN_SIZE * 9; 906 uinfo->mem[1].size = BNX2_SBLK_MSIX_ALIGN_SIZE * 9;
906 else 907 else
@@ -1103,10 +1104,9 @@ static int cnic_alloc_bnx2x_resc(struct cnic_dev *dev)
1103 if (ret) 1104 if (ret)
1104 goto error; 1105 goto error;
1105 1106
1106 cp->bnx2x_status_blk = cp->status_blk;
1107 cp->bnx2x_def_status_blk = cp->ethdev->irq_arr[1].status_blk; 1107 cp->bnx2x_def_status_blk = cp->ethdev->irq_arr[1].status_blk;
1108 1108
1109 memset(cp->bnx2x_status_blk, 0, sizeof(struct host_status_block)); 1109 memset(cp->status_blk.bnx2x, 0, sizeof(*cp->status_blk.bnx2x));
1110 1110
1111 cp->l2_rx_ring_size = 15; 1111 cp->l2_rx_ring_size = 15;
1112 1112
@@ -2205,7 +2205,7 @@ static void cnic_service_bnx2_msix(unsigned long data)
2205{ 2205{
2206 struct cnic_dev *dev = (struct cnic_dev *) data; 2206 struct cnic_dev *dev = (struct cnic_dev *) data;
2207 struct cnic_local *cp = dev->cnic_priv; 2207 struct cnic_local *cp = dev->cnic_priv;
2208 struct status_block_msix *status_blk = cp->bnx2_status_blk; 2208 struct status_block_msix *status_blk = cp->status_blk.bnx2;
2209 u32 status_idx = status_blk->status_idx; 2209 u32 status_idx = status_blk->status_idx;
2210 u16 hw_prod, sw_prod; 2210 u16 hw_prod, sw_prod;
2211 int kcqe_cnt; 2211 int kcqe_cnt;
@@ -2251,7 +2251,7 @@ static irqreturn_t cnic_irq(int irq, void *dev_instance)
2251 if (cp->ack_int) 2251 if (cp->ack_int)
2252 cp->ack_int(dev); 2252 cp->ack_int(dev);
2253 2253
2254 prefetch(cp->status_blk); 2254 prefetch(cp->status_blk.gen);
2255 prefetch(&cp->kcq[KCQ_PG(prod)][KCQ_IDX(prod)]); 2255 prefetch(&cp->kcq[KCQ_PG(prod)][KCQ_IDX(prod)]);
2256 2256
2257 if (likely(test_bit(CNIC_F_CNIC_UP, &dev->flags))) 2257 if (likely(test_bit(CNIC_F_CNIC_UP, &dev->flags)))
@@ -2292,7 +2292,7 @@ static void cnic_service_bnx2x_bh(unsigned long data)
2292 struct cnic_local *cp = dev->cnic_priv; 2292 struct cnic_local *cp = dev->cnic_priv;
2293 u16 hw_prod, sw_prod; 2293 u16 hw_prod, sw_prod;
2294 struct cstorm_status_block_c *sblk = 2294 struct cstorm_status_block_c *sblk =
2295 &cp->bnx2x_status_blk->c_status_block; 2295 &cp->status_blk.bnx2x->c_status_block;
2296 u32 status_idx = sblk->status_block_index; 2296 u32 status_idx = sblk->status_block_index;
2297 int kcqe_cnt; 2297 int kcqe_cnt;
2298 2298
@@ -2334,7 +2334,7 @@ static int cnic_service_bnx2x(void *data, void *status_blk)
2334 struct cnic_local *cp = dev->cnic_priv; 2334 struct cnic_local *cp = dev->cnic_priv;
2335 u16 prod = cp->kcq_prod_idx & MAX_KCQ_IDX; 2335 u16 prod = cp->kcq_prod_idx & MAX_KCQ_IDX;
2336 2336
2337 prefetch(cp->status_blk); 2337 prefetch(cp->status_blk.bnx2x);
2338 prefetch(&cp->kcq[KCQ_PG(prod)][KCQ_IDX(prod)]); 2338 prefetch(&cp->kcq[KCQ_PG(prod)][KCQ_IDX(prod)]);
2339 2339
2340 if (likely(test_bit(CNIC_F_CNIC_UP, &dev->flags))) 2340 if (likely(test_bit(CNIC_F_CNIC_UP, &dev->flags)))
@@ -3409,8 +3409,7 @@ static int cnic_init_bnx2_irq(struct cnic_dev *dev)
3409 CNIC_WR(dev, base + BNX2_HC_COM_TICKS_OFF, (64 << 16) | 220); 3409 CNIC_WR(dev, base + BNX2_HC_COM_TICKS_OFF, (64 << 16) | 220);
3410 CNIC_WR(dev, base + BNX2_HC_CMD_TICKS_OFF, (64 << 16) | 220); 3410 CNIC_WR(dev, base + BNX2_HC_CMD_TICKS_OFF, (64 << 16) | 220);
3411 3411
3412 cp->bnx2_status_blk = cp->status_blk; 3412 cp->last_status_idx = cp->status_blk.bnx2->status_idx;
3413 cp->last_status_idx = cp->bnx2_status_blk->status_idx;
3414 tasklet_init(&cp->cnic_irq_task, cnic_service_bnx2_msix, 3413 tasklet_init(&cp->cnic_irq_task, cnic_service_bnx2_msix,
3415 (unsigned long) dev); 3414 (unsigned long) dev);
3416 err = request_irq(ethdev->irq_arr[0].vector, cnic_irq, 0, 3415 err = request_irq(ethdev->irq_arr[0].vector, cnic_irq, 0,
@@ -3419,7 +3418,7 @@ static int cnic_init_bnx2_irq(struct cnic_dev *dev)
3419 tasklet_disable(&cp->cnic_irq_task); 3418 tasklet_disable(&cp->cnic_irq_task);
3420 return err; 3419 return err;
3421 } 3420 }
3422 while (cp->bnx2_status_blk->status_completion_producer_index && 3421 while (cp->status_blk.bnx2->status_completion_producer_index &&
3423 i < 10) { 3422 i < 10) {
3424 CNIC_WR(dev, BNX2_HC_COALESCE_NOW, 3423 CNIC_WR(dev, BNX2_HC_COALESCE_NOW,
3425 1 << (11 + sblk_num)); 3424 1 << (11 + sblk_num));
@@ -3427,13 +3426,13 @@ static int cnic_init_bnx2_irq(struct cnic_dev *dev)
3427 i++; 3426 i++;
3428 barrier(); 3427 barrier();
3429 } 3428 }
3430 if (cp->bnx2_status_blk->status_completion_producer_index) { 3429 if (cp->status_blk.bnx2->status_completion_producer_index) {
3431 cnic_free_irq(dev); 3430 cnic_free_irq(dev);
3432 goto failed; 3431 goto failed;
3433 } 3432 }
3434 3433
3435 } else { 3434 } else {
3436 struct status_block *sblk = cp->status_blk; 3435 struct status_block *sblk = cp->status_blk.gen;
3437 u32 hc_cmd = CNIC_RD(dev, BNX2_HC_COMMAND); 3436 u32 hc_cmd = CNIC_RD(dev, BNX2_HC_COMMAND);
3438 int i = 0; 3437 int i = 0;
3439 3438
@@ -3490,7 +3489,7 @@ static void cnic_init_bnx2_tx_ring(struct cnic_dev *dev)
3490 int i; 3489 int i;
3491 struct tx_bd *txbd; 3490 struct tx_bd *txbd;
3492 dma_addr_t buf_map; 3491 dma_addr_t buf_map;
3493 struct status_block *s_blk = cp->status_blk; 3492 struct status_block *s_blk = cp->status_blk.gen;
3494 3493
3495 sb_id = cp->status_blk_num; 3494 sb_id = cp->status_blk_num;
3496 tx_cid = 20; 3495 tx_cid = 20;
@@ -3498,7 +3497,7 @@ static void cnic_init_bnx2_tx_ring(struct cnic_dev *dev)
3498 cnic_init_context(dev, tx_cid + 1); 3497 cnic_init_context(dev, tx_cid + 1);
3499 cp->tx_cons_ptr = &s_blk->status_tx_quick_consumer_index2; 3498 cp->tx_cons_ptr = &s_blk->status_tx_quick_consumer_index2;
3500 if (ethdev->drv_state & CNIC_DRV_STATE_USING_MSIX) { 3499 if (ethdev->drv_state & CNIC_DRV_STATE_USING_MSIX) {
3501 struct status_block_msix *sblk = cp->status_blk; 3500 struct status_block_msix *sblk = cp->status_blk.bnx2;
3502 3501
3503 tx_cid = TX_TSS_CID + sb_id - 1; 3502 tx_cid = TX_TSS_CID + sb_id - 1;
3504 cnic_init_context(dev, tx_cid); 3503 cnic_init_context(dev, tx_cid);
@@ -3554,7 +3553,7 @@ static void cnic_init_bnx2_rx_ring(struct cnic_dev *dev)
3554 u32 cid_addr, sb_id, val, coal_reg, coal_val; 3553 u32 cid_addr, sb_id, val, coal_reg, coal_val;
3555 int i; 3554 int i;
3556 struct rx_bd *rxbd; 3555 struct rx_bd *rxbd;
3557 struct status_block *s_blk = cp->status_blk; 3556 struct status_block *s_blk = cp->status_blk.gen;
3558 3557
3559 sb_id = cp->status_blk_num; 3558 sb_id = cp->status_blk_num;
3560 cnic_init_context(dev, 2); 3559 cnic_init_context(dev, 2);
@@ -3562,7 +3561,7 @@ static void cnic_init_bnx2_rx_ring(struct cnic_dev *dev)
3562 coal_reg = BNX2_HC_COMMAND; 3561 coal_reg = BNX2_HC_COMMAND;
3563 coal_val = CNIC_RD(dev, coal_reg); 3562 coal_val = CNIC_RD(dev, coal_reg);
3564 if (ethdev->drv_state & CNIC_DRV_STATE_USING_MSIX) { 3563 if (ethdev->drv_state & CNIC_DRV_STATE_USING_MSIX) {
3565 struct status_block_msix *sblk = cp->status_blk; 3564 struct status_block_msix *sblk = cp->status_blk.bnx2;
3566 3565
3567 cp->rx_cons_ptr = &sblk->status_rx_quick_consumer_index; 3566 cp->rx_cons_ptr = &sblk->status_rx_quick_consumer_index;
3568 coal_reg = BNX2_HC_COALESCE_NOW; 3567 coal_reg = BNX2_HC_COALESCE_NOW;
@@ -3661,7 +3660,7 @@ static int cnic_start_bnx2_hw(struct cnic_dev *dev)
3661{ 3660{
3662 struct cnic_local *cp = dev->cnic_priv; 3661 struct cnic_local *cp = dev->cnic_priv;
3663 struct cnic_eth_dev *ethdev = cp->ethdev; 3662 struct cnic_eth_dev *ethdev = cp->ethdev;
3664 struct status_block *sblk = cp->status_blk; 3663 struct status_block *sblk = cp->status_blk.gen;
3665 u32 val; 3664 u32 val;
3666 int err; 3665 int err;
3667 3666
@@ -4250,7 +4249,7 @@ static int cnic_start_hw(struct cnic_dev *dev)
4250 cp->chip_id = ethdev->chip_id; 4249 cp->chip_id = ethdev->chip_id;
4251 pci_dev_get(dev->pcidev); 4250 pci_dev_get(dev->pcidev);
4252 cp->func = PCI_FUNC(dev->pcidev->devfn); 4251 cp->func = PCI_FUNC(dev->pcidev->devfn);
4253 cp->status_blk = ethdev->irq_arr[0].status_blk; 4252 cp->status_blk.gen = ethdev->irq_arr[0].status_blk;
4254 cp->status_blk_num = ethdev->irq_arr[0].status_blk_num; 4253 cp->status_blk_num = ethdev->irq_arr[0].status_blk_num;
4255 4254
4256 err = cp->alloc_resc(dev); 4255 err = cp->alloc_resc(dev);
diff --git a/drivers/net/cnic.h b/drivers/net/cnic.h
index 1921597ab4a3..d566390b8c4d 100644
--- a/drivers/net/cnic.h
+++ b/drivers/net/cnic.h
@@ -224,9 +224,12 @@ struct cnic_local {
224 u16 kcq_prod_idx; 224 u16 kcq_prod_idx;
225 u32 kcq_io_addr; 225 u32 kcq_io_addr;
226 226
227 void *status_blk; 227 union {
228 struct status_block_msix *bnx2_status_blk; 228 void *gen;
229 struct host_status_block *bnx2x_status_blk; 229 struct status_block_msix *bnx2;
230 struct host_status_block *bnx2x;
231 } status_blk;
232
230 struct host_def_status_block *bnx2x_def_status_blk; 233 struct host_def_status_block *bnx2x_def_status_blk;
231 234
232 u32 status_blk_num; 235 u32 status_blk_num;