Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp1715565pxy; Thu, 6 May 2021 14:08:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyo2YbOiDEL5oTFqYiBqrgoSJ73ozjIZKR65bp/sO3TCtCvugH8rP4YO9uKCtmPNsQh0c0g X-Received: by 2002:a63:9a41:: with SMTP id e1mr6313554pgo.390.1620335292386; Thu, 06 May 2021 14:08:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620335292; cv=none; d=google.com; s=arc-20160816; b=0xDFS62wUeDcbwGUbRiIcWwRZuWCmERiawtel0h6N2e5v8ayJD85JZ2kygUmb37Mu3 mNkrN9Qz/eGRptpeZeH2/z363LD/X3fUmrk2eS5UmSJaKgcwCiK2BdMPN6dbwEnj9R5d pAejPOcfxwTAtv8nwSEYkZq8+FJgjFCJeTgEKGG/VGiXeclPQK7uB+i1GaUk3/cdeHys frqRfkX6qm13y0a/3A/aTMaQge7rsdtzSaKz6xdP1ww6Agg89NJbHjS+d8T/4t+GiqYZ 9NypzWbRSawEJ2KGWX9Y3TMQ4fsRoqhSP+T0yJeg1/iCihjOAzowNAcJeblsL7xK/sFw IgiQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=EolN3S76JhU+Rm6/tBI8XvxyF60e5YRm8VX++aL8HME=; b=T3Amt8wSHVtac326HsfjpSPx7VZOU8FCrlKbmQwJvO65hsyLB1kv2FUWRukSkn/r0A 7BPelhCpstCkzboHB3b4FkhI7oO0LFHtrPXnNz0zgzPS1akmslFmGmABuFrpA9ON836z QoTkG1RO8rW/010SITMDo877y5//mXWZiQi58MoBcSGGL7dEpRHKEd/q6R+xEeOB3j0F 6Go1DLsdYtOGXAFJBvrU0rIsFSeF5FT9lF+Hdh0vUeuCxfUISrkFZ9RUw5if/K6+/sa4 avkMXlAKRTCUSV4Jwfebmu8bDYnCdH0eUKprephVx883ZdIa6mTqhZgrHnBdareiYQoQ LdNg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x9si2742004pgh.2.2021.05.06.14.07.47; Thu, 06 May 2021 14:08:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229544AbhEFVHi (ORCPT + 99 others); Thu, 6 May 2021 17:07:38 -0400 Received: from smtp01.smtpout.orange.fr ([80.12.242.123]:52099 "EHLO smtp.smtpout.orange.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230251AbhEFVHh (ORCPT ); Thu, 6 May 2021 17:07:37 -0400 Received: from localhost.localdomain ([86.243.172.93]) by mwinf5d54 with ME id 1Z6c2500B21Fzsu03Z6dmj; Thu, 06 May 2021 23:06:37 +0200 X-ME-Helo: localhost.localdomain X-ME-Auth: Y2hyaXN0b3BoZS5qYWlsbGV0QHdhbmFkb28uZnI= X-ME-Date: Thu, 06 May 2021 23:06:37 +0200 X-ME-IP: 86.243.172.93 From: Christophe JAILLET To: mchehab@kernel.org Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, Christophe JAILLET Subject: [PATCH] media: ttpci: switch from 'pci_' to 'dma_' API Date: Thu, 6 May 2021 23:06:34 +0200 Message-Id: <5fedfb7d18b8b1ae9c9fee0dd894e87f735f70f6.1620335119.git.christophe.jaillet@wanadoo.fr> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 'ace_allocate_descriptors()' and 'ace_init()' GFP_KERNEL can be used because both functions are called from the probe function and no lock is acquired. @@ @@ - 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 --- If needed, see post from Christoph Hellwig on the kernel-janitors ML: https://marc.info/?l=kernel-janitors&m=158745678307186&w=4 --- drivers/media/pci/ttpci/budget-core.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/drivers/media/pci/ttpci/budget-core.c b/drivers/media/pci/ttpci/budget-core.c index d405eea5c37f..5d5796f24469 100644 --- a/drivers/media/pci/ttpci/budget-core.c +++ b/drivers/media/pci/ttpci/budget-core.c @@ -180,7 +180,8 @@ static void vpeirq(struct tasklet_struct *t) u32 count; /* Ensure streamed PCI data is synced to CPU */ - pci_dma_sync_sg_for_cpu(budget->dev->pci, budget->pt.slist, budget->pt.nents, PCI_DMA_FROMDEVICE); + dma_sync_sg_for_cpu(&budget->dev->pci->dev, budget->pt.slist, + budget->pt.nents, DMA_FROM_DEVICE); /* nearest lower position divisible by 188 */ newdma -= newdma % 188; -- 2.30.2