]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
dt-bindings: clock: convert lpc1850-cgu.txt to yaml format
authorFrank Li <Frank.Li@nxp.com>
Fri, 6 Jun 2025 16:24:09 +0000 (12:24 -0400)
committerStephen Boyd <sboyd@kernel.org>
Thu, 24 Jul 2025 21:26:01 +0000 (14:26 -0700)
Convert lpc1850-cgu.txt to yaml format.

Additional changes:
- remove extra clock source nodes in example.
- remove clock consumer in example.
- remove clock-output-names and clock-clock-indices from required list to
  match existed dts.

Signed-off-by: Frank Li <Frank.Li@nxp.com>
Link: https://lore.kernel.org/r/20250606162410.1361169-1-Frank.Li@nxp.com
Reviewed-by: Rob Herring (Arm) <robh@kernel.org>
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
Documentation/devicetree/bindings/clock/lpc1850-cgu.txt [deleted file]
Documentation/devicetree/bindings/clock/nxp,lpc1850-cgu.yaml [new file with mode: 0644]

diff --git a/Documentation/devicetree/bindings/clock/lpc1850-cgu.txt b/Documentation/devicetree/bindings/clock/lpc1850-cgu.txt
deleted file mode 100644 (file)
index 2cc32a9..0000000
+++ /dev/null
@@ -1,131 +0,0 @@
-* NXP LPC1850 Clock Generation Unit (CGU)
-
-The CGU generates multiple independent clocks for the core and the
-peripheral blocks of the LPC18xx. Each independent clock is called
-a base clock and itself is one of the inputs to the two Clock
-Control Units (CCUs) which control the branch clocks to the
-individual peripherals.
-
-The CGU selects the inputs to the clock generators from multiple
-clock sources, controls the clock generation, and routes the outputs
-of the clock generators through the clock source bus to the output
-stages. Each output stage provides an independent clock source and
-corresponds to one of the base clocks for the LPC18xx.
-
- - Above text taken from NXP LPC1850 User Manual.
-
-
-This binding uses the common clock binding:
-    Documentation/devicetree/bindings/clock/clock-bindings.txt
-
-Required properties:
-- compatible:
-       Should be "nxp,lpc1850-cgu"
-- reg:
-       Shall define the base and range of the address space
-       containing clock control registers
-- #clock-cells:
-       Shall have value <1>.  The permitted clock-specifier values
-       are the base clock numbers defined below.
-- clocks:
-       Shall contain a list of phandles for the external input
-       sources to the CGU. The list shall be in the following
-       order: xtal, 32khz, enet_rx_clk, enet_tx_clk, gp_clkin.
-- clock-indices:
-       Shall be an ordered list of numbers defining the base clock
-       number provided by the CGU.
-- clock-output-names:
-       Shall be an ordered list of strings defining the names of
-       the clocks provided by the CGU.
-
-Which base clocks that are available on the CGU depends on the
-specific LPC part. Base clocks are numbered from 0 to 27.
-
-Number:                Name:                   Description:
- 0             BASE_SAFE_CLK           Base safe clock (always on) for WWDT
- 1             BASE_USB0_CLK           Base clock for USB0
- 2             BASE_PERIPH_CLK         Base clock for Cortex-M0SUB subsystem,
-                                       SPI, and SGPIO
- 3             BASE_USB1_CLK           Base clock for USB1
- 4             BASE_CPU_CLK            System base clock for ARM Cortex-M core
-                                       and APB peripheral blocks #0 and #2
- 5             BASE_SPIFI_CLK          Base clock for SPIFI
- 6             BASE_SPI_CLK            Base clock for SPI
- 7             BASE_PHY_RX_CLK         Base clock for Ethernet PHY Receive clock
- 8             BASE_PHY_TX_CLK         Base clock for Ethernet PHY Transmit clock
- 9             BASE_APB1_CLK           Base clock for APB peripheral block # 1
-10             BASE_APB3_CLK           Base clock for APB peripheral block # 3
-11             BASE_LCD_CLK            Base clock for LCD
-12             BASE_ADCHS_CLK          Base clock for ADCHS
-13             BASE_SDIO_CLK           Base clock for SD/MMC
-14             BASE_SSP0_CLK           Base clock for SSP0
-15             BASE_SSP1_CLK           Base clock for SSP1
-16             BASE_UART0_CLK          Base clock for UART0
-17             BASE_UART1_CLK          Base clock for UART1
-18             BASE_UART2_CLK          Base clock for UART2
-19             BASE_UART3_CLK          Base clock for UART3
-20             BASE_OUT_CLK            Base clock for CLKOUT pin
-24-21          -                       Reserved
-25             BASE_AUDIO_CLK          Base clock for audio system (I2S)
-26             BASE_CGU_OUT0_CLK       Base clock for CGU_OUT0 clock output
-27             BASE_CGU_OUT1_CLK       Base clock for CGU_OUT1 clock output
-
-BASE_PERIPH_CLK and BASE_SPI_CLK is only available on LPC43xx.
-BASE_ADCHS_CLK is only available on LPC4370.
-
-
-Example board file:
-
-/ {
-       clocks {
-               xtal: xtal {
-                       compatible = "fixed-clock";
-                       #clock-cells = <0>;
-                       clock-frequency = <12000000>;
-               };
-
-               xtal32: xtal32 {
-                       compatible = "fixed-clock";
-                       #clock-cells = <0>;
-                       clock-frequency = <32768>;
-               };
-
-               enet_rx_clk: enet_rx_clk {
-                       compatible = "fixed-clock";
-                       #clock-cells = <0>;
-                       clock-frequency = <0>;
-                       clock-output-names = "enet_rx_clk";
-               };
-
-               enet_tx_clk: enet_tx_clk {
-                       compatible = "fixed-clock";
-                       #clock-cells = <0>;
-                       clock-frequency = <0>;
-                       clock-output-names = "enet_tx_clk";
-               };
-
-               gp_clkin: gp_clkin {
-                       compatible = "fixed-clock";
-                       #clock-cells = <0>;
-                       clock-frequency = <0>;
-                       clock-output-names = "gp_clkin";
-               };
-       };
-
-       soc {
-               cgu: clock-controller@40050000 {
-                       compatible = "nxp,lpc1850-cgu";
-                       reg = <0x40050000 0x1000>;
-                       #clock-cells = <1>;
-                       clocks = <&xtal>, <&creg_clk 1>, <&enet_rx_clk>, <&enet_tx_clk>, <&gp_clkin>;
-               };
-
-               /* A CGU and CCU clock consumer */
-               lcdc: lcdc@40008000 {
-                       ...
-                       clocks = <&cgu BASE_LCD_CLK>, <&ccu1 CLK_CPU_LCD>;
-                       clock-names = "clcdclk", "apb_pclk";
-                       ...
-               };
-       };
-};
diff --git a/Documentation/devicetree/bindings/clock/nxp,lpc1850-cgu.yaml b/Documentation/devicetree/bindings/clock/nxp,lpc1850-cgu.yaml
new file mode 100644 (file)
index 0000000..ed178c7
--- /dev/null
@@ -0,0 +1,99 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/clock/nxp,lpc1850-cgu.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: NXP LPC1850 Clock Generation Unit (CGU)
+
+description: >
+  The CGU generates multiple independent clocks for the core and the
+  peripheral blocks of the LPC18xx. Each independent clock is called
+  a base clock and itself is one of the inputs to the two Clock
+  Control Units (CCUs) which control the branch clocks to the
+  individual peripherals.
+
+  The CGU selects the inputs to the clock generators from multiple
+  clock sources, controls the clock generation, and routes the outputs
+  of the clock generators through the clock source bus to the output
+  stages. Each output stage provides an independent clock source and
+  corresponds to one of the base clocks for the LPC18xx.
+
+  Above text taken from NXP LPC1850 User Manual.
+
+maintainers:
+  - Frank Li <Frank.Li@nxp.com>
+
+properties:
+  compatible:
+    const: nxp,lpc1850-cgu
+
+  reg:
+    maxItems: 1
+
+  '#clock-cells':
+    const: 1
+    description: |
+      Which base clocks that are available on the CGU depends on the
+      specific LPC part. Base clocks are numbered from 0 to 27.
+
+      Number:         Name:                   Description:
+       0              BASE_SAFE_CLK           Base safe clock (always on) for WWDT
+       1              BASE_USB0_CLK           Base clock for USB0
+       2              BASE_PERIPH_CLK         Base clock for Cortex-M0SUB subsystem,
+                                        SPI, and SGPIO
+       3              BASE_USB1_CLK           Base clock for USB1
+       4              BASE_CPU_CLK            System base clock for ARM Cortex-M core
+                                        and APB peripheral blocks #0 and #2
+       5              BASE_SPIFI_CLK          Base clock for SPIFI
+       6              BASE_SPI_CLK            Base clock for SPI
+       7              BASE_PHY_RX_CLK         Base clock for Ethernet PHY Receive clock
+       8              BASE_PHY_TX_CLK         Base clock for Ethernet PHY Transmit clock
+       9              BASE_APB1_CLK           Base clock for APB peripheral block # 1
+      10              BASE_APB3_CLK           Base clock for APB peripheral block # 3
+      11              BASE_LCD_CLK            Base clock for LCD
+      12              BASE_ADCHS_CLK          Base clock for ADCHS
+      13              BASE_SDIO_CLK           Base clock for SD/MMC
+      14              BASE_SSP0_CLK           Base clock for SSP0
+      15              BASE_SSP1_CLK           Base clock for SSP1
+      16              BASE_UART0_CLK          Base clock for UART0
+      17              BASE_UART1_CLK          Base clock for UART1
+      18              BASE_UART2_CLK          Base clock for UART2
+      19              BASE_UART3_CLK          Base clock for UART3
+      20              BASE_OUT_CLK            Base clock for CLKOUT pin
+      24-21           -                       Reserved
+      25              BASE_AUDIO_CLK          Base clock for audio system (I2S)
+      26              BASE_CGU_OUT0_CLK       Base clock for CGU_OUT0 clock output
+      27              BASE_CGU_OUT1_CLK       Base clock for CGU_OUT1 clock output
+
+      BASE_PERIPH_CLK and BASE_SPI_CLK is only available on LPC43xx.
+      BASE_ADCHS_CLK is only available on LPC4370.
+
+  clocks:
+    maxItems: 5
+
+  clock-indices:
+    minItems: 1
+    maxItems: 28
+
+  clock-output-names:
+    minItems: 1
+    maxItems: 28
+
+required:
+  - compatible
+  - reg
+  - clocks
+  - '#clock-cells'
+
+additionalProperties: false
+
+examples:
+  - |
+    clock-controller@40050000 {
+        compatible = "nxp,lpc1850-cgu";
+        reg = <0x40050000 0x1000>;
+        #clock-cells = <1>;
+        clocks = <&xtal>, <&creg_clk 1>, <&enet_rx_clk>, <&enet_tx_clk>, <&gp_clkin>;
+    };
+