Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp5214811imm; Tue, 12 Jun 2018 04:35:06 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJnCGSlVM+sq1Jt/J3jv9wExREcfJoVoaoegzW4y1KEwMfexLaZGDlH7yolGTQzFfxD095J X-Received: by 2002:a62:303:: with SMTP id 3-v6mr3428253pfd.255.1528803306895; Tue, 12 Jun 2018 04:35:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528803306; cv=none; d=google.com; s=arc-20160816; b=xOkuMU33tv0kb2oyISGiCvsLdhMGpfQZr9ZZ86cJuZ9b+dsjsnhlbkbxPm7gXWaHzi 8tqtfJSaKeWhjZtaud5ViZ5bqoxWgc6NOadshCixbZ4p07lYjRO+TxW+x2PfvaaKSuJL GFcqcfLBkEoZOs4JfliCm89bJxsJBPB2G+t86xe+cQr/U+ikGkHfIHcnQlFGiaJhcfmE Z20U5SADD+66/6MXsAF0pqRIqht4UewHbh+YdmQKTSfx9GnAlnEJCcfg6TL8a3MPd/6K q5q8az9zNB9FnJQLU9HmkolJ2j88aBZAvH0aGWLggWN1h84q9thYGTPOA4NTCDKDxRhI IxUw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=i3zrRJG2becceSrBxsnbhX67FKRgfd0MEktHfud2DwM=; b=N2TyuDymn5JpgB3BSSuGl890NdVxER7OH4nk6maEtxT3ZBWTOQ5irkGd21sXD3gHTw GM0k9mpv7I6PV/YEnnNIuWuHvb8yXHyeZzw5Q7uK1XPUSLcUHswTOd/YUoK3hq69BkcV HEGjtbYjC+EsMzgBdaESpgHnPYPXuH1lFzamMgaiwMItIdvHnfqnTz53XKVgF87OcT+q vqsnoRc5N9GtSnXnxWHyPNs16hojMioarplHCA3KQATRzS+S7zeyri2RRgl7a1oKDiv7 3dVDWQy00npGlLCAvD9M6Zt44zEGifyzaItd164OodrORsFfRAwptEmZnrbMFkchAcD3 kFmQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=MHYl0tLV; dkim=pass header.i=@codeaurora.org header.s=default header.b=MHYl0tLV; 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 i86-v6si697446pfk.146.2018.06.12.04.34.52; Tue, 12 Jun 2018 04:35:06 -0700 (PDT) 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=MHYl0tLV; dkim=pass header.i=@codeaurora.org header.s=default header.b=MHYl0tLV; 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 S1754329AbeFLLe0 (ORCPT + 99 others); Tue, 12 Jun 2018 07:34:26 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:55362 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752806AbeFLLeZ (ORCPT ); Tue, 12 Jun 2018 07:34:25 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id D9717602BD; Tue, 12 Jun 2018 11:34:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1528803264; bh=xGTAYXGGWT7YxfXrF4M/0s9mR5yQ6HfFWSCkKV7QiH4=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=MHYl0tLVetOoL5choXHh2/nbBM3njDHwI/WJOsyOaV8TAMy1bkrrFdoz7E8CeFJ0I iXlyCsqI3/MH/NeVHP/fRJGL8/lM2vV3hngsPAblfLOYerbb28Yq+DZYaFrK/opaqM RHCH0hUSJtr+PUUlDHiJCf8Fg6BXqdnqscwfJrnk= 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.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [10.79.40.126] (blr-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.18.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: vivek.gautam@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 7C5B2602BD; Tue, 12 Jun 2018 11:34:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1528803264; bh=xGTAYXGGWT7YxfXrF4M/0s9mR5yQ6HfFWSCkKV7QiH4=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=MHYl0tLVetOoL5choXHh2/nbBM3njDHwI/WJOsyOaV8TAMy1bkrrFdoz7E8CeFJ0I iXlyCsqI3/MH/NeVHP/fRJGL8/lM2vV3hngsPAblfLOYerbb28Yq+DZYaFrK/opaqM RHCH0hUSJtr+PUUlDHiJCf8Fg6BXqdnqscwfJrnk= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 7C5B2602BD 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=vivek.gautam@codeaurora.org Subject: Re: [PATCH v6 1/3] phy: Update PHY power control sequence To: Can Guo , subhashj@codeaurora.org, asutoshd@codeaurora.org, mgautam@codeaurora.org, kishon@ti.com, robh+dt@kernel.org, mark.rutland@arm.com Cc: linux-kernel@vger.kernel.org, devicetree@vger.kernel.org References: <20180529043751.10580-1-cang@codeaurora.org> <20180529043751.10580-2-cang@codeaurora.org> From: Vivek Gautam Message-ID: <261d2697-ed21-1562-0e6b-f9858108f2b4@codeaurora.org> Date: Tue, 12 Jun 2018 17:04:18 +0530 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <20180529043751.10580-2-cang@codeaurora.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Can, On 5/29/2018 10:07 AM, Can Guo wrote: > All PHYs should be powered on before register configuration starts. And > only PCIe PHYs need an extra power control before deasserts reset state. > > Signed-off-by: Can Guo > --- > drivers/phy/qualcomm/phy-qcom-qmp.c | 5 ++++- > 1 file changed, 4 insertions(+), 1 deletion(-) > > diff --git a/drivers/phy/qualcomm/phy-qcom-qmp.c b/drivers/phy/qualcomm/phy-qcom-qmp.c > index 97ef942..f779b0f 100644 > --- a/drivers/phy/qualcomm/phy-qcom-qmp.c > +++ b/drivers/phy/qualcomm/phy-qcom-qmp.c > @@ -982,6 +982,8 @@ static int qcom_qmp_phy_com_init(struct qcom_qmp *qmp) > if (cfg->has_phy_com_ctrl) > qphy_setbits(serdes, cfg->regs[QPHY_COM_POWER_DOWN_CONTROL], > SW_PWRDN); > + else > + qphy_setbits(pcs, QPHY_POWER_DOWN_CONTROL, cfg->pwrdn_ctrl); No definition of 'pcs' in this function. You are doing that in the second patch. But, we should add this definition here. Also instead of having the change like this: + struct qmp_phy *qphy = qmp->phys[0]; void __iomem *serdes = qmp->serdes; + void __iomem *pcs = qphy->pcs; Let's pass 'struct qmp_phy' to qcom_qmp_phy_com_init(), and then get 'struct qcom_qmp' and 'void __iomem *pcs' from that. So, -static int qcom_qmp_phy_com_init(struct qcom_qmp *qmp) +static int qcom_qmp_phy_com_init(struct qmp_phy *qphy)  { +       struct qcom_qmp *qmp = qphy->qmp;         const struct qmp_phy_cfg *cfg = qmp->cfg;         void __iomem *serdes = qmp->serdes;         void __iomem *dp_com = qmp->dp_com; +       void __iomem *pcs = qphy->pcs; and -       ret = qcom_qmp_phy_com_init(qmp); +       ret = qcom_qmp_phy_com_init(qphy); That looks cleaner than extracting from the 0th phys. BRs Vivek > > if (cfg->has_phy_dp_com_ctrl) { > qphy_setbits(dp_com, QPHY_V3_DP_COM_POWER_DOWN_CTRL, > @@ -1127,7 +1129,8 @@ static int qcom_qmp_phy_init(struct phy *phy) > * Pull out PHY from POWER DOWN state. > * This is active low enable signal to power-down PHY. > */ > - qphy_setbits(pcs, QPHY_POWER_DOWN_CONTROL, cfg->pwrdn_ctrl); > + if (cfg->type == PHY_TYPE_PCIE) > + qphy_setbits(pcs, QPHY_POWER_DOWN_CONTROL, cfg->pwrdn_ctrl); > > if (cfg->has_pwrdn_delay) > usleep_range(cfg->pwrdn_delay_min, cfg->pwrdn_delay_max);