Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp735362ybx; Thu, 7 Nov 2019 01:52:01 -0800 (PST) X-Google-Smtp-Source: APXvYqz7U9Zq/I0Na6Logvib4We4M7PieI7WBAd7DgfjpZbCCTID1JI9Ux9aspKambaXUXOrnWJj X-Received: by 2002:aa7:db09:: with SMTP id t9mr2500324eds.171.1573120321701; Thu, 07 Nov 2019 01:52:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573120321; cv=none; d=google.com; s=arc-20160816; b=W4IjAX7kkd5M47o5IRgNYJvkXcivU8hq+wqbX7fkFUk09yFj0jat5FFiMivRa7G5rz kiP2jKZZ20njTmCG6bkJfrI1q1Vr/WRjNndd0e6PmSylkWMtccyjmSDU3y7nhIxYWmzu /fMJVAvuVP3MrFnN6wpey7bysVHbnvFF+LrSkVXEPYjX8YJkjesT1K8FPlgUZVCYj+kY 8cw7O8rUlNzyfPCcgI7qcmBZWeRbzktDdN8GPnCfDy2TmBuVRpvxj+jKGrFywOBmI8zA 8Dtpl3Kr1Sjxde/0KB+trXHNxB+AV14LgKS/tDCRQ5Ci3lVaS2xkjxQ8cA/TfXT7RhXl OBZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dmarc-filter:dkim-signature:dkim-signature; bh=V6FoCxGrBr7oU+TorbvPQcsJfcHy1g9aO5Idf/SlwlI=; b=wfG4pWbMlmpQQmlcA3ujI+/eSG7tHte4DQG8U8LkNkeMbcQzPN0cbaP1tkqClWF4Ff 09uiRVc1xRdzg1EbMO5+yJH4pNZY4jG6GB/43Av3hLK99b1//BaD1Tzjym0HHFpQNsn/ Y0xPKKEgAGsAl5l8NI1vujG8gsuK6cSH5WRgyT1I973pO9ELr7CyUWFQjQ4VPQp5hGxj 2JQ2u7IBgjzc5I0xpb6sUg4zprH72HaT0Qgi6zb0KEITBpIwiaYa86lUcOX2oG/GfQWK LLIKy1Cguhv/oJYalOC4d52AMHWffTK2/kkHCUpuZOlsdcjLO2SCLwDAN2MCWeTSOC02 8jcg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=CBBKLOfJ; dkim=pass header.i=@codeaurora.org header.s=default header.b=bfh3wXp5; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p4si1025727ejo.21.2019.11.07.01.51.38; Thu, 07 Nov 2019 01:52:01 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=CBBKLOfJ; dkim=pass header.i=@codeaurora.org header.s=default header.b=bfh3wXp5; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388025AbfKGJsr (ORCPT + 99 others); Thu, 7 Nov 2019 04:48:47 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:60780 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387964AbfKGJsq (ORCPT ); Thu, 7 Nov 2019 04:48:46 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 0BAA260E20; Thu, 7 Nov 2019 09:48:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1573120124; bh=BeQ/yTr+Uyd66MAuVY6kgngE10RSn0pe7YmPe0gdDc0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CBBKLOfJIPQ2ejeXXJoJo/q3JkLeEqOSTE0YtgUEvEdt/wG0BJrXvkkNhPSfL7lV0 3joyMNzAmHj8Kyoih3cNvjItnsyRjNcUgovgNhZB175m2M8rbEd8/3MSZvW4FPAGO3 YqITIrBlHjSsJrwshPqVXnjOK5sRvuwUgOZz19mM= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED,SPF_NONE autolearn=no autolearn_force=no version=3.4.0 Received: from pacamara-linux.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: cang@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id ACD4160AD9; Thu, 7 Nov 2019 09:48:39 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1573120120; bh=BeQ/yTr+Uyd66MAuVY6kgngE10RSn0pe7YmPe0gdDc0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bfh3wXp5cDcH4OlLKf/2qoXqviR0kgfbDhRV07NeBWXm7+S+g6puVd4/1gu8foXEX CYtQ4fHR3DdsNMiB8Dz9ZIA7FvEBOeMPlSm+mmob6oLg8VJmPG4PAkAHGQRILBd2An ysOVycmT0B5voG0KBGNOV56R8ldnER3N2dRpaPLk= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org ACD4160AD9 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=cang@codeaurora.org From: Can Guo To: asutoshd@codeaurora.org, nguyenb@codeaurora.org, rnayak@codeaurora.org, linux-scsi@vger.kernel.org, kernel-team@android.com, saravanak@google.com, salyzyn@google.com, cang@codeaurora.org Cc: Andy Gross , Alim Akhtar , Avri Altman , Pedro Sousa , "James E.J. Bottomley" , "Martin K. Petersen" , linux-arm-msm@vger.kernel.org (open list:ARM/QUALCOMM SUPPORT), linux-kernel@vger.kernel.org (open list) Subject: [PATCH v2 4/6] scsi: ufs-qcom: Adjust bus bandwidth voting and unvoting Date: Thu, 7 Nov 2019 01:47:55 -0800 Message-Id: <1573120078-15547-5-git-send-email-cang@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1573120078-15547-1-git-send-email-cang@codeaurora.org> References: <1573120078-15547-1-git-send-email-cang@codeaurora.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The bus bandwidth voting is required to be done before the bus clocks are enabled, and the unvoting is required to be done only after the bus clocks are disabled. Signed-off-by: Can Guo --- drivers/scsi/ufs/ufs-qcom.c | 57 +++++++++++++++++++++++++++++++-------------- 1 file changed, 39 insertions(+), 18 deletions(-) diff --git a/drivers/scsi/ufs/ufs-qcom.c b/drivers/scsi/ufs/ufs-qcom.c index c69c29a1c..85d7c17 100644 --- a/drivers/scsi/ufs/ufs-qcom.c +++ b/drivers/scsi/ufs/ufs-qcom.c @@ -38,7 +38,6 @@ enum { static struct ufs_qcom_host *ufs_qcom_hosts[MAX_UFS_QCOM_HOSTS]; -static int ufs_qcom_set_bus_vote(struct ufs_qcom_host *host, int vote); static void ufs_qcom_get_default_testbus_cfg(struct ufs_qcom_host *host); static int ufs_qcom_set_dme_vs_core_clk_ctrl_clear_div(struct ufs_hba *hba, u32 clk_cycles); @@ -674,7 +673,7 @@ static void ufs_qcom_get_speed_mode(struct ufs_pa_layer_attr *p, char *result) } } -static int ufs_qcom_set_bus_vote(struct ufs_qcom_host *host, int vote) +static int __ufs_qcom_set_bus_vote(struct ufs_qcom_host *host, int vote) { int err = 0; @@ -705,7 +704,7 @@ static int ufs_qcom_update_bus_bw_vote(struct ufs_qcom_host *host) vote = ufs_qcom_get_bus_vote(host, mode); if (vote >= 0) - err = ufs_qcom_set_bus_vote(host, vote); + err = __ufs_qcom_set_bus_vote(host, vote); else err = vote; @@ -716,6 +715,35 @@ static int ufs_qcom_update_bus_bw_vote(struct ufs_qcom_host *host) return err; } +static int ufs_qcom_set_bus_vote(struct ufs_hba *hba, bool on) +{ + struct ufs_qcom_host *host = ufshcd_get_variant(hba); + int vote, err; + + /* + * In case ufs_qcom_init() is not yet done, simply ignore. + * This ufs_qcom_set_bus_vote() shall be called from + * ufs_qcom_init() after init is done. + */ + if (!host) + return 0; + + if (on) { + vote = host->bus_vote.saved_vote; + if (vote == host->bus_vote.min_bw_vote) + ufs_qcom_update_bus_bw_vote(host); + } else { + vote = host->bus_vote.min_bw_vote; + } + + err = __ufs_qcom_set_bus_vote(host, vote); + if (err) + dev_err(hba->dev, "%s: set bus vote failed %d\n", + __func__, err); + + return err; +} + static ssize_t show_ufs_to_mem_max_bus_bw(struct device *dev, struct device_attribute *attr, char *buf) @@ -792,7 +820,7 @@ static int ufs_qcom_update_bus_bw_vote(struct ufs_qcom_host *host) return 0; } -static int ufs_qcom_set_bus_vote(struct ufs_qcom_host *host, int vote) +static int ufs_qcom_set_bus_vote(struct ufs_hba *host, bool on) { return 0; } @@ -1030,8 +1058,7 @@ static int ufs_qcom_setup_clocks(struct ufs_hba *hba, bool on, enum ufs_notify_change_status status) { struct ufs_qcom_host *host = ufshcd_get_variant(hba); - int err; - int vote = 0; + int err = 0; /* * In case ufs_qcom_init() is not yet done, simply ignore. @@ -1041,28 +1068,21 @@ static int ufs_qcom_setup_clocks(struct ufs_hba *hba, bool on, if (!host) return 0; - if (on && (status == POST_CHANGE)) { + if (on && (status == PRE_CHANGE)) { + err = ufs_qcom_set_bus_vote(hba, true); + } else if (on && (status == POST_CHANGE)) { /* enable the device ref clock for HS mode*/ if (ufshcd_is_hs_mode(&hba->pwr_info)) ufs_qcom_dev_ref_clk_ctrl(host, true); - vote = host->bus_vote.saved_vote; - if (vote == host->bus_vote.min_bw_vote) - ufs_qcom_update_bus_bw_vote(host); - } else if (!on && (status == PRE_CHANGE)) { if (!ufs_qcom_is_link_active(hba)) { /* disable device ref_clk */ ufs_qcom_dev_ref_clk_ctrl(host, false); } - - vote = host->bus_vote.min_bw_vote; + } else if (!on && (status == POST_CHANGE)) { + err = ufs_qcom_set_bus_vote(hba, false); } - err = ufs_qcom_set_bus_vote(host, vote); - if (err) - dev_err(hba->dev, "%s: set bus vote failed %d\n", - __func__, err); - return err; } @@ -1238,6 +1258,7 @@ static int ufs_qcom_init(struct ufs_hba *hba) ufs_qcom_set_caps(hba); ufs_qcom_advertise_quirks(hba); + ufs_qcom_set_bus_vote(hba, true); ufs_qcom_setup_clocks(hba, true, POST_CHANGE); if (hba->dev->id < MAX_UFS_QCOM_HOSTS) -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project