[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250226234234.125305-2-inochiama@gmail.com>
Date: Thu, 27 Feb 2025 07:42:29 +0800
From: Inochi Amaoto <inochiama@...il.com>
To: Philipp Zabel <p.zabel@...gutronix.de>,
Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>,
Chen Wang <unicorn_wang@...look.com>,
Inochi Amaoto <inochiama@...il.com>,
Paul Walmsley <paul.walmsley@...ive.com>,
Palmer Dabbelt <palmer@...belt.com>,
Albert Ou <aou@...s.berkeley.edu>,
Uwe Kleine-König <u.kleine-koenig@...libre.com>,
Guo Ren <guoren@...nel.org>
Cc: devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org,
sophgo@...ts.linux.dev,
linux-riscv@...ts.infradead.org,
Yixun Lan <dlan@...too.org>,
Longbin Li <looong.bin@...il.com>
Subject: [PATCH v2 1/5] dt-bindings: reset: add generic bit reset controller
Some SoCs from Aspeed, Allwinner, Sophgo and Synopsys have
a simple reset controller by toggling bit. It is a hard time
for each device to add its own compatible to the driver.
Since these devices share a common design, it is possible to
add a common device to reduce these unnecessary change for
the driver.
Add common binding for these kind generic reset controller.
Check the binding description for its requirement and
suitable scenarios.
Signed-off-by: Inochi Amaoto <inochiama@...il.com>
---
.../bindings/reset/reset-simple.yaml | 61 +++++++++++++++++++
1 file changed, 61 insertions(+)
create mode 100644 Documentation/devicetree/bindings/reset/reset-simple.yaml
diff --git a/Documentation/devicetree/bindings/reset/reset-simple.yaml b/Documentation/devicetree/bindings/reset/reset-simple.yaml
new file mode 100644
index 000000000000..86c33a608148
--- /dev/null
+++ b/Documentation/devicetree/bindings/reset/reset-simple.yaml
@@ -0,0 +1,61 @@
+# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/reset/reset-simple.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Generic Bit Reset Controller
+
+maintainers:
+ - Inochi Amaoto <inochiama@...il.com>
+
+description: |
+ This document defines device tree properties common to reset
+ controller devices that perform assert/deassert by simply
+ toggling bit.
+
+ All devices in this binding should satisfy the following requirement:
+ - There is a single, contiguous range of 32-bit registers.
+ - All bits in each register directly control a reset line.
+ - There are no self-deasserting resets.
+ - There are no timing requirements.
+ - The bits are exclusively resets, nothing else.
+ - All bits behave the same, so all reset bits are either
+ active-high or all are active-low.
+ - The bits can be read back, but the read status may
+ be active-low independently from the writes.
+
+ If the device is not meet the requirement, it should use its
+ own binding to describe the device.
+
+properties:
+ compatible:
+ const: reset-simple
+
+ reg:
+ maxItems: 1
+
+ "#reset-cells":
+ const: 1
+
+ active-low:
+ type: boolean
+ description:
+ If true, bits are cleared to assert the reset. Otherwise,
+ bits are set to assert the reset. This also applies to
+ read back.
+
+required:
+ - compatible
+ - reg
+ - "#reset-cells"
+
+additionalProperties: false
+
+examples:
+ - |
+ reset-controller@...0000 {
+ compatible = "reset-simple";
+ reg = <0x1000000 0x1000>;
+ #reset-cells = <1>;
+ };
--
2.48.1
Powered by blists - more mailing lists