Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1365502pxb; Fri, 21 Jan 2022 16:37:59 -0800 (PST) X-Google-Smtp-Source: ABdhPJwlkh5nyif1bJ+W91EKqtDGj8QZELKyE6iZGJQPHE41o0I6VgjYujgLNI9uQbfbYpOsXayC X-Received: by 2002:a63:7c10:: with SMTP id x16mr4596114pgc.128.1642811879680; Fri, 21 Jan 2022 16:37:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642811879; cv=none; d=google.com; s=arc-20160816; b=lAkVeTan9AKRCZ+hlOdNHLTZRBg/jEo4vpHA2tai9h52Akb6N5pV8ShqNPSZ/+4Tvx CVHosf1rcoJd93Ffvj77OLyaJX5I9yomur+Xsvix8jVMtYVhk6+6dM4fSlPb/8vWdkt1 R5ZM75bTWjGVlThoGZrk9U6sJiwF2mXjY7Fmuvnl3SPdjnMLzusuHfagbkScpgFtNA/Q IYbETXeusXYjlPuqllXlhRj6coyCIlPHO6urmPBMuu0P5TNt8TTkRpwnPvuiZHIIhptl 1Lc4i8SiQmexMldQiFgPnm3YOAQ8kCCCnI0D1ZxasSTcykCkzgwbCHjxMZ/b/uJpI01j Pshg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=y7xC1JaOCAYBIg7JrHXcBbrwaHD8V1q0t0vCq4BMDKg=; b=KFmgt5PMXbQSwTWDZdWxlcyKey6ixC0MyiIg28rAjUl8WiWRmJYPTerc9X3IKgvesg gF4o4kS4ihfeQH6woyGFsi5CpeaRwi51P9JofBx+G7Uyaza+Gn5dtYOzZTUbsudpDn7z hoVFQWJOPHK3NZ9+J61A4XDZvpksgqt81VUkei7sk1Hc1QbBIrU3wIGFH7fPLVNc4qgb WJeiTwVdzjNT6Xg9HzrA7s1em59zLkQSy+Ul324BF5uFUPO6dpRTox45AsHkTcw0WEVI uBYb5Hbx8d4CIfCMkRlIdRwAF5ww1rerotaeqbYfOQvjOnlDjB29sXvyf+vxSytg0S+9 QEjQ== 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 d13si7955162pfj.20.2022.01.21.16.37.47; Fri, 21 Jan 2022 16:37:59 -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 S1349292AbiAUHpO (ORCPT + 99 others); Fri, 21 Jan 2022 02:45:14 -0500 Received: from mail-sz.amlogic.com ([211.162.65.117]:14996 "EHLO mail-sz.amlogic.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234478AbiAUHpO (ORCPT ); Fri, 21 Jan 2022 02:45:14 -0500 Received: from droid11-sz.amlogic.com (10.28.8.21) by mail-sz.amlogic.com (10.28.11.5) with Microsoft SMTP Server id 15.1.2176.2; Fri, 21 Jan 2022 15:45:11 +0800 From: Liang Yang To: Neil Armstrong , Jerome Brunet , Kevin Hilman , Michael Turquette , Stephen Boyd , Rob Herring , CC: Liang Yang , Martin Blumenstingl , Jianxin Pan , Victor Wan , XianWei Zhao , Kelvin Zhang , BiChao Zheng , YongHui Yu , , , , Subject: [PATCH v10 0/4] clk: meson: add a sub EMMC clock controller support Date: Fri, 21 Jan 2022 15:45:04 +0800 Message-ID: <20220121074508.42168-1-liang.yang@amlogic.com> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.28.8.21] Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This driver will add a MMC clock controller driver support. The original idea about adding a clock controller is during the discussion in the NAND driver mainline effort[1]. This driver is tested in the S400 board (AXG platform) with NAND driver. Changes since v9 [10] - use clk_parent_data instead of parent_names Changes since v8 [9] - use MESON_SCLK_ONE_BASED instead of CLK_DIVIDER_ONE_BASED - use struct_size to caculate onecell_data - add clk-phase-delay.h - define CLK_DELAY_STEP_PS_GX and CLK_DELAY_STEP_PS_AXG Changes since v7 [8] - move meson_clk_get_phase_delay_data() from header to driver - CONFIG sclk-div with COMMON_CLK_AMLOGIC instead of COMMON_CLK_AMLOGIC_AUDIO - remove onecell date and ID for internal MUX clk - use helper for functions for ONE_BASED in sclk-div - add ONE_BASED support for duty cycle Changes since v6 [7]: - add one based support for sclk divier - alloc sclk in probe for multiple instance - fix coding styles Changes since v5 [6]: - remove divider ops with .init and use sclk_div instead - drop CLK_DIVIDER_ROUND_CLOSEST in mux and div - drop the useless type cast Changes since v4 [5]: - use struct parm in phase delay driver - remove 0 delay releted part in phase delay driver - don't rebuild the parent name once again - add divider ops with .init Changes since v3 [4]: - separate clk-phase-delay driver - replace clk_get_rate() with clk_hw_get_rate() - collect Rob's R-Y - drop 'meson-' prefix from compatible string Changes since v2 [3]: - squash dt-binding clock-id patch - update license - fix alignment - construct a clk register helper() function Changes since v1 [2]: - implement phase clock - update compatible name - adjust file name - divider probe() into small functions, and re-use them [1] https://lkml.kernel.org/r/20180628090034.0637a062@xps13 [2] https://lkml.kernel.org/r/20180703145716.31860-1-yixun.lan@amlogic.com [3] https://lkml.kernel.org/r/20180710163658.6175-1-yixun.lan@amlogic.com [4] https://lkml.kernel.org/r/20180712211244.11428-1-yixun.lan@amlogic.com [5] https://lkml.kernel.org/r/20180809070724.11935-4-yixun.lan@amlogic.com [6] https://lkml.kernel.org/r/1539839245-13793-1-git-send-email-jianxin.pan@amlogic.com [7] https://lkml.kernel.org/r/1541089855-19356-1-git-send-email-jianxin.pan@amlogic.com [8] https://lkml.kernel.org/r/1544457877-51301-1-git-send-email-jianxin.pan@amlogic.com [9] https://lkml.kernel.org/r/1545063850-21504-1-git-send-email-jianxin.pan@amlogic.com [10] https://lore.kernel.org/all/20220113115745.45826-1-liang.yang@amlogic.com/ Liang Yang (4): clk: meson: add one based divider support for sclk clk: meson: add emmc sub clock phase delay driver clk: meson: add DT documentation for emmc clock controller clk: meson: add sub MMC clock controller driver .../bindings/clock/amlogic,mmc-clkc.yaml | 64 ++++ drivers/clk/meson/Kconfig | 18 ++ drivers/clk/meson/Makefile | 2 + drivers/clk/meson/clk-phase-delay.c | 69 ++++ drivers/clk/meson/clk-phase-delay.h | 20 ++ drivers/clk/meson/mmc-clkc.c | 302 ++++++++++++++++++ drivers/clk/meson/sclk-div.c | 59 ++-- drivers/clk/meson/sclk-div.h | 3 + include/dt-bindings/clock/amlogic,mmc-clkc.h | 14 + 9 files changed, 529 insertions(+), 22 deletions(-) create mode 100644 Documentation/devicetree/bindings/clock/amlogic,mmc-clkc.yaml create mode 100644 drivers/clk/meson/clk-phase-delay.c create mode 100644 drivers/clk/meson/clk-phase-delay.h create mode 100644 drivers/clk/meson/mmc-clkc.c create mode 100644 include/dt-bindings/clock/amlogic,mmc-clkc.h -- 2.34.1