Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp4400049pxv; Mon, 5 Jul 2021 23:21:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxNbKTKDGTPyWHzMALwzzmRdw3t3qIBmYRRU+exhMT4fq4uQMkRdTww3lon7iDa2U/RxVtK X-Received: by 2002:a17:907:c21:: with SMTP id ga33mr16658089ejc.553.1625552497173; Mon, 05 Jul 2021 23:21:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625552497; cv=none; d=google.com; s=arc-20160816; b=KZ+RNM8/8mXgbGfXMWGE1eMrVA8nDALhmuleICja7JBCMy2bv4mStjgN2fMFBfLSCq rFbpP1I5C7NhP8VJn9ppZFQYL2YZgr4Web93i15ralHcE4AD2z+oPahp4mZb5GYKuILH NCmLpsI/E5q7vVWd4MuOO07jN9CdRXeHWvld08wvNMGdtWq80NFu8wLAn/xMI58uKtS7 4I7enu1abIuRN09T0n+JQiBQItyVE7dP845z9G8kpdZvYJ07fSdSNOc+2Y7yA3iFw3Am OVNdhd/nwg8R0OiDJg5x+sTR7uSKt+QSuiK5js2BlTqaQJF3Eg0c+I/8BsYBWiUhB59k vvGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from; bh=i1CjZF5zAzL5Ejx+GgkLychpNajkj7TJyL6K0wGDW5A=; b=McsXbgmjo0ger/4MNvQsDPjeO4qa+2/miZ2cWOP31qaZy2XMfChm6Tgg6tgBiXbx3D cpJD8rM6QAzIEF5pdhSR8sB7C7OGa+NOU4PRcooY6x1WdXTMqxXOssVVsWmPHLesKKOc cXxVSxdE59pE8JsvuZZMWEFfINO1BVMUovw8nOs5zticO4ifYdr6zjmrL/JilI7qEmDC 6Wz8D2T9nYD9a7Ji2JZIfgZFRss88V3+ZLq8nNwdYzCG7ioxTrW34ZuzX9xG2j5eEB2c SJ/A799uLzdneNUYcUGzTfOFzX1Ntytkc7db7QwY65n2DFsRdxKRkeQgOEIhXGREKrXV MLSA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p16si14044278eja.659.2021.07.05.23.21.13; Mon, 05 Jul 2021 23:21:37 -0700 (PDT) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230145AbhGFGWu (ORCPT + 99 others); Tue, 6 Jul 2021 02:22:50 -0400 Received: from mailgw02.mediatek.com ([210.61.82.184]:37952 "EHLO mailgw02.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S230138AbhGFGWt (ORCPT ); Tue, 6 Jul 2021 02:22:49 -0400 X-UUID: 1109c59dd0d54c58ac84cd727afea75b-20210706 X-UUID: 1109c59dd0d54c58ac84cd727afea75b-20210706 Received: from mtkcas11.mediatek.inc [(172.21.101.40)] by mailgw02.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 1120509484; Tue, 06 Jul 2021 14:20:04 +0800 Received: from mtkcas10.mediatek.inc (172.21.101.39) by mtkmbs07n1.mediatek.inc (172.21.101.16) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Tue, 6 Jul 2021 14:20:04 +0800 Received: from mtksdccf07.mediatek.inc (172.21.84.99) by mtkcas10.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Tue, 6 Jul 2021 14:20:04 +0800 From: Chun-Jie Chen To: Matthias Brugger , Stephen Boyd , Nicolas Boichat , Rob Herring CC: , , , , , , Subject: [v13 00/21] Mediatek MT8192 clock support Date: Tue, 6 Jul 2021 14:18:59 +0800 Message-ID: <20210706061920.16013-1-chun-jie.chen@mediatek.com> X-Mailer: git-send-email 2.18.0 MIME-Version: 1.0 Content-Type: text/plain X-MTK: N Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org this patch series is based on 5.13-rc3. changes since v12: - move audsys binding to "mediatek,audsys.txt" (patch 3) changes since v11: - move mmsys binding to "mediatek,mmsys.txt" (patch 2) - fix new DT binding error (patch 1) change since v10: - refine binding document in patch 1 (drop the 'oneOf') change since v9: - combine similiar dt-binding file for system and functional clock - change api of getting regmap if it's not a syscon node (patch 3) change since v8: - fix mm dt-binding file conflict. reason for sending v8: - due to this patch series including dt-binding file, so add device tree reviewer to mail list, no change between [1] and v8. [1] https://patchwork.kernel.org/project/linux-mediatek/list/?series=454523 reason for resending v7: - add review history from series below [1] https://patchwork.kernel.org/project/linux-mediatek/list/?series=405295 change since v6: - update from series below [1] https://patchwork.kernel.org/project/linux-mediatek/list/?series=405295 - fix DT bindings fail - fix checkpatch warning - update mux ops without gate control change since v5: - remove unused clocks by rolling Tinghan's patches[1][2] into series [1] https://patchwork.kernel.org/project/linux-mediatek/list/?series=398781 [2] https://patchwork.kernel.org/project/linux-mediatek/list/?series=405143 - remove dts related patches from series change since v4: - merge some subsystem into same driver - add a generic probe function to reduce duplicated code changes since v3: - add critical clocks - split large patches into small ones changes since v2: - update and split dt-binding documents by functionalities - add error checking in probe() function - fix incorrect clock relation and add critical clocks - update license identifier and minor fix of coding style changes since v1: - fix asymmetrical control of PLL - have en_mask used as divider enable mask on all MediaTek SoC Chun-Jie Chen (21): dt-bindings: ARM: Mediatek: Add new document bindings of MT8192 clock dt-bindings: ARM: Mediatek: Add mmsys document binding for MT8192 dt-bindings: ARM: Mediatek: Add audsys document binding for MT8192 clk: mediatek: Add dt-bindings of MT8192 clocks clk: mediatek: Get regmap without syscon compatible check clk: mediatek: Fix asymmetrical PLL enable and disable control clk: mediatek: Add configurable enable control to mtk_pll_data clk: mediatek: Add mtk_clk_simple_probe() to simplify clock providers clk: mediatek: Add MT8192 basic clocks support clk: mediatek: Add MT8192 audio clock support clk: mediatek: Add MT8192 camsys clock support clk: mediatek: Add MT8192 imgsys clock support clk: mediatek: Add MT8192 imp i2c wrapper clock support clk: mediatek: Add MT8192 ipesys clock support clk: mediatek: Add MT8192 mdpsys clock support clk: mediatek: Add MT8192 mfgcfg clock support clk: mediatek: Add MT8192 mmsys clock support clk: mediatek: Add MT8192 msdc clock support clk: mediatek: Add MT8192 scp adsp clock support clk: mediatek: Add MT8192 vdecsys clock support clk: mediatek: Add MT8192 vencsys clock support .../bindings/arm/mediatek/mediatek,audsys.txt | 1 + .../bindings/arm/mediatek/mediatek,mmsys.txt | 1 + .../arm/mediatek/mediatek,mt8192-clock.yaml | 199 +++ .../mediatek/mediatek,mt8192-sys-clock.yaml | 65 + drivers/clk/mediatek/Kconfig | 80 + drivers/clk/mediatek/Makefile | 13 + drivers/clk/mediatek/clk-cpumux.c | 2 +- drivers/clk/mediatek/clk-mt8192-aud.c | 118 ++ drivers/clk/mediatek/clk-mt8192-cam.c | 107 ++ drivers/clk/mediatek/clk-mt8192-img.c | 70 + .../clk/mediatek/clk-mt8192-imp_iic_wrap.c | 119 ++ drivers/clk/mediatek/clk-mt8192-ipe.c | 57 + drivers/clk/mediatek/clk-mt8192-mdp.c | 82 + drivers/clk/mediatek/clk-mt8192-mfg.c | 50 + drivers/clk/mediatek/clk-mt8192-mm.c | 108 ++ drivers/clk/mediatek/clk-mt8192-msdc.c | 85 ++ drivers/clk/mediatek/clk-mt8192-scp_adsp.c | 50 + drivers/clk/mediatek/clk-mt8192-vdec.c | 94 ++ drivers/clk/mediatek/clk-mt8192-venc.c | 53 + drivers/clk/mediatek/clk-mt8192.c | 1326 +++++++++++++++++ drivers/clk/mediatek/clk-mtk.c | 25 +- drivers/clk/mediatek/clk-mtk.h | 28 +- drivers/clk/mediatek/clk-mux.c | 11 +- drivers/clk/mediatek/clk-mux.h | 18 +- drivers/clk/mediatek/clk-pll.c | 31 +- drivers/clk/mediatek/reset.c | 2 +- include/dt-bindings/clock/mt8192-clk.h | 585 ++++++++ 27 files changed, 3356 insertions(+), 24 deletions(-) create mode 100644 Documentation/devicetree/bindings/arm/mediatek/mediatek,mt8192-clock.yaml create mode 100644 Documentation/devicetree/bindings/arm/mediatek/mediatek,mt8192-sys-clock.yaml create mode 100644 drivers/clk/mediatek/clk-mt8192-aud.c create mode 100644 drivers/clk/mediatek/clk-mt8192-cam.c create mode 100644 drivers/clk/mediatek/clk-mt8192-img.c create mode 100644 drivers/clk/mediatek/clk-mt8192-imp_iic_wrap.c create mode 100644 drivers/clk/mediatek/clk-mt8192-ipe.c create mode 100644 drivers/clk/mediatek/clk-mt8192-mdp.c create mode 100644 drivers/clk/mediatek/clk-mt8192-mfg.c create mode 100644 drivers/clk/mediatek/clk-mt8192-mm.c create mode 100644 drivers/clk/mediatek/clk-mt8192-msdc.c create mode 100644 drivers/clk/mediatek/clk-mt8192-scp_adsp.c create mode 100644 drivers/clk/mediatek/clk-mt8192-vdec.c create mode 100644 drivers/clk/mediatek/clk-mt8192-venc.c create mode 100644 drivers/clk/mediatek/clk-mt8192.c create mode 100644 include/dt-bindings/clock/mt8192-clk.h -- 2.18.0