Re: [PATCH v5 1/4] dt-bindings: Document the hi3559a clock bindings

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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
>>
> .
> 



[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]


  Powered by Linux