Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3057224ybt; Mon, 29 Jun 2020 14:08:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzs6LvuihqcIHfminaik07JE8ELA/kChZJhUXdSs3ZSTM/W1ngZd31kJkxsRQqNy+FbYI1l X-Received: by 2002:a50:8a62:: with SMTP id i89mr5437142edi.324.1593464926062; Mon, 29 Jun 2020 14:08:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593464926; cv=none; d=google.com; s=arc-20160816; b=dum4HL1c1Oqnb7wvuqTO8nTN3cFZsHYW9JVJN95uKqPfqWJeLnnKw5AHVCWWqa+4U2 HQbRvMztJMvwzzefS1Se77RBPBixdD9V6CGvspXspOOu/TvtfLmofda34Vi+zxX7Z4QN 6Co0AWQ982kB5m1dGGizBjIXPPrR/PwrBhY7dsn2iB6mrBbiV8FhBrHm9c/Ja6FiSE1T QsVN3+7JlJZyn+779FpBIcC2jhC875NVJZJLW/c2HJ7f3w7MDo+tufJwZZsm+68RPhcb 7MiCrhTUe3dJGGSUbDpFmi9OVCgYmnAhL8ULPWmEgh1llPWHHtkyyIBqeOGiPuLCQb5r j5EA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=9aa7GUtUCyD+TE+fXclqTMD6UKnqsl6e1mNDECt/zhU=; b=NH7x1pB5n2zM8/m5jRmhoOAYyp1d3+31lIEwUqjbAtoE4aRkKpJ6GbtV6yN0lCTUAi /t9p4ftpqTIvAr65icOrqFLuwVy3xDA8Jea8ehyDHEP+71SddLT2Nu7VhZL435NNhlqJ H6gSa22CecTWrLWjacYScqVMqKvsgQJEK/nJLolOWhyZr5zgAebdqb/Bi/QiqRrB39Xe Qu8pIuMHdMVECbuubWP/2rtOj213e9Y+IfHUPDyTrt/DyEe/Yhb/T4jiTr6FzuFjsQJG mem/F5WDfK8ChpDGIM02kwdtqxKHPzr8Fd603GYcBZO+Adr3UaSisWVNQPynJm6XA+Zv FaJA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="g/Rb61CA"; 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 b10si396976eja.426.2020.06.29.14.08.23; Mon, 29 Jun 2020 14:08:46 -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; dkim=pass header.i=@kernel.org header.s=default header.b="g/Rb61CA"; 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 S1732064AbgF2VHC (ORCPT + 99 others); Mon, 29 Jun 2020 17:07:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:53710 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730948AbgF2TKR (ORCPT ); Mon, 29 Jun 2020 15:10:17 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 521D02549C; Mon, 29 Jun 2020 15:53:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1593445996; bh=Q1CRTgJqVhHeGD77GsHlmsq1FI/04IgUKLWSf3geoME=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=g/Rb61CA/LLwp1feqSdEmy5969D9CYWhHcKCj4AxvDEgKvVEr6nnsDghvHNEfSvj9 IkiGAfkoBwp22ea4S4bddgrg62ETCbqltaglG6EqqDJOQhlY5/UpcewOEPNw1mo54f PnCU1nP6jsdPuJXZWU+U2c29PvHo7gKpr3/XThBs= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Bryan O'Donoghue , Georgi Djakov , Andy Gross , Bjorn Andersson , Michael Turquette , Stephen Boyd , Sasha Levin Subject: [PATCH 4.4 004/135] clk: qcom: msm8916: Fix the address location of pll->config_reg Date: Mon, 29 Jun 2020 11:50:58 -0400 Message-Id: <20200629155309.2495516-5-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200629155309.2495516-1-sashal@kernel.org> References: <20200629155309.2495516-1-sashal@kernel.org> MIME-Version: 1.0 X-KernelTest-Patch: http://kernel.org/pub/linux/kernel/v4.x/stable-review/patch-4.4.229-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-4.4.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 4.4.229-rc1 X-KernelTest-Deadline: 2020-07-01T15:53+00:00 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Bryan O'Donoghue [ Upstream commit f47ab3c2f5338828a67e89d5f688d2cef9605245 ] During the process of debugging a processor derived from the msm8916 which we found the new processor was not starting one of its PLLs. After tracing the addresses and writes that downstream was doing and comparing to upstream it became obvious that we were writing to a different register location than downstream when trying to configure the PLL. This error is also present in upstream msm8916. As an example clk-pll.c::clk_pll_recalc_rate wants to write to pll->config_reg updating the bit-field POST_DIV_RATIO. That bit-field is defined in PLL_USER_CTL not in PLL_CONFIG_CTL. Taking the BIMC PLL as an example lm80-p0436-13_c_qc_snapdragon_410_processor_hrd.pdf 0x01823010 GCC_BIMC_PLL_USER_CTL 0x01823014 GCC_BIMC_PLL_CONFIG_CTL This pattern is repeated for gpll0, gpll1, gpll2 and bimc_pll. This error is likely not apparent since the bootloader will already have initialized these PLLs. This patch corrects the location of config_reg from PLL_CONFIG_CTL to PLL_USER_CTL for all relevant PLLs on msm8916. Fixes commit 3966fab8b6ab ("clk: qcom: Add MSM8916 Global Clock Controller support") Cc: Georgi Djakov Cc: Andy Gross Cc: Bjorn Andersson Cc: Michael Turquette Cc: Stephen Boyd Signed-off-by: Bryan O'Donoghue Link: https://lkml.kernel.org/r/20200329124116.4185447-1-bryan.odonoghue@linaro.org Signed-off-by: Stephen Boyd Signed-off-by: Sasha Levin --- drivers/clk/qcom/gcc-msm8916.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/clk/qcom/gcc-msm8916.c b/drivers/clk/qcom/gcc-msm8916.c index 95a4dd290f35a..d7dd0417ef5e8 100644 --- a/drivers/clk/qcom/gcc-msm8916.c +++ b/drivers/clk/qcom/gcc-msm8916.c @@ -270,7 +270,7 @@ static struct clk_pll gpll0 = { .l_reg = 0x21004, .m_reg = 0x21008, .n_reg = 0x2100c, - .config_reg = 0x21014, + .config_reg = 0x21010, .mode_reg = 0x21000, .status_reg = 0x2101c, .status_bit = 17, @@ -297,7 +297,7 @@ static struct clk_pll gpll1 = { .l_reg = 0x20004, .m_reg = 0x20008, .n_reg = 0x2000c, - .config_reg = 0x20014, + .config_reg = 0x20010, .mode_reg = 0x20000, .status_reg = 0x2001c, .status_bit = 17, @@ -324,7 +324,7 @@ static struct clk_pll gpll2 = { .l_reg = 0x4a004, .m_reg = 0x4a008, .n_reg = 0x4a00c, - .config_reg = 0x4a014, + .config_reg = 0x4a010, .mode_reg = 0x4a000, .status_reg = 0x4a01c, .status_bit = 17, @@ -351,7 +351,7 @@ static struct clk_pll bimc_pll = { .l_reg = 0x23004, .m_reg = 0x23008, .n_reg = 0x2300c, - .config_reg = 0x23014, + .config_reg = 0x23010, .mode_reg = 0x23000, .status_reg = 0x2301c, .status_bit = 17, -- 2.25.1