Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp792788pxk; Mon, 31 Aug 2020 00:37:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwiFr0ppwFuSTYu95Pjjten6FyR0sF7r8bplDTpcVqGlT0FPdNahsLD3SSGuE3/4/9D6OiN X-Received: by 2002:a17:906:54d3:: with SMTP id c19mr11452833ejp.408.1598859425885; Mon, 31 Aug 2020 00:37:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598859425; cv=none; d=google.com; s=arc-20160816; b=bQBgGgwLeCLVxJOGTVip3WljlC4sHdn4bR5kIHmUH74A1/36a9sN2u65ZymL1qTYOA UpRZYtzYToHhPETaq9ah/vCPrN4I/SrVs4FTFJvuE9y3SaoRnuuvvvBVGuauh2wkYMbJ pQVoCqQMvx3HYaA4jWeAixTEZgqKWZaSvv2II/FDr2aePth5AiBZ4MEfZV4h4jpXckBg Zes8/AIfooquvO6UAgXCz14PM1YK5J8Y/Va4CylTi5pqEwH+HDCFtDOjjae8KIQSGyR7 BL6g86jLW6UrkG0EVUpxb/dsLaOEPqujqOtaN8k2ih50NpQbx5cmEDIqBVOHZJ8oq722 0+DQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=Tu7M9V6wEM+kIwQZBHn4ViGRwilIUEhG1y+KUQvPRJ4=; b=NXb6mSHnmpdfx0I8pgd320u1Og1GAwkyGUPd1pzDNKtc50OSULYmH6YJqCr2I7O5E1 XuiCpJ8EmxHiWnotm2dEMiFltTvkdtPN+gSpVNzu8uzyYtkt/O1uwFoRd2bAYmbBC67Z jmAA7cSan78U/+/oEk6DjaJX6IiRpBBC3Deb3vibzYH/Jo+MvfbEBUcs0pRzLLbtC+mO lKFxpo/irUwQH1SXzB/O9HWhkTBTKl4zP8eCIMuf+W1X88n1mwoT38L1Af9Z1XjLb8DP P/acBvElr5yP4WQroTjio1tzGyVcHZOhiGLoa9U5WjMn6y7tg286Z4xImYFE2ZWfG+Vs xnCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=omVR4E1V; 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 k25si4723915edv.381.2020.08.31.00.36.43; Mon, 31 Aug 2020 00:37:05 -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=omVR4E1V; 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 S1727965AbgHaHgC (ORCPT + 99 others); Mon, 31 Aug 2020 03:36:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:44872 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725794AbgHaHgA (ORCPT ); Mon, 31 Aug 2020 03:36:00 -0400 Received: from localhost (unknown [122.171.38.130]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 3F5A8206EB; Mon, 31 Aug 2020 07:35:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1598859359; bh=AmuiRA9ag6zrrQLhZzSQH64RuSqSCWUPiji2PS7IRfg=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=omVR4E1V9p59SGh3NCwkGPbmZ4yk/C/d/XOEDQpdjEleYqYq/n7fV+WAEz8AwOg0o SaApy4rCEULKr1VjvVTTOL0PfAOq180K4h16Ov1mVNF7/k+GlTryeeTwkkS+8xrIeM n5V+9MfMGUv2Yuor0Z1kAymt+BfsndpTc+08KuVQ= Date: Mon, 31 Aug 2020 13:05:54 +0530 From: Vinod Koul To: Nagarjuna Kristam Cc: kishon@ti.com, thierry.reding@gmail.com, devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH V5 4/7] phy: tegra: xusb: Add soc ops API to enable UTMI PAD protection Message-ID: <20200831073554.GF2639@vkoul-mobl> References: <1595238948-20531-1-git-send-email-nkristam@nvidia.com> <1595238948-20531-5-git-send-email-nkristam@nvidia.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1595238948-20531-5-git-send-email-nkristam@nvidia.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20-07-20, 15:25, Nagarjuna Kristam wrote: > When USB charger is enabled, UTMI PAD needs to be protected according > to the direction and current level. Add support for the same on Tegra210 > and Tegra186. > > Signed-off-by: Nagarjuna Kristam > Acked-by: Thierry Reding > --- > V5: > - No changes. > --- > V4: > - Added Acked-by updates to commit message. > --- > V3: > - Alligned function and its arguments. > - Fixed other comments from Thierry. > --- > V2: > - Commit message coorected. > - Patch re-based. > --- > drivers/phy/tegra/xusb-tegra186.c | 40 +++++++++++++++++++++++++++++++++++++++ > drivers/phy/tegra/xusb-tegra210.c | 32 +++++++++++++++++++++++++++++++ > drivers/phy/tegra/xusb.h | 13 +++++++++++++ > 3 files changed, 85 insertions(+) > > diff --git a/drivers/phy/tegra/xusb-tegra186.c b/drivers/phy/tegra/xusb-tegra186.c > index f862254..59b78a7 100644 > --- a/drivers/phy/tegra/xusb-tegra186.c > +++ b/drivers/phy/tegra/xusb-tegra186.c > @@ -68,6 +68,13 @@ > #define PORTX_SPEED_SUPPORT_MASK (0x3) > #define PORT_SPEED_SUPPORT_GEN1 (0x0) > > +#define USB2_BATTERY_CHRG_OTGPADX_CTL1(x) (0x84 + (x) * 0x40) > +#define PD_VREG (1 << 6) > +#define VREG_LEV(x) (((x) & 0x3) << 7) > +#define VREG_DIR(x) (((x) & 0x3) << 11) maybe FIELD_GET() would be better, avoids error with shifts > +#define VREG_DIR_IN VREG_DIR(1) > +#define VREG_DIR_OUT VREG_DIR(2) > + > #define XUSB_PADCTL_USB2_OTG_PADX_CTL0(x) (0x88 + (x) * 0x40) > #define HS_CURR_LEVEL(x) ((x) & 0x3f) > #define TERM_SEL BIT(25) > @@ -289,6 +296,37 @@ static void tegra_phy_xusb_utmi_pad_power_down(struct phy *phy) > usb2->powered_on = false; > } > > +static void > +tegra186_xusb_padctl_utmi_pad_set_protection(struct tegra_xusb_port *port, > + int level, > + enum tegra_vbus_dir dir) > +{ > + u32 value; > + struct tegra_xusb_padctl *padctl = port->padctl; > + unsigned int index = port->index; > + > + value = padctl_readl(padctl, USB2_BATTERY_CHRG_OTGPADX_CTL1(index)); > + > + if (level < 0) { > + /* disable pad protection */ > + value |= PD_VREG; > + value &= ~VREG_LEV(~0); > + value &= ~VREG_DIR(~0); > + } else { > + if (dir == TEGRA_VBUS_SOURCE) > + value |= VREG_DIR_OUT; > + else if (dir == TEGRA_VBUS_SINK) > + value |= VREG_DIR_IN; > + > + value &= ~PD_VREG; > + value &= ~VREG_DIR(~0); > + value &= ~VREG_LEV(~0); > + value |= VREG_LEV(level); This would look much cleaner with FIELD_PREP() or u32_encoded_bits() > + } > + > + padctl_writel(padctl, value, USB2_BATTERY_CHRG_OTGPADX_CTL1(index)); > +} > + > static int tegra186_xusb_padctl_vbus_override(struct tegra_xusb_padctl *padctl, > bool status) > { > @@ -935,6 +973,8 @@ static const struct tegra_xusb_padctl_ops tegra186_xusb_padctl_ops = { > .vbus_override = tegra186_xusb_padctl_vbus_override, > .utmi_pad_power_on = tegra_phy_xusb_utmi_pad_power_on, > .utmi_pad_power_down = tegra_phy_xusb_utmi_pad_power_down, > + .utmi_pad_set_protection = > + tegra186_xusb_padctl_utmi_pad_set_protection, single line please > }; > > #if IS_ENABLED(CONFIG_ARCH_TEGRA_186_SOC) > diff --git a/drivers/phy/tegra/xusb-tegra210.c b/drivers/phy/tegra/xusb-tegra210.c > index 2e5f71c..3aff284 100644 > --- a/drivers/phy/tegra/xusb-tegra210.c > +++ b/drivers/phy/tegra/xusb-tegra210.c > @@ -74,6 +74,8 @@ > #define XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_LEV_MASK 0x3 > #define XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_LEV_VAL 0x1 > #define XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_FIX18 (1 << 6) > +#define USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_LEV(x) (((x) & 0x3) << 7) > +#define USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_DIR(x) (((x) & 0x3) << 11) > > #define XUSB_PADCTL_USB2_OTG_PADX_CTL0(x) (0x088 + (x) * 0x40) > #define XUSB_PADCTL_USB2_OTG_PAD_CTL0_PD_ZI (1 << 29) > @@ -1116,6 +1118,34 @@ static void tegra210_usb2_pad_power_down(struct phy *phy) > usb2->powered_on = false; > } > > +static void > +tegra210_xusb_padctl_utmi_pad_set_protection(struct tegra_xusb_port *port, > + int level, > + enum tegra_vbus_dir dir) single line and aligned to preceeding parenthesis (hint checkpatch.pl with --strict option tells you so) > +{ > + u32 value; > + struct tegra_xusb_padctl *padctl = port->padctl; > + unsigned int index = port->index; > + > + value = padctl_readl(padctl, > + XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPADX_CTL1(index)); Single line please > + > + if (level < 0) { > + /* disable pad protection */ > + value |= XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_FIX18; > + value &= USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_LEV(~0); > + value &= ~USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_DIR(~0); > + } else { > + value &= ~XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_FIX18; > + value &= ~USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_DIR(~0); > + value &= USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_LEV(~0); > + value |= USB2_BATTERY_CHRG_OTGPAD_CTL1_VREG_LEV(level); > + } > + > + padctl_writel(padctl, value, > + XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPADX_CTL1(index)); > +} > + > static int tegra210_usb2_phy_set_mode(struct phy *phy, enum phy_mode mode, > int submode) > { > @@ -2291,6 +2321,8 @@ static const struct tegra_xusb_padctl_ops tegra210_xusb_padctl_ops = { > .utmi_port_reset = tegra210_utmi_port_reset, > .utmi_pad_power_on = tegra210_usb2_pad_power_on, > .utmi_pad_power_down = tegra210_usb2_pad_power_down, > + .utmi_pad_set_protection = > + tegra210_xusb_padctl_utmi_pad_set_protection, Here too > }; > > static const char * const tegra210_xusb_padctl_supply_names[] = { > diff --git a/drivers/phy/tegra/xusb.h b/drivers/phy/tegra/xusb.h > index 6995fc4..475bcc6 100644 > --- a/drivers/phy/tegra/xusb.h > +++ b/drivers/phy/tegra/xusb.h > @@ -259,6 +259,17 @@ to_sata_pad(struct tegra_xusb_pad *pad) > */ > struct tegra_xusb_port_ops; > > +/* > + * Tegra OTG port VBUS direction: > + * default (based on port capability) or > + * as source or sink > + */ > +enum tegra_vbus_dir { > + TEGRA_VBUS_DEFAULT, > + TEGRA_VBUS_SOURCE, > + TEGRA_VBUS_SINK > +}; > + > struct tegra_xusb_port { > struct tegra_xusb_padctl *padctl; > struct tegra_xusb_lane *lane; > @@ -398,6 +409,8 @@ struct tegra_xusb_padctl_ops { > int (*utmi_port_reset)(struct phy *phy); > void (*utmi_pad_power_on)(struct phy *phy); > void (*utmi_pad_power_down)(struct phy *phy); > + void (*utmi_pad_set_protection)(struct tegra_xusb_port *port, > + int level, enum tegra_vbus_dir dir); > }; > > struct tegra_xusb_padctl_soc { > -- > 2.7.4 -- ~Vinod