[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250611093934.4208-1-wsa+renesas@sang-engineering.com>
Date: Wed, 11 Jun 2025 11:39:24 +0200
From: Wolfram Sang <wsa+renesas@...g-engineering.com>
To: linux-renesas-soc@...r.kernel.org
Cc: Tommaso Merciai <tommaso.merciai.xr@...renesas.com>,
Wolfram Sang <wsa+renesas@...g-engineering.com>,
Alexandre Belloni <alexandre.belloni@...tlin.com>,
Conor Dooley <conor+dt@...nel.org>,
devicetree@...r.kernel.org,
Frank Li <Frank.Li@....com>,
Geert Uytterhoeven <geert+renesas@...der.be>,
"Gustavo A. R. Silva" <gustavoars@...nel.org>,
Kees Cook <kees@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>,
linux-clk@...r.kernel.org,
linux-hardening@...r.kernel.org,
linux-i3c@...ts.infradead.org,
Magnus Damm <magnus.damm@...il.com>,
Michael Turquette <mturquette@...libre.com>,
Philipp Zabel <p.zabel@...gutronix.de>,
Rob Herring <robh@...nel.org>,
Stephen Boyd <sboyd@...nel.org>
Subject: [PATCH RFC 0/7] i3c: add driver for the Renesas IP and support RZ/G3S+G3E
Here is finally the first RFC of a driver for the Renesas I3C IP. It was
created by merging two versions of it from two different BSPs. Then,
improved according to code analyzers, cleaned up with regard to coding
style, and then refactored to hopefully match I3C subsystem standards.
It is a basic driver for the I3C IP found in various SoCs like RZ/G3S
and G3E. Missing features to be added incrementally are IBI, HotJoin and
maybe target support. Other than that, this driver has been tested with
I3C pure busses (2 targets) and mixed busses (2 I3C + various I2C
targets). DAA and reading/writing to the temperature sensors worked
reliably at different speeds. Scoping the bus, the output from the
protocol analyzer seems reasonable, too. But hey, I am still new to all
this, so I might have overlooked something.
The first patches are needed to enable I3C on the RZ/G3S and G3E boards.
Once this series loses RFC status, they will be sent out individually,
of course. All is on top of 6.16-rc1. A branch can be found here:
git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux.git renesas/g3s/i3c
Why is this still RFC?
- On G3E (but not G3S), we get a spurious irq during boot. We are
working on it. This is just platform dependent, though, kind of
independent of the high level design of the driver. For this, we
would love to get comments already. So, we can fix things in parallel
- G3S has 17 irqs, G3E only 16. The way we handle this might need
discussion (see patch 3)
- On G3S, clocks are named 'i3c' while on G3E they are named 'i3c0'
I don't have all the needed docs for this, but Tommaso can surely
figure this out meanwhile
- There are some open questions regarding the driver itself
(see patch 4)
Really looking forward to comments! This has been quite a ride. Getting
a suitable test setup was a surprisingly big task. If someone knows an
off-the-shelf device supporting HotJoin, I am all ears. I couldn't find
one.
So much for now here, some patches have more details.
All the best,
Wolfram
Quynh Nguyen (1):
arm64: dts: renesas: r9a08g045: Add I3C node
Tommaso Merciai (3):
clk: renesas: r9a09g047: Add I3C0 clocks and resets
dt-bindings: i3c: renesas,i3c: Add binding for Renesas I3C controller
arm64: dts: renesas: r9a09g047: Add I3C node
Wolfram Sang (3):
clk: renesas: r9a08g045: Add I3C clocks, resets and power domain
i3c: add driver for Renesas I3C IP
WIP: arm64: dts: renesas: rzg3s-smarc-som: Enable I3C
.../devicetree/bindings/i3c/renesas,i3c.yaml | 186 +++
MAINTAINERS | 7 +
arch/arm64/boot/dts/renesas/r9a08g045.dtsi | 35 +
arch/arm64/boot/dts/renesas/r9a09g047.dtsi | 35 +
.../boot/dts/renesas/rzg3s-smarc-som.dtsi | 33 +
drivers/clk/renesas/r9a08g045-cpg.c | 7 +
drivers/clk/renesas/r9a09g047-cpg.c | 8 +
drivers/i3c/master/Kconfig | 10 +
drivers/i3c/master/Makefile | 1 +
drivers/i3c/master/renesas-i3c.c | 1441 +++++++++++++++++
10 files changed, 1763 insertions(+)
create mode 100644 Documentation/devicetree/bindings/i3c/renesas,i3c.yaml
create mode 100644 drivers/i3c/master/renesas-i3c.c
--
2.47.2
Powered by blists - more mailing lists