tlan: switch from 'pci_' to 'dma_' API

The wrappers in include/linux/pci-dma-compat.h should go away.

The patch has been generated with the coccinelle script below and has been
hand modified to replace GFP_ with a correct flag.
It has been compile tested.

When memory is allocated in 'tlan_init()' GFP_KERNEL can be used because
it is only called from a probe function or a module_init function and no
lock is taken in the between.
The call chain is:
  tlan_probe                        (module_init function)
    --> tlan_eisa_probe
or
  tlan_init_one                     (probe function)

then in both cases:
    --> tlan_probe1
      --> tlan_init

@@
@@
-    PCI_DMA_BIDIRECTIONAL
+    DMA_BIDIRECTIONAL

@@
@@
-    PCI_DMA_TODEVICE
+    DMA_TO_DEVICE

@@
@@
-    PCI_DMA_FROMDEVICE
+    DMA_FROM_DEVICE

@@
@@
-    PCI_DMA_NONE
+    DMA_NONE

@@
expression e1, e2, e3;
@@
-    pci_alloc_consistent(e1, e2, e3)
+    dma_alloc_coherent(&e1->dev, e2, e3, GFP_)

@@
expression e1, e2, e3;
@@
-    pci_zalloc_consistent(e1, e2, e3)
+    dma_alloc_coherent(&e1->dev, e2, e3, GFP_)

@@
expression e1, e2, e3, e4;
@@
-    pci_free_consistent(e1, e2, e3, e4)
+    dma_free_coherent(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_map_single(e1, e2, e3, e4)
+    dma_map_single(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_unmap_single(e1, e2, e3, e4)
+    dma_unmap_single(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4, e5;
@@
-    pci_map_page(e1, e2, e3, e4, e5)
+    dma_map_page(&e1->dev, e2, e3, e4, e5)

@@
expression e1, e2, e3, e4;
@@
-    pci_unmap_page(e1, e2, e3, e4)
+    dma_unmap_page(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_map_sg(e1, e2, e3, e4)
+    dma_map_sg(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_unmap_sg(e1, e2, e3, e4)
+    dma_unmap_sg(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_dma_sync_single_for_cpu(e1, e2, e3, e4)
+    dma_sync_single_for_cpu(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_dma_sync_single_for_device(e1, e2, e3, e4)
+    dma_sync_single_for_device(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_dma_sync_sg_for_cpu(e1, e2, e3, e4)
+    dma_sync_sg_for_cpu(&e1->dev, e2, e3, e4)

@@
expression e1, e2, e3, e4;
@@
-    pci_dma_sync_sg_for_device(e1, e2, e3, e4)
+    dma_sync_sg_for_device(&e1->dev, e2, e3, e4)

@@
expression e1, e2;
@@
-    pci_dma_mapping_error(e1, e2)
+    dma_mapping_error(&e1->dev, e2)

@@
expression e1, e2;
@@
-    pci_set_dma_mask(e1, e2)
+    dma_set_mask(&e1->dev, e2)

@@
expression e1, e2;
@@
-    pci_set_consistent_dma_mask(e1, e2)
+    dma_set_coherent_mask(&e1->dev, e2)

Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Christophe JAILLET 2020-09-12 12:25:18 +02:00 committed by David S. Miller
parent e5e252ba21
commit 9720bae378
1 changed files with 28 additions and 33 deletions
drivers/net/ethernet/ti

View File

@ -305,9 +305,8 @@ static void tlan_remove_one(struct pci_dev *pdev)
unregister_netdev(dev); unregister_netdev(dev);
if (priv->dma_storage) { if (priv->dma_storage) {
pci_free_consistent(priv->pci_dev, dma_free_coherent(&priv->pci_dev->dev, priv->dma_size,
priv->dma_size, priv->dma_storage, priv->dma_storage, priv->dma_storage_dma);
priv->dma_storage_dma);
} }
#ifdef CONFIG_PCI #ifdef CONFIG_PCI
@ -482,7 +481,7 @@ static int tlan_probe1(struct pci_dev *pdev, long ioaddr, int irq, int rev,
priv->adapter = &board_info[ent->driver_data]; priv->adapter = &board_info[ent->driver_data];
rc = pci_set_dma_mask(pdev, DMA_BIT_MASK(32)); rc = dma_set_mask(&pdev->dev, DMA_BIT_MASK(32));
if (rc) { if (rc) {
pr_err("No suitable PCI mapping available\n"); pr_err("No suitable PCI mapping available\n");
goto err_out_free_dev; goto err_out_free_dev;
@ -584,8 +583,8 @@ static int tlan_probe1(struct pci_dev *pdev, long ioaddr, int irq, int rev,
return 0; return 0;
err_out_uninit: err_out_uninit:
pci_free_consistent(priv->pci_dev, priv->dma_size, priv->dma_storage, dma_free_coherent(&priv->pci_dev->dev, priv->dma_size,
priv->dma_storage_dma); priv->dma_storage, priv->dma_storage_dma);
err_out_free_dev: err_out_free_dev:
free_netdev(dev); free_netdev(dev);
err_out_regions: err_out_regions:
@ -609,9 +608,9 @@ static void tlan_eisa_cleanup(void)
dev = tlan_eisa_devices; dev = tlan_eisa_devices;
priv = netdev_priv(dev); priv = netdev_priv(dev);
if (priv->dma_storage) { if (priv->dma_storage) {
pci_free_consistent(priv->pci_dev, priv->dma_size, dma_free_coherent(&priv->pci_dev->dev, priv->dma_size,
priv->dma_storage, priv->dma_storage,
priv->dma_storage_dma); priv->dma_storage_dma);
} }
release_region(dev->base_addr, 0x10); release_region(dev->base_addr, 0x10);
unregister_netdev(dev); unregister_netdev(dev);
@ -826,9 +825,8 @@ static int tlan_init(struct net_device *dev)
dma_size = (TLAN_NUM_RX_LISTS + TLAN_NUM_TX_LISTS) dma_size = (TLAN_NUM_RX_LISTS + TLAN_NUM_TX_LISTS)
* (sizeof(struct tlan_list)); * (sizeof(struct tlan_list));
priv->dma_storage = pci_alloc_consistent(priv->pci_dev, priv->dma_storage = dma_alloc_coherent(&priv->pci_dev->dev, dma_size,
dma_size, &priv->dma_storage_dma, GFP_KERNEL);
&priv->dma_storage_dma);
priv->dma_size = dma_size; priv->dma_size = dma_size;
if (priv->dma_storage == NULL) { if (priv->dma_storage == NULL) {
@ -1069,9 +1067,9 @@ static netdev_tx_t tlan_start_tx(struct sk_buff *skb, struct net_device *dev)
tail_list->forward = 0; tail_list->forward = 0;
tail_list->buffer[0].address = pci_map_single(priv->pci_dev, tail_list->buffer[0].address = dma_map_single(&priv->pci_dev->dev,
skb->data, txlen, skb->data, txlen,
PCI_DMA_TODEVICE); DMA_TO_DEVICE);
tlan_store_skb(tail_list, skb); tlan_store_skb(tail_list, skb);
tail_list->frame_size = (u16) txlen; tail_list->frame_size = (u16) txlen;
@ -1365,10 +1363,10 @@ static u32 tlan_handle_tx_eof(struct net_device *dev, u16 host_int)
struct sk_buff *skb = tlan_get_skb(head_list); struct sk_buff *skb = tlan_get_skb(head_list);
ack++; ack++;
pci_unmap_single(priv->pci_dev, head_list->buffer[0].address, dma_unmap_single(&priv->pci_dev->dev,
max(skb->len, head_list->buffer[0].address,
(unsigned int)TLAN_MIN_FRAME_SIZE), max(skb->len, (unsigned int)TLAN_MIN_FRAME_SIZE),
PCI_DMA_TODEVICE); DMA_TO_DEVICE);
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);
head_list->buffer[8].address = 0; head_list->buffer[8].address = 0;
head_list->buffer[9].address = 0; head_list->buffer[9].address = 0;
@ -1511,8 +1509,8 @@ static u32 tlan_handle_rx_eof(struct net_device *dev, u16 host_int)
goto drop_and_reuse; goto drop_and_reuse;
skb = tlan_get_skb(head_list); skb = tlan_get_skb(head_list);
pci_unmap_single(priv->pci_dev, frame_dma, dma_unmap_single(&priv->pci_dev->dev, frame_dma,
TLAN_MAX_FRAME_SIZE, PCI_DMA_FROMDEVICE); TLAN_MAX_FRAME_SIZE, DMA_FROM_DEVICE);
skb_put(skb, frame_size); skb_put(skb, frame_size);
dev->stats.rx_bytes += frame_size; dev->stats.rx_bytes += frame_size;
@ -1521,8 +1519,8 @@ static u32 tlan_handle_rx_eof(struct net_device *dev, u16 host_int)
netif_rx(skb); netif_rx(skb);
head_list->buffer[0].address = head_list->buffer[0].address =
pci_map_single(priv->pci_dev, new_skb->data, dma_map_single(&priv->pci_dev->dev, new_skb->data,
TLAN_MAX_FRAME_SIZE, PCI_DMA_FROMDEVICE); TLAN_MAX_FRAME_SIZE, DMA_FROM_DEVICE);
tlan_store_skb(head_list, new_skb); tlan_store_skb(head_list, new_skb);
drop_and_reuse: drop_and_reuse:
@ -1923,10 +1921,10 @@ static void tlan_reset_lists(struct net_device *dev)
if (!skb) if (!skb)
break; break;
list->buffer[0].address = pci_map_single(priv->pci_dev, list->buffer[0].address = dma_map_single(&priv->pci_dev->dev,
skb->data, skb->data,
TLAN_MAX_FRAME_SIZE, TLAN_MAX_FRAME_SIZE,
PCI_DMA_FROMDEVICE); DMA_FROM_DEVICE);
tlan_store_skb(list, skb); tlan_store_skb(list, skb);
list->buffer[1].count = 0; list->buffer[1].count = 0;
list->buffer[1].address = 0; list->buffer[1].address = 0;
@ -1954,12 +1952,10 @@ static void tlan_free_lists(struct net_device *dev)
list = priv->tx_list + i; list = priv->tx_list + i;
skb = tlan_get_skb(list); skb = tlan_get_skb(list);
if (skb) { if (skb) {
pci_unmap_single( dma_unmap_single(&priv->pci_dev->dev,
priv->pci_dev, list->buffer[0].address,
list->buffer[0].address, max(skb->len, (unsigned int)TLAN_MIN_FRAME_SIZE),
max(skb->len, DMA_TO_DEVICE);
(unsigned int)TLAN_MIN_FRAME_SIZE),
PCI_DMA_TODEVICE);
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);
list->buffer[8].address = 0; list->buffer[8].address = 0;
list->buffer[9].address = 0; list->buffer[9].address = 0;
@ -1970,10 +1966,9 @@ static void tlan_free_lists(struct net_device *dev)
list = priv->rx_list + i; list = priv->rx_list + i;
skb = tlan_get_skb(list); skb = tlan_get_skb(list);
if (skb) { if (skb) {
pci_unmap_single(priv->pci_dev, dma_unmap_single(&priv->pci_dev->dev,
list->buffer[0].address, list->buffer[0].address,
TLAN_MAX_FRAME_SIZE, TLAN_MAX_FRAME_SIZE, DMA_FROM_DEVICE);
PCI_DMA_FROMDEVICE);
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);
list->buffer[8].address = 0; list->buffer[8].address = 0;
list->buffer[9].address = 0; list->buffer[9].address = 0;