dmaengine.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 00/59] dma: Convert to platform remove callback returning void
@ 2023-09-19 13:31 Uwe Kleine-König
  2023-09-19 13:31 ` [PATCH 01/59] dma: altera-msgdma: " Uwe Kleine-König
                   ` (60 more replies)
  0 siblings, 61 replies; 82+ messages in thread
From: Uwe Kleine-König @ 2023-09-19 13:31 UTC (permalink / raw)
  To: Vinod Koul
  Cc: Olivier Dautricourt, Stefan Roese, dmaengine, kernel,
	Hector Martin, Sven Peter, Alyssa Rosenzweig, asahi,
	linux-arm-kernel, Ludovic Desroches, Tudor Ambarus,
	Florian Fainelli, Broadcom internal kernel review list, Ray Jui,
	Scott Branden, linux-rpi-kernel, Rob Herring, Lars-Peter Clausen,
	Paul Cercueil, linux-mips, Eugeniy Paltsev, Viresh Kumar,
	Andy Shevchenko, Li Yang, Zhang Wei, linuxppc-dev, Shawn Guo,
	Sascha Hauer, Fabio Estevam, NXP Linux Team, Sean Wang,
	Matthias Brugger, AngeloGioacchino Del Regno, linux-mediatek,
	Andreas Färber, Manivannan Sadhasivam, linux-actions,
	ye xingchen, Daniel Mack, Haojian Zhuang, Robert Jarzmik,
	Andy Gross, Bjorn Andersson, Konrad Dybcio, linux-arm-msm,
	Sinan Kaya, Green Wan, Kees Cook, Gustavo A. R. Silva, Biju Das,
	Geert Uytterhoeven, Lad Prabhakar, Pavel Machek, Hien Huynh,
	Yangtao Li, Peter Ujfalusi, Jernej Skrabec, Orson Zhai,
	Baolin Wang, Chunyan Zhang, Patrice Chotard, Chen-Yu Tsai,
	Samuel Holland, linux-sunxi, Laxman Dewangan, Jon Hunter,
	Thierry Reding, linux-tegra, Lizhi Hou, Brian Xu,
	Raj Kumar Rampelli, Michal Simek, Radhey Shyam Pandey,
	Peter Korsgaard, Liu Shixin, Laurent Pinchart, Harini Katakam,
	Swati Agarwal

Hello,

this series convert nearly all platform drivers below drivers/dma to use
.remove_new(). The motivation is to get rid of an integer return code
that is (mostly) ignored by the platform driver core and error prone on
the driver side.

See commit 5c5a7680e67b ("platform: Provide a remove callback that
returns no value") for an extended explanation and the eventual goal.

There are 4 drivers I didn't convert in this series:

	drivers/dma/milbeaut-hdmac.c
	drivers/dma/milbeaut-xdmac.c
	drivers/dma/uniphier-mdmac.c
	drivers/dma/uniphier-xdmac.c

These all might return early in .remove() if dmaengine_terminate_sync()
fails. I only looked deeper into the first one, and this shows exactly
the error that is easy to make with .remove() returning an int: When
returning early from .remove(), some cleanup (here:
dma_async_device_unregister()) is skipped. So the dma device stays
known, but the device is still unregistered and the devm allocated stuff
(here e.g. *mdev) is freed. So it can probably easily happen, that
something tries to use the dma device and this will likely result in an
oops.

I don't know enough about the dma framework to address this properly,
maybe someone else knows what to do?

There are no interdependencies between the patches. As there are still
quite a few drivers to convert, I'm happy about every patch that makes
it in. So even if there is a merge conflict with one patch until you
apply or I picked a wrong subject prefix, please apply the remainder of
this series anyhow.

Best regards
Uwe


Uwe Kleine-König (59):
  dma: altera-msgdma: Convert to platform remove callback returning void
  dma: apple-admac: Convert to platform remove callback returning void
  dma: at_hdmac: Convert to platform remove callback returning void
  dma: at_xdmac: Convert to platform remove callback returning void
  dma: bcm-sba-raid: Convert to platform remove callback returning void
  dma: bcm2835-dma: Convert to platform remove callback returning void
  dma: bestcomm: bestcomm: Convert to platform remove callback returning
    void
  dma: dma-axi-dmac: Convert to platform remove callback returning void
  dma: dma-jz4780: Convert to platform remove callback returning void
  dma: dw-axi-dmac: dw-axi-dmac-platform: Convert to platform remove
    callback returning void
  dma: dw: platform: Convert to platform remove callback returning void
  dma: fsl-edma-main: Convert to platform remove callback returning void
  dma: fsl-qdma: Convert to platform remove callback returning void
  dma: fsl_raid: Convert to platform remove callback returning void
  dma: fsldma: Convert to platform remove callback returning void
  dma: idma64: Convert to platform remove callback returning void
  dma: img-mdc-dma: Convert to platform remove callback returning void
  dma: imx-dma: Convert to platform remove callback returning void
  dma: imx-sdma: Convert to platform remove callback returning void
  dma: k3dma: Convert to platform remove callback returning void
  dma: mcf-edma-main: Convert to platform remove callback returning void
  dma: mediatek: mtk-cqdma: Convert to platform remove callback
    returning void
  dma: mediatek: mtk-hsdma: Convert to platform remove callback
    returning void
  dma: mediatek: mtk-uart-apdma: Convert to platform remove callback
    returning void
  dma: mmp_pdma: Convert to platform remove callback returning void
  dma: mmp_tdma: Convert to platform remove callback returning void
  dma: moxart-dma: Convert to platform remove callback returning void
  dma: mpc512x_dma: Convert to platform remove callback returning void
  dma: mv_xor_v2: Convert to platform remove callback returning void
  dma: nbpfaxi: Convert to platform remove callback returning void
  dma: owl-dma: Convert to platform remove callback returning void
  dma: ppc4xx: adma: Convert to platform remove callback returning void
  dma: pxa_dma: Convert to platform remove callback returning void
  dma: qcom: bam_dma: Convert to platform remove callback returning void
  dma: qcom: hidma: Convert to platform remove callback returning void
  dma: qcom: qcom_adm: Convert to platform remove callback returning
    void
  dma: sa11x0-dma: Convert to platform remove callback returning void
  dma: sf-pdma: sf-pdma: Convert to platform remove callback returning
    void
  dma: sh: rcar-dmac: Convert to platform remove callback returning void
  dma: sh: rz-dmac: Convert to platform remove callback returning void
  dma: sh: shdmac: Convert to platform remove callback returning void
  dma: sh: usb-dmac: Convert to platform remove callback returning void
  dma: sprd-dma: Convert to platform remove callback returning void
  dma: st_fdma: Convert to platform remove callback returning void
  dma: sun4i-dma: Convert to platform remove callback returning void
  dma: sun6i-dma: Convert to platform remove callback returning void
  dma: tegra186-gpc-dma: Convert to platform remove callback returning
    void
  dma: tegra20-apb-dma: Convert to platform remove callback returning
    void
  dma: tegra210-adma: Convert to platform remove callback returning void
  dma: ti: cppi41: Convert to platform remove callback returning void
  dma: ti: edma: Convert to platform remove callback returning void
  dma: ti: omap-dma: Convert to platform remove callback returning void
  dma: timb_dma: Convert to platform remove callback returning void
  dma: txx9dmac: Convert to platform remove callback returning void
  dma: xgene-dma: Convert to platform remove callback returning void
  dma: xilinx: xdma: Convert to platform remove callback returning void
  dma: xilinx: xilinx_dma: Convert to platform remove callback returning
    void
  dma: xilinx: xilinx_dpdma: Convert to platform remove callback
    returning void
  dma: xilinx: zynqmp_dma: Convert to platform remove callback returning
    void

 drivers/dma/altera-msgdma.c                    |  6 ++----
 drivers/dma/apple-admac.c                      |  6 ++----
 drivers/dma/at_hdmac.c                         |  6 ++----
 drivers/dma/at_xdmac.c                         |  6 ++----
 drivers/dma/bcm-sba-raid.c                     |  6 ++----
 drivers/dma/bcm2835-dma.c                      |  6 ++----
 drivers/dma/bestcomm/bestcomm.c                |  6 ++----
 drivers/dma/dma-axi-dmac.c                     |  6 ++----
 drivers/dma/dma-jz4780.c                       |  6 ++----
 drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c |  6 ++----
 drivers/dma/dw/platform.c                      |  6 ++----
 drivers/dma/fsl-edma-main.c                    |  6 ++----
 drivers/dma/fsl-qdma.c                         |  5 ++---
 drivers/dma/fsl_raid.c                         |  6 ++----
 drivers/dma/fsldma.c                           |  6 ++----
 drivers/dma/idma64.c                           |  6 ++----
 drivers/dma/img-mdc-dma.c                      |  6 ++----
 drivers/dma/imx-dma.c                          |  6 ++----
 drivers/dma/imx-sdma.c                         |  5 ++---
 drivers/dma/k3dma.c                            |  5 ++---
 drivers/dma/mcf-edma-main.c                    |  6 ++----
 drivers/dma/mediatek/mtk-cqdma.c               |  6 ++----
 drivers/dma/mediatek/mtk-hsdma.c               |  6 ++----
 drivers/dma/mediatek/mtk-uart-apdma.c          |  6 ++----
 drivers/dma/mmp_pdma.c                         |  5 ++---
 drivers/dma/mmp_tdma.c                         |  6 ++----
 drivers/dma/moxart-dma.c                       |  6 ++----
 drivers/dma/mpc512x_dma.c                      |  6 ++----
 drivers/dma/mv_xor_v2.c                        |  6 ++----
 drivers/dma/nbpfaxi.c                          |  6 ++----
 drivers/dma/owl-dma.c                          |  6 ++----
 drivers/dma/ppc4xx/adma.c                      |  5 ++---
 drivers/dma/pxa_dma.c                          |  5 ++---
 drivers/dma/qcom/bam_dma.c                     |  6 ++----
 drivers/dma/qcom/hidma.c                       |  6 ++----
 drivers/dma/qcom/qcom_adm.c                    |  6 ++----
 drivers/dma/sa11x0-dma.c                       |  6 ++----
 drivers/dma/sf-pdma/sf-pdma.c                  |  6 ++----
 drivers/dma/sh/rcar-dmac.c                     |  6 ++----
 drivers/dma/sh/rz-dmac.c                       |  6 ++----
 drivers/dma/sh/shdmac.c                        |  6 ++----
 drivers/dma/sh/usb-dmac.c                      |  6 ++----
 drivers/dma/sprd-dma.c                         |  5 ++---
 drivers/dma/st_fdma.c                          |  6 ++----
 drivers/dma/sun4i-dma.c                        |  6 ++----
 drivers/dma/sun6i-dma.c                        |  6 ++----
 drivers/dma/tegra186-gpc-dma.c                 |  6 ++----
 drivers/dma/tegra20-apb-dma.c                  |  6 ++----
 drivers/dma/tegra210-adma.c                    |  6 ++----
 drivers/dma/ti/cppi41.c                        |  5 ++---
 drivers/dma/ti/edma.c                          |  6 ++----
 drivers/dma/ti/omap-dma.c                      |  6 ++----
 drivers/dma/timb_dma.c                         |  5 ++---
 drivers/dma/txx9dmac.c                         | 10 ++++------
 drivers/dma/xgene-dma.c                        |  6 ++----
 drivers/dma/xilinx/xdma.c                      |  6 ++----
 drivers/dma/xilinx/xilinx_dma.c                |  6 ++----
 drivers/dma/xilinx/xilinx_dpdma.c              |  6 ++----
 drivers/dma/xilinx/zynqmp_dma.c                |  6 ++----
 59 files changed, 120 insertions(+), 229 deletions(-)


base-commit: 29e400e3ea486bf942b214769fc9778098114113
-- 
2.40.1


^ permalink raw reply	[flat|nested] 82+ messages in thread

end of thread, other threads:[~2023-09-28  7:49 UTC | newest]

Thread overview: 82+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-09-19 13:31 [PATCH 00/59] dma: Convert to platform remove callback returning void Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 01/59] dma: altera-msgdma: " Uwe Kleine-König
2023-09-20 18:13   ` Olivier Dautricourt
2023-09-19 13:31 ` [PATCH 02/59] dma: apple-admac: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 03/59] dma: at_hdmac: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 04/59] dma: at_xdmac: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 05/59] dma: bcm-sba-raid: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 06/59] dma: bcm2835-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 07/59] dma: bestcomm: bestcomm: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 08/59] dma: dma-axi-dmac: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 09/59] dma: dma-jz4780: " Uwe Kleine-König
2023-09-19 13:39   ` Paul Cercueil
2023-09-19 14:48     ` Uwe Kleine-König
2023-09-20 15:44   ` Philippe Mathieu-Daudé
2023-09-19 13:31 ` [PATCH 10/59] dma: dw-axi-dmac: dw-axi-dmac-platform: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 11/59] dma: dw: platform: " Uwe Kleine-König
2023-09-28  7:09   ` Viresh Kumar
2023-09-19 13:31 ` [PATCH 12/59] dma: fsl-edma-main: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 13/59] dma: fsl-qdma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 14/59] dma: fsl_raid: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 15/59] dma: fsldma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 16/59] dma: idma64: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 17/59] dma: img-mdc-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 18/59] dma: imx-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 19/59] dma: imx-sdma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 20/59] dma: k3dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 21/59] dma: mcf-edma-main: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 22/59] dma: mediatek: mtk-cqdma: " Uwe Kleine-König
2023-09-20 10:28   ` AngeloGioacchino Del Regno
2023-09-19 13:31 ` [PATCH 23/59] dma: mediatek: mtk-hsdma: " Uwe Kleine-König
2023-09-20 10:28   ` AngeloGioacchino Del Regno
2023-09-19 13:31 ` [PATCH 24/59] dma: mediatek: mtk-uart-apdma: " Uwe Kleine-König
2023-09-20 10:28   ` AngeloGioacchino Del Regno
2023-09-19 13:31 ` [PATCH 25/59] dma: mmp_pdma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 26/59] dma: mmp_tdma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 27/59] dma: moxart-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 28/59] dma: mpc512x_dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 29/59] dma: mv_xor_v2: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 30/59] dma: nbpfaxi: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 31/59] dma: owl-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 32/59] dma: ppc4xx: adma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 33/59] dma: pxa_dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 34/59] dma: qcom: bam_dma: " Uwe Kleine-König
2023-09-19 21:02   ` Konrad Dybcio
2023-09-19 13:31 ` [PATCH 35/59] dma: qcom: hidma: " Uwe Kleine-König
2023-09-19 21:02   ` Konrad Dybcio
2023-09-19 13:31 ` [PATCH 36/59] dma: qcom: qcom_adm: " Uwe Kleine-König
2023-09-19 21:02   ` Konrad Dybcio
2023-09-19 13:31 ` [PATCH 37/59] dma: sa11x0-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 38/59] dma: sf-pdma: sf-pdma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 39/59] dma: sh: rcar-dmac: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 40/59] dma: sh: rz-dmac: " Uwe Kleine-König
2023-09-19 13:35   ` Geert Uytterhoeven
2023-09-19 13:31 ` [PATCH 41/59] dma: sh: shdmac: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 42/59] dma: sh: usb-dmac: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 43/59] dma: sprd-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 44/59] dma: st_fdma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 45/59] dma: sun4i-dma: " Uwe Kleine-König
2023-09-19 17:21   ` Jernej Škrabec
2023-09-19 13:31 ` [PATCH 46/59] dma: sun6i-dma: " Uwe Kleine-König
2023-09-19 17:22   ` Jernej Škrabec
2023-09-19 13:31 ` [PATCH 47/59] dma: tegra186-gpc-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 48/59] dma: tegra20-apb-dma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 49/59] dma: tegra210-adma: " Uwe Kleine-König
2023-09-19 13:31 ` [PATCH 50/59] dma: ti: cppi41: " Uwe Kleine-König
2023-09-20 17:55   ` Péter Ujfalusi
2023-09-19 13:31 ` [PATCH 51/59] dma: ti: edma: " Uwe Kleine-König
2023-09-20 17:54   ` Péter Ujfalusi
2023-09-19 13:32 ` [PATCH 52/59] dma: ti: omap-dma: " Uwe Kleine-König
2023-09-20 17:54   ` Péter Ujfalusi
2023-09-19 13:32 ` [PATCH 53/59] dma: timb_dma: " Uwe Kleine-König
2023-09-19 13:32 ` [PATCH 54/59] dma: txx9dmac: " Uwe Kleine-König
2023-09-19 13:32 ` [PATCH 55/59] dma: xgene-dma: " Uwe Kleine-König
2023-09-19 13:32 ` [PATCH 56/59] dma: xilinx: xdma: " Uwe Kleine-König
2023-09-19 13:32 ` [PATCH 57/59] dma: xilinx: xilinx_dma: " Uwe Kleine-König
2023-09-22 11:36   ` Pandey, Radhey Shyam
2023-09-28  7:27     ` Uwe Kleine-König
2023-09-28  7:47       ` Vinod Koul
2023-09-19 13:32 ` [PATCH 58/59] dma: xilinx: xilinx_dpdma: " Uwe Kleine-König
2023-09-19 13:32 ` [PATCH 59/59] dma: xilinx: zynqmp_dma: " Uwe Kleine-König
2023-09-28  7:46 ` [PATCH 00/59] dma: " Vinod Koul
2023-09-28  7:49 ` Vinod Koul

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).