Received: by 2002:a05:6358:bb9e:b0:b9:5105:a5b4 with SMTP id df30csp2794884rwb; Mon, 5 Sep 2022 01:20:14 -0700 (PDT) X-Google-Smtp-Source: AA6agR7WRI2VsnwEzp81FPT3gIiqdzbH+zB+LDhi0wTSbcJizDaScXAlz8KGON8EK7ZMIt0P7yVk X-Received: by 2002:aa7:cb87:0:b0:43b:e650:6036 with SMTP id r7-20020aa7cb87000000b0043be6506036mr43306308edt.350.1662366014340; Mon, 05 Sep 2022 01:20:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662366014; cv=none; d=google.com; s=arc-20160816; b=AXKJlEcnv8d4+g8QyB4aUP/V8Xim0pS6jRJscYcS8cm5AHF3yWiOx3kmtLrD+n8hTI dj7ZudlL0hwsDdvwm+0r64URcm7wFkM8hAmYdMxw9w/XQzJvB+r0b12ygM+Pf4c91Chy ebIoAUICbRHViptOw8qdo6tXv+hmxKmVNqhNhhI7wjLktNB3X5jxWcN2hlEoR7pmcOUD M47oA5oP2+angfN9dsVkfRqoQfzr8CWJ8BW1ju/jGBHvQzw2sI59xFPZVtm5TysH52Hf ZI8ebsJzKXD6fbcL94+MyxTqzf7Fh+jEhUCzzDRvkGg3/uO/XuGbIugTLwjp6qcVUZG/ ljLQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=UNXvlVjo187MWu3yoYckcXbqqs1lHNuMO52iCAYBAu8=; b=VCLtPRLJs1vLbmX34QvWb6WrbM+cUURzXbYT/w9r3EfILmpbADSvxjQ3fbzY5fvNFq H4gWSAzPq3IMCdldfe9E/7V7qYd+KJRJeoI5qEvrU9izQ9XgRsJR+1cfsna9bnS+0aKg vZ7+x9Dn865GhOxR8+9ekn1C//cSZxdmsFZmmmz+MD7ygmjo7kb5+Ia2O+2nX4iXOvHs eebOThPWe9NaF73SOX1jCbb8yvA1/U2cx0YCxt3xOGB233+4KMSMvQ/VwM/TUV6kTta2 3YampjPHpoGDVwDwA3HtpFy+ju5AvNirc7JH+W1E0CmN04EBj9oxOdKHvogOYF4fa1op 3nkA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@maxlinear.com header.s=selector header.b=ZGMiSiy4; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=maxlinear.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id d4-20020a056402078400b0044e8fe826a0si989319edy.156.2022.09.05.01.19.49; Mon, 05 Sep 2022 01:20:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@maxlinear.com header.s=selector header.b=ZGMiSiy4; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=maxlinear.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237017AbiIEHyW (ORCPT + 99 others); Mon, 5 Sep 2022 03:54:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54730 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237001AbiIEHyN (ORCPT ); Mon, 5 Sep 2022 03:54:13 -0400 Received: from us-smtp-delivery-115.mimecast.com (us-smtp-delivery-115.mimecast.com [170.10.133.115]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0EC164505E for ; Mon, 5 Sep 2022 00:54:05 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=maxlinear.com; s=selector; t=1662364381; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=UNXvlVjo187MWu3yoYckcXbqqs1lHNuMO52iCAYBAu8=; b=ZGMiSiy4gQaJYliigo/Y/nEdwmaKWrxQLwwt1iSyqlFjWFFy3FLBL+wlVSyYqIs/WEpYus 3a3xHsJWZ0ZYaZ9zdHnddZNSuLMy5TqcnWB1Scup5fUidaDzoB+m7DGDHV7A+H25twFR1B k87S0sK+afZRyx93CD3QuoroMZpLTNooMoT2SMMRD2JcHnLhv2WbUEaXIMSFGqjKWDp6jE 3gK7OT+b9EADUmGArcC4qfZnjVV1KCwGDIFJYG+1qGViAL+Pdcu+25/DhbHvIYGw0RfBb5 qcFpvG9tq9r3rHYSzeOZ4fypL34jJBUy6umPHo3vC+wPMAoLrkyfrx6C4Npv4w== Received: from mail.maxlinear.com (174-47-1-83.static.ctl.one [174.47.1.83]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id us-mta-292-9FJ67FUwNnqjlk24SeUneg-1; Mon, 05 Sep 2022 03:43:57 -0400 X-MC-Unique: 9FJ67FUwNnqjlk24SeUneg-1 Received: from sgsxdev001.isng.phoenix.local (10.226.81.111) by mail.maxlinear.com (10.23.38.120) with Microsoft SMTP Server id 15.1.2375.24; Mon, 5 Sep 2022 00:43:54 -0700 From: Rahul Tanwar To: , , CC: , , "Rahul Tanwar" Subject: [PATCH v2 1/5] clk: mxl: Switch from direct readl/writel based IO to regmap based IO Date: Mon, 5 Sep 2022 15:43:44 +0800 Message-ID: <43c6a8ac66b5f7acfb99f919f9c3088a80b55175.1662363020.git.rtanwar@maxlinear.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: References: MIME-Version: 1.0 X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: maxlinear.com Content-Type: text/plain; charset=WINDOWS-1252 Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Earlier version of driver used direct io remapped register read writes using readl/writel. But we need secure boot access which is only possible when registers are read & written using regmap. This is because the security bus/hook is written & coupled only with regmap layer. Switch the driver from direct readl/writel based register accesses to regmap based register accesses. Additionally, update the license headers to latest status. Signed-off-by: Rahul Tanwar --- drivers/clk/x86/Kconfig | 5 +++-- drivers/clk/x86/clk-cgu-pll.c | 10 +++++---- drivers/clk/x86/clk-cgu.c | 5 +++-- drivers/clk/x86/clk-cgu.h | 38 +++++++++++++++++++---------------- drivers/clk/x86/clk-lgm.c | 13 ++++++++---- 5 files changed, 42 insertions(+), 29 deletions(-) diff --git a/drivers/clk/x86/Kconfig b/drivers/clk/x86/Kconfig index 69642e15fcc1..ced99e082e3d 100644 --- a/drivers/clk/x86/Kconfig +++ b/drivers/clk/x86/Kconfig @@ -1,8 +1,9 @@ # SPDX-License-Identifier: GPL-2.0-only config CLK_LGM_CGU =09depends on OF && HAS_IOMEM && (X86 || COMPILE_TEST) +=09select MFD_SYSCON =09select OF_EARLY_FLATTREE =09bool "Clock driver for Lightning Mountain(LGM) platform" =09help -=09 Clock Generation Unit(CGU) driver for Intel Lightning Mountain(LGM) -=09 network processor SoC. +=09 Clock Generation Unit(CGU) driver for MaxLinear's x86 based +=09 Lightning Mountain(LGM) network processor SoC. diff --git a/drivers/clk/x86/clk-cgu-pll.c b/drivers/clk/x86/clk-cgu-pll.c index 3179557b5f78..c83083affe88 100644 --- a/drivers/clk/x86/clk-cgu-pll.c +++ b/drivers/clk/x86/clk-cgu-pll.c @@ -1,8 +1,9 @@ // SPDX-License-Identifier: GPL-2.0 /* + * Copyright (C) 2020-2022 MaxLinear, Inc. * Copyright (C) 2020 Intel Corporation. - * Zhu YiXin - * Rahul Tanwar + * Zhu Yixin + * Rahul Tanwar */ =20 #include @@ -76,8 +77,9 @@ static int lgm_pll_enable(struct clk_hw *hw) =20 =09spin_lock_irqsave(&pll->lock, flags); =09lgm_set_clk_val(pll->membase, pll->reg, 0, 1, 1); -=09ret =3D readl_poll_timeout_atomic(pll->membase + pll->reg, -=09=09=09=09=09val, (val & 0x1), 1, 100); +=09ret =3D regmap_read_poll_timeout_atomic(pll->membase, pll->reg, +=09=09=09=09=09 val, (val & 0x1), 1, 100); + =09spin_unlock_irqrestore(&pll->lock, flags); =20 =09return ret; diff --git a/drivers/clk/x86/clk-cgu.c b/drivers/clk/x86/clk-cgu.c index 33de600e0c38..f5f30a18f486 100644 --- a/drivers/clk/x86/clk-cgu.c +++ b/drivers/clk/x86/clk-cgu.c @@ -1,8 +1,9 @@ // SPDX-License-Identifier: GPL-2.0 /* + * Copyright (C) 2020-2022 MaxLinear, Inc. * Copyright (C) 2020 Intel Corporation. - * Zhu YiXin - * Rahul Tanwar + * Zhu Yixin + * Rahul Tanwar */ #include #include diff --git a/drivers/clk/x86/clk-cgu.h b/drivers/clk/x86/clk-cgu.h index 4e22bfb22312..dbcb66468797 100644 --- a/drivers/clk/x86/clk-cgu.h +++ b/drivers/clk/x86/clk-cgu.h @@ -1,18 +1,19 @@ /* SPDX-License-Identifier: GPL-2.0 */ /* - * Copyright(c) 2020 Intel Corporation. - * Zhu YiXin - * Rahul Tanwar + * Copyright (C) 2020-2022 MaxLinear, Inc. + * Copyright (C) 2020 Intel Corporation. + * Zhu Yixin + * Rahul Tanwar */ =20 #ifndef __CLK_CGU_H #define __CLK_CGU_H =20 -#include +#include =20 struct lgm_clk_mux { =09struct clk_hw hw; -=09void __iomem *membase; +=09struct regmap *membase; =09unsigned int reg; =09u8 shift; =09u8 width; @@ -22,7 +23,7 @@ struct lgm_clk_mux { =20 struct lgm_clk_divider { =09struct clk_hw hw; -=09void __iomem *membase; +=09struct regmap *membase; =09unsigned int reg; =09u8 shift; =09u8 width; @@ -35,7 +36,7 @@ struct lgm_clk_divider { =20 struct lgm_clk_ddiv { =09struct clk_hw hw; -=09void __iomem *membase; +=09struct regmap *membase; =09unsigned int reg; =09u8 shift0; =09u8 width0; @@ -53,7 +54,7 @@ struct lgm_clk_ddiv { =20 struct lgm_clk_gate { =09struct clk_hw hw; -=09void __iomem *membase; +=09struct regmap *membase; =09unsigned int reg; =09u8 shift; =09unsigned long flags; @@ -77,7 +78,7 @@ enum lgm_clk_type { * @clk_data: array of hw clocks and clk number. */ struct lgm_clk_provider { -=09void __iomem *membase; +=09struct regmap *membase; =09struct device_node *np; =09struct device *dev; =09struct clk_hw_onecell_data clk_data; @@ -92,7 +93,7 @@ enum pll_type { =20 struct lgm_clk_pll { =09struct clk_hw hw; -=09void __iomem *membase; +=09struct regmap *membase; =09unsigned int reg; =09unsigned long flags; =09enum pll_type type; @@ -300,29 +301,32 @@ struct lgm_clk_branch { =09=09.div =3D _d,=09=09=09=09=09\ =09} =20 -static inline void lgm_set_clk_val(void __iomem *membase, u32 reg, +static inline void lgm_set_clk_val(struct regmap *membase, u32 reg, =09=09=09=09 u8 shift, u8 width, u32 set_val) { =09u32 mask =3D (GENMASK(width - 1, 0) << shift); -=09u32 regval; =20 -=09regval =3D readl(membase + reg); -=09regval =3D (regval & ~mask) | ((set_val << shift) & mask); -=09writel(regval, membase + reg); +=09regmap_update_bits(membase, reg, mask, set_val << shift); } =20 -static inline u32 lgm_get_clk_val(void __iomem *membase, u32 reg, +static inline u32 lgm_get_clk_val(struct regmap *membase, u32 reg, =09=09=09=09 u8 shift, u8 width) { =09u32 mask =3D (GENMASK(width - 1, 0) << shift); =09u32 val; =20 -=09val =3D readl(membase + reg); +=09if (regmap_read(membase, reg, &val)) { +=09=09WARN_ONCE(1, "Failed to read clk reg: 0x%x\n", reg); +=09=09return 0; +=09} + =09val =3D (val & mask) >> shift; =20 =09return val; } =20 + + int lgm_clk_register_branches(struct lgm_clk_provider *ctx, =09=09=09 const struct lgm_clk_branch *list, =09=09=09 unsigned int nr_clk); diff --git a/drivers/clk/x86/clk-lgm.c b/drivers/clk/x86/clk-lgm.c index 020f4e83a5cc..4fa2bcaf71c8 100644 --- a/drivers/clk/x86/clk-lgm.c +++ b/drivers/clk/x86/clk-lgm.c @@ -1,10 +1,12 @@ // SPDX-License-Identifier: GPL-2.0 /* + * Copyright (C) 2020-2022 MaxLinear, Inc. * Copyright (C) 2020 Intel Corporation. - * Zhu YiXin - * Rahul Tanwar + * Zhu Yixin + * Rahul Tanwar */ #include +#include #include #include #include @@ -433,9 +435,12 @@ static int lgm_cgu_probe(struct platform_device *pdev) =20 =09ctx->clk_data.num =3D CLK_NR_CLKS; =20 -=09ctx->membase =3D devm_platform_ioremap_resource(pdev, 0); -=09if (IS_ERR(ctx->membase)) +=09ctx->membase =3D syscon_node_to_regmap(np); +=09if (IS_ERR_OR_NULL(ctx->membase)) { +=09=09dev_err(dev, "Failed to get clk CGU iomem\n"); =09=09return PTR_ERR(ctx->membase); +=09} + =20 =09ctx->np =3D np; =09ctx->dev =3D dev; --=20 2.17.1