mirror of https://gitee.com/openkylin/linux.git
usb: phy: tegra: Use relaxed versions of readl/writel
There is nothing to synchronize in regards to memory stores, thus all readl/writel occurrences in the code could be replaced with a relaxed versions, for consistency. Acked-by: Thierry Reding <treding@nvidia.com> Signed-off-by: Dmitry Osipenko <digetx@gmail.com> Link: https://lore.kernel.org/r/20200106013416.9604-9-digetx@gmail.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
5bb69850ad
commit
b07e5f863f
|
@ -207,15 +207,16 @@ static void set_pts(struct tegra_usb_phy *phy, u8 pts_val)
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
|
|
||||||
if (phy->soc_config->has_hostpc) {
|
if (phy->soc_config->has_hostpc) {
|
||||||
val = readl(base + TEGRA_USB_HOSTPC1_DEVLC);
|
val = readl_relaxed(base + TEGRA_USB_HOSTPC1_DEVLC);
|
||||||
val &= ~TEGRA_USB_HOSTPC1_DEVLC_PTS(~0);
|
val &= ~TEGRA_USB_HOSTPC1_DEVLC_PTS(~0);
|
||||||
val |= TEGRA_USB_HOSTPC1_DEVLC_PTS(pts_val);
|
val |= TEGRA_USB_HOSTPC1_DEVLC_PTS(pts_val);
|
||||||
writel(val, base + TEGRA_USB_HOSTPC1_DEVLC);
|
writel_relaxed(val, base + TEGRA_USB_HOSTPC1_DEVLC);
|
||||||
} else {
|
} else {
|
||||||
val = readl(base + TEGRA_USB_PORTSC1) & ~TEGRA_PORTSC1_RWC_BITS;
|
val = readl_relaxed(base + TEGRA_USB_PORTSC1);
|
||||||
|
val &= ~TEGRA_PORTSC1_RWC_BITS;
|
||||||
val &= ~TEGRA_USB_PORTSC1_PTS(~0);
|
val &= ~TEGRA_USB_PORTSC1_PTS(~0);
|
||||||
val |= TEGRA_USB_PORTSC1_PTS(pts_val);
|
val |= TEGRA_USB_PORTSC1_PTS(pts_val);
|
||||||
writel(val, base + TEGRA_USB_PORTSC1);
|
writel_relaxed(val, base + TEGRA_USB_PORTSC1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -225,19 +226,19 @@ static void set_phcd(struct tegra_usb_phy *phy, bool enable)
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
|
|
||||||
if (phy->soc_config->has_hostpc) {
|
if (phy->soc_config->has_hostpc) {
|
||||||
val = readl(base + TEGRA_USB_HOSTPC1_DEVLC);
|
val = readl_relaxed(base + TEGRA_USB_HOSTPC1_DEVLC);
|
||||||
if (enable)
|
if (enable)
|
||||||
val |= TEGRA_USB_HOSTPC1_DEVLC_PHCD;
|
val |= TEGRA_USB_HOSTPC1_DEVLC_PHCD;
|
||||||
else
|
else
|
||||||
val &= ~TEGRA_USB_HOSTPC1_DEVLC_PHCD;
|
val &= ~TEGRA_USB_HOSTPC1_DEVLC_PHCD;
|
||||||
writel(val, base + TEGRA_USB_HOSTPC1_DEVLC);
|
writel_relaxed(val, base + TEGRA_USB_HOSTPC1_DEVLC);
|
||||||
} else {
|
} else {
|
||||||
val = readl(base + TEGRA_USB_PORTSC1) & ~PORT_RWC_BITS;
|
val = readl_relaxed(base + TEGRA_USB_PORTSC1) & ~PORT_RWC_BITS;
|
||||||
if (enable)
|
if (enable)
|
||||||
val |= TEGRA_USB_PORTSC1_PHCD;
|
val |= TEGRA_USB_PORTSC1_PHCD;
|
||||||
else
|
else
|
||||||
val &= ~TEGRA_USB_PORTSC1_PHCD;
|
val &= ~TEGRA_USB_PORTSC1_PHCD;
|
||||||
writel(val, base + TEGRA_USB_PORTSC1);
|
writel_relaxed(val, base + TEGRA_USB_PORTSC1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -319,7 +320,7 @@ static int utmip_pad_power_on(struct tegra_usb_phy *phy)
|
||||||
spin_lock_irqsave(&utmip_pad_lock, flags);
|
spin_lock_irqsave(&utmip_pad_lock, flags);
|
||||||
|
|
||||||
if (utmip_pad_count++ == 0) {
|
if (utmip_pad_count++ == 0) {
|
||||||
val = readl(base + UTMIP_BIAS_CFG0);
|
val = readl_relaxed(base + UTMIP_BIAS_CFG0);
|
||||||
val &= ~(UTMIP_OTGPD | UTMIP_BIASPD);
|
val &= ~(UTMIP_OTGPD | UTMIP_BIASPD);
|
||||||
|
|
||||||
if (phy->soc_config->requires_extra_tuning_parameters) {
|
if (phy->soc_config->requires_extra_tuning_parameters) {
|
||||||
|
@ -331,7 +332,7 @@ static int utmip_pad_power_on(struct tegra_usb_phy *phy)
|
||||||
val |= UTMIP_HSDISCON_LEVEL(config->hsdiscon_level);
|
val |= UTMIP_HSDISCON_LEVEL(config->hsdiscon_level);
|
||||||
val |= UTMIP_HSDISCON_LEVEL_MSB(config->hsdiscon_level);
|
val |= UTMIP_HSDISCON_LEVEL_MSB(config->hsdiscon_level);
|
||||||
}
|
}
|
||||||
writel(val, base + UTMIP_BIAS_CFG0);
|
writel_relaxed(val, base + UTMIP_BIAS_CFG0);
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock_irqrestore(&utmip_pad_lock, flags);
|
spin_unlock_irqrestore(&utmip_pad_lock, flags);
|
||||||
|
@ -359,9 +360,9 @@ static int utmip_pad_power_off(struct tegra_usb_phy *phy)
|
||||||
spin_lock_irqsave(&utmip_pad_lock, flags);
|
spin_lock_irqsave(&utmip_pad_lock, flags);
|
||||||
|
|
||||||
if (--utmip_pad_count == 0) {
|
if (--utmip_pad_count == 0) {
|
||||||
val = readl(base + UTMIP_BIAS_CFG0);
|
val = readl_relaxed(base + UTMIP_BIAS_CFG0);
|
||||||
val |= UTMIP_OTGPD | UTMIP_BIASPD;
|
val |= UTMIP_OTGPD | UTMIP_BIASPD;
|
||||||
writel(val, base + UTMIP_BIAS_CFG0);
|
writel_relaxed(val, base + UTMIP_BIAS_CFG0);
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock_irqrestore(&utmip_pad_lock, flags);
|
spin_unlock_irqrestore(&utmip_pad_lock, flags);
|
||||||
|
@ -375,7 +376,7 @@ static int utmi_wait_register(void __iomem *reg, u32 mask, u32 result)
|
||||||
{
|
{
|
||||||
u32 tmp;
|
u32 tmp;
|
||||||
|
|
||||||
return readl_poll_timeout(reg, tmp, (tmp & mask) == result,
|
return readl_relaxed_poll_timeout(reg, tmp, (tmp & mask) == result,
|
||||||
2000, 6000);
|
2000, 6000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -393,15 +394,15 @@ static void utmi_phy_clk_disable(struct tegra_usb_phy *phy)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (phy->is_legacy_phy) {
|
if (phy->is_legacy_phy) {
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= USB_SUSP_SET;
|
val |= USB_SUSP_SET;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
usleep_range(10, 100);
|
usleep_range(10, 100);
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val &= ~USB_SUSP_SET;
|
val &= ~USB_SUSP_SET;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
} else {
|
} else {
|
||||||
set_phcd(phy, true);
|
set_phcd(phy, true);
|
||||||
}
|
}
|
||||||
|
@ -426,15 +427,15 @@ static void utmi_phy_clk_enable(struct tegra_usb_phy *phy)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (phy->is_legacy_phy) {
|
if (phy->is_legacy_phy) {
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= USB_SUSP_CLR;
|
val |= USB_SUSP_CLR;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
usleep_range(10, 100);
|
usleep_range(10, 100);
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val &= ~USB_SUSP_CLR;
|
val &= ~USB_SUSP_CLR;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
} else {
|
} else {
|
||||||
set_phcd(phy, false);
|
set_phcd(phy, false);
|
||||||
}
|
}
|
||||||
|
@ -452,75 +453,75 @@ static int utmi_phy_power_on(struct tegra_usb_phy *phy)
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= UTMIP_RESET;
|
val |= UTMIP_RESET;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
if (phy->is_legacy_phy) {
|
if (phy->is_legacy_phy) {
|
||||||
val = readl(base + USB1_LEGACY_CTRL);
|
val = readl_relaxed(base + USB1_LEGACY_CTRL);
|
||||||
val |= USB1_NO_LEGACY_MODE;
|
val |= USB1_NO_LEGACY_MODE;
|
||||||
writel(val, base + USB1_LEGACY_CTRL);
|
writel_relaxed(val, base + USB1_LEGACY_CTRL);
|
||||||
}
|
}
|
||||||
|
|
||||||
val = readl(base + UTMIP_TX_CFG0);
|
val = readl_relaxed(base + UTMIP_TX_CFG0);
|
||||||
val |= UTMIP_FS_PREABMLE_J;
|
val |= UTMIP_FS_PREABMLE_J;
|
||||||
writel(val, base + UTMIP_TX_CFG0);
|
writel_relaxed(val, base + UTMIP_TX_CFG0);
|
||||||
|
|
||||||
val = readl(base + UTMIP_HSRX_CFG0);
|
val = readl_relaxed(base + UTMIP_HSRX_CFG0);
|
||||||
val &= ~(UTMIP_IDLE_WAIT(~0) | UTMIP_ELASTIC_LIMIT(~0));
|
val &= ~(UTMIP_IDLE_WAIT(~0) | UTMIP_ELASTIC_LIMIT(~0));
|
||||||
val |= UTMIP_IDLE_WAIT(config->idle_wait_delay);
|
val |= UTMIP_IDLE_WAIT(config->idle_wait_delay);
|
||||||
val |= UTMIP_ELASTIC_LIMIT(config->elastic_limit);
|
val |= UTMIP_ELASTIC_LIMIT(config->elastic_limit);
|
||||||
writel(val, base + UTMIP_HSRX_CFG0);
|
writel_relaxed(val, base + UTMIP_HSRX_CFG0);
|
||||||
|
|
||||||
val = readl(base + UTMIP_HSRX_CFG1);
|
val = readl_relaxed(base + UTMIP_HSRX_CFG1);
|
||||||
val &= ~UTMIP_HS_SYNC_START_DLY(~0);
|
val &= ~UTMIP_HS_SYNC_START_DLY(~0);
|
||||||
val |= UTMIP_HS_SYNC_START_DLY(config->hssync_start_delay);
|
val |= UTMIP_HS_SYNC_START_DLY(config->hssync_start_delay);
|
||||||
writel(val, base + UTMIP_HSRX_CFG1);
|
writel_relaxed(val, base + UTMIP_HSRX_CFG1);
|
||||||
|
|
||||||
val = readl(base + UTMIP_DEBOUNCE_CFG0);
|
val = readl_relaxed(base + UTMIP_DEBOUNCE_CFG0);
|
||||||
val &= ~UTMIP_BIAS_DEBOUNCE_A(~0);
|
val &= ~UTMIP_BIAS_DEBOUNCE_A(~0);
|
||||||
val |= UTMIP_BIAS_DEBOUNCE_A(phy->freq->debounce);
|
val |= UTMIP_BIAS_DEBOUNCE_A(phy->freq->debounce);
|
||||||
writel(val, base + UTMIP_DEBOUNCE_CFG0);
|
writel_relaxed(val, base + UTMIP_DEBOUNCE_CFG0);
|
||||||
|
|
||||||
val = readl(base + UTMIP_MISC_CFG0);
|
val = readl_relaxed(base + UTMIP_MISC_CFG0);
|
||||||
val &= ~UTMIP_SUSPEND_EXIT_ON_EDGE;
|
val &= ~UTMIP_SUSPEND_EXIT_ON_EDGE;
|
||||||
writel(val, base + UTMIP_MISC_CFG0);
|
writel_relaxed(val, base + UTMIP_MISC_CFG0);
|
||||||
|
|
||||||
if (!phy->soc_config->utmi_pll_config_in_car_module) {
|
if (!phy->soc_config->utmi_pll_config_in_car_module) {
|
||||||
val = readl(base + UTMIP_MISC_CFG1);
|
val = readl_relaxed(base + UTMIP_MISC_CFG1);
|
||||||
val &= ~(UTMIP_PLL_ACTIVE_DLY_COUNT(~0) |
|
val &= ~(UTMIP_PLL_ACTIVE_DLY_COUNT(~0) |
|
||||||
UTMIP_PLLU_STABLE_COUNT(~0));
|
UTMIP_PLLU_STABLE_COUNT(~0));
|
||||||
val |= UTMIP_PLL_ACTIVE_DLY_COUNT(phy->freq->active_delay) |
|
val |= UTMIP_PLL_ACTIVE_DLY_COUNT(phy->freq->active_delay) |
|
||||||
UTMIP_PLLU_STABLE_COUNT(phy->freq->stable_count);
|
UTMIP_PLLU_STABLE_COUNT(phy->freq->stable_count);
|
||||||
writel(val, base + UTMIP_MISC_CFG1);
|
writel_relaxed(val, base + UTMIP_MISC_CFG1);
|
||||||
|
|
||||||
val = readl(base + UTMIP_PLL_CFG1);
|
val = readl_relaxed(base + UTMIP_PLL_CFG1);
|
||||||
val &= ~(UTMIP_XTAL_FREQ_COUNT(~0) |
|
val &= ~(UTMIP_XTAL_FREQ_COUNT(~0) |
|
||||||
UTMIP_PLLU_ENABLE_DLY_COUNT(~0));
|
UTMIP_PLLU_ENABLE_DLY_COUNT(~0));
|
||||||
val |= UTMIP_XTAL_FREQ_COUNT(phy->freq->xtal_freq_count) |
|
val |= UTMIP_XTAL_FREQ_COUNT(phy->freq->xtal_freq_count) |
|
||||||
UTMIP_PLLU_ENABLE_DLY_COUNT(phy->freq->enable_delay);
|
UTMIP_PLLU_ENABLE_DLY_COUNT(phy->freq->enable_delay);
|
||||||
writel(val, base + UTMIP_PLL_CFG1);
|
writel_relaxed(val, base + UTMIP_PLL_CFG1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (phy->mode == USB_DR_MODE_PERIPHERAL) {
|
if (phy->mode == USB_DR_MODE_PERIPHERAL) {
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val &= ~(USB_WAKE_ON_CNNT_EN_DEV | USB_WAKE_ON_DISCON_EN_DEV);
|
val &= ~(USB_WAKE_ON_CNNT_EN_DEV | USB_WAKE_ON_DISCON_EN_DEV);
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
val = readl(base + UTMIP_BAT_CHRG_CFG0);
|
val = readl_relaxed(base + UTMIP_BAT_CHRG_CFG0);
|
||||||
val &= ~UTMIP_PD_CHRG;
|
val &= ~UTMIP_PD_CHRG;
|
||||||
writel(val, base + UTMIP_BAT_CHRG_CFG0);
|
writel_relaxed(val, base + UTMIP_BAT_CHRG_CFG0);
|
||||||
} else {
|
} else {
|
||||||
val = readl(base + UTMIP_BAT_CHRG_CFG0);
|
val = readl_relaxed(base + UTMIP_BAT_CHRG_CFG0);
|
||||||
val |= UTMIP_PD_CHRG;
|
val |= UTMIP_PD_CHRG;
|
||||||
writel(val, base + UTMIP_BAT_CHRG_CFG0);
|
writel_relaxed(val, base + UTMIP_BAT_CHRG_CFG0);
|
||||||
}
|
}
|
||||||
|
|
||||||
err = utmip_pad_power_on(phy);
|
err = utmip_pad_power_on(phy);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
val = readl(base + UTMIP_XCVR_CFG0);
|
val = readl_relaxed(base + UTMIP_XCVR_CFG0);
|
||||||
val &= ~(UTMIP_FORCE_PD_POWERDOWN | UTMIP_FORCE_PD2_POWERDOWN |
|
val &= ~(UTMIP_FORCE_PD_POWERDOWN | UTMIP_FORCE_PD2_POWERDOWN |
|
||||||
UTMIP_FORCE_PDZI_POWERDOWN | UTMIP_XCVR_LSBIAS_SEL |
|
UTMIP_FORCE_PDZI_POWERDOWN | UTMIP_XCVR_LSBIAS_SEL |
|
||||||
UTMIP_XCVR_SETUP(~0) | UTMIP_XCVR_SETUP_MSB(~0) |
|
UTMIP_XCVR_SETUP(~0) | UTMIP_XCVR_SETUP_MSB(~0) |
|
||||||
|
@ -538,57 +539,57 @@ static int utmi_phy_power_on(struct tegra_usb_phy *phy)
|
||||||
val |= UTMIP_XCVR_HSSLEW(config->xcvr_hsslew);
|
val |= UTMIP_XCVR_HSSLEW(config->xcvr_hsslew);
|
||||||
val |= UTMIP_XCVR_HSSLEW_MSB(config->xcvr_hsslew);
|
val |= UTMIP_XCVR_HSSLEW_MSB(config->xcvr_hsslew);
|
||||||
}
|
}
|
||||||
writel(val, base + UTMIP_XCVR_CFG0);
|
writel_relaxed(val, base + UTMIP_XCVR_CFG0);
|
||||||
|
|
||||||
val = readl(base + UTMIP_XCVR_CFG1);
|
val = readl_relaxed(base + UTMIP_XCVR_CFG1);
|
||||||
val &= ~(UTMIP_FORCE_PDDISC_POWERDOWN | UTMIP_FORCE_PDCHRP_POWERDOWN |
|
val &= ~(UTMIP_FORCE_PDDISC_POWERDOWN | UTMIP_FORCE_PDCHRP_POWERDOWN |
|
||||||
UTMIP_FORCE_PDDR_POWERDOWN | UTMIP_XCVR_TERM_RANGE_ADJ(~0));
|
UTMIP_FORCE_PDDR_POWERDOWN | UTMIP_XCVR_TERM_RANGE_ADJ(~0));
|
||||||
val |= UTMIP_XCVR_TERM_RANGE_ADJ(config->term_range_adj);
|
val |= UTMIP_XCVR_TERM_RANGE_ADJ(config->term_range_adj);
|
||||||
writel(val, base + UTMIP_XCVR_CFG1);
|
writel_relaxed(val, base + UTMIP_XCVR_CFG1);
|
||||||
|
|
||||||
val = readl(base + UTMIP_BIAS_CFG1);
|
val = readl_relaxed(base + UTMIP_BIAS_CFG1);
|
||||||
val &= ~UTMIP_BIAS_PDTRK_COUNT(~0);
|
val &= ~UTMIP_BIAS_PDTRK_COUNT(~0);
|
||||||
val |= UTMIP_BIAS_PDTRK_COUNT(0x5);
|
val |= UTMIP_BIAS_PDTRK_COUNT(0x5);
|
||||||
writel(val, base + UTMIP_BIAS_CFG1);
|
writel_relaxed(val, base + UTMIP_BIAS_CFG1);
|
||||||
|
|
||||||
val = readl(base + UTMIP_SPARE_CFG0);
|
val = readl_relaxed(base + UTMIP_SPARE_CFG0);
|
||||||
if (config->xcvr_setup_use_fuses)
|
if (config->xcvr_setup_use_fuses)
|
||||||
val |= FUSE_SETUP_SEL;
|
val |= FUSE_SETUP_SEL;
|
||||||
else
|
else
|
||||||
val &= ~FUSE_SETUP_SEL;
|
val &= ~FUSE_SETUP_SEL;
|
||||||
writel(val, base + UTMIP_SPARE_CFG0);
|
writel_relaxed(val, base + UTMIP_SPARE_CFG0);
|
||||||
|
|
||||||
if (!phy->is_legacy_phy) {
|
if (!phy->is_legacy_phy) {
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= UTMIP_PHY_ENABLE;
|
val |= UTMIP_PHY_ENABLE;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
}
|
}
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val &= ~UTMIP_RESET;
|
val &= ~UTMIP_RESET;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
if (phy->is_legacy_phy) {
|
if (phy->is_legacy_phy) {
|
||||||
val = readl(base + USB1_LEGACY_CTRL);
|
val = readl_relaxed(base + USB1_LEGACY_CTRL);
|
||||||
val &= ~USB1_VBUS_SENSE_CTL_MASK;
|
val &= ~USB1_VBUS_SENSE_CTL_MASK;
|
||||||
val |= USB1_VBUS_SENSE_CTL_A_SESS_VLD;
|
val |= USB1_VBUS_SENSE_CTL_A_SESS_VLD;
|
||||||
writel(val, base + USB1_LEGACY_CTRL);
|
writel_relaxed(val, base + USB1_LEGACY_CTRL);
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val &= ~USB_SUSP_SET;
|
val &= ~USB_SUSP_SET;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
}
|
}
|
||||||
|
|
||||||
utmi_phy_clk_enable(phy);
|
utmi_phy_clk_enable(phy);
|
||||||
|
|
||||||
if (phy->soc_config->requires_usbmode_setup) {
|
if (phy->soc_config->requires_usbmode_setup) {
|
||||||
val = readl(base + USB_USBMODE);
|
val = readl_relaxed(base + USB_USBMODE);
|
||||||
val &= ~USB_USBMODE_MASK;
|
val &= ~USB_USBMODE_MASK;
|
||||||
if (phy->mode == USB_DR_MODE_HOST)
|
if (phy->mode == USB_DR_MODE_HOST)
|
||||||
val |= USB_USBMODE_HOST;
|
val |= USB_USBMODE_HOST;
|
||||||
else
|
else
|
||||||
val |= USB_USBMODE_DEVICE;
|
val |= USB_USBMODE_DEVICE;
|
||||||
writel(val, base + USB_USBMODE);
|
writel_relaxed(val, base + USB_USBMODE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!phy->is_legacy_phy)
|
if (!phy->is_legacy_phy)
|
||||||
|
@ -605,29 +606,29 @@ static int utmi_phy_power_off(struct tegra_usb_phy *phy)
|
||||||
utmi_phy_clk_disable(phy);
|
utmi_phy_clk_disable(phy);
|
||||||
|
|
||||||
if (phy->mode == USB_DR_MODE_PERIPHERAL) {
|
if (phy->mode == USB_DR_MODE_PERIPHERAL) {
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val &= ~USB_WAKEUP_DEBOUNCE_COUNT(~0);
|
val &= ~USB_WAKEUP_DEBOUNCE_COUNT(~0);
|
||||||
val |= USB_WAKE_ON_CNNT_EN_DEV | USB_WAKEUP_DEBOUNCE_COUNT(5);
|
val |= USB_WAKE_ON_CNNT_EN_DEV | USB_WAKEUP_DEBOUNCE_COUNT(5);
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
}
|
}
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= UTMIP_RESET;
|
val |= UTMIP_RESET;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
val = readl(base + UTMIP_BAT_CHRG_CFG0);
|
val = readl_relaxed(base + UTMIP_BAT_CHRG_CFG0);
|
||||||
val |= UTMIP_PD_CHRG;
|
val |= UTMIP_PD_CHRG;
|
||||||
writel(val, base + UTMIP_BAT_CHRG_CFG0);
|
writel_relaxed(val, base + UTMIP_BAT_CHRG_CFG0);
|
||||||
|
|
||||||
val = readl(base + UTMIP_XCVR_CFG0);
|
val = readl_relaxed(base + UTMIP_XCVR_CFG0);
|
||||||
val |= UTMIP_FORCE_PD_POWERDOWN | UTMIP_FORCE_PD2_POWERDOWN |
|
val |= UTMIP_FORCE_PD_POWERDOWN | UTMIP_FORCE_PD2_POWERDOWN |
|
||||||
UTMIP_FORCE_PDZI_POWERDOWN;
|
UTMIP_FORCE_PDZI_POWERDOWN;
|
||||||
writel(val, base + UTMIP_XCVR_CFG0);
|
writel_relaxed(val, base + UTMIP_XCVR_CFG0);
|
||||||
|
|
||||||
val = readl(base + UTMIP_XCVR_CFG1);
|
val = readl_relaxed(base + UTMIP_XCVR_CFG1);
|
||||||
val |= UTMIP_FORCE_PDDISC_POWERDOWN | UTMIP_FORCE_PDCHRP_POWERDOWN |
|
val |= UTMIP_FORCE_PDDISC_POWERDOWN | UTMIP_FORCE_PDCHRP_POWERDOWN |
|
||||||
UTMIP_FORCE_PDDR_POWERDOWN;
|
UTMIP_FORCE_PDDR_POWERDOWN;
|
||||||
writel(val, base + UTMIP_XCVR_CFG1);
|
writel_relaxed(val, base + UTMIP_XCVR_CFG1);
|
||||||
|
|
||||||
return utmip_pad_power_off(phy);
|
return utmip_pad_power_off(phy);
|
||||||
}
|
}
|
||||||
|
@ -637,9 +638,9 @@ static void utmi_phy_preresume(struct tegra_usb_phy *phy)
|
||||||
void __iomem *base = phy->regs;
|
void __iomem *base = phy->regs;
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
|
|
||||||
val = readl(base + UTMIP_TX_CFG0);
|
val = readl_relaxed(base + UTMIP_TX_CFG0);
|
||||||
val |= UTMIP_HS_DISCON_DISABLE;
|
val |= UTMIP_HS_DISCON_DISABLE;
|
||||||
writel(val, base + UTMIP_TX_CFG0);
|
writel_relaxed(val, base + UTMIP_TX_CFG0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void utmi_phy_postresume(struct tegra_usb_phy *phy)
|
static void utmi_phy_postresume(struct tegra_usb_phy *phy)
|
||||||
|
@ -647,9 +648,9 @@ static void utmi_phy_postresume(struct tegra_usb_phy *phy)
|
||||||
void __iomem *base = phy->regs;
|
void __iomem *base = phy->regs;
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
|
|
||||||
val = readl(base + UTMIP_TX_CFG0);
|
val = readl_relaxed(base + UTMIP_TX_CFG0);
|
||||||
val &= ~UTMIP_HS_DISCON_DISABLE;
|
val &= ~UTMIP_HS_DISCON_DISABLE;
|
||||||
writel(val, base + UTMIP_TX_CFG0);
|
writel_relaxed(val, base + UTMIP_TX_CFG0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void utmi_phy_restore_start(struct tegra_usb_phy *phy,
|
static void utmi_phy_restore_start(struct tegra_usb_phy *phy,
|
||||||
|
@ -658,18 +659,18 @@ static void utmi_phy_restore_start(struct tegra_usb_phy *phy,
|
||||||
void __iomem *base = phy->regs;
|
void __iomem *base = phy->regs;
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
|
|
||||||
val = readl(base + UTMIP_MISC_CFG0);
|
val = readl_relaxed(base + UTMIP_MISC_CFG0);
|
||||||
val &= ~UTMIP_DPDM_OBSERVE_SEL(~0);
|
val &= ~UTMIP_DPDM_OBSERVE_SEL(~0);
|
||||||
if (port_speed == TEGRA_USB_PHY_PORT_SPEED_LOW)
|
if (port_speed == TEGRA_USB_PHY_PORT_SPEED_LOW)
|
||||||
val |= UTMIP_DPDM_OBSERVE_SEL_FS_K;
|
val |= UTMIP_DPDM_OBSERVE_SEL_FS_K;
|
||||||
else
|
else
|
||||||
val |= UTMIP_DPDM_OBSERVE_SEL_FS_J;
|
val |= UTMIP_DPDM_OBSERVE_SEL_FS_J;
|
||||||
writel(val, base + UTMIP_MISC_CFG0);
|
writel_relaxed(val, base + UTMIP_MISC_CFG0);
|
||||||
usleep_range(1, 10);
|
usleep_range(1, 10);
|
||||||
|
|
||||||
val = readl(base + UTMIP_MISC_CFG0);
|
val = readl_relaxed(base + UTMIP_MISC_CFG0);
|
||||||
val |= UTMIP_DPDM_OBSERVE;
|
val |= UTMIP_DPDM_OBSERVE;
|
||||||
writel(val, base + UTMIP_MISC_CFG0);
|
writel_relaxed(val, base + UTMIP_MISC_CFG0);
|
||||||
usleep_range(10, 100);
|
usleep_range(10, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -678,9 +679,9 @@ static void utmi_phy_restore_end(struct tegra_usb_phy *phy)
|
||||||
void __iomem *base = phy->regs;
|
void __iomem *base = phy->regs;
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
|
|
||||||
val = readl(base + UTMIP_MISC_CFG0);
|
val = readl_relaxed(base + UTMIP_MISC_CFG0);
|
||||||
val &= ~UTMIP_DPDM_OBSERVE;
|
val &= ~UTMIP_DPDM_OBSERVE;
|
||||||
writel(val, base + UTMIP_MISC_CFG0);
|
writel_relaxed(val, base + UTMIP_MISC_CFG0);
|
||||||
usleep_range(10, 100);
|
usleep_range(10, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -712,31 +713,31 @@ static int ulpi_phy_power_on(struct tegra_usb_phy *phy)
|
||||||
|
|
||||||
usleep_range(1000, 2000);
|
usleep_range(1000, 2000);
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= UHSIC_RESET;
|
val |= UHSIC_RESET;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
val = readl(base + ULPI_TIMING_CTRL_0);
|
val = readl_relaxed(base + ULPI_TIMING_CTRL_0);
|
||||||
val |= ULPI_OUTPUT_PINMUX_BYP | ULPI_CLKOUT_PINMUX_BYP;
|
val |= ULPI_OUTPUT_PINMUX_BYP | ULPI_CLKOUT_PINMUX_BYP;
|
||||||
writel(val, base + ULPI_TIMING_CTRL_0);
|
writel_relaxed(val, base + ULPI_TIMING_CTRL_0);
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= ULPI_PHY_ENABLE;
|
val |= ULPI_PHY_ENABLE;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
val = 0;
|
val = 0;
|
||||||
writel(val, base + ULPI_TIMING_CTRL_1);
|
writel_relaxed(val, base + ULPI_TIMING_CTRL_1);
|
||||||
|
|
||||||
val |= ULPI_DATA_TRIMMER_SEL(4);
|
val |= ULPI_DATA_TRIMMER_SEL(4);
|
||||||
val |= ULPI_STPDIRNXT_TRIMMER_SEL(4);
|
val |= ULPI_STPDIRNXT_TRIMMER_SEL(4);
|
||||||
val |= ULPI_DIR_TRIMMER_SEL(4);
|
val |= ULPI_DIR_TRIMMER_SEL(4);
|
||||||
writel(val, base + ULPI_TIMING_CTRL_1);
|
writel_relaxed(val, base + ULPI_TIMING_CTRL_1);
|
||||||
usleep_range(10, 100);
|
usleep_range(10, 100);
|
||||||
|
|
||||||
val |= ULPI_DATA_TRIMMER_LOAD;
|
val |= ULPI_DATA_TRIMMER_LOAD;
|
||||||
val |= ULPI_STPDIRNXT_TRIMMER_LOAD;
|
val |= ULPI_STPDIRNXT_TRIMMER_LOAD;
|
||||||
val |= ULPI_DIR_TRIMMER_LOAD;
|
val |= ULPI_DIR_TRIMMER_LOAD;
|
||||||
writel(val, base + ULPI_TIMING_CTRL_1);
|
writel_relaxed(val, base + ULPI_TIMING_CTRL_1);
|
||||||
|
|
||||||
/* Fix VbusInvalid due to floating VBUS */
|
/* Fix VbusInvalid due to floating VBUS */
|
||||||
err = usb_phy_io_write(phy->ulpi, 0x40, 0x08);
|
err = usb_phy_io_write(phy->ulpi, 0x40, 0x08);
|
||||||
|
@ -751,14 +752,14 @@ static int ulpi_phy_power_on(struct tegra_usb_phy *phy)
|
||||||
goto disable_clk;
|
goto disable_clk;
|
||||||
}
|
}
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val |= USB_SUSP_CLR;
|
val |= USB_SUSP_CLR;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
usleep_range(100, 1000);
|
usleep_range(100, 1000);
|
||||||
|
|
||||||
val = readl(base + USB_SUSP_CTRL);
|
val = readl_relaxed(base + USB_SUSP_CTRL);
|
||||||
val &= ~USB_SUSP_CLR;
|
val &= ~USB_SUSP_CLR;
|
||||||
writel(val, base + USB_SUSP_CTRL);
|
writel_relaxed(val, base + USB_SUSP_CTRL);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue