[PATCH v2 00/24] ASoC: rsnd: Add audio support for the Renesas RZ/G3E SoC
From: John Madieu
Date: Thu Apr 02 2026 - 05:13:38 EST
This series adds audio support for the Renesas RZ/G3E SoC and enables
it on the SMARC EVK board with the Dialog DA7212 codec.
The RZ/G3E audio subsystem is based on R-Car Sound IP but has several
differences requiring dedicated handling:
- SSI operates exclusively in BUSIF mode (no PIO)
- 2 BUSIF channels per SSI instead of 4/8 on R-Car
- Different register offsets for SCU, ADG, SSIU, and SSI
- Per-SSI ADG and SSIF supply clocks
- DMA ACK signal routing through ICU
This series includes:
- Clock driver support for audio clocks and resets
- DT bindings update for DMA ACK signal field
- IRQ chip extension for DMA ACK signal routing
- RZ-DMAC driver updates for ACK signal support
- R-Car Sound driver updates for RZ/G3E support
- System suspend/resume support
- Device tree nodes for RZ/G3E SMARC EVK
Note: patch 04/22 depends on [1]. As this patch will propably be routed
through the DMA tree independently, the rest of the series can be reviewed
and the remaining patches applied without this dependency being resolved
first.
Audio configuration on SMARC EVK:
- Codec: Dialog DA7212 on I2C1
- Playback: SSI3 -> SRC1 -> DVC1
- Capture: SSI4 -> SRC0 -> DVC0
- MCLK: 12.288MHz from Versa3 clock generator
- Format: I2S, RZ/G3E Sound as clock master
- SSI4 shares clock pins with SSI3 (shared-pin)
Tested on RZ/G3E SMARC EVK with:
- Playback to headphone output
- Capture from line-in (AUX) input and/or Mic
- Full duplex operation
- System suspend/resume
Merge strategy:
- Patch 01-02/24: Clock tree
- Patch 03-04/24: both in DMA tree, as there is hard inter-dependency between
these patches
- Patch 05-18/24: ASoC tree
- Patch 19-24/24: SoC dts tree
[1] https://lore.kernel.org/all/20260320112838.2200198-1-claudiu.beznea.uj@xxxxxxxxxxxxxx/
Changes:
v2:
- Fix Rob's comment on maxItems not needed with items lists.
- Drop DMA ACK second cell from DT specifier
- Derive ACK signal number in-driver from MID/RID using arithmetic formulas
per ICU Table 4.6-28 (3 linear peripheral groups)
- Split of rsnd.yaml into common and R-Car-specific schemas
- Introduce RZ/G3E sound binding as a standalone schema
- Addressed Kuninori'comments, details are in individual patches
John Madieu (24):
dt-bindings: clock: renesas: Add audio clock inputs for RZ/V2H family
clk: renesas: r9a09g047: Add audio clock and reset support
irqchip/renesas-rzv2h: Add DMA ACK signal routing support
dma: sh: rz-dmac: Add DMA ACK signal routing support
ASoC: dt-bindings: renesas,rsnd: Split into generic and SoC-specific
parts
ASoC: dt-bindings: Add RZ/G3E (R9A09G047) sound binding
ASoC: rsnd: Add reset controller support to rsnd_mod
ASoC: rsnd: Add RZ/G3E SoC probing and register map
ASoC: rsnd: Add audmacpp clock and reset support for RZ/G3E
ASoC: rsnd: Add RZ/G3E DMA address calculation support
ASoC: rsnd: ssui: Add RZ/G3E SSIU BUSIF support
ASoC: rsnd: Add SSI reset support for RZ/G3E platforms
ASoC: rsnd: Add ADG reset support for RZ/G3E
ASoC: rsnd: adg: Add per-SSI ADG and SSIF supply clock management
ASoC: rsnd: src: Add SRC reset and clock support for RZ/G3E
ASoC: rsnd: Add rsnd_adg_mod_get() for PM support
ASoC: rsnd: Export rsnd_ssiu_mod_get() for PM support
ASoC: rsnd: Add system suspend/resume support
arm64: dts: renesas: rzv2h: Add audio clock inputs
arm64: dts: renesas: r9a09g047: Add R-Car Sound support
arm64: dts: renesas: rzg3e-smarc-som: Add Versa3 clock generator
arm64: dts: renesas: rzg3e-smarc-som: Add I2C1 support
arm64: dts: renesas: rzg3e-smarc-som: add audio pinmux definitions
arm64: dts: renesas: r9a09g047e57-smarc: add DA7212 audio codec
support
.../bindings/clock/renesas,rzv2h-cpg.yaml | 8 +
.../sound/renesas,r9a09g047-sound.yaml | 371 ++++++++++++
.../bindings/sound/renesas,rsnd-common.yaml | 196 +++++++
.../bindings/sound/renesas,rsnd.yaml | 319 +++--------
arch/arm64/boot/dts/renesas/r9a09g047.dtsi | 529 +++++++++++++++++-
.../boot/dts/renesas/r9a09g047e57-smarc.dts | 114 ++++
arch/arm64/boot/dts/renesas/r9a09g056.dtsi | 27 +-
arch/arm64/boot/dts/renesas/r9a09g057.dtsi | 27 +-
.../boot/dts/renesas/rzg3e-smarc-som.dtsi | 44 ++
drivers/clk/renesas/r9a09g047-cpg.c | 129 ++++-
drivers/dma/sh/rz-dmac.c | 72 +++
drivers/irqchip/irq-renesas-rzv2h.c | 40 ++
include/linux/irqchip/irq-renesas-rzv2h.h | 5 +
sound/soc/renesas/rcar/adg.c | 133 ++++-
sound/soc/renesas/rcar/cmd.c | 2 +-
sound/soc/renesas/rcar/core.c | 60 +-
sound/soc/renesas/rcar/ctu.c | 22 +-
sound/soc/renesas/rcar/dma.c | 167 +++++-
sound/soc/renesas/rcar/dvc.c | 22 +-
sound/soc/renesas/rcar/gen.c | 180 ++++++
sound/soc/renesas/rcar/mix.c | 22 +-
sound/soc/renesas/rcar/rsnd.h | 53 +-
sound/soc/renesas/rcar/src.c | 71 ++-
sound/soc/renesas/rcar/ssi.c | 51 +-
sound/soc/renesas/rcar/ssiu.c | 69 ++-
25 files changed, 2427 insertions(+), 306 deletions(-)
create mode 100644 Documentation/devicetree/bindings/sound/renesas,r9a09g047-sound.yaml
create mode 100644 Documentation/devicetree/bindings/sound/renesas,rsnd-common.yaml
--
2.25.1