The JHB100 SoC has 13 pinctrl domains - sys0, sys0h, sys1, sys2, per0, per1,
per2, per2pok, per3, adc0, adc1, emmc, and vga.
In the current series, we will only add the following pinctrl:
- sys0, sys0h, sys1, sys2
- per0, per1, per2, per2pok, per3
The remaining pinctrl will be implemented in future series.
This series depends on the series:
https://lore.kernel.org/all/20260508053632.818548-1-changhuang.liang@starfivetech.com/
Change since v2:
- Remove v2 PATCH 3
PATCH 1/2:
- Replace input-debounce-nanoseconds with input-debounce-ns.
PATCH 4/6/8/10/12/14/16/18/20:
- Replace unevaluatedProperties with additionalProperties.
- Add the description for power-source.
PATCH 5:
- `jhb100_pinconf_group_set()` invokes `jhb100_pinconf_set()` to
reduce redundant code.
- Add `jhb100_pincfg_pin_vref_set()` to handle pin voltage configuration.
PATCH 7/9/11/13/15/17/19/21:
- Add `numpv` to record the number of elements in the `struct pinvref_desc` array.
- Remove the `name` member of `struct pinvref_desc`.
PATCH 22:
- Replace the pin group voltage configuration with individual
pin power-source configurations.
v2: https://lore.kernel.org/all/20260514111218.94519-1-changhuang.liang@starfivetech.com/
v1: https://lore.kernel.org/all/20260424111330.702272-1-changhuang.liang@starfivetech.com/
Changhuang Liang (21):
dt-bindings: pincfg-node: Add property 'input-debounce-ns'
pinctrl: pinconf-generic: Add property 'input-debounce-ns'
dt-bindings: pinctrl: Add starfive,jhb100-sys0-pinctrl
pinctrl: starfive: Add StarFive JHB100 sys0 controller driver
dt-bindings: pinctrl: Add starfive,jhb100-sys0h-pinctrl
pinctrl: starfive: Add StarFive JHB100 sys0h controller driver
dt-bindings: pinctrl: Add starfive,jhb100-sys1-pinctrl
pinctrl: starfive: Add StarFive JHB100 sys1 controller driver
dt-bindings: pinctrl: Add starfive,jhb100-sys2-pinctrl
pinctrl: starfive: Add StarFive JHB100 sys2 controller driver
dt-bindings: pinctrl: Add starfive,jhb100-per0-pinctrl
pinctrl: starfive: Add StarFive JHB100 per0 controller driver
dt-bindings: pinctrl: Add starfive,jhb100-per1-pinctrl
pinctrl: starfive: Add StarFive JHB100 per1 controller driver
dt-bindings: pinctrl: Add starfive,jhb100-per2-pinctrl
pinctrl: starfive: Add StarFive JHB100 per2 controller driver
dt-bindings: pinctrl: Add starfive,jhb100-per2pok-pinctrl
pinctrl: starfive: Add StarFive JHB100 per2pok controller driver
dt-bindings: pinctrl: Add starfive,jhb100-per3-pinctrl
pinctrl: starfive: Add StarFive JHB100 per3 controller driver
riscv: dts: starfive: jhb100: Add pinctrl nodes
.../bindings/pinctrl/pincfg-node.yaml | 11 +
.../pinctrl/starfive,jhb100-per0-pinctrl.yaml | 179 ++
.../pinctrl/starfive,jhb100-per1-pinctrl.yaml | 178 ++
.../pinctrl/starfive,jhb100-per2-pinctrl.yaml | 168 ++
.../starfive,jhb100-per2pok-pinctrl.yaml | 159 ++
.../pinctrl/starfive,jhb100-per3-pinctrl.yaml | 165 ++
.../pinctrl/starfive,jhb100-sys0-pinctrl.yaml | 161 ++
.../starfive,jhb100-sys0h-pinctrl.yaml | 160 ++
.../pinctrl/starfive,jhb100-sys1-pinctrl.yaml | 161 ++
.../pinctrl/starfive,jhb100-sys2-pinctrl.yaml | 169 ++
MAINTAINERS | 9 +
arch/riscv/boot/dts/starfive/jhb100-evb1.dts | 3 +
.../boot/dts/starfive/jhb100-pinctrl.dtsi | 23 +
arch/riscv/boot/dts/starfive/jhb100.dtsi | 110 ++
drivers/pinctrl/pinconf-generic.c | 2 +
drivers/pinctrl/starfive/Kconfig | 115 ++
drivers/pinctrl/starfive/Makefile | 11 +
.../starfive/pinctrl-starfive-jhb100-per0.c | 154 ++
.../starfive/pinctrl-starfive-jhb100-per1.c | 165 ++
.../starfive/pinctrl-starfive-jhb100-per2.c | 126 ++
.../pinctrl-starfive-jhb100-per2pok.c | 97 +
.../starfive/pinctrl-starfive-jhb100-per3.c | 119 ++
.../starfive/pinctrl-starfive-jhb100-sys0.c | 123 ++
.../starfive/pinctrl-starfive-jhb100-sys0h.c | 97 +
.../starfive/pinctrl-starfive-jhb100-sys1.c | 93 +
.../starfive/pinctrl-starfive-jhb100-sys2.c | 134 ++
.../starfive/pinctrl-starfive-jhb100.c | 1607 +++++++++++++++++
.../starfive/pinctrl-starfive-jhb100.h | 152 ++
.../pinctrl/starfive,jhb100-pinctrl.h | 252 +++
include/linux/pinctrl/pinconf-generic.h | 5 +
30 files changed, 4908 insertions(+)
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-per0-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-per1-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-per2-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-per2pok-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-per3-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-sys0-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-sys0h-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-sys1-pinctrl.yaml
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jhb100-sys2-pinctrl.yaml
create mode 100644 arch/riscv/boot/dts/starfive/jhb100-pinctrl.dtsi
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-per0.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-per1.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-per2.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-per2pok.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-per3.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-sys0.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-sys0h.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-sys1.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100-sys2.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100.c
create mode 100644 drivers/pinctrl/starfive/pinctrl-starfive-jhb100.h
create mode 100644 include/dt-bindings/pinctrl/starfive,jhb100-pinctrl.h
--
2.25.1