Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp2714538ybl; Thu, 19 Dec 2019 19:33:29 -0800 (PST) X-Google-Smtp-Source: APXvYqzyS3fiKi3dVpZrjeRwALKYnSLJrurlpxGIfl/JOB0feBk0Yjf/CRs40OZVAFXWsBm18Pu9 X-Received: by 2002:a05:6830:11c3:: with SMTP id v3mr13234915otq.74.1576812808838; Thu, 19 Dec 2019 19:33:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576812808; cv=none; d=google.com; s=arc-20160816; b=m0Q0rUIfwn0TMOTEePezpojKzn9bvz/7NqyKMwZ56S4sbUQIp6/wG4mcfrRBU82PrT qlcbITeHd0uc2NVHIFHCYd8Bk4SFcxDfLN+aNukHchkmzBOiECphVHQmJ55OeE5Axvp9 POjrbC1KJS9t7qJBbxscLV7aDX5sNCk1VZK67TYiATBCO04CmhKS82mGLfeXYAEWbbks WqY6sVYW6cs8Lh/2qiUXl2pXF9G1Et9D1O1vXCsDf9ildefqghuiIzFWh9c+czv3mLI0 EJyGA+Xip8ixAt01/eyolj9eqg7XicBLQULecWluRkFdwZBPsj9NYEPylgMxJBOhxM6B Qvmg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from; bh=XA0atmNlk6acc/HImgy1Q9WIcy93DU22XJAcPPfGccM=; b=FFjBk7rSBJU2ce5NxUFu4TfGXGuBruJcMlFXoitiTanXQbKP7Ctb74vs9TuD/pYXoj wIgEydWSKCqlwREv7fpzSvJfhU+rx0loHGtXEcBxeP2KVxE78GkRmiLfgN9E25wwTeaT 2NPn8jidLHvoXIxRrNq0VWjbD0EU//L1gH58bIlmtmluOo0rtYecUOzqayvDECAAFUyb DA8GB6MZtvZfFm7cQwQvS3RdiJzYvZrCjDzGJalUZ4gWH7EjtgqDukepnOK9gd89KZyK xQA8t4aEt+lMctidub180C0v1IeU6+2DfC/2UHyZYwPigWd6ePn6ylCRgPUCJo8DPcir +Fpw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l17si4089739otk.218.2019.12.19.19.33.16; Thu, 19 Dec 2019 19:33:28 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727381AbfLTDbX (ORCPT + 99 others); Thu, 19 Dec 2019 22:31:23 -0500 Received: from mga18.intel.com ([134.134.136.126]:63520 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726986AbfLTDbX (ORCPT ); Thu, 19 Dec 2019 22:31:23 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga106.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 19 Dec 2019 19:31:22 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.69,334,1571727600"; d="scan'208";a="366276824" Received: from sgsxdev001.isng.intel.com (HELO localhost) ([10.226.88.11]) by orsmga004.jf.intel.com with ESMTP; 19 Dec 2019 19:31:19 -0800 From: Rahul Tanwar To: mturquette@baylibre.com, sboyd@kernel.org, robh+dt@kernel.org, mark.rutland@arm.com Cc: linux-clk@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, andriy.shevchenko@intel.com, yixin.zhu@linux.intel.com, qi-ming.wu@intel.com, Rahul Tanwar Subject: [PATCH v2 2/2] dt-bindings: clk: intel: Add bindings document & header file for CGU Date: Fri, 20 Dec 2019 11:31:08 +0800 Message-Id: <706ef9c0e08e10798a4cecacff52a4c72e8fe693.1576811332.git.rahul.tanwar@linux.intel.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Clock generation unit(CGU) is a clock controller IP of Intel's Lightning Mountain(LGM) SoC. Add DT bindings include file and document for CGU clock controller driver of LGM. Signed-off-by: Rahul Tanwar --- .../devicetree/bindings/clock/intel,cgu-lgm.yaml | 43 ++++++ include/dt-bindings/clock/intel,lgm-clk.h | 150 +++++++++++++++++++++ 2 files changed, 193 insertions(+) create mode 100644 Documentation/devicetree/bindings/clock/intel,cgu-lgm.yaml create mode 100644 include/dt-bindings/clock/intel,lgm-clk.h diff --git a/Documentation/devicetree/bindings/clock/intel,cgu-lgm.yaml b/Documentation/devicetree/bindings/clock/intel,cgu-lgm.yaml new file mode 100644 index 000000000000..2c9edabe0490 --- /dev/null +++ b/Documentation/devicetree/bindings/clock/intel,cgu-lgm.yaml @@ -0,0 +1,43 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/bindings/clock/intel,cgu-lgm.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Intel Lightning Mountain SoC's Clock Controller(CGU) Binding + +maintainers: + - Rahul Tanwar + +description: | + Lightning Mountain(LGM) SoC's Clock Generation Unit(CGU) driver provides + all means to access the CGU hardware module in order to generate a series + of clocks for the whole system and individual peripherals. + + This binding uses the common clock bindings + [1] Documentation/devicetree/bindings/clock/clock-bindings.txt + +properties: + compatible: + const: intel,cgu-lgm + + reg: + maxItems: 1 + + '#clock-cells': + const: 1 + +required: + - compatible + - reg + - '#clock-cells' + +examples: + - | + cgu: cgu@e0200000 { + compatible = "intel,cgu-lgm"; + reg = <0xe0200000 0x33c>; + #clock-cells = <1>; + }; + +... diff --git a/include/dt-bindings/clock/intel,lgm-clk.h b/include/dt-bindings/clock/intel,lgm-clk.h new file mode 100644 index 000000000000..09e5dc59ff5b --- /dev/null +++ b/include/dt-bindings/clock/intel,lgm-clk.h @@ -0,0 +1,150 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +/* + * Copyright (C) 2018 Intel Corporation. + * Lei Chuanhua + * Zhu Yixin + */ + +#ifndef __INTEL_LGM_CLK_H +#define __INTEL_LGM_CLK_H + +/* PLL clocks */ +#define LGM_CLK_PLLPP 2 +#define LGM_CLK_PLL2 3 +#define LGM_CLK_PLL0CZ 4 +#define LGM_CLK_PLL0B 5 +#define LGM_CLK_PLL1 6 +#define LGM_CLK_LJPLL3 7 +#define LGM_CLK_LJPLL4 8 +#define LGM_CLK_PLL0CM0 9 +#define LGM_CLK_PLL0CM1 10 + +/* clocks from PLLs */ + +/* ROPLL clocks */ +#define LGM_CLK_PP_HW 15 +#define LGM_CLK_PP_UC 16 +#define LGM_CLK_PP_FXD 17 +#define LGM_CLK_PP_TBM 18 + +/* PLL2 clocks */ +#define LGM_CLK_DDR 20 + +/* PLL0CZ */ +#define LGM_CLK_CM 25 +#define LGM_CLK_IC 26 +#define LGM_CLK_SDIO3 27 + +/* PLL0B */ +#define LGM_CLK_NGI 30 +#define LGM_CLK_NOC4 31 +#define LGM_CLK_SW 32 +#define LGM_CLK_QSPI 33 +#define LGM_CLK_CQEM LGM_CLK_SW +#define LGM_CLK_EMMC5 LGM_CLK_NOC4 + +/* PLL1 */ +#define LGM_CLK_CT 35 +#define LGM_CLK_DSP 36 +#define LGM_CLK_4X 37 +#define LGM_CLK_DCL 38 + +/* LJPLL3 */ +#define LGM_CLK_CML 40 +#define LGM_CLK_CBPHY 41 +#define LGM_CLK_POOL 42 +#define LGM_CLK_PTP 43 + +/* LJPLL4 */ +#define LGM_CLK_PCIE 45 +#define LGM_CLK_SATA LGM_CLK_PCIE + +/* Miscellaneous clocks */ +#define LGM_CLK_EMMC4 46 +#define LGM_CLK_SDIO2 47 +#define LGM_CLK_EMMC 48 +#define LGM_CLK_SDIO 49 + + +/* Gate clocks */ +/* Gate CLK0 */ +#define LGM_GCLK_C55 60 +#define LGM_GCLK_VCODEC 61 +#define LGM_GCLK_QSPI 62 +#define LGM_GCLK_TEP 63 +#define LGM_GCLK_EIP197 64 +#define LGM_GCLK_VAULT 65 +#define LGM_GCLK_TOE 66 +#define LGM_GCLK_SDXC 67 +#define LGM_GCLK_EMMC 68 +#define LGM_GCLK_EIP154 69 +#define LGM_GCLK_SPI_DBG 70 +#define LGM_GCLK_DMA3 71 +#define LGM_GCLK_TOPNOC 72 + +/* Gate CLK1 */ +#define LGM_GCLK_DMA0 80 +#define LGM_GCLK_LEDC0 81 +#define LGM_GCLK_LEDC1 82 +#define LGM_GCLK_I2S0 83 +#define LGM_GCLK_I2S1 84 +#define LGM_GCLK_EBU 85 +#define LGM_GCLK_I2C0 86 +#define LGM_GCLK_I2C1 87 +#define LGM_GCLK_I2C2 88 +#define LGM_GCLK_I2C3 89 +#define LGM_GCLK_SSC0 90 +#define LGM_GCLK_SSC1 91 +#define LGM_GCLK_SSC2 92 +#define LGM_GCLK_SSC3 93 +#define LGM_GCLK_GPTC0 94 +#define LGM_GCLK_GPTC1 95 +#define LGM_GCLK_GPTC2 96 +#define LGM_GCLK_GPTC3 97 +#define LGM_GCLK_ASC0 98 +#define LGM_GCLK_ASC1 99 +#define LGM_GCLK_ASC2 100 +#define LGM_GCLK_ASC3 101 +#define LGM_GCLK_PCM0 102 +#define LGM_GCLK_PCM1 103 +#define LGM_GCLK_PCM2 104 +#define LGM_GCLK_PERINOC 105 + +/* Gate CLK2 */ +#define LGM_GCLK_PCIE10 120 +#define LGM_GCLK_PCIE11 121 +#define LGM_GCLK_PCIE30 122 +#define LGM_GCLK_PCIE31 123 +#define LGM_GCLK_PCIE20 124 +#define LGM_GCLK_PCIE21 125 +#define LGM_GCLK_PCIE40 126 +#define LGM_GCLK_PCIE41 127 +#define LGM_GCLK_XPCS0 128 +#define LGM_GCLK_XPCS1 129 +#define LGM_GCLK_XPCS2 130 +#define LGM_GCLK_XPCS3 131 +#define LGM_GCLK_SATA0 132 +#define LGM_GCLK_SATA1 133 +#define LGM_GCLK_SATA2 134 +#define LGM_GCLK_SATA3 135 + +/* Gate CLK3 */ +#define LGM_GCLK_ARCEM4 140 +#define LGM_GCLK_VPNHOST 141 +#define LGM_GCLK_IDMAR1 142 +#define LGM_GCLK_IDMAT0 143 +#define LGM_GCLK_IDMAT1 144 +#define LGM_GCLK_IDMAT2 145 +#define LGM_GCLK_PPV4 146 +#define LGM_GCLK_GSWIPO 147 +#define LGM_GCLK_CQEM 148 +#define LGM_GCLK_PON 149 +#define LGM_GCLK_BM 150 +#define LGM_GCLK_PB 151 +#define LGM_GCLK_XPCS5 152 +#define LGM_GCLK_USB1 153 +#define LGM_GCLK_USB2 154 + +#define CLK_NR_CLKS 180 + +#endif /* __INTEL_LGM_CLK_H */ -- 2.11.0