Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2342621pxu; Mon, 7 Dec 2020 04:18:57 -0800 (PST) X-Google-Smtp-Source: ABdhPJy0gR2wFQRYLbjbP1Dt9sIZkj3+uycjswpnU5hkOwXS2oofI/wvb6kOh+LUthRnl+5EbadN X-Received: by 2002:a17:906:e24f:: with SMTP id gq15mr17256843ejb.256.1607343537197; Mon, 07 Dec 2020 04:18:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607343537; cv=none; d=google.com; s=arc-20160816; b=GRujG3vElTHtlEzrzmg0ZK7l3PnfRaHfN+b5X6H82mbskxGNEOgg1Ab7ahZFhoMVsw oddSxEYunsSO/keOXQwDN3Pc9Euaf2kWMgYPHSNmjZjtiff26SnrYuFXbdbcCDKr5tn1 TO5IoRUTXq6vUUt5XxbvXzee+jevwnYUXS/fyEPpOytwDZ04FOnm1FigZpPKItdpZPTv 9BfN5Le4AWuhdbk4raJUS6TDBAkYS7gEsSl59/KuXqDhCZEcssuxzwcEyqjryT0a/uJw zdWhfL0off20MlKe7DeosCLORQav9WlitQ0Lg1a3K0Z+/AvcHEkHuYKQ1rb5j4ShIwJx K0Pg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=okMB9KPJcSNFMnH/9pop+rOOY1/Rrkt4/puNcfO4gi8=; b=WBsb8Cbs6DvVJCJ46FAHsNS2f16BMS5t4CjRV0Gxhr8aytxbfnYwxZr0eSMie5bXhz HVjT0sYIVV52yYNPJd+z3C6bVuUuhSRpadhvoL7qBEvbF2uEA2/rPuWi1vNi210/cEzF hzrfyEDbc5U7GKstCA73IdCUB75t0Qp6aAXhSVBbUpvtTReNvr9yxysGg6IrVcbZhqsK c0LJqSSsQqjB0qv1UKMdN445YglNRb3BIPQ5Oek+/0Hf3oFbb7kdTaHtsSZaVKWqVC2b RLearY2l8T2+0R4STEJF4wPjJXnM1MEIp9n0APYkghaB7F0DEpYfywFga/uJjhwGm0Ya jo5A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qo17si6307463ejb.296.2020.12.07.04.18.33; Mon, 07 Dec 2020 04:18:57 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727113AbgLGMOX (ORCPT + 99 others); Mon, 7 Dec 2020 07:14:23 -0500 Received: from szxga02-in.huawei.com ([45.249.212.188]:2473 "EHLO szxga02-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726874AbgLGMOX (ORCPT ); Mon, 7 Dec 2020 07:14:23 -0500 Received: from dggeme755-chm.china.huawei.com (unknown [172.30.72.53]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4CqMdw5z38z4yXs; Mon, 7 Dec 2020 20:13:08 +0800 (CST) Received: from [10.140.157.68] (10.140.157.68) by dggeme755-chm.china.huawei.com (10.3.19.101) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1913.5; Mon, 7 Dec 2020 20:13:38 +0800 Subject: Re: [PATCH v5 1/4] dt-bindings: Document the hi3559a clock bindings To: Rob Herring CC: , , , , , , , , References: <20201119200129.28532-1-gengdongjiu@huawei.com> <20201119200129.28532-2-gengdongjiu@huawei.com> <20201130220711.GA3112118@robh.at.kernel.org> From: Dongjiu Geng Message-ID: Date: Mon, 7 Dec 2020 20:13:38 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <20201130220711.GA3112118@robh.at.kernel.org> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.140.157.68] X-ClientProxiedBy: dggeme705-chm.china.huawei.com (10.1.199.101) To dggeme755-chm.china.huawei.com (10.3.19.101) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 >> --- >> .../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 >> + >> +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 >> + */ >> + >> +#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 >> > . >