On 2020/12/1 6:07, Rob Herring wrote: > On Thu, Nov 19, 2020 at 08:01:26PM +0000, Dongjiu Geng wrote: >> Add DT bindings documentation for hi3559a SoC clock. >> >> Signed-off-by: Dongjiu Geng <gengdongjiu@xxxxxxxxxx> >> --- >> .../clock/hisilicon,hi3559av100-clock.yaml | 66 +++++++ >> include/dt-bindings/clock/hi3559av100-clock.h | 165 ++++++++++++++++++ >> 2 files changed, 231 insertions(+) >> create mode 100644 Documentation/devicetree/bindings/clock/hisilicon,hi3559av100-clock.yaml >> create mode 100644 include/dt-bindings/clock/hi3559av100-clock.h >> >> diff --git a/Documentation/devicetree/bindings/clock/hisilicon,hi3559av100-clock.yaml b/Documentation/devicetree/bindings/clock/hisilicon,hi3559av100-clock.yaml >> new file mode 100644 >> index 000000000000..0f531e8186d2 >> --- /dev/null >> +++ b/Documentation/devicetree/bindings/clock/hisilicon,hi3559av100-clock.yaml >> @@ -0,0 +1,66 @@ >> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >> +%YAML 1.2 >> +--- >> +$id: http://devicetree.org/schemas/clock/hisilicon,hi3559av100-clock.yaml# >> +$schema: http://devicetree.org/meta-schemas/core.yaml# >> + >> +title: Hisilicon SOC Clock for HI3559AV100 >> + >> +maintainers: >> + - Dongjiu Geng <gengdongjiu@xxxxxxxxxx> >> + >> +description: | >> + Hisilicon SOC clock control module which supports the clocks, resets and >> + power domains on HI3559AV100. >> + >> + See also: >> + dt-bindings/clock/hi3559av100-clock.h >> + >> +properties: >> + compatible: >> + enum: >> + - hisilicon,hi3559av100-clock >> + - hisilicon,hi3559av100-shub-clock >> + >> + reg: >> + minItems: 1 >> + maxItems: 2 >> + >> + '#clock-cells': >> + const: 1 >> + >> + '#reset-cells': >> + const: 2 > > What's in each cell? I will add description for each cell. > >> + >> + '#address-cells': >> + const: 2 >> + >> + '#size-cells': >> + const: 2 > > #address-cells and #size-cells are for child nodes, but you have none so > drop them. Ok, thanks for the reminder. > >> + >> +required: >> + - compatible >> + - reg >> + - '#clock-cells' >> + - '#reset-cells' >> + - '#address-cells' >> + - '#size-cells' >> + >> +additionalProperties: false >> + >> +examples: >> + - | >> + soc { >> + #address-cells = <2>; >> + #size-cells = <2>; >> + >> + clock: clock0@12010000 { > > clock-controller@... ok. > >> + compatible = "hisilicon,hi3559av100-clock"; >> + #address-cells = <2>; >> + #size-cells = <2>; >> + #clock-cells = <1>; >> + #reset-cells = <2>; >> + reg = <0x0 0x12010000 0x0 0x10000>; >> + }; >> + }; >> +... >> diff --git a/include/dt-bindings/clock/hi3559av100-clock.h b/include/dt-bindings/clock/hi3559av100-clock.h >> new file mode 100644 >> index 000000000000..88baa86cff85 >> --- /dev/null >> +++ b/include/dt-bindings/clock/hi3559av100-clock.h >> @@ -0,0 +1,165 @@ >> +/* SPDX-License-Identifier: GPL-2.0-only */ > > Don't care about non-GPL OS/users? will fix it. I will modify it to "GPL-2.0-only OR BSD-2-Clause" > >> +/* >> + * Copyright (c) 2019-2020, Huawei Tech. Co., Ltd. >> + * >> + * Author: Dongjiu Geng <gengdongjiu@xxxxxxxxxx> >> + */ >> + >> +#ifndef __DTS_HI3559AV100_CLOCK_H >> +#define __DTS_HI3559AV100_CLOCK_H >> + >> +/* fixed rate */ >> +#define HI3559AV100_FIXED_1188M 1 >> +#define HI3559AV100_FIXED_1000M 2 >> +#define HI3559AV100_FIXED_842M 3 >> +#define HI3559AV100_FIXED_792M 4 >> +#define HI3559AV100_FIXED_750M 5 >> +#define HI3559AV100_FIXED_710M 6 >> +#define HI3559AV100_FIXED_680M 7 >> +#define HI3559AV100_FIXED_667M 8 >> +#define HI3559AV100_FIXED_631M 9 >> +#define HI3559AV100_FIXED_600M 10 >> +#define HI3559AV100_FIXED_568M 11 >> +#define HI3559AV100_FIXED_500M 12 >> +#define HI3559AV100_FIXED_475M 13 >> +#define HI3559AV100_FIXED_428M 14 >> +#define HI3559AV100_FIXED_400M 15 >> +#define HI3559AV100_FIXED_396M 16 >> +#define HI3559AV100_FIXED_300M 17 >> +#define HI3559AV100_FIXED_250M 18 >> +#define HI3559AV100_FIXED_198M 19 >> +#define HI3559AV100_FIXED_187p5M 20 >> +#define HI3559AV100_FIXED_150M 21 >> +#define HI3559AV100_FIXED_148p5M 22 >> +#define HI3559AV100_FIXED_125M 23 >> +#define HI3559AV100_FIXED_107M 24 >> +#define HI3559AV100_FIXED_100M 25 >> +#define HI3559AV100_FIXED_99M 26 >> +#define HI3559AV100_FIXED_74p25M 27 >> +#define HI3559AV100_FIXED_72M 28 >> +#define HI3559AV100_FIXED_60M 29 >> +#define HI3559AV100_FIXED_54M 30 >> +#define HI3559AV100_FIXED_50M 31 >> +#define HI3559AV100_FIXED_49p5M 32 >> +#define HI3559AV100_FIXED_37p125M 33 >> +#define HI3559AV100_FIXED_36M 34 >> +#define HI3559AV100_FIXED_32p4M 35 >> +#define HI3559AV100_FIXED_27M 36 >> +#define HI3559AV100_FIXED_25M 37 >> +#define HI3559AV100_FIXED_24M 38 >> +#define HI3559AV100_FIXED_12M 39 >> +#define HI3559AV100_FIXED_3M 40 >> +#define HI3559AV100_FIXED_1p6M 41 >> +#define HI3559AV100_FIXED_400K 42 >> +#define HI3559AV100_FIXED_100K 43 >> +#define HI3559AV100_FIXED_200M 44 >> +#define HI3559AV100_FIXED_75M 75 >> + >> +#define HI3559AV100_I2C0_CLK 50 >> +#define HI3559AV100_I2C1_CLK 51 >> +#define HI3559AV100_I2C2_CLK 52 >> +#define HI3559AV100_I2C3_CLK 53 >> +#define HI3559AV100_I2C4_CLK 54 >> +#define HI3559AV100_I2C5_CLK 55 >> +#define HI3559AV100_I2C6_CLK 56 >> +#define HI3559AV100_I2C7_CLK 57 >> +#define HI3559AV100_I2C8_CLK 58 >> +#define HI3559AV100_I2C9_CLK 59 >> +#define HI3559AV100_I2C10_CLK 60 >> +#define HI3559AV100_I2C11_CLK 61 >> + >> +#define HI3559AV100_SPI0_CLK 62 >> +#define HI3559AV100_SPI1_CLK 63 >> +#define HI3559AV100_SPI2_CLK 64 >> +#define HI3559AV100_SPI3_CLK 65 >> +#define HI3559AV100_SPI4_CLK 66 >> +#define HI3559AV100_SPI5_CLK 67 >> +#define HI3559AV100_SPI6_CLK 68 >> + >> +#define HI3559AV100_EDMAC_CLK 69 >> +#define HI3559AV100_EDMAC_AXICLK 70 >> +#define HI3559AV100_EDMAC1_CLK 71 >> +#define HI3559AV100_EDMAC1_AXICLK 72 >> +#define HI3559AV100_VDMAC_CLK 73 >> + >> +/* mux clocks */ >> +#define HI3559AV100_FMC_MUX 80 >> +#define HI3559AV100_SYSAPB_MUX 81 >> +#define HI3559AV100_UART_MUX 82 >> +#define HI3559AV100_SYSBUS_MUX 83 >> +#define HI3559AV100_A73_MUX 84 >> +#define HI3559AV100_MMC0_MUX 85 >> +#define HI3559AV100_MMC1_MUX 86 >> +#define HI3559AV100_MMC2_MUX 87 >> +#define HI3559AV100_MMC3_MUX 88 >> + >> +/* gate clocks */ >> +#define HI3559AV100_FMC_CLK 90 >> +#define HI3559AV100_UART0_CLK 91 >> +#define HI3559AV100_UART1_CLK 92 >> +#define HI3559AV100_UART2_CLK 93 >> +#define HI3559AV100_UART3_CLK 94 >> +#define HI3559AV100_UART4_CLK 95 >> +#define HI3559AV100_MMC0_CLK 96 >> +#define HI3559AV100_MMC1_CLK 97 >> +#define HI3559AV100_MMC2_CLK 98 >> +#define HI3559AV100_MMC3_CLK 99 >> + >> +#define HI3559AV100_ETH_CLK 100 >> +#define HI3559AV100_ETH_MACIF_CLK 101 >> +#define HI3559AV100_ETH1_CLK 102 >> +#define HI3559AV100_ETH1_MACIF_CLK 103 >> + >> +/* complex */ >> +#define HI3559AV100_MAC0_CLK 110 >> +#define HI3559AV100_MAC1_CLK 111 >> +#define HI3559AV100_SATA_CLK 112 >> +#define HI3559AV100_USB_CLK 113 >> +#define HI3559AV100_USB1_CLK 114 >> + >> +/* pll clocks */ >> +#define HI3559AV100_APLL_CLK 250 >> +#define HI3559AV100_GPLL_CLK 251 >> + >> +#define HI3559AV100_CRG_NR_CLKS 256 >> + >> +#define HI3559AV100_SHUB_SOURCE_SOC_24M 0 >> +#define HI3559AV100_SHUB_SOURCE_SOC_200M 1 >> +#define HI3559AV100_SHUB_SOURCE_SOC_300M 2 >> +#define HI3559AV100_SHUB_SOURCE_PLL 3 >> +#define HI3559AV100_SHUB_SOURCE_CLK 4 >> + >> +#define HI3559AV100_SHUB_I2C0_CLK 10 >> +#define HI3559AV100_SHUB_I2C1_CLK 11 >> +#define HI3559AV100_SHUB_I2C2_CLK 12 >> +#define HI3559AV100_SHUB_I2C3_CLK 13 >> +#define HI3559AV100_SHUB_I2C4_CLK 14 >> +#define HI3559AV100_SHUB_I2C5_CLK 15 >> +#define HI3559AV100_SHUB_I2C6_CLK 16 >> +#define HI3559AV100_SHUB_I2C7_CLK 17 >> + >> +#define HI3559AV100_SHUB_SPI_SOURCE_CLK 20 >> +#define HI3559AV100_SHUB_SPI4_SOURCE_CLK 21 >> +#define HI3559AV100_SHUB_SPI0_CLK 22 >> +#define HI3559AV100_SHUB_SPI1_CLK 23 >> +#define HI3559AV100_SHUB_SPI2_CLK 24 >> +#define HI3559AV100_SHUB_SPI3_CLK 25 >> +#define HI3559AV100_SHUB_SPI4_CLK 26 >> + >> +#define HI3559AV100_SHUB_UART_CLK_32K 30 >> +#define HI3559AV100_SHUB_UART_SOURCE_CLK 31 >> +#define HI3559AV100_SHUB_UART_DIV_CLK 32 >> +#define HI3559AV100_SHUB_UART0_CLK 33 >> +#define HI3559AV100_SHUB_UART1_CLK 34 >> +#define HI3559AV100_SHUB_UART2_CLK 35 >> +#define HI3559AV100_SHUB_UART3_CLK 36 >> +#define HI3559AV100_SHUB_UART4_CLK 37 >> +#define HI3559AV100_SHUB_UART5_CLK 38 >> +#define HI3559AV100_SHUB_UART6_CLK 39 >> + >> +#define HI3559AV100_SHUB_EDMAC_CLK 40 >> + >> +#define HI3559AV100_SHUB_NR_CLKS 50 >> + >> +#endif /* __DTS_HI3559AV100_CLOCK_H */ >> + >> -- >> 2.17.1 >> > . >