From: Alex Elder <elder@riscstar.com>
To: Yixun Lan <dlan@gentoo.org>
Cc: robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org,
mturquette@baylibre.com, sboyd@kernel.org,
p.zabel@pengutronix.de, paul.walmsley@sifive.com,
palmer@dabbelt.com, aou@eecs.berkeley.edu, alex@ghiti.fr,
heylenay@4d2.org, inochiama@outlook.com, guodong@riscstar.com,
devicetree@vger.kernel.org, linux-clk@vger.kernel.org,
spacemit@lists.linux.dev, linux-riscv@lists.infradead.org,
linux-kernel@vger.kernel.org,
Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Subject: Re: [PATCH v6 1/6] dt-bindings: soc: spacemit: define spacemit,k1-ccu resets
Date: Wed, 7 May 2025 21:19:54 -0500 [thread overview]
Message-ID: <c9aac0f1-7fed-4d12-b80a-767df7168a43@riscstar.com> (raw)
In-Reply-To: <20250507223554-GYA505240@gentoo>
On 5/7/25 5:35 PM, Yixun Lan wrote:
> hi Alex,
>
> On 16:06 Tue 06 May , Alex Elder wrote:
>> There are additional SpacemiT syscon CCUs whose registers control both
>> clocks and resets: RCPU, RCPU2, and APBC2. Unlike those defined
>> previously, these will (initially) support only resets. They do not
>> incorporate power domain functionality.
>>
>> Previously the clock properties were required for all compatible nodes.
>> Make that requirement only apply to the three existing CCUs (APBC, APMU,
>> and MPMU), so that the new reset-only CCUs can go without specifying them.
>>
>> Define the index values for resets associated with all SpacemiT K1
>> syscon nodes, including those with clocks already defined, as well as
>> the new ones (without clocks).
>>
>> Signed-off-by: Alex Elder <elder@riscstar.com>
>> Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
>> ---
>> .../soc/spacemit/spacemit,k1-syscon.yaml | 29 +++-
>> .../dt-bindings/clock/spacemit,k1-syscon.h | 128 ++++++++++++++++++
>> 2 files changed, 150 insertions(+), 7 deletions(-)
>>
>> diff --git a/Documentation/devicetree/bindings/soc/spacemit/spacemit,k1-syscon.yaml b/Documentation/devicetree/bindings/soc/spacemit/spacemit,k1-syscon.yaml
>> index 30aaf49da03d3..133a391ee68cd 100644
>> --- a/Documentation/devicetree/bindings/soc/spacemit/spacemit,k1-syscon.yaml
>> +++ b/Documentation/devicetree/bindings/soc/spacemit/spacemit,k1-syscon.yaml
>> @@ -19,6 +19,9 @@ properties:
>> - spacemit,k1-syscon-apbc
>> - spacemit,k1-syscon-apmu
>> - spacemit,k1-syscon-mpmu
>> + - spacemit,k1-syscon-rcpu
>> + - spacemit,k1-syscon-rcpu2
>> + - spacemit,k1-syscon-apbc2
>>
>> reg:
>> maxItems: 1
>> @@ -47,9 +50,6 @@ properties:
>> required:
>> - compatible
>> - reg
>> - - clocks
>> - - clock-names
>> - - "#clock-cells"
>> - "#reset-cells"
>>
>> allOf:
>> @@ -57,13 +57,28 @@ allOf:
>> properties:
>> compatible:
>> contains:
>> - const: spacemit,k1-syscon-apbc
>> + enum:
>> + - spacemit,k1-syscon-apmu
>> + - spacemit,k1-syscon-mpmu
>> then:
>> - properties:
>> - "#power-domain-cells": false
>> - else:
>> required:
>> - "#power-domain-cells"
>> + else:
>> + properties:
>> + "#power-domain-cells": false
>> + - if:
>> + properties:
>> + compatible:
>> + contains:
>> + enum:
>> + - spacemit,k1-syscon-apbc
>> + - spacemit,k1-syscon-apmu
>> + - spacemit,k1-syscon-mpmu
>> + then:
>> + required:
>> + - clocks
>> + - clock-names
>> + - "#clock-cells"
>>
>> additionalProperties: false
>>
>> diff --git a/include/dt-bindings/clock/spacemit,k1-syscon.h b/include/dt-bindings/clock/spacemit,k1-syscon.h
>> index 35968ae982466..f5965dda3b905 100644
>> --- a/include/dt-bindings/clock/spacemit,k1-syscon.h
>> +++ b/include/dt-bindings/clock/spacemit,k1-syscon.h
> would it be better to move all reset definition to its dedicated dir?
> which like: include/dt-bindings/reset/spacemit,k1-syscon.h?
That's fine with me. I should have thought of that.
Krzysztof, I'll drop your Reviewed-by if I make that change,
but if you say I can before I post v7 I will keep it.
I'll wait a bit more before I update so others can comment
(on this or anything else).
Thanks.
-Alex
>
>> @@ -78,6 +78,9 @@
>> #define CLK_APB 31
>> #define CLK_WDT_BUS 32
>>
>> +/* MPMU resets */
>> +#define RESET_WDT 0
>> +
>> /* APBC clocks */
>> #define CLK_UART0 0
>> #define CLK_UART2 1
>> @@ -180,6 +183,59 @@
>> #define CLK_TSEN_BUS 98
>> #define CLK_IPC_AP2AUD_BUS 99
>>
>> +/* APBC resets */
>> +#define RESET_UART0 0
>> +#define RESET_UART2 1
>> +#define RESET_UART3 2
>> +#define RESET_UART4 3
>> +#define RESET_UART5 4
>> +#define RESET_UART6 5
>> +#define RESET_UART7 6
>> +#define RESET_UART8 7
>> +#define RESET_UART9 8
>> +#define RESET_GPIO 9
>> +#define RESET_PWM0 10
>> +#define RESET_PWM1 11
>> +#define RESET_PWM2 12
>> +#define RESET_PWM3 13
>> +#define RESET_PWM4 14
>> +#define RESET_PWM5 15
>> +#define RESET_PWM6 16
>> +#define RESET_PWM7 17
>> +#define RESET_PWM8 18
>> +#define RESET_PWM9 19
>> +#define RESET_PWM10 20
>> +#define RESET_PWM11 21
>> +#define RESET_PWM12 22
>> +#define RESET_PWM13 23
>> +#define RESET_PWM14 24
>> +#define RESET_PWM15 25
>> +#define RESET_PWM16 26
>> +#define RESET_PWM17 27
>> +#define RESET_PWM18 28
>> +#define RESET_PWM19 29
>> +#define RESET_SSP3 30
>> +#define RESET_RTC 31
>> +#define RESET_TWSI0 32
>> +#define RESET_TWSI1 33
>> +#define RESET_TWSI2 34
>> +#define RESET_TWSI4 35
>> +#define RESET_TWSI5 36
>> +#define RESET_TWSI6 37
>> +#define RESET_TWSI7 38
>> +#define RESET_TWSI8 39
>> +#define RESET_TIMERS1 40
>> +#define RESET_TIMERS2 41
>> +#define RESET_AIB 42
>> +#define RESET_ONEWIRE 43
>> +#define RESET_SSPA0 44
>> +#define RESET_SSPA1 45
>> +#define RESET_DRO 46
>> +#define RESET_IR 47
>> +#define RESET_TSEN 48
>> +#define RESET_IPC_AP2AUD 49
>> +#define RESET_CAN0 50
>> +
>> /* APMU clocks */
>> #define CLK_CCI550 0
>> #define CLK_CPU_C0_HI 1
>> @@ -244,4 +300,76 @@
>> #define CLK_V2D 60
>> #define CLK_EMMC_BUS 61
>>
>> +/* APMU resets */
>> +#define RESET_CCIC_4X 0
>> +#define RESET_CCIC1_PHY 1
>> +#define RESET_SDH_AXI 2
>> +#define RESET_SDH0 3
>> +#define RESET_SDH1 4
>> +#define RESET_SDH2 5
>> +#define RESET_USBP1_AXI 6
>> +#define RESET_USB_AXI 7
>> +#define RESET_USB3_0 8
>> +#define RESET_QSPI 9
>> +#define RESET_QSPI_BUS 10
>> +#define RESET_DMA 11
>> +#define RESET_AES 12
>> +#define RESET_VPU 13
>> +#define RESET_GPU 14
>> +#define RESET_EMMC 15
>> +#define RESET_EMMC_X 16
>> +#define RESET_AUDIO 17
>> +#define RESET_HDMI 18
>> +#define RESET_PCIE0 19
>> +#define RESET_PCIE1 20
>> +#define RESET_PCIE2 21
>> +#define RESET_EMAC0 22
>> +#define RESET_EMAC1 23
>> +#define RESET_JPG 24
>> +#define RESET_CCIC2PHY 25
>> +#define RESET_CCIC3PHY 26
>> +#define RESET_CSI 27
>> +#define RESET_ISP_CPP 28
>> +#define RESET_ISP_BUS 29
>> +#define RESET_ISP 30
>> +#define RESET_ISP_CI 31
>> +#define RESET_DPU_MCLK 32
>> +#define RESET_DPU_ESC 33
>> +#define RESET_DPU_HCLK 34
>> +#define RESET_DPU_SPIBUS 35
>> +#define RESET_DPU_SPI_HBUS 36
>> +#define RESET_V2D 37
>> +#define RESET_MIPI 38
>> +#define RESET_MC 39
>> +
>> +/* RCPU resets */
>> +#define RESET_RCPU_SSP0 0
>> +#define RESET_RCPU_I2C0 1
>> +#define RESET_RCPU_UART1 2
>> +#define RESET_RCPU_IR 3
>> +#define RESET_RCPU_CAN 4
>> +#define RESET_RCPU_UART0 5
>> +#define RESET_RCPU_HDMI_AUDIO 6
>> +
>> +/* RCPU2 resets */
>> +#define RESET_RCPU2_PWM0 0
>> +#define RESET_RCPU2_PWM1 1
>> +#define RESET_RCPU2_PWM2 2
>> +#define RESET_RCPU2_PWM3 3
>> +#define RESET_RCPU2_PWM4 4
>> +#define RESET_RCPU2_PWM5 5
>> +#define RESET_RCPU2_PWM6 6
>> +#define RESET_RCPU2_PWM7 7
>> +#define RESET_RCPU2_PWM8 8
>> +#define RESET_RCPU2_PWM9 9
>> +
>> +/* APBC2 resets */
>> +#define RESET_APBC2_UART1 0
>> +#define RESET_APBC2_SSP2 1
>> +#define RESET_APBC2_TWSI3 2
>> +#define RESET_APBC2_RTC 3
>> +#define RESET_APBC2_TIMERS0 4
>> +#define RESET_APBC2_KPC 5
>> +#define RESET_APBC2_GPIO 6
>> +
>> #endif /* _DT_BINDINGS_SPACEMIT_CCU_H_ */
>> --
>> 2.45.2
>>
>
_______________________________________________
linux-riscv mailing list
linux-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-riscv
next prev parent reply other threads:[~2025-05-08 2:20 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-05-06 21:06 [PATCH v6 0/6] clk: spacemit: add K1 reset support Alex Elder
2025-05-06 21:06 ` [PATCH v6 1/6] dt-bindings: soc: spacemit: define spacemit,k1-ccu resets Alex Elder
2025-05-07 22:35 ` Yixun Lan
2025-05-08 2:19 ` Alex Elder [this message]
2025-05-08 12:02 ` Krzysztof Kozlowski
2025-05-08 12:17 ` Alex Elder
2025-05-08 12:36 ` Krzysztof Kozlowski
2025-05-08 12:42 ` Alex Elder
2025-05-08 12:40 ` Yixun Lan
2025-05-06 21:06 ` [PATCH v6 2/6] soc: spacemit: create a header for clock/reset registers Alex Elder
2025-05-08 4:16 ` Haylen Chu
2025-05-08 11:40 ` Alex Elder
2025-05-06 21:06 ` [PATCH v6 3/6] clk: spacemit: set up reset auxiliary devices Alex Elder
2025-05-08 4:09 ` kernel test robot
2025-05-08 4:46 ` Haylen Chu
2025-05-08 20:04 ` Alex Elder
2025-05-08 20:17 ` Alex Elder
2025-05-06 21:06 ` [PATCH v6 4/6] reset: spacemit: add support for SpacemiT CCU resets Alex Elder
2025-05-08 5:38 ` Haylen Chu
2025-05-08 11:55 ` Alex Elder
2025-05-08 12:47 ` Haylen Chu
2025-05-08 9:01 ` Philipp Zabel
2025-05-08 12:05 ` Alex Elder
2025-05-06 21:06 ` [PATCH v6 5/6] reset: spacemit: define three more CCUs Alex Elder
2025-05-08 9:11 ` Philipp Zabel
2025-05-08 12:29 ` Alex Elder
2025-05-06 21:06 ` [PATCH v6 6/6] riscv: dts: spacemit: add reset support for the K1 SoC Alex Elder
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=c9aac0f1-7fed-4d12-b80a-767df7168a43@riscstar.com \
--to=elder@riscstar.com \
--cc=alex@ghiti.fr \
--cc=aou@eecs.berkeley.edu \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=dlan@gentoo.org \
--cc=guodong@riscstar.com \
--cc=heylenay@4d2.org \
--cc=inochiama@outlook.com \
--cc=krzk+dt@kernel.org \
--cc=krzysztof.kozlowski@linaro.org \
--cc=linux-clk@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-riscv@lists.infradead.org \
--cc=mturquette@baylibre.com \
--cc=p.zabel@pengutronix.de \
--cc=palmer@dabbelt.com \
--cc=paul.walmsley@sifive.com \
--cc=robh@kernel.org \
--cc=sboyd@kernel.org \
--cc=spacemit@lists.linux.dev \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox