|
|
Log in / Subscribe / Register

dmaengine: Add new API to combine configuration and descriptor preparation

From:  Frank.Li-AT-oss.nxp.com
To:  Vinod Koul <vkoul-AT-kernel.org>, Manivannan Sadhasivam <mani-AT-kernel.org>, Krzysztof WilczyƄski <kwilczynski-AT-kernel.org>, Kishon Vijay Abraham I <kishon-AT-kernel.org>, Bjorn Helgaas <bhelgaas-AT-google.com>, Christoph Hellwig <hch-AT-lst.de>, Sagi Grimberg <sagi-AT-grimberg.me>, Chaitanya Kulkarni <kch-AT-nvidia.com>, Herbert Xu <herbert-AT-gondor.apana.org.au>, "David S. Miller" <davem-AT-davemloft.net>, Nicolas Ferre <nicolas.ferre-AT-microchip.com>, Alexandre Belloni <alexandre.belloni-AT-bootlin.com>, Claudiu Beznea <claudiu.beznea-AT-tuxon.dev>, Koichiro Den <den-AT-valinux.co.jp>, Niklas Cassel <cassel-AT-kernel.org>
Subject:  [PATCH v6 0/9] dmaengine: Add new API to combine configuration and descriptor preparation
Date:  Wed, 20 May 2026 18:00:41 -0400
Message-ID:  <20260520-dma_prep_config-v6-0-06e49b7acb38@nxp.com>
Cc:  dmaengine-AT-vger.kernel.org, linux-kernel-AT-vger.kernel.org, linux-pci-AT-vger.kernel.org, linux-nvme-AT-lists.infradead.org, mhi-AT-lists.linux.dev, linux-arm-msm-AT-vger.kernel.org, linux-crypto-AT-vger.kernel.org, linux-arm-kernel-AT-lists.infradead.org, imx-AT-lists.linux.dev, Frank Li <Frank.Li-AT-nxp.com>, Damien Le Moal <dlemoal-AT-kernel.org>
Archive-link:  Article

Previously, configuration and preparation required two separate calls. This
works well when configuration is done only once during initialization.

However, in cases where the burst length or source/destination address must
be adjusted for each transfer, calling two functions is verbose.

	if (dmaengine_slave_config(chan, &sconf)) {
		dev_err(dev, "DMA slave config fail\n");
		return -EIO;
	}

	tx = dmaengine_prep_slave_single(chan, dma_local, len, dir, flags);

After new API added

	tx = dmaengine_prep_config_single(chan, dma_local, len, dir, flags, &sconf);

Additional, prevous two calls requires additional locking to ensure both
steps complete atomically.

    mutex_lock()
    dmaengine_slave_config()
    dmaengine_prep_slave_single()
    mutex_unlock()

after new API added, mutex lock can be moved. See patch
     nvmet: pci-epf: Use dmaengine_prep_config_single_safe() API

Signed-off-by: Frank Li <Frank.Li@nxp.com>
---
Changes in v6:
- Fix sashaki AI report problem, detail see each patch's change log
- Link to v5: https://lore.kernel.org/r/20260512-dma_prep_config-v5-0-2...

Changes in v5:
- collect Mani's reviewed-by tags
- use kernel doc for new APIs.
- Link to v4: https://lore.kernel.org/r/20260506-dma_prep_config-v4-0-8...

Changes in v4:
- remove void* context in config_prep() callback
- use spin lock to protect config() and prep().
- Link to v3: https://lore.kernel.org/r/20260105-dma_prep_config-v3-0-a...

Changes in v3:
- collect review tags
- create safe version in framework
- Link to v2: https://lore.kernel.org/r/20251218-dma_prep_config-v2-0-c...

Changes in v2:
- Use name dmaengine_prep_config_single() and dmaengine_prep_config_sg()
- Add _safe version to avoid confuse, which needn't additional mutex.
- Update document/
- Update commit message. add () for function name. Use upcase for subject.
- Add more explain for remove lock.
- Link to v1: https://lore.kernel.org/r/20251208-dma_prep_config-v1-0-5...

---
Frank Li (9):
      dmaengine: Add API to combine configuration and preparation (sg and single)
      dmaengine: Add safe API to combine configuration and preparation
      PCI: endpoint: pci-epf-test: Use dmaenigne_prep_config_single() to simplify code
      dmaengine: dw-edma: Use new .device_prep_config_sg() callback
      dmaengine: dw-edma: Pass dma_slave_config to dw_edma_device_transfer()
      nvmet: pci-epf: Remove unnecessary dmaengine_terminate_sync() on each DMA transfer
      nvmet: pci-epf: Use dmaengine_prep_config_single_safe() API
      PCI: epf-mhi: Use dmaengine_prep_config_single() to simplify code
      crypto: atmel: Use dmaengine_prep_config_sg() API

 Documentation/driver-api/dmaengine/client.rst |   9 ++
 drivers/crypto/atmel-aes.c                    |  10 +-
 drivers/dma/dmaengine.c                       |   2 +
 drivers/dma/dw-edma/dw-edma-core.c            |  41 +++++--
 drivers/nvme/target/pci-epf.c                 |  24 +----
 drivers/pci/endpoint/functions/pci-epf-mhi.c  |  52 +++------
 drivers/pci/endpoint/functions/pci-epf-test.c |   8 +-
 include/linux/dmaengine.h                     | 149 ++++++++++++++++++++++++--
 8 files changed, 208 insertions(+), 87 deletions(-)
---
base-commit: 254f49634ee16a731174d2ae34bc50bd5f45e731
change-id: 20251204-dma_prep_config-654170d245a2

Best regards,
--  
Frank Li <Frank.Li@nxp.com>




Copyright © 2026, Eklektix, Inc.
Comments and public postings are copyrighted by their creators.
Linux is a registered trademark of Linus Torvalds