aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/chelsio/sge.c54
1 files changed, 19 insertions, 35 deletions
diff --git a/drivers/net/chelsio/sge.c b/drivers/net/chelsio/sge.c
index ac7c46b0eeb4..f94d63971642 100644
--- a/drivers/net/chelsio/sge.c
+++ b/drivers/net/chelsio/sge.c
@@ -85,10 +85,6 @@
85 */ 85 */
86#define TX_RECLAIM_PERIOD (HZ / 4) 86#define TX_RECLAIM_PERIOD (HZ / 4)
87 87
88#ifndef NET_IP_ALIGN
89# define NET_IP_ALIGN 2
90#endif
91
92#define M_CMD_LEN 0x7fffffff 88#define M_CMD_LEN 0x7fffffff
93#define V_CMD_LEN(v) (v) 89#define V_CMD_LEN(v) (v)
94#define G_CMD_LEN(v) ((v) & M_CMD_LEN) 90#define G_CMD_LEN(v) ((v) & M_CMD_LEN)
@@ -575,11 +571,10 @@ static int alloc_rx_resources(struct sge *sge, struct sge_params *p)
575 q->size = p->freelQ_size[i]; 571 q->size = p->freelQ_size[i];
576 q->dma_offset = sge->rx_pkt_pad ? 0 : NET_IP_ALIGN; 572 q->dma_offset = sge->rx_pkt_pad ? 0 : NET_IP_ALIGN;
577 size = sizeof(struct freelQ_e) * q->size; 573 size = sizeof(struct freelQ_e) * q->size;
578 q->entries = (struct freelQ_e *) 574 q->entries = pci_alloc_consistent(pdev, size, &q->dma_addr);
579 pci_alloc_consistent(pdev, size, &q->dma_addr);
580 if (!q->entries) 575 if (!q->entries)
581 goto err_no_mem; 576 goto err_no_mem;
582 memset(q->entries, 0, size); 577
583 size = sizeof(struct freelQ_ce) * q->size; 578 size = sizeof(struct freelQ_ce) * q->size;
584 q->centries = kzalloc(size, GFP_KERNEL); 579 q->centries = kzalloc(size, GFP_KERNEL);
585 if (!q->centries) 580 if (!q->centries)
@@ -613,11 +608,10 @@ static int alloc_rx_resources(struct sge *sge, struct sge_params *p)
613 sge->respQ.size = SGE_RESPQ_E_N; 608 sge->respQ.size = SGE_RESPQ_E_N;
614 sge->respQ.credits = 0; 609 sge->respQ.credits = 0;
615 size = sizeof(struct respQ_e) * sge->respQ.size; 610 size = sizeof(struct respQ_e) * sge->respQ.size;
616 sge->respQ.entries = (struct respQ_e *) 611 sge->respQ.entries =
617 pci_alloc_consistent(pdev, size, &sge->respQ.dma_addr); 612 pci_alloc_consistent(pdev, size, &sge->respQ.dma_addr);
618 if (!sge->respQ.entries) 613 if (!sge->respQ.entries)
619 goto err_no_mem; 614 goto err_no_mem;
620 memset(sge->respQ.entries, 0, size);
621 return 0; 615 return 0;
622 616
623err_no_mem: 617err_no_mem:
@@ -637,20 +631,12 @@ static void free_cmdQ_buffers(struct sge *sge, struct cmdQ *q, unsigned int n)
637 q->in_use -= n; 631 q->in_use -= n;
638 ce = &q->centries[cidx]; 632 ce = &q->centries[cidx];
639 while (n--) { 633 while (n--) {
640 if (q->sop) { 634 if (likely(pci_unmap_len(ce, dma_len))) {
641 if (likely(pci_unmap_len(ce, dma_len))) { 635 pci_unmap_single(pdev, pci_unmap_addr(ce, dma_addr),
642 pci_unmap_single(pdev, 636 pci_unmap_len(ce, dma_len),
643 pci_unmap_addr(ce, dma_addr), 637 PCI_DMA_TODEVICE);
644 pci_unmap_len(ce, dma_len), 638 if (q->sop)
645 PCI_DMA_TODEVICE);
646 q->sop = 0; 639 q->sop = 0;
647 }
648 } else {
649 if (likely(pci_unmap_len(ce, dma_len))) {
650 pci_unmap_page(pdev, pci_unmap_addr(ce, dma_addr),
651 pci_unmap_len(ce, dma_len),
652 PCI_DMA_TODEVICE);
653 }
654 } 640 }
655 if (ce->skb) { 641 if (ce->skb) {
656 dev_kfree_skb_any(ce->skb); 642 dev_kfree_skb_any(ce->skb);
@@ -711,11 +697,10 @@ static int alloc_tx_resources(struct sge *sge, struct sge_params *p)
711 q->stop_thres = 0; 697 q->stop_thres = 0;
712 spin_lock_init(&q->lock); 698 spin_lock_init(&q->lock);
713 size = sizeof(struct cmdQ_e) * q->size; 699 size = sizeof(struct cmdQ_e) * q->size;
714 q->entries = (struct cmdQ_e *) 700 q->entries = pci_alloc_consistent(pdev, size, &q->dma_addr);
715 pci_alloc_consistent(pdev, size, &q->dma_addr);
716 if (!q->entries) 701 if (!q->entries)
717 goto err_no_mem; 702 goto err_no_mem;
718 memset(q->entries, 0, size); 703
719 size = sizeof(struct cmdQ_ce) * q->size; 704 size = sizeof(struct cmdQ_ce) * q->size;
720 q->centries = kzalloc(size, GFP_KERNEL); 705 q->centries = kzalloc(size, GFP_KERNEL);
721 if (!q->centries) 706 if (!q->centries)
@@ -1447,19 +1432,18 @@ static inline int enough_free_Tx_descs(const struct cmdQ *q)
1447static void restart_tx_queues(struct sge *sge) 1432static void restart_tx_queues(struct sge *sge)
1448{ 1433{
1449 struct adapter *adap = sge->adapter; 1434 struct adapter *adap = sge->adapter;
1435 int i;
1450 1436
1451 if (enough_free_Tx_descs(&sge->cmdQ[0])) { 1437 if (!enough_free_Tx_descs(&sge->cmdQ[0]))
1452 int i; 1438 return;
1453 1439
1454 for_each_port(adap, i) { 1440 for_each_port(adap, i) {
1455 struct net_device *nd = adap->port[i].dev; 1441 struct net_device *nd = adap->port[i].dev;
1456 1442
1457 if (test_and_clear_bit(nd->if_port, 1443 if (test_and_clear_bit(nd->if_port, &sge->stopped_tx_queues) &&
1458 &sge->stopped_tx_queues) && 1444 netif_running(nd)) {
1459 netif_running(nd)) { 1445 sge->stats.cmdQ_restarted[2]++;
1460 sge->stats.cmdQ_restarted[2]++; 1446 netif_wake_queue(nd);
1461 netif_wake_queue(nd);
1462 }
1463 } 1447 }
1464 } 1448 }
1465} 1449}