mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-10 15:03:07 +00:00
304 lines
8.2 KiB
Diff
304 lines
8.2 KiB
Diff
|
From 28518a9637fee6b84464beff9d4308edc3efba72 Mon Sep 17 00:00:00 2001
|
||
|
From: Jianlong Huang <jianlong.huang@starfivetech.com>
|
||
|
Date: Thu, 9 Feb 2023 22:36:59 +0800
|
||
|
Subject: [PATCH 026/122] dt-bindings: pinctrl: Add StarFive JH7110 sys pinctrl
|
||
|
|
||
|
Add pinctrl bindings for StarFive JH7110 SoC sys pinctrl controller.
|
||
|
|
||
|
Reviewed-by: Rob Herring <robh@kernel.org>
|
||
|
Signed-off-by: Jianlong Huang <jianlong.huang@starfivetech.com>
|
||
|
Co-developed-by: Emil Renner Berthing <kernel@esmil.dk>
|
||
|
Signed-off-by: Emil Renner Berthing <kernel@esmil.dk>
|
||
|
Signed-off-by: Hal Feng <hal.feng@starfivetech.com>
|
||
|
---
|
||
|
.../pinctrl/starfive,jh7110-sys-pinctrl.yaml | 142 ++++++++++++++++++
|
||
|
MAINTAINERS | 6 +-
|
||
|
.../pinctrl/starfive,jh7110-pinctrl.h | 115 ++++++++++++++
|
||
|
3 files changed, 261 insertions(+), 2 deletions(-)
|
||
|
create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jh7110-sys-pinctrl.yaml
|
||
|
create mode 100644 include/dt-bindings/pinctrl/starfive,jh7110-pinctrl.h
|
||
|
|
||
|
--- /dev/null
|
||
|
+++ b/Documentation/devicetree/bindings/pinctrl/starfive,jh7110-sys-pinctrl.yaml
|
||
|
@@ -0,0 +1,142 @@
|
||
|
+# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
|
||
|
+%YAML 1.2
|
||
|
+---
|
||
|
+$id: http://devicetree.org/schemas/pinctrl/starfive,jh7110-sys-pinctrl.yaml#
|
||
|
+$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||
|
+
|
||
|
+title: StarFive JH7110 SYS Pin Controller
|
||
|
+
|
||
|
+description: |
|
||
|
+ Bindings for the JH7110 RISC-V SoC from StarFive Technology Ltd.
|
||
|
+
|
||
|
+ Out of the SoC's many pins only the ones named PAD_GPIO0 to PAD_GPIO63
|
||
|
+ can be multiplexed and have configurable bias, drive strength,
|
||
|
+ schmitt trigger etc.
|
||
|
+ Some peripherals have their I/O go through the 64 "GPIOs". This also
|
||
|
+ includes a number of other UARTs, I2Cs, SPIs, PWMs etc.
|
||
|
+ All these peripherals are connected to all 64 GPIOs such that
|
||
|
+ any GPIO can be set up to be controlled by any of the peripherals.
|
||
|
+
|
||
|
+maintainers:
|
||
|
+ - Jianlong Huang <jianlong.huang@starfivetech.com>
|
||
|
+
|
||
|
+properties:
|
||
|
+ compatible:
|
||
|
+ const: starfive,jh7110-sys-pinctrl
|
||
|
+
|
||
|
+ reg:
|
||
|
+ maxItems: 1
|
||
|
+
|
||
|
+ clocks:
|
||
|
+ maxItems: 1
|
||
|
+
|
||
|
+ resets:
|
||
|
+ maxItems: 1
|
||
|
+
|
||
|
+ interrupts:
|
||
|
+ maxItems: 1
|
||
|
+
|
||
|
+ interrupt-controller: true
|
||
|
+
|
||
|
+ '#interrupt-cells':
|
||
|
+ const: 2
|
||
|
+
|
||
|
+ gpio-controller: true
|
||
|
+
|
||
|
+ '#gpio-cells':
|
||
|
+ const: 2
|
||
|
+
|
||
|
+patternProperties:
|
||
|
+ '-[0-9]+$':
|
||
|
+ type: object
|
||
|
+ additionalProperties: false
|
||
|
+ patternProperties:
|
||
|
+ '-pins$':
|
||
|
+ type: object
|
||
|
+ description: |
|
||
|
+ A pinctrl node should contain at least one subnode representing the
|
||
|
+ pinctrl groups available on the machine. Each subnode will list the
|
||
|
+ pins it needs, and how they should be configured, with regard to
|
||
|
+ muxer configuration, bias, input enable/disable, input schmitt
|
||
|
+ trigger enable/disable, slew-rate and drive strength.
|
||
|
+ allOf:
|
||
|
+ - $ref: /schemas/pinctrl/pincfg-node.yaml
|
||
|
+ - $ref: /schemas/pinctrl/pinmux-node.yaml
|
||
|
+ additionalProperties: false
|
||
|
+
|
||
|
+ properties:
|
||
|
+ pinmux:
|
||
|
+ description: |
|
||
|
+ The list of GPIOs and their mux settings that properties in the
|
||
|
+ node apply to. This should be set using the GPIOMUX or PINMUX
|
||
|
+ macros.
|
||
|
+
|
||
|
+ bias-disable: true
|
||
|
+
|
||
|
+ bias-pull-up:
|
||
|
+ type: boolean
|
||
|
+
|
||
|
+ bias-pull-down:
|
||
|
+ type: boolean
|
||
|
+
|
||
|
+ drive-strength:
|
||
|
+ enum: [ 2, 4, 8, 12 ]
|
||
|
+
|
||
|
+ input-enable: true
|
||
|
+
|
||
|
+ input-disable: true
|
||
|
+
|
||
|
+ input-schmitt-enable: true
|
||
|
+
|
||
|
+ input-schmitt-disable: true
|
||
|
+
|
||
|
+ slew-rate:
|
||
|
+ maximum: 1
|
||
|
+
|
||
|
+required:
|
||
|
+ - compatible
|
||
|
+ - reg
|
||
|
+ - clocks
|
||
|
+ - interrupts
|
||
|
+ - interrupt-controller
|
||
|
+ - '#interrupt-cells'
|
||
|
+ - gpio-controller
|
||
|
+ - '#gpio-cells'
|
||
|
+
|
||
|
+additionalProperties: false
|
||
|
+
|
||
|
+examples:
|
||
|
+ - |
|
||
|
+ pinctrl@13040000 {
|
||
|
+ compatible = "starfive,jh7110-sys-pinctrl";
|
||
|
+ reg = <0x13040000 0x10000>;
|
||
|
+ clocks = <&syscrg 112>;
|
||
|
+ resets = <&syscrg 2>;
|
||
|
+ interrupts = <86>;
|
||
|
+ interrupt-controller;
|
||
|
+ #interrupt-cells = <2>;
|
||
|
+ gpio-controller;
|
||
|
+ #gpio-cells = <2>;
|
||
|
+
|
||
|
+ uart0-0 {
|
||
|
+ tx-pins {
|
||
|
+ pinmux = <0xff140005>;
|
||
|
+ bias-disable;
|
||
|
+ drive-strength = <12>;
|
||
|
+ input-disable;
|
||
|
+ input-schmitt-disable;
|
||
|
+ slew-rate = <0>;
|
||
|
+ };
|
||
|
+
|
||
|
+ rx-pins {
|
||
|
+ pinmux = <0x0E000406>;
|
||
|
+ bias-pull-up;
|
||
|
+ drive-strength = <2>;
|
||
|
+ input-enable;
|
||
|
+ input-schmitt-enable;
|
||
|
+ slew-rate = <0>;
|
||
|
+ };
|
||
|
+ };
|
||
|
+ };
|
||
|
+
|
||
|
+...
|
||
|
--- a/MAINTAINERS
|
||
|
+++ b/MAINTAINERS
|
||
|
@@ -19658,13 +19658,15 @@ F: Documentation/devicetree/bindings/clo
|
||
|
F: drivers/clk/starfive/clk-starfive-jh71*
|
||
|
F: include/dt-bindings/clock/starfive?jh71*.h
|
||
|
|
||
|
-STARFIVE JH7100 PINCTRL DRIVER
|
||
|
+STARFIVE JH71X0 PINCTRL DRIVERS
|
||
|
M: Emil Renner Berthing <kernel@esmil.dk>
|
||
|
+M: Jianlong Huang <jianlong.huang@starfivetech.com>
|
||
|
L: linux-gpio@vger.kernel.org
|
||
|
S: Maintained
|
||
|
-F: Documentation/devicetree/bindings/pinctrl/starfive,jh7100-pinctrl.yaml
|
||
|
+F: Documentation/devicetree/bindings/pinctrl/starfive,jh71*.yaml
|
||
|
F: drivers/pinctrl/starfive/
|
||
|
F: include/dt-bindings/pinctrl/pinctrl-starfive-jh7100.h
|
||
|
+F: include/dt-bindings/pinctrl/starfive,jh7110-pinctrl.h
|
||
|
|
||
|
STARFIVE JH71X0 RESET CONTROLLER DRIVERS
|
||
|
M: Emil Renner Berthing <kernel@esmil.dk>
|
||
|
--- /dev/null
|
||
|
+++ b/include/dt-bindings/pinctrl/starfive,jh7110-pinctrl.h
|
||
|
@@ -0,0 +1,115 @@
|
||
|
+/* SPDX-License-Identifier: GPL-2.0 OR MIT */
|
||
|
+/*
|
||
|
+ * Copyright (C) 2022 Emil Renner Berthing <kernel@esmil.dk>
|
||
|
+ * Copyright (C) 2022 StarFive Technology Co., Ltd.
|
||
|
+ */
|
||
|
+
|
||
|
+#ifndef __DT_BINDINGS_PINCTRL_STARFIVE_JH7110_H__
|
||
|
+#define __DT_BINDINGS_PINCTRL_STARFIVE_JH7110_H__
|
||
|
+
|
||
|
+/* sys_iomux pins */
|
||
|
+#define PAD_GPIO0 0
|
||
|
+#define PAD_GPIO1 1
|
||
|
+#define PAD_GPIO2 2
|
||
|
+#define PAD_GPIO3 3
|
||
|
+#define PAD_GPIO4 4
|
||
|
+#define PAD_GPIO5 5
|
||
|
+#define PAD_GPIO6 6
|
||
|
+#define PAD_GPIO7 7
|
||
|
+#define PAD_GPIO8 8
|
||
|
+#define PAD_GPIO9 9
|
||
|
+#define PAD_GPIO10 10
|
||
|
+#define PAD_GPIO11 11
|
||
|
+#define PAD_GPIO12 12
|
||
|
+#define PAD_GPIO13 13
|
||
|
+#define PAD_GPIO14 14
|
||
|
+#define PAD_GPIO15 15
|
||
|
+#define PAD_GPIO16 16
|
||
|
+#define PAD_GPIO17 17
|
||
|
+#define PAD_GPIO18 18
|
||
|
+#define PAD_GPIO19 19
|
||
|
+#define PAD_GPIO20 20
|
||
|
+#define PAD_GPIO21 21
|
||
|
+#define PAD_GPIO22 22
|
||
|
+#define PAD_GPIO23 23
|
||
|
+#define PAD_GPIO24 24
|
||
|
+#define PAD_GPIO25 25
|
||
|
+#define PAD_GPIO26 26
|
||
|
+#define PAD_GPIO27 27
|
||
|
+#define PAD_GPIO28 28
|
||
|
+#define PAD_GPIO29 29
|
||
|
+#define PAD_GPIO30 30
|
||
|
+#define PAD_GPIO31 31
|
||
|
+#define PAD_GPIO32 32
|
||
|
+#define PAD_GPIO33 33
|
||
|
+#define PAD_GPIO34 34
|
||
|
+#define PAD_GPIO35 35
|
||
|
+#define PAD_GPIO36 36
|
||
|
+#define PAD_GPIO37 37
|
||
|
+#define PAD_GPIO38 38
|
||
|
+#define PAD_GPIO39 39
|
||
|
+#define PAD_GPIO40 40
|
||
|
+#define PAD_GPIO41 41
|
||
|
+#define PAD_GPIO42 42
|
||
|
+#define PAD_GPIO43 43
|
||
|
+#define PAD_GPIO44 44
|
||
|
+#define PAD_GPIO45 45
|
||
|
+#define PAD_GPIO46 46
|
||
|
+#define PAD_GPIO47 47
|
||
|
+#define PAD_GPIO48 48
|
||
|
+#define PAD_GPIO49 49
|
||
|
+#define PAD_GPIO50 50
|
||
|
+#define PAD_GPIO51 51
|
||
|
+#define PAD_GPIO52 52
|
||
|
+#define PAD_GPIO53 53
|
||
|
+#define PAD_GPIO54 54
|
||
|
+#define PAD_GPIO55 55
|
||
|
+#define PAD_GPIO56 56
|
||
|
+#define PAD_GPIO57 57
|
||
|
+#define PAD_GPIO58 58
|
||
|
+#define PAD_GPIO59 59
|
||
|
+#define PAD_GPIO60 60
|
||
|
+#define PAD_GPIO61 61
|
||
|
+#define PAD_GPIO62 62
|
||
|
+#define PAD_GPIO63 63
|
||
|
+#define PAD_SD0_CLK 64
|
||
|
+#define PAD_SD0_CMD 65
|
||
|
+#define PAD_SD0_DATA0 66
|
||
|
+#define PAD_SD0_DATA1 67
|
||
|
+#define PAD_SD0_DATA2 68
|
||
|
+#define PAD_SD0_DATA3 69
|
||
|
+#define PAD_SD0_DATA4 70
|
||
|
+#define PAD_SD0_DATA5 71
|
||
|
+#define PAD_SD0_DATA6 72
|
||
|
+#define PAD_SD0_DATA7 73
|
||
|
+#define PAD_SD0_STRB 74
|
||
|
+#define PAD_GMAC1_MDC 75
|
||
|
+#define PAD_GMAC1_MDIO 76
|
||
|
+#define PAD_GMAC1_RXD0 77
|
||
|
+#define PAD_GMAC1_RXD1 78
|
||
|
+#define PAD_GMAC1_RXD2 79
|
||
|
+#define PAD_GMAC1_RXD3 80
|
||
|
+#define PAD_GMAC1_RXDV 81
|
||
|
+#define PAD_GMAC1_RXC 82
|
||
|
+#define PAD_GMAC1_TXD0 83
|
||
|
+#define PAD_GMAC1_TXD1 84
|
||
|
+#define PAD_GMAC1_TXD2 85
|
||
|
+#define PAD_GMAC1_TXD3 86
|
||
|
+#define PAD_GMAC1_TXEN 87
|
||
|
+#define PAD_GMAC1_TXC 88
|
||
|
+#define PAD_QSPI_SCLK 89
|
||
|
+#define PAD_QSPI_CS0 90
|
||
|
+#define PAD_QSPI_DATA0 91
|
||
|
+#define PAD_QSPI_DATA1 92
|
||
|
+#define PAD_QSPI_DATA2 93
|
||
|
+#define PAD_QSPI_DATA3 94
|
||
|
+
|
||
|
+#define GPOUT_LOW 0
|
||
|
+#define GPOUT_HIGH 1
|
||
|
+
|
||
|
+#define GPOEN_ENABLE 0
|
||
|
+#define GPOEN_DISABLE 1
|
||
|
+
|
||
|
+#define GPI_NONE 255
|
||
|
+
|
||
|
+#endif
|