[PATCH v3 0/8] Add StarFive JHB100 syscon modules
Changhuang Liang
changhuang.liang at starfivetech.com
Wed May 20 18:29:24 PDT 2026
StarFive JHB100 has many syscon modules, as listed below:
- pcieep0_ecsr_syscon (PCIe endpoint 0 externel syscon)
- pcieep1_ecsr_syscon
- host0_syscon (Host0 syscon)
- host1_syscon
- husb0_syscon (Host USB 0 syscon)
- husb1_syscon
- husbd0_syscon (Host USB device 0 syscon)
- husbd1_syscon
- husbcmn_syscon (Host USB common syscon)
- gpu0_syscon (GPU0 syscon)
- gpu1_syscon
- b2h_syscon (BMC to Host syscon)
- h2b_syscon (Host to BMC syscon)
- vout_syscon (Video output syscon)
- pcierp_ecsr_syscon (PCIe root port externel syscon)
- pcierp_syscon (PCIe root port syscon)
- usb_syscon
- npu_syscon
- per0_syscon (Peripheral 0 syscon)
- per1_syscon
- per2_syscon
- per3_syscon
- sys0_syscon (System 0 syscon)
- sys1_syscon
- sys2_syscon
- strap_syscon
Some syscon modules contain PLL, reset, and socinfo nodes
This series will add these syscon modules, as well as the
nodes under them.
-PATCH 1: syscon binging
-PATCH 2/3/4: syscon sys0/per0/per1 PLL driver
-PATCH 5/6: syscon PCIe RP reset driver
-PATCH 7: syscon socinfo driver
-PATCH 8: syscon device tree
This series depends on the series:
https://lore.kernel.org/all/20260508053632.818548-1-changhuang.liang@starfivetech.com/
changes since v2:
- Squash patches 2, 4, 6, and 8 into patch 1
PATCH 1:
- Add else: clocks/#clock-cells: false
- Add else: #reset-cells: false
PATCH 5/7:
- Remove (void *) cast
PATCH 9/10:
- Rename assert_polarity to active_low
PATCH 11:
- Add drivers/soc/starfive back to the "STARFIVE SOC DRIVERS" entry
- Replace early_initcall with subsys_initcall
v2: https://lore.kernel.org/all/20260512083521.3448-1-changhuang.liang@starfivetech.com/
V1: https://lore.kernel.org/all/20260403054945.467700-1-changhuang.liang@starfivetech.com/
Changhuang Liang (8):
dt-bindings: soc: starfive: Add StarFive JHB100 syscon modules
clk: starfive: Add system-0 domain PLL clock driver
clk: starfive: Add peripheral-0 domain PLL clock driver
clk: starfive: Add Peripheral-1 domain PLL clock driver
reset: starfive: Introduce active_low
reset: starfive: Add syscon reset driver support
soc: starfive: Add socinfo driver for JHB100 SoC
riscv: dts: starfive: jhb100: Add syscon nodes
.../soc/starfive/starfive,jhb100-syscon.yaml | 114 ++++
MAINTAINERS | 11 +
arch/riscv/boot/dts/starfive/jhb100.dtsi | 180 ++++--
drivers/clk/starfive/Kconfig | 8 +
drivers/clk/starfive/Makefile | 1 +
.../clk/starfive/clk-starfive-jhb100-pll.c | 586 ++++++++++++++++++
drivers/reset/starfive/Kconfig | 9 +
drivers/reset/starfive/Makefile | 1 +
.../reset/starfive/reset-starfive-common.c | 5 +-
.../reset/starfive/reset-starfive-common.h | 6 +
.../starfive/reset-starfive-jhb100-syscon.c | 62 ++
drivers/soc/Kconfig | 1 +
drivers/soc/Makefile | 1 +
drivers/soc/starfive/Kconfig | 6 +
drivers/soc/starfive/Makefile | 2 +
drivers/soc/starfive/socinfo/Kconfig | 11 +
drivers/soc/starfive/socinfo/Makefile | 2 +
drivers/soc/starfive/socinfo/jhb100-socinfo.c | 80 +++
.../dt-bindings/clock/starfive,jhb100-crg.h | 12 +
.../dt-bindings/reset/starfive,jhb100-crg.h | 3 +
20 files changed, 1065 insertions(+), 36 deletions(-)
create mode 100644 Documentation/devicetree/bindings/soc/starfive/starfive,jhb100-syscon.yaml
create mode 100644 drivers/clk/starfive/clk-starfive-jhb100-pll.c
create mode 100644 drivers/reset/starfive/reset-starfive-jhb100-syscon.c
create mode 100644 drivers/soc/starfive/Kconfig
create mode 100644 drivers/soc/starfive/Makefile
create mode 100644 drivers/soc/starfive/socinfo/Kconfig
create mode 100644 drivers/soc/starfive/socinfo/Makefile
create mode 100644 drivers/soc/starfive/socinfo/jhb100-socinfo.c
--
2.25.1
More information about the linux-riscv
mailing list