Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp788686imu; Fri, 21 Dec 2018 07:23:47 -0800 (PST) X-Google-Smtp-Source: ALg8bN4JBvxkD/KBxFoSZZJvY1ZDuGNBd511/ux9umbatrCwUNDLUsicafcJTgjnIp83OUBp5P9V X-Received: by 2002:a63:f141:: with SMTP id o1mr2884752pgk.134.1545405827620; Fri, 21 Dec 2018 07:23:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545405827; cv=none; d=google.com; s=arc-20160816; b=oD4PfdMqag0AssKNITq+62vHWpQJXlXifomJLrev+WSTqZEL7oiTGz3m52Dsdo7s+c IfsT/Y+jXZMwSIGBIhQ3lwu35KA7i7P4OMuaW5mgvIz286X3WilMp6RU/JG74QJDkmtY roKcdoLkjGNdFNTya6RUsE4tndKTyA8+drUjE6WV1AMPcbt/ypHmLae4asJPeND7Bsy2 3673MhAGllZOlloKKOk4fM+e/WrdFWfTQFHtnkluVG3fZPj0og5V0QQj+/48KLqUpWDg n5TiaT+7hyj0yTaSSXB3KgtI945itHdq8kq3cVTkW3Xte6SPq92W8kWQq/L8WpK+kPBA 4uDg== 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; bh=/o9cCtlpgUQZlXfiuKsW0YKqAJof9sDI4eohfstOv1w=; b=nxoGPwKenFF2OyASa4DK+ddKuTO2lMG0C/66RxjWUhKuxdWV4GHk+MfzD/sNq3WdGS 0RRYU1S1r4py6xaAcFon+RfpS8aj0YA0lweZ2V4BzG/78j5z0HkWZW5X+8cAPvPoRrQ9 nGvLtRN5qmo+K7n+iZN6wXn0L8k3pGWauF1J83pH69yQEw80GBcQO9/bYYx5Wp13Px3R yjIXEV9sTcg+0kIAQI+tMEsHH+88UYuXNiUdQDatLPtL+aywpfx9sTjhne+cK3CM8owQ vzWnRvwnKl/+SoVwxK3bep0gAb24SVhbYdGEA87gSF20Y/0qwHjJ2jcy2j9p9FbyJTMh zI2Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=H5rxtO1A; dkim=pass header.i=@codeaurora.org header.s=default header.b=X8prDouE; 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 j22si4315879pfi.252.2018.12.21.07.23.31; Fri, 21 Dec 2018 07:23:47 -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=H5rxtO1A; dkim=pass header.i=@codeaurora.org header.s=default header.b=X8prDouE; 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 S1732915AbeLUINS (ORCPT + 99 others); Fri, 21 Dec 2018 03:13:18 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:40998 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730509AbeLUINR (ORCPT ); Fri, 21 Dec 2018 03:13:17 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 2F5296053B; Fri, 21 Dec 2018 08:13:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1545379996; bh=GjwTpVy9d8uEuliEBXqbCqXteFKRpN0TvzzwTpPcbXk=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=H5rxtO1AKd8W9jS5QauqQxKfvsZtQyFb6YCfdfMNPFGy09XEqwyeqlK9rWTuMTGu4 hvaWckG8lPodgJlEY+qz1N3y5E8EVAScR21dQPanMM9Fj2h8Jfde/FrrNVqRCMdKSt DqTNTlK3n9gpvOxJ9UJoMwSuc1ggEV+u2V5fj2TA= 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 autolearn=no autolearn_force=no version=3.4.0 Received: from [10.206.25.155] (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: mgautam@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 060F8606FC; Fri, 21 Dec 2018 08:13:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1545379995; bh=GjwTpVy9d8uEuliEBXqbCqXteFKRpN0TvzzwTpPcbXk=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=X8prDouEiy5KRHAjiNHD7Jev2JETQnSDAc6vXEf5VGxKuqpdAXLQyH60a0e2LYQRV OCWhWjmTS37j59z7XRaP7vSPi8NPPDHCnfpKdbwE9Tu+MWhk4CD4gyw/UYdAcLFdhB XoVytbaAx4bzLDClJTm+zEbxucmY3q1OgNXDGHAE= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 060F8606FC 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=mgautam@codeaurora.org Subject: Re: [PATCH v6 2/2] phy: qualcomm: Add Synopsys High-Speed USB PHY driver To: Shawn Guo Cc: Kishon Vijay Abraham I , Rob Herring , Sriharsha Allenki , Anu Ramanathan , Bjorn Andersson , Vinod Koul , Jack Pham , linux-arm-msm@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm-owner@vger.kernel.org References: <20181220010112.16824-1-shawn.guo@linaro.org> <20181220010112.16824-3-shawn.guo@linaro.org> <20181220110956.GA17416@dragon> From: Manu Gautam Message-ID: Date: Fri, 21 Dec 2018 13:43:09 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <20181220110956.GA17416@dragon> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 12/20/2018 4:39 PM, Shawn Guo wrote: > Hi Manu, > > On Thu, Dec 20, 2018 at 09:33:43AM +0530, mgautam@codeaurora.org wrote: >> Hi Shawn, >> >> On 2018-12-20 06:31, Shawn Guo wrote: >>> It adds Synopsys 28nm Femto High-Speed USB PHY driver support, which >>> is usually paired with Synopsys DWC3 USB controllers on Qualcomm SoCs. >>> >>> Signed-off-by: Shawn Guo >>> --- >> ... >>> +struct hsphy_priv { >> nit-pick - indentation for following structure members? > Hmm, my personal taste says no, because I found that it's hard to keep > the indentation when adding new members later. ok > >>> + void __iomem *base; >>> + struct clk_bulk_data *clks; >>> + int num_clks; >>> + struct reset_control *phy_reset; >>> + struct reset_control *por_reset; >>> + struct regulator_bulk_data vregs[VREG_NUM]; >>> + unsigned int voltages[VREG_NUM][VOL_NUM]; >>> + const struct hsphy_data *data; >>> + bool cable_connected; >> You can get cable-connected state from "enum phy_mode mode" which >> is present in this driver. >> E.g. cable_connected is false if mode is neither HOST nor DEVICE. >> >> >>> + struct extcon_dev *vbus_edev; >>> + struct notifier_block vbus_notify; >> extcons not needed if you use "mode" for the same purpose. > The extcon is there for indicating cable connection status. I'm not > sure that phy_mode can be used for that purpose. For example, what > value would phy core set phy_mode to, if we disconnect the cable from > phy_mode being HOST or DEVICE? it depends how it is used. Looks like it is used to decide whether to turn-off regulators or not. Unless you plan to add low power support as part of runtime-suspend of PHY during host mode, there is no reason to not turn-off regulators on pm_suspend(). Please refer to my comments below. > >> >>> + enum phy_mode mode; >>> +}; >>> + >> >>> + >>> +static int qcom_snps_hsphy_vbus_notifier(struct notifier_block *nb, >>> + unsigned long event, void *ptr) >>> +{ >>> + struct hsphy_priv *priv = container_of(nb, struct hsphy_priv, >>> + vbus_notify); >>> + priv->cable_connected = !!event; >>> + return 0; >>> +} >>> + >>> +static int qcom_snps_hsphy_power_on(struct phy *phy) >> Can you instead merge this power_on function with phy_init? > I can do that, but what's the gain/advantage from doing that? dwc3 core calls phy_init() before power_on(). AFAIK, PHY regulators need to be ON before initializing it. > >>> +{ >>> + struct hsphy_priv *priv = phy_get_drvdata(phy); >>> + int ret; >>> + >>> + if (priv->cable_connected) { >> Why distinguish between cable connected vs not-connected? > This is based on the vendor driver implementation. It does a more > aggressive low power management in case that cable is not connected, > i.e. turning off regulator and entering retention mode. I believe 'aggressive low power management' will be triggered on pm_suspend? And dwc3 core will in any case perform phy_exit()->phy_init() across pm_suspend/resume which will reset PHYs. Hence, there is no need to check for cable connected state here. > >>> + ret = clk_bulk_prepare_enable(priv->num_clks, priv->clks); >>> + if (ret) >>> + return ret; >>> + qcom_snps_hsphy_disable_hv_interrupts(priv); >>> + } else { >>> + ret = qcom_snps_hsphy_enable_regulators(priv); >>> + if (ret) >>> + return ret; >>> + ret = clk_bulk_prepare_enable(priv->num_clks, priv->clks); >>> + if (ret) >>> + return ret; >>> + qcom_snps_hsphy_exit_retention(priv); >>> + } >>> + >>> + return 0; >>> +} >>> + >>> +static int qcom_snps_hsphy_power_off(struct phy *phy) >>> +{ >>> + struct hsphy_priv *priv = phy_get_drvdata(phy); >>> + >>> + if (priv->cable_connected) { >>> + qcom_snps_hsphy_enable_hv_interrupts(priv); >>> + clk_bulk_disable_unprepare(priv->num_clks, priv->clks); >>> + } else { >>> + qcom_snps_hsphy_enter_retention(priv); >>> + clk_bulk_disable_unprepare(priv->num_clks, priv->clks); >>> + qcom_snps_hsphy_disable_regulators(priv); >>> + } >>> + >>> + return 0; >>> +} >>> + >> >> >> .. >>> +static const struct phy_ops qcom_snps_hsphy_ops = { >>> + .init = qcom_snps_hsphy_init, >>> + .power_on = qcom_snps_hsphy_power_on, >>> + .power_off = qcom_snps_hsphy_power_off, >>> + .set_mode = qcom_snps_hsphy_set_mode, >> .phy_exit()? >> I believe that is needed as dwc3 core driver performs >> phy_exit/phy_init across pm_suspend/resume. > I just do not see anything that we should be doing in .exit hook right > now. After you merge power_on() with phy_init() as per my previous comment, you can rely on phy_exit() to take care of putting PHY in low power state and turn off regulators as well. > > Shawn > >> >>> + .owner = THIS_MODULE, >>> +}; >>> + -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project