[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250424102509.1083185-1-wenst@chromium.org>
Date: Thu, 24 Apr 2025 18:24:54 +0800
From: Chen-Yu Tsai <wenst@...omium.org>
To: Liam Girdwood <lgirdwood@...il.com>,
Mark Brown <broonie@...nel.org>,
Matthias Brugger <matthias.bgg@...il.com>,
AngeloGioacchino Del Regno <angelogioacchino.delregno@...labora.com>,
Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>
Cc: Chen-Yu Tsai <wenst@...omium.org>,
Jaroslav Kysela <perex@...ex.cz>,
Takashi Iwai <tiwai@...e.com>,
Jiaxin Yu <jiaxin.yu@...iatek.com>,
linux-sound@...r.kernel.org,
devicetree@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org,
linux-mediatek@...ts.infradead.org,
linux-kernel@...r.kernel.org
Subject: [PATCH v2 00/13] ASoC: mediatek: use reserved memory or enable buffer pre-allocation
Hi everyone,
This is v2 of what was just a single patch "ASoC: mediatek: re-enable
buffer pre-allocation on some platforms". Link to v1:
https://lore.kernel.org/all/20250401085659.1222008-1-wenst@chromium.org/
Angelo requested that these platforms use reserved memory regions if
possible, and fall back to pre-allocated buffers only if that fails,
to align with other MediaTek SoCs / platforms that already use reserved
memory. The series covers MediaTek's MT8173, MT8183, MT8186, and MT8192
SoCs.
There are three parts to the series:
- Part one (patches 1 through 5) update the DT bindings to allow having
a memory region. The text binding for the MT8173 was converted to YAML
and also aligned with current usage by addition of a power domain.
Note that the MT8183 text binding was _not_ converted. It is
drastically different from what was landed in the device trees. Some
time is needed to work out the differences. I might try to recombine
the audio clocks (which are actually part of the same hardware block)
as well.
- Part two (patches 6 through 9) update the audio frontend drivers for
the various platforms covered in this series.
- Patch 6 is the evolution of version 1, now defaulting to reserved
memory if possible.
- Patch 7 adds support for >32 bit DMA addresses to the MT8183 driver.
This was missing, and prevents the memory regions, which are
allocated from the top end of main memory by default, from working.
- Patch 8 and 9 are just some minor cleanups to reduce the number of
"&pdev->dev" style dereferences. They are placed after the other
changes to make it easier for the fixes to be backported.
- Part three (patches 10 through 13) add a reserved memory region for
the audio frontend on the various platforms.
For the MT8173, the change covers the whole platform. In practice
there are only ChromeOS devices.
For the other platforms, only the ChromeOS devices are covered. These
are what I have available for testing.
Please have a look. I assume the DT binding and driver changes will go
through the ASoC tree, while the device tree changes will go through the
MediaTek tree.
Thanks
ChenYu
Chen-Yu Tsai (13):
ASoC: dt-bindings: Convert MT8173 AFE binding to dt-schema
ASoC: dt-bindings: mt8173-afe-pcm: Add power domain
ASoC: dt-bindings: mt8173-afe-pcm: Allow specifying reserved memory
region
ASoC: dt-bindings: mt8186-afe-pcm: Allow specifying reserved memory
region
ASoC: dt-bindings: mt8192-afe-pcm: Allow specifying reserved memory
region
ASoC: mediatek: use reserved memory or enable buffer pre-allocation
ASoC: mediatek: mt8183-afe-pcm: Support >32 bit DMA addresses
ASoC: mediatek: mt8173-afe-pcm: use local `dev` pointer in driver
callbacks
ASoC: mediatek: mt8183-afe-pcm: use local `dev` pointer in driver
callbacks
arm64: dts: mediatek: mt8173: Reserve memory for audio frontend
arm64: dts: mediatek: mt8183-kukui: Reserve memory for audio frontend
arm64: dts: mediatek: mt8186-corsola: Reserve memory for audio
frontend
arm64: dts: mediatek: mt8192-asurada: Reserve memory for audio
frontend
.../sound/mediatek,mt8173-afe-pcm.yaml | 98 +++++++++++++++++++
.../bindings/sound/mt8186-afe-pcm.yaml | 5 +
.../bindings/sound/mt8192-afe-pcm.yaml | 5 +
.../devicetree/bindings/sound/mtk-afe-pcm.txt | 45 ---------
arch/arm64/boot/dts/mediatek/mt8173.dtsi | 9 ++
.../arm64/boot/dts/mediatek/mt8183-kukui.dtsi | 11 +++
.../boot/dts/mediatek/mt8186-corsola.dtsi | 8 ++
.../boot/dts/mediatek/mt8192-asurada.dtsi | 11 +++
.../mediatek/common/mtk-afe-platform-driver.c | 4 +-
sound/soc/mediatek/common/mtk-base-afe.h | 1 +
sound/soc/mediatek/mt8173/mt8173-afe-pcm.c | 66 +++++++------
sound/soc/mediatek/mt8183/mt8183-afe-pcm.c | 83 ++++++++++++----
sound/soc/mediatek/mt8186/mt8186-afe-pcm.c | 7 ++
sound/soc/mediatek/mt8192/mt8192-afe-pcm.c | 7 ++
14 files changed, 266 insertions(+), 94 deletions(-)
create mode 100644 Documentation/devicetree/bindings/sound/mediatek,mt8173-afe-pcm.yaml
delete mode 100644 Documentation/devicetree/bindings/sound/mtk-afe-pcm.txt
--
2.49.0.805.g082f7c87e0-goog
Powered by blists - more mailing lists