aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/igbvf/netdev.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/igbvf/netdev.c')
-rw-r--r--drivers/net/igbvf/netdev.c82
1 files changed, 42 insertions, 40 deletions
diff --git a/drivers/net/igbvf/netdev.c b/drivers/net/igbvf/netdev.c
index f16e981812a9..5e2b2a8c56c6 100644
--- a/drivers/net/igbvf/netdev.c
+++ b/drivers/net/igbvf/netdev.c
@@ -165,10 +165,10 @@ static void igbvf_alloc_rx_buffers(struct igbvf_ring *rx_ring,
165 buffer_info->page_offset ^= PAGE_SIZE / 2; 165 buffer_info->page_offset ^= PAGE_SIZE / 2;
166 } 166 }
167 buffer_info->page_dma = 167 buffer_info->page_dma =
168 pci_map_page(pdev, buffer_info->page, 168 dma_map_page(&pdev->dev, buffer_info->page,
169 buffer_info->page_offset, 169 buffer_info->page_offset,
170 PAGE_SIZE / 2, 170 PAGE_SIZE / 2,
171 PCI_DMA_FROMDEVICE); 171 DMA_FROM_DEVICE);
172 } 172 }
173 173
174 if (!buffer_info->skb) { 174 if (!buffer_info->skb) {
@@ -179,9 +179,9 @@ static void igbvf_alloc_rx_buffers(struct igbvf_ring *rx_ring,
179 } 179 }
180 180
181 buffer_info->skb = skb; 181 buffer_info->skb = skb;
182 buffer_info->dma = pci_map_single(pdev, skb->data, 182 buffer_info->dma = dma_map_single(&pdev->dev, skb->data,
183 bufsz, 183 bufsz,
184 PCI_DMA_FROMDEVICE); 184 DMA_FROM_DEVICE);
185 } 185 }
186 /* Refresh the desc even if buffer_addrs didn't change because 186 /* Refresh the desc even if buffer_addrs didn't change because
187 * each write-back erases this info. */ 187 * each write-back erases this info. */
@@ -269,28 +269,28 @@ static bool igbvf_clean_rx_irq(struct igbvf_adapter *adapter,
269 prefetch(skb->data - NET_IP_ALIGN); 269 prefetch(skb->data - NET_IP_ALIGN);
270 buffer_info->skb = NULL; 270 buffer_info->skb = NULL;
271 if (!adapter->rx_ps_hdr_size) { 271 if (!adapter->rx_ps_hdr_size) {
272 pci_unmap_single(pdev, buffer_info->dma, 272 dma_unmap_single(&pdev->dev, buffer_info->dma,
273 adapter->rx_buffer_len, 273 adapter->rx_buffer_len,
274 PCI_DMA_FROMDEVICE); 274 DMA_FROM_DEVICE);
275 buffer_info->dma = 0; 275 buffer_info->dma = 0;
276 skb_put(skb, length); 276 skb_put(skb, length);
277 goto send_up; 277 goto send_up;
278 } 278 }
279 279
280 if (!skb_shinfo(skb)->nr_frags) { 280 if (!skb_shinfo(skb)->nr_frags) {
281 pci_unmap_single(pdev, buffer_info->dma, 281 dma_unmap_single(&pdev->dev, buffer_info->dma,
282 adapter->rx_ps_hdr_size, 282 adapter->rx_ps_hdr_size,
283 PCI_DMA_FROMDEVICE); 283 DMA_FROM_DEVICE);
284 skb_put(skb, hlen); 284 skb_put(skb, hlen);
285 } 285 }
286 286
287 if (length) { 287 if (length) {
288 pci_unmap_page(pdev, buffer_info->page_dma, 288 dma_unmap_page(&pdev->dev, buffer_info->page_dma,
289 PAGE_SIZE / 2, 289 PAGE_SIZE / 2,
290 PCI_DMA_FROMDEVICE); 290 DMA_FROM_DEVICE);
291 buffer_info->page_dma = 0; 291 buffer_info->page_dma = 0;
292 292
293 skb_fill_page_desc(skb, skb_shinfo(skb)->nr_frags++, 293 skb_fill_page_desc(skb, skb_shinfo(skb)->nr_frags,
294 buffer_info->page, 294 buffer_info->page,
295 buffer_info->page_offset, 295 buffer_info->page_offset,
296 length); 296 length);
@@ -370,15 +370,15 @@ static void igbvf_put_txbuf(struct igbvf_adapter *adapter,
370{ 370{
371 if (buffer_info->dma) { 371 if (buffer_info->dma) {
372 if (buffer_info->mapped_as_page) 372 if (buffer_info->mapped_as_page)
373 pci_unmap_page(adapter->pdev, 373 dma_unmap_page(&adapter->pdev->dev,
374 buffer_info->dma, 374 buffer_info->dma,
375 buffer_info->length, 375 buffer_info->length,
376 PCI_DMA_TODEVICE); 376 DMA_TO_DEVICE);
377 else 377 else
378 pci_unmap_single(adapter->pdev, 378 dma_unmap_single(&adapter->pdev->dev,
379 buffer_info->dma, 379 buffer_info->dma,
380 buffer_info->length, 380 buffer_info->length,
381 PCI_DMA_TODEVICE); 381 DMA_TO_DEVICE);
382 buffer_info->dma = 0; 382 buffer_info->dma = 0;
383 } 383 }
384 if (buffer_info->skb) { 384 if (buffer_info->skb) {
@@ -439,8 +439,8 @@ int igbvf_setup_tx_resources(struct igbvf_adapter *adapter,
439 tx_ring->size = tx_ring->count * sizeof(union e1000_adv_tx_desc); 439 tx_ring->size = tx_ring->count * sizeof(union e1000_adv_tx_desc);
440 tx_ring->size = ALIGN(tx_ring->size, 4096); 440 tx_ring->size = ALIGN(tx_ring->size, 4096);
441 441
442 tx_ring->desc = pci_alloc_consistent(pdev, tx_ring->size, 442 tx_ring->desc = dma_alloc_coherent(&pdev->dev, tx_ring->size,
443 &tx_ring->dma); 443 &tx_ring->dma, GFP_KERNEL);
444 444
445 if (!tx_ring->desc) 445 if (!tx_ring->desc)
446 goto err; 446 goto err;
@@ -481,8 +481,8 @@ int igbvf_setup_rx_resources(struct igbvf_adapter *adapter,
481 rx_ring->size = rx_ring->count * desc_len; 481 rx_ring->size = rx_ring->count * desc_len;
482 rx_ring->size = ALIGN(rx_ring->size, 4096); 482 rx_ring->size = ALIGN(rx_ring->size, 4096);
483 483
484 rx_ring->desc = pci_alloc_consistent(pdev, rx_ring->size, 484 rx_ring->desc = dma_alloc_coherent(&pdev->dev, rx_ring->size,
485 &rx_ring->dma); 485 &rx_ring->dma, GFP_KERNEL);
486 486
487 if (!rx_ring->desc) 487 if (!rx_ring->desc)
488 goto err; 488 goto err;
@@ -550,7 +550,8 @@ void igbvf_free_tx_resources(struct igbvf_ring *tx_ring)
550 vfree(tx_ring->buffer_info); 550 vfree(tx_ring->buffer_info);
551 tx_ring->buffer_info = NULL; 551 tx_ring->buffer_info = NULL;
552 552
553 pci_free_consistent(pdev, tx_ring->size, tx_ring->desc, tx_ring->dma); 553 dma_free_coherent(&pdev->dev, tx_ring->size, tx_ring->desc,
554 tx_ring->dma);
554 555
555 tx_ring->desc = NULL; 556 tx_ring->desc = NULL;
556} 557}
@@ -575,13 +576,13 @@ static void igbvf_clean_rx_ring(struct igbvf_ring *rx_ring)
575 buffer_info = &rx_ring->buffer_info[i]; 576 buffer_info = &rx_ring->buffer_info[i];
576 if (buffer_info->dma) { 577 if (buffer_info->dma) {
577 if (adapter->rx_ps_hdr_size){ 578 if (adapter->rx_ps_hdr_size){
578 pci_unmap_single(pdev, buffer_info->dma, 579 dma_unmap_single(&pdev->dev, buffer_info->dma,
579 adapter->rx_ps_hdr_size, 580 adapter->rx_ps_hdr_size,
580 PCI_DMA_FROMDEVICE); 581 DMA_FROM_DEVICE);
581 } else { 582 } else {
582 pci_unmap_single(pdev, buffer_info->dma, 583 dma_unmap_single(&pdev->dev, buffer_info->dma,
583 adapter->rx_buffer_len, 584 adapter->rx_buffer_len,
584 PCI_DMA_FROMDEVICE); 585 DMA_FROM_DEVICE);
585 } 586 }
586 buffer_info->dma = 0; 587 buffer_info->dma = 0;
587 } 588 }
@@ -593,9 +594,10 @@ static void igbvf_clean_rx_ring(struct igbvf_ring *rx_ring)
593 594
594 if (buffer_info->page) { 595 if (buffer_info->page) {
595 if (buffer_info->page_dma) 596 if (buffer_info->page_dma)
596 pci_unmap_page(pdev, buffer_info->page_dma, 597 dma_unmap_page(&pdev->dev,
598 buffer_info->page_dma,
597 PAGE_SIZE / 2, 599 PAGE_SIZE / 2,
598 PCI_DMA_FROMDEVICE); 600 DMA_FROM_DEVICE);
599 put_page(buffer_info->page); 601 put_page(buffer_info->page);
600 buffer_info->page = NULL; 602 buffer_info->page = NULL;
601 buffer_info->page_dma = 0; 603 buffer_info->page_dma = 0;
@@ -1399,7 +1401,7 @@ static void igbvf_set_multi(struct net_device *netdev)
1399{ 1401{
1400 struct igbvf_adapter *adapter = netdev_priv(netdev); 1402 struct igbvf_adapter *adapter = netdev_priv(netdev);
1401 struct e1000_hw *hw = &adapter->hw; 1403 struct e1000_hw *hw = &adapter->hw;
1402 struct dev_mc_list *mc_ptr; 1404 struct netdev_hw_addr *ha;
1403 u8 *mta_list = NULL; 1405 u8 *mta_list = NULL;
1404 int i; 1406 int i;
1405 1407
@@ -1414,8 +1416,8 @@ static void igbvf_set_multi(struct net_device *netdev)
1414 1416
1415 /* prepare a packed array of only addresses. */ 1417 /* prepare a packed array of only addresses. */
1416 i = 0; 1418 i = 0;
1417 netdev_for_each_mc_addr(mc_ptr, netdev) 1419 netdev_for_each_mc_addr(ha, netdev)
1418 memcpy(mta_list + (i++ * ETH_ALEN), mc_ptr->dmi_addr, ETH_ALEN); 1420 memcpy(mta_list + (i++ * ETH_ALEN), ha->addr, ETH_ALEN);
1419 1421
1420 hw->mac.ops.update_mc_addr_list(hw, mta_list, i, 0, 0); 1422 hw->mac.ops.update_mc_addr_list(hw, mta_list, i, 0, 0);
1421 kfree(mta_list); 1423 kfree(mta_list);
@@ -2105,9 +2107,9 @@ static inline int igbvf_tx_map_adv(struct igbvf_adapter *adapter,
2105 buffer_info->time_stamp = jiffies; 2107 buffer_info->time_stamp = jiffies;
2106 buffer_info->next_to_watch = i; 2108 buffer_info->next_to_watch = i;
2107 buffer_info->mapped_as_page = false; 2109 buffer_info->mapped_as_page = false;
2108 buffer_info->dma = pci_map_single(pdev, skb->data, len, 2110 buffer_info->dma = dma_map_single(&pdev->dev, skb->data, len,
2109 PCI_DMA_TODEVICE); 2111 DMA_TO_DEVICE);
2110 if (pci_dma_mapping_error(pdev, buffer_info->dma)) 2112 if (dma_mapping_error(&pdev->dev, buffer_info->dma))
2111 goto dma_error; 2113 goto dma_error;
2112 2114
2113 2115
@@ -2128,12 +2130,12 @@ static inline int igbvf_tx_map_adv(struct igbvf_adapter *adapter,
2128 buffer_info->time_stamp = jiffies; 2130 buffer_info->time_stamp = jiffies;
2129 buffer_info->next_to_watch = i; 2131 buffer_info->next_to_watch = i;
2130 buffer_info->mapped_as_page = true; 2132 buffer_info->mapped_as_page = true;
2131 buffer_info->dma = pci_map_page(pdev, 2133 buffer_info->dma = dma_map_page(&pdev->dev,
2132 frag->page, 2134 frag->page,
2133 frag->page_offset, 2135 frag->page_offset,
2134 len, 2136 len,
2135 PCI_DMA_TODEVICE); 2137 DMA_TO_DEVICE);
2136 if (pci_dma_mapping_error(pdev, buffer_info->dma)) 2138 if (dma_mapping_error(&pdev->dev, buffer_info->dma))
2137 goto dma_error; 2139 goto dma_error;
2138 } 2140 }
2139 2141
@@ -2645,16 +2647,16 @@ static int __devinit igbvf_probe(struct pci_dev *pdev,
2645 return err; 2647 return err;
2646 2648
2647 pci_using_dac = 0; 2649 pci_using_dac = 0;
2648 err = pci_set_dma_mask(pdev, DMA_BIT_MASK(64)); 2650 err = dma_set_mask(&pdev->dev, DMA_BIT_MASK(64));
2649 if (!err) { 2651 if (!err) {
2650 err = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(64)); 2652 err = dma_set_coherent_mask(&pdev->dev, DMA_BIT_MASK(64));
2651 if (!err) 2653 if (!err)
2652 pci_using_dac = 1; 2654 pci_using_dac = 1;
2653 } else { 2655 } else {
2654 err = pci_set_dma_mask(pdev, DMA_BIT_MASK(32)); 2656 err = dma_set_mask(&pdev->dev, DMA_BIT_MASK(32));
2655 if (err) { 2657 if (err) {
2656 err = pci_set_consistent_dma_mask(pdev, 2658 err = dma_set_coherent_mask(&pdev->dev,
2657 DMA_BIT_MASK(32)); 2659 DMA_BIT_MASK(32));
2658 if (err) { 2660 if (err) {
2659 dev_err(&pdev->dev, "No usable DMA " 2661 dev_err(&pdev->dev, "No usable DMA "
2660 "configuration, aborting\n"); 2662 "configuration, aborting\n");