Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3365240pxb; Mon, 17 Jan 2022 18:42:12 -0800 (PST) X-Google-Smtp-Source: ABdhPJx8MQVqoaa6I9l/km+zG/0PyjTndYTuLPb1lS+t8JLrpPhWlh/rLuWlUNUiYIxG5vMiTVMm X-Received: by 2002:a17:90b:1bce:: with SMTP id oa14mr13439408pjb.209.1642473732019; Mon, 17 Jan 2022 18:42:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642473732; cv=none; d=google.com; s=arc-20160816; b=Hugp0V76Xip468tHc99bRsQcy6HxF/kWRfODBxh/BmXDeiHDzg6uHYirbubRq+jwXC OybvOuKaRsHAIAan5/bwNhn3HeRkPDi/eh1uDhubPX73J618E3wXLbqgROqG9L+NbVIQ Fn1wtTB6xBh9W8oAjeTf8i5Y30qyfva9XrQUMhTk+RkYOzUN8zjep6uDjLSG8Zm+Ot03 pB6KAWNAHGyKmDFNmefGNM2AQpBJBGxaretZ68Z8ZZsYKZtMZVmM7+4+L0KLXUvbcmOF nj6b03O6EXMw7LZ4yj3wXBL3UlyBiEWL0kXD5H/inmT3UKntvkSg0mawAp/9aSGt7RPJ 71xw== 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=IeVBvH8w9aMZ2bz+yawfVsKVbeZ465lgYXUDnDZC0N4=; b=Bsorx0chgvLm/XpdsvBSiedys4aL0eXOQ7AeVQv7lnNa6nSq7Lzre4K8LdG6iekoHk GUH36VFq4h98WFd53mfgkV4LbT+mEEJpu6S2FJkytkBoAcyk7q5xf0RHdSE9ajbEDtAf 0JrxcDZ4fwNPTaYmr7I6DGICItrXcTT3Zd7O6ygHp1lK7qIxg9zzxJmveb6XjR97031P Uda25/OECR0i1sbvTad19ubMUZsv37grw7VxI9HliJrccjV6jXYNkFnA9o5wuJMxGtI+ HDmJjlxAr07cM/nVdwtgi4cwq7hb93Fw/5jlEySNGYOmZQng9pTchikrYXjtrpdsb9Ue NdyQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=pBwFXJh7; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id nh10si1123189pjb.144.2022.01.17.18.42.00; Mon, 17 Jan 2022 18:42:11 -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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=pBwFXJh7; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241169AbiAQQ7G (ORCPT + 99 others); Mon, 17 Jan 2022 11:59:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44474 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241154AbiAQQ7B (ORCPT ); Mon, 17 Jan 2022 11:59:01 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 08EFEC061574; Mon, 17 Jan 2022 08:59:01 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id C5E85B81131; Mon, 17 Jan 2022 16:58:59 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 1EDFBC36AF2; Mon, 17 Jan 2022 16:58:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1642438738; bh=yXNyj5w8WPn/dUWK5qhdWXLoj5pVBSY3hqJPXa2z4tY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pBwFXJh7I16xBKBvnY+P0MEHpQd4FRruBXzAXY0H0plMkUA4lqc5VfMIk41ZkTo5C SvwfhaUiuo2P5DPau2sO5fGMQpvsXTN1H2XnllfW6ECAGii6CKl5Y2TVS6h2T9cp+d untEUPcrBZncXnhTGR2HlMZtAy6/SGwMJLGki+HVQKbu3s7w5ypwXmnsxA8ITHL3Sw rxIzSX6DoReIMths0NjnGSJ4tYg9IvBXpuSBVn3UwA0q/lzBV8x7PmP8sGboydpubH JucI1OLtnHps2XYHTGyerFgaqemjfu/0Mf+Urd6EJA/5B+GlUMYwUP2IWIbjgBXwY3 WtIhbR97U6jCg== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Sam Protsenko , Sylwester Nawrocki , Krzysztof Kozlowski , Sasha Levin , tomasz.figa@gmail.com, cw00.choi@samsung.com, mturquette@baylibre.com, sboyd@kernel.org, matthias.bgg@gmail.com, linux-samsung-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org Subject: [PATCH AUTOSEL 5.16 02/52] clk: samsung: exynos850: Register clocks early Date: Mon, 17 Jan 2022 11:58:03 -0500 Message-Id: <20220117165853.1470420-2-sashal@kernel.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220117165853.1470420-1-sashal@kernel.org> References: <20220117165853.1470420-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sam Protsenko [ Upstream commit bcda841f9bf2cddcf2f000cba96f2e27f6f2bdbf ] Some clocks must be registered before init calls. For example MCT clock (from CMU_PERI) is needed for MCT timer driver, which is registered with TIMER_OF_DECLARE(). By the time we get to core_initcall() used for clk-exynos850 platform driver init, it's already too late. Inability to get "mct" clock in MCT driver leads to kernel panic, as functions registered with *_OF_DECLARE() can't do deferred calls. MCT timer driver can't be fixed either, as it's acting as a clock source and it's essential to register it in start_kernel() -> time_init(). Let's register CMU_PERI clocks early, using CLK_OF_DECLARE(). CMU_TOP generates clocks needed for CMU_PERI, but it's already registered early. While at it, let's cleanup the code a bit, by extracting everything related to CMU initialization and registration to the separate function. Similar issue was discussed at [1] and addressed in commit 1f7db7bbf031 ("clk: renesas: cpg-mssr: Add early clock support"), as well as in drivers/clk/mediatek/clk-mt2712.c. [1] https://patchwork.kernel.org/project/linux-renesas-soc/patch/20180829132954.64862-2-chris.brandt@renesas.com/ Signed-off-by: Sam Protsenko Signed-off-by: Sylwester Nawrocki Reviewed-by: Krzysztof Kozlowski Link: https://lore.kernel.org/r/20211122144206.23134-1-semen.protsenko@linaro.org Signed-off-by: Sasha Levin --- drivers/clk/samsung/clk-exynos850.c | 70 ++++++++++++++++++++--------- 1 file changed, 49 insertions(+), 21 deletions(-) diff --git a/drivers/clk/samsung/clk-exynos850.c b/drivers/clk/samsung/clk-exynos850.c index 2294989e244c5..79cce8ba88831 100644 --- a/drivers/clk/samsung/clk-exynos850.c +++ b/drivers/clk/samsung/clk-exynos850.c @@ -60,6 +60,43 @@ static void __init exynos850_init_clocks(struct device_node *np, iounmap(reg_base); } +/** + * exynos850_register_cmu - Register specified Exynos850 CMU domain + * @dev: Device object; may be NULL if this function is not being + * called from platform driver probe function + * @np: CMU device tree node + * @cmu: CMU data + * + * Register specified CMU domain, which includes next steps: + * + * 1. Enable parent clock of @cmu CMU + * 2. Set initial registers configuration for @cmu CMU clocks + * 3. Register @cmu CMU clocks using Samsung clock framework API + */ +static void __init exynos850_register_cmu(struct device *dev, + struct device_node *np, const struct samsung_cmu_info *cmu) +{ + /* Keep CMU parent clock running (needed for CMU registers access) */ + if (cmu->clk_name) { + struct clk *parent_clk; + + if (dev) + parent_clk = clk_get(dev, cmu->clk_name); + else + parent_clk = of_clk_get_by_name(np, cmu->clk_name); + + if (IS_ERR(parent_clk)) { + pr_err("%s: could not find bus clock %s; err = %ld\n", + __func__, cmu->clk_name, PTR_ERR(parent_clk)); + } else { + clk_prepare_enable(parent_clk); + } + } + + exynos850_init_clocks(np, cmu->clk_regs, cmu->nr_clk_regs); + samsung_cmu_register_one(np, cmu); +} + /* ---- CMU_TOP ------------------------------------------------------------- */ /* Register Offset definitions for CMU_TOP (0x120e0000) */ @@ -347,10 +384,10 @@ static const struct samsung_cmu_info top_cmu_info __initconst = { static void __init exynos850_cmu_top_init(struct device_node *np) { - exynos850_init_clocks(np, top_clk_regs, ARRAY_SIZE(top_clk_regs)); - samsung_cmu_register_one(np, &top_cmu_info); + exynos850_register_cmu(NULL, np, &top_cmu_info); } +/* Register CMU_TOP early, as it's a dependency for other early domains */ CLK_OF_DECLARE(exynos850_cmu_top, "samsung,exynos850-cmu-top", exynos850_cmu_top_init); @@ -615,6 +652,15 @@ static const struct samsung_cmu_info peri_cmu_info __initconst = { .clk_name = "dout_peri_bus", }; +static void __init exynos850_cmu_peri_init(struct device_node *np) +{ + exynos850_register_cmu(NULL, np, &peri_cmu_info); +} + +/* Register CMU_PERI early, as it's needed for MCT timer */ +CLK_OF_DECLARE(exynos850_cmu_peri, "samsung,exynos850-cmu-peri", + exynos850_cmu_peri_init); + /* ---- CMU_CORE ------------------------------------------------------------ */ /* Register Offset definitions for CMU_CORE (0x12000000) */ @@ -779,24 +825,9 @@ static int __init exynos850_cmu_probe(struct platform_device *pdev) { const struct samsung_cmu_info *info; struct device *dev = &pdev->dev; - struct device_node *np = dev->of_node; info = of_device_get_match_data(dev); - exynos850_init_clocks(np, info->clk_regs, info->nr_clk_regs); - samsung_cmu_register_one(np, info); - - /* Keep bus clock running, so it's possible to access CMU registers */ - if (info->clk_name) { - struct clk *bus_clk; - - bus_clk = clk_get(dev, info->clk_name); - if (IS_ERR(bus_clk)) { - pr_err("%s: could not find bus clock %s; err = %ld\n", - __func__, info->clk_name, PTR_ERR(bus_clk)); - } else { - clk_prepare_enable(bus_clk); - } - } + exynos850_register_cmu(dev, dev->of_node, info); return 0; } @@ -806,9 +837,6 @@ static const struct of_device_id exynos850_cmu_of_match[] = { { .compatible = "samsung,exynos850-cmu-hsi", .data = &hsi_cmu_info, - }, { - .compatible = "samsung,exynos850-cmu-peri", - .data = &peri_cmu_info, }, { .compatible = "samsung,exynos850-cmu-core", .data = &core_cmu_info, -- 2.34.1