From patchwork Wed May 30 15:06:45 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Dmitry Osipenko X-Patchwork-Id: 922852 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=none (mailfrom) smtp.mailfrom=vger.kernel.org (client-ip=209.132.180.67; helo=vger.kernel.org; envelope-from=linux-tegra-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dmarc=fail (p=none dis=none) header.from=gmail.com Authentication-Results: ozlabs.org; dkim=fail reason="signature verification failed" (2048-bit key; unprotected) header.d=gmail.com header.i=@gmail.com header.b="VKDGbtTB"; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 40wvDC5NDpz9s1d for ; Thu, 31 May 2018 01:10:35 +1000 (AEST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753739AbeE3PKc (ORCPT ); Wed, 30 May 2018 11:10:32 -0400 Received: from mail-lf0-f65.google.com ([209.85.215.65]:36130 "EHLO mail-lf0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753648AbeE3PK1 (ORCPT ); Wed, 30 May 2018 11:10:27 -0400 Received: by mail-lf0-f65.google.com with SMTP id u4-v6so4857074lff.3; Wed, 30 May 2018 08:10:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=mJbAPOImtc7hZ45o1iBpn/OOLUD0U9g8/4ojUQ0kqv4=; b=VKDGbtTBoIFr/zupCqWoHhWlYscIZsJOdyASHNAaRFE+X5jRoDtp2fqxIgZCMu3XLn 5dOMczKvpmkZ08Z0/5k14l0Wg/Ov5Edg8rMx9eFceoY/ceGfiM67P9cY/3DrlR9qWe2j UDxqEt1ZcQh6YY6zSIRMjMWYVo7vChv0O3oi0gQHqfQQDuOtsuUSxUTqekM0FsOZkM3S qRJkHe04sr4fpRHL99r26+kVw0yckP+EEAaAiStZMMMG406rPNpdNGasT1VyjnoW22Qb kASlYIcPUlv6rDAn6gCg31Cc9AsZKzqSztf/OTdTDnSfWWzeeLf6kxO4VFZz83dxIC/T UmEQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=mJbAPOImtc7hZ45o1iBpn/OOLUD0U9g8/4ojUQ0kqv4=; b=dNe3WHu49oB4fbQgqX32NHaT+1kySBmLmvQH0LF3FGTOyRIQDdPq+nWUHvZHhRu3wC 6EaG2VFz6GxE2ndhN4DqfHUFJFmu99MxXSlzw4XbmRjMCttADbEhHfIC5n43xWp5HOd/ e8KnWL8cjvdesH7gFpyh5+GPZXMHmFWJ1HeCJF6csFtjm7hdsVKcDSo6IVPHsLTNRto2 7Mx2D0GshJ8KeDqZdXBhMVlnhkXHfR2MX7TbdV5X82q0E4uoa6nuWzM3RaOiXu7OyWeC B8K0tmHyDLxBsZ4IC8dh2huDJ+eWYdSzsBgp8H9Qx6zDR/TbeBmvm+dNASebHFuoBx4B KOzQ== X-Gm-Message-State: ALKqPweJKAmAaU/yPs0EtVwsXwcn9NoBuhb9Q2WWv8iSIikxAS9EaIjs sZ35cVaiKeGfEGPcqXy51vTta6v8 X-Google-Smtp-Source: ADUXVKIQk4UQxcDOeMoRPGpVHxjFshTtj3wMw0XKrPZFBfFn9wvyyqmwMhTjha2ybZMlDKgIjkDuIg== X-Received: by 2002:a19:4e86:: with SMTP id u6-v6mr2038331lfk.105.1527693025072; Wed, 30 May 2018 08:10:25 -0700 (PDT) Received: from localhost.localdomain (109-252-91-41.nat.spd-mgts.ru. [109.252.91.41]) by smtp.gmail.com with ESMTPSA id v3-v6sm6982134ljv.61.2018.05.30.08.10.23 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 30 May 2018 08:10:24 -0700 (PDT) From: Dmitry Osipenko To: Thierry Reding , Peter De Schrijver , Jonathan Hunter , Prashant Gaikwad , Michael Turquette , Stephen Boyd , Rob Herring , Mark Rutland Cc: linux-tegra@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v1 3/4] clk: tegra20: Turn EMC clock gate into divider Date: Wed, 30 May 2018 18:06:45 +0300 Message-Id: <20180530150646.19030-4-digetx@gmail.com> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180530150646.19030-1-digetx@gmail.com> References: <20180530150646.19030-1-digetx@gmail.com> Sender: linux-tegra-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-tegra@vger.kernel.org Kernel should never gate the EMC clock as it causes immediate lockup, so removing clk-gate functionality doesn't affect anything. Turning EMC clk gate into divider allows to implement glitch-less EMC scaling, avoiding reparenting to a backup clock. Signed-off-by: Dmitry Osipenko --- drivers/clk/tegra/clk-tegra20.c | 39 ++++++++++++++++++++++++--------- 1 file changed, 29 insertions(+), 10 deletions(-) diff --git a/drivers/clk/tegra/clk-tegra20.c b/drivers/clk/tegra/clk-tegra20.c index cc857d4d4a86..189dbc86ab71 100644 --- a/drivers/clk/tegra/clk-tegra20.c +++ b/drivers/clk/tegra/clk-tegra20.c @@ -578,7 +578,6 @@ static struct tegra_clk tegra20_clks[tegra_clk_max] __initdata = { [tegra_clk_afi] = { .dt_id = TEGRA20_CLK_AFI, .present = true }, [tegra_clk_fuse] = { .dt_id = TEGRA20_CLK_FUSE, .present = true }, [tegra_clk_kfuse] = { .dt_id = TEGRA20_CLK_KFUSE, .present = true }, - [tegra_clk_emc] = { .dt_id = TEGRA20_CLK_EMC, .present = true }, }; static unsigned long tegra20_clk_measure_input_freq(void) @@ -799,19 +798,18 @@ static struct tegra_periph_init_data tegra_periph_nodiv_clk_list[] = { TEGRA_INIT_DATA_NODIV("disp2", mux_pllpdc_clkm, CLK_SOURCE_DISP2, 30, 2, 26, 0, TEGRA20_CLK_DISP2), }; -static void __init tegra20_periph_clk_init(void) +static void __init tegra20_emc_clk_init(void) { - struct tegra_periph_init_data *data; + u32 emc_reg = readl_relaxed(clk_base + CLK_SOURCE_EMC); + u32 use_pllm_ud = BIT(29); struct clk *clk; - unsigned int i; - /* ac97 */ - clk = tegra_clk_register_periph_gate("ac97", "pll_a_out0", - TEGRA_PERIPH_ON_APB, - clk_base, 0, 3, periph_clk_enb_refcnt); - clks[TEGRA20_CLK_AC97] = clk; + if (emc_reg & use_pllm_ud) { + pr_err("%s: un-divided PllM_out0 used as clock source\n", + __func__); + return; + } - /* emc */ clk = clk_register_mux(NULL, "emc_mux", mux_pllmcp_clkm, ARRAY_SIZE(mux_pllmcp_clkm), CLK_SET_RATE_NO_REPARENT, @@ -822,6 +820,27 @@ static void __init tegra20_periph_clk_init(void) &emc_lock); clks[TEGRA20_CLK_MC] = clk; + clk = clk_register_divider(NULL, "emc", "emc_mux", CLK_IS_CRITICAL, + clk_base + CLK_SOURCE_EMC, 0, 7, + 0, &emc_lock); + clks[TEGRA20_CLK_EMC] = clk; +} + +static void __init tegra20_periph_clk_init(void) +{ + struct tegra_periph_init_data *data; + struct clk *clk; + unsigned int i; + + /* ac97 */ + clk = tegra_clk_register_periph_gate("ac97", "pll_a_out0", + TEGRA_PERIPH_ON_APB, + clk_base, 0, 3, periph_clk_enb_refcnt); + clks[TEGRA20_CLK_AC97] = clk; + + /* emc */ + tegra20_emc_clk_init(); + /* dsi */ clk = tegra_clk_register_periph_gate("dsi", "pll_d", 0, clk_base, 0, 48, periph_clk_enb_refcnt);