linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 01/11] dt-bindings: timer: Convert Allwinner A10 Timer to a schema
@ 2019-07-22  8:12 Maxime Ripard
  2019-07-22  8:12 ` [PATCH 02/11] dt-bindings: timer: Add missing compatibles Maxime Ripard
                   ` (10 more replies)
  0 siblings, 11 replies; 23+ messages in thread
From: Maxime Ripard @ 2019-07-22  8:12 UTC (permalink / raw)
  To: Mark Rutland, Rob Herring, Frank Rowand, Chen-Yu Tsai,
	Maxime Ripard, daniel.lezcano, tglx
  Cc: devicetree, linux-arm-kernel

The older Allwinner SoCs have a Timer supported in Linux, with a matching
Device Tree binding.

While the original binding only mentions one interrupt, the timer actually
has 6 of them.

Now that we have the DT validation in place, let's convert the device tree
bindings for that controller over to a YAML schemas.

Signed-off-by: Maxime Ripard <maxime.ripard@bootlin.com>
---
 .../timer/allwinner,sun4i-a10-timer.yaml      | 76 +++++++++++++++++++
 .../bindings/timer/allwinner,sun4i-timer.txt  | 19 -----
 2 files changed, 76 insertions(+), 19 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/timer/allwinner,sun4i-a10-timer.yaml
 delete mode 100644 Documentation/devicetree/bindings/timer/allwinner,sun4i-timer.txt

diff --git a/Documentation/devicetree/bindings/timer/allwinner,sun4i-a10-timer.yaml b/Documentation/devicetree/bindings/timer/allwinner,sun4i-a10-timer.yaml
new file mode 100644
index 000000000000..7292a424092c
--- /dev/null
+++ b/Documentation/devicetree/bindings/timer/allwinner,sun4i-a10-timer.yaml
@@ -0,0 +1,76 @@
+# SPDX-License-Identifier: GPL-2.0
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/timer/allwinner,sun4i-a10-timer.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Allwinner A10 Timer Device Tree Bindings
+
+maintainers:
+  - Chen-Yu Tsai <wens@csie.org>
+  - Maxime Ripard <maxime.ripard@bootlin.com>
+
+properties:
+  compatible:
+    enum:
+      - allwinner,sun4i-a10-timer
+      - allwinner,suniv-f1c100s-timer
+
+  reg:
+    maxItems: 1
+
+  interrupts:
+    description:
+      List of timers interrupts
+
+  clocks:
+    maxItems: 1
+
+allOf:
+  - if:
+      properties:
+        compatible:
+          items:
+            const: allwinner,sun4i-a10-timer
+
+    then:
+      properties:
+        interrupts:
+          minItems: 6
+          maxItems: 6
+
+  - if:
+      properties:
+        compatible:
+          items:
+            const: allwinner,suniv-f1c100s-timer
+
+    then:
+      properties:
+        interrupts:
+          minItems: 3
+          maxItems: 3
+
+required:
+  - compatible
+  - reg
+  - interrupts
+  - clocks
+
+additionalProperties: false
+
+examples:
+  - |
+    timer {
+        compatible = "allwinner,sun4i-a10-timer";
+        reg = <0x01c20c00 0x400>;
+        interrupts = <22>,
+                     <23>,
+                     <24>,
+                     <25>,
+                     <67>,
+                     <68>;
+        clocks = <&osc>;
+    };
+
+...
diff --git a/Documentation/devicetree/bindings/timer/allwinner,sun4i-timer.txt b/Documentation/devicetree/bindings/timer/allwinner,sun4i-timer.txt
deleted file mode 100644
index 3da9d515c03a..000000000000
--- a/Documentation/devicetree/bindings/timer/allwinner,sun4i-timer.txt
+++ /dev/null
@@ -1,19 +0,0 @@
-Allwinner A1X SoCs Timer Controller
-
-Required properties:
-
-- compatible : should be one of the following:
-              "allwinner,sun4i-a10-timer"
-              "allwinner,suniv-f1c100s-timer"
-- reg : Specifies base physical address and size of the registers.
-- interrupts : The interrupt of the first timer
-- clocks: phandle to the source clock (usually a 24 MHz fixed clock)
-
-Example:
-
-timer {
-	compatible = "allwinner,sun4i-a10-timer";
-	reg = <0x01c20c00 0x400>;
-	interrupts = <22>;
-	clocks = <&osc>;
-};
-- 
2.21.0


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply related	[flat|nested] 23+ messages in thread

end of thread, other threads:[~2019-08-19 19:43 UTC | newest]

Thread overview: 23+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-07-22  8:12 [PATCH 01/11] dt-bindings: timer: Convert Allwinner A10 Timer to a schema Maxime Ripard
2019-07-22  8:12 ` [PATCH 02/11] dt-bindings: timer: Add missing compatibles Maxime Ripard
2019-07-22 15:07   ` Rob Herring
2019-07-22  8:12 ` [PATCH 03/11] clocksource: sun4i: " Maxime Ripard
2019-08-12  8:58   ` Maxime Ripard
2019-08-12  8:59   ` Daniel Lezcano
2019-08-12  9:16     ` Maxime Ripard
2019-08-12  9:21       ` Daniel Lezcano
2019-08-12 11:24         ` Maxime Ripard
2019-08-19 13:30           ` Maxime Ripard
2019-08-19 13:45             ` Daniel Lezcano
2019-08-19 19:13               ` Maxime Ripard
2019-08-19 19:43                 ` Daniel Lezcano
2019-07-22  8:12 ` [PATCH 04/11] dt-bindings: timer: Convert Allwinner A13 HSTimer to a schema Maxime Ripard
2019-07-22 15:08   ` Rob Herring
2019-07-22  8:12 ` [PATCH 05/11] ARM: dts: sun4i: Add missing timers interrupts Maxime Ripard
2019-07-22  8:12 ` [PATCH 06/11] ARM: dts: sun5i: " Maxime Ripard
2019-07-22  8:12 ` [PATCH 07/11] ARM: dts: sun6i: " Maxime Ripard
2019-07-22  8:12 ` [PATCH 08/11] ARM: dts: a23/a33: Change the timers compatible Maxime Ripard
2019-07-22  8:12 ` [PATCH 09/11] ARM: dts: a83t: " Maxime Ripard
2019-07-22  8:12 ` [PATCH 10/11] ARM: dts: h3: " Maxime Ripard
2019-07-22  8:12 ` [PATCH 11/11] ARM: dts: v3s: " Maxime Ripard
2019-07-22 15:05 ` [PATCH 01/11] dt-bindings: timer: Convert Allwinner A10 Timer to a schema Rob Herring

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).