Lines Matching +full:2 +full:- +full:lane
1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (c) 2014-2020, NVIDIA CORPORATION. All rights reserved.
27 ((x) ? (11 + ((x) - 1) * 6) : 0)
66 USB2_PORT_WAKEUP_EVENT(2) | USB2_PORT_WAKEUP_EVENT(3) | \
68 SS_PORT_WAKEUP_EVENT(2) | SS_PORT_WAKEUP_EVENT(3) | \
75 #define XUSB_PADCTL_ELPG_PROGRAM1_SSPX_ELPG_VCORE_DOWN(x) (1 << (2 + (x) * 3))
106 #define XUSB_PADCTL_USB2_OTG_PAD_CTL1_PD_DR (1 << 2)
146 #define XUSB_PADCTL_HSIC_PAD_CTL0_PD_TX_DATA1 (1 << 2)
188 #define XUSB_PADCTL_UPHY_PLL_CTL2_CAL_OVRD (1 << 2)
276 (((_port) <= 2) ? (_offset1) : (_offset2))
282 #define UTMIP_PCTRL_USE_PMC(x) UTMIP(x, BIT(8 * (x) + 2), \
283 BIT(2))
308 #define UTMIP_FAKE_USBOP_EN(x) UTMIP(x, BIT(4 * (x) + 2), \
330 #define UTMI_LS(_port) SPEED(_port, 2)
382 #define UHSIC_WAKE_VAL_SD10 UHSIC_WAKE_VAL(2)
405 #define UHSIC_STROBE_RPU_A BIT(2)
440 { 2, "pcie", 0 },
441 { 2, "pcie", 3 },
447 static int tegra210_usb3_lane_map(struct tegra_xusb_lane *lane) in tegra210_usb3_lane_map() argument
451 for (map = tegra210_usb3_map; map->type; map++) { in tegra210_usb3_lane_map()
452 if (map->index == lane->index && in tegra210_usb3_lane_map()
453 strcmp(map->type, lane->pad->soc->name) == 0) { in tegra210_usb3_lane_map()
454 dev_dbg(lane->pad->padctl->dev, "lane = %s map to port = usb3-%d\n", in tegra210_usb3_lane_map()
455 lane->pad->soc->lanes[lane->index].name, map->port); in tegra210_usb3_lane_map()
456 return map->port; in tegra210_usb3_lane_map()
460 return -EINVAL; in tegra210_usb3_lane_map()
463 /* must be called under padctl->lock */
466 struct tegra_xusb_pcie_pad *pcie = to_pcie_pad(padctl->pcie); in tegra210_pex_uphy_enable()
472 if (pcie->enable) in tegra210_pex_uphy_enable()
475 err = clk_prepare_enable(pcie->pll); in tegra210_pex_uphy_enable()
482 err = reset_control_deassert(pcie->rst); in tegra210_pex_uphy_enable()
561 err = -ETIMEDOUT; in tegra210_pex_uphy_enable()
580 err = -ETIMEDOUT; in tegra210_pex_uphy_enable()
599 err = -ETIMEDOUT; in tegra210_pex_uphy_enable()
619 err = -ETIMEDOUT; in tegra210_pex_uphy_enable()
638 err = -ETIMEDOUT; in tegra210_pex_uphy_enable()
665 pcie->enable = true; in tegra210_pex_uphy_enable()
667 for (i = 0; i < padctl->pcie->soc->num_lanes; i++) { in tegra210_pex_uphy_enable()
676 reset_control_assert(pcie->rst); in tegra210_pex_uphy_enable()
678 clk_disable_unprepare(pcie->pll); in tegra210_pex_uphy_enable()
684 struct tegra_xusb_pcie_pad *pcie = to_pcie_pad(padctl->pcie); in tegra210_pex_uphy_disable()
688 if (WARN_ON(!pcie->enable)) in tegra210_pex_uphy_disable()
691 pcie->enable = false; in tegra210_pex_uphy_disable()
693 for (i = 0; i < padctl->pcie->soc->num_lanes; i++) { in tegra210_pex_uphy_disable()
699 clk_disable_unprepare(pcie->pll); in tegra210_pex_uphy_disable()
702 /* must be called under padctl->lock */
705 struct tegra_xusb_sata_pad *sata = to_sata_pad(padctl->sata); in tegra210_sata_uphy_enable()
706 struct tegra_xusb_lane *lane = tegra_xusb_find_lane(padctl, "sata", 0); in tegra210_sata_uphy_enable() local
713 if (sata->enable) in tegra210_sata_uphy_enable()
716 if (IS_ERR(lane)) in tegra210_sata_uphy_enable()
722 usb = tegra_xusb_lane_check(lane, "usb3-ss"); in tegra210_sata_uphy_enable()
724 err = clk_prepare_enable(sata->pll); in tegra210_sata_uphy_enable()
728 err = reset_control_deassert(sata->rst); in tegra210_sata_uphy_enable()
820 err = -ETIMEDOUT; in tegra210_sata_uphy_enable()
839 err = -ETIMEDOUT; in tegra210_sata_uphy_enable()
858 err = -ETIMEDOUT; in tegra210_sata_uphy_enable()
878 err = -ETIMEDOUT; in tegra210_sata_uphy_enable()
897 err = -ETIMEDOUT; in tegra210_sata_uphy_enable()
924 sata->enable = true; in tegra210_sata_uphy_enable()
926 for (i = 0; i < padctl->sata->soc->num_lanes; i++) { in tegra210_sata_uphy_enable()
935 reset_control_assert(sata->rst); in tegra210_sata_uphy_enable()
937 clk_disable_unprepare(sata->pll); in tegra210_sata_uphy_enable()
943 struct tegra_xusb_sata_pad *sata = to_sata_pad(padctl->sata); in tegra210_sata_uphy_disable()
947 if (WARN_ON(!sata->enable)) in tegra210_sata_uphy_disable()
950 sata->enable = false; in tegra210_sata_uphy_disable()
952 for (i = 0; i < padctl->sata->soc->num_lanes; i++) { in tegra210_sata_uphy_disable()
958 clk_disable_unprepare(sata->pll); in tegra210_sata_uphy_disable()
1005 if (padctl->pcie) in tegra210_uphy_init()
1008 if (padctl->sata) in tegra210_uphy_init()
1014 dev_dbg(padctl->dev, "PLLE is already in HW control\n"); in tegra210_uphy_init()
1026 if (padctl->sata) in tegra210_uphy_deinit()
1029 if (padctl->pcie) in tegra210_uphy_deinit()
1058 static int tegra210_usb3_enable_phy_sleepwalk(struct tegra_xusb_lane *lane, in tegra210_usb3_enable_phy_sleepwalk() argument
1061 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb3_enable_phy_sleepwalk()
1062 int port = tegra210_usb3_lane_map(lane); in tegra210_usb3_enable_phy_sleepwalk()
1063 struct device *dev = padctl->dev; in tegra210_usb3_enable_phy_sleepwalk()
1068 return -EINVAL; in tegra210_usb3_enable_phy_sleepwalk()
1071 mutex_lock(&padctl->lock); in tegra210_usb3_enable_phy_sleepwalk()
1085 mutex_unlock(&padctl->lock); in tegra210_usb3_enable_phy_sleepwalk()
1090 static int tegra210_usb3_disable_phy_sleepwalk(struct tegra_xusb_lane *lane) in tegra210_usb3_disable_phy_sleepwalk() argument
1092 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb3_disable_phy_sleepwalk()
1093 int port = tegra210_usb3_lane_map(lane); in tegra210_usb3_disable_phy_sleepwalk()
1094 struct device *dev = padctl->dev; in tegra210_usb3_disable_phy_sleepwalk()
1099 return -EINVAL; in tegra210_usb3_disable_phy_sleepwalk()
1102 mutex_lock(&padctl->lock); in tegra210_usb3_disable_phy_sleepwalk()
1114 mutex_unlock(&padctl->lock); in tegra210_usb3_disable_phy_sleepwalk()
1119 static int tegra210_usb3_enable_phy_wake(struct tegra_xusb_lane *lane) in tegra210_usb3_enable_phy_wake() argument
1121 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb3_enable_phy_wake()
1122 int port = tegra210_usb3_lane_map(lane); in tegra210_usb3_enable_phy_wake()
1123 struct device *dev = padctl->dev; in tegra210_usb3_enable_phy_wake()
1128 return -EINVAL; in tegra210_usb3_enable_phy_wake()
1131 mutex_lock(&padctl->lock); in tegra210_usb3_enable_phy_wake()
1145 mutex_unlock(&padctl->lock); in tegra210_usb3_enable_phy_wake()
1150 static int tegra210_usb3_disable_phy_wake(struct tegra_xusb_lane *lane) in tegra210_usb3_disable_phy_wake() argument
1152 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb3_disable_phy_wake()
1153 int port = tegra210_usb3_lane_map(lane); in tegra210_usb3_disable_phy_wake()
1154 struct device *dev = padctl->dev; in tegra210_usb3_disable_phy_wake()
1159 return -EINVAL; in tegra210_usb3_disable_phy_wake()
1162 mutex_lock(&padctl->lock); in tegra210_usb3_disable_phy_wake()
1176 mutex_unlock(&padctl->lock); in tegra210_usb3_disable_phy_wake()
1181 static bool tegra210_usb3_phy_remote_wake_detected(struct tegra_xusb_lane *lane) in tegra210_usb3_phy_remote_wake_detected() argument
1183 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb3_phy_remote_wake_detected()
1184 int index = tegra210_usb3_lane_map(lane); in tegra210_usb3_phy_remote_wake_detected()
1197 static int tegra210_utmi_enable_phy_wake(struct tegra_xusb_lane *lane) in tegra210_utmi_enable_phy_wake() argument
1199 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_utmi_enable_phy_wake()
1200 unsigned int index = lane->index; in tegra210_utmi_enable_phy_wake()
1203 mutex_lock(&padctl->lock); in tegra210_utmi_enable_phy_wake()
1217 mutex_unlock(&padctl->lock); in tegra210_utmi_enable_phy_wake()
1222 static int tegra210_utmi_disable_phy_wake(struct tegra_xusb_lane *lane) in tegra210_utmi_disable_phy_wake() argument
1224 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_utmi_disable_phy_wake()
1225 unsigned int index = lane->index; in tegra210_utmi_disable_phy_wake()
1228 mutex_lock(&padctl->lock); in tegra210_utmi_disable_phy_wake()
1242 mutex_unlock(&padctl->lock); in tegra210_utmi_disable_phy_wake()
1247 static bool tegra210_utmi_phy_remote_wake_detected(struct tegra_xusb_lane *lane) in tegra210_utmi_phy_remote_wake_detected() argument
1249 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_utmi_phy_remote_wake_detected()
1250 unsigned int index = lane->index; in tegra210_utmi_phy_remote_wake_detected()
1261 static int tegra210_hsic_enable_phy_wake(struct tegra_xusb_lane *lane) in tegra210_hsic_enable_phy_wake() argument
1263 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_hsic_enable_phy_wake()
1264 unsigned int index = lane->index; in tegra210_hsic_enable_phy_wake()
1267 mutex_lock(&padctl->lock); in tegra210_hsic_enable_phy_wake()
1281 mutex_unlock(&padctl->lock); in tegra210_hsic_enable_phy_wake()
1286 static int tegra210_hsic_disable_phy_wake(struct tegra_xusb_lane *lane) in tegra210_hsic_disable_phy_wake() argument
1288 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_hsic_disable_phy_wake()
1289 unsigned int index = lane->index; in tegra210_hsic_disable_phy_wake()
1292 mutex_lock(&padctl->lock); in tegra210_hsic_disable_phy_wake()
1306 mutex_unlock(&padctl->lock); in tegra210_hsic_disable_phy_wake()
1311 static bool tegra210_hsic_phy_remote_wake_detected(struct tegra_xusb_lane *lane) in tegra210_hsic_phy_remote_wake_detected() argument
1313 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_hsic_phy_remote_wake_detected()
1314 unsigned int index = lane->index; in tegra210_hsic_phy_remote_wake_detected()
1328 WARN(regmap_read(_priv->regmap, _offset, &value), "read %s failed\n", #_offset);\
1333 WARN(regmap_write(_priv->regmap, _offset, _value), "write %s failed\n", #_offset)
1335 static int tegra210_pmc_utmi_enable_phy_sleepwalk(struct tegra_xusb_lane *lane, in tegra210_pmc_utmi_enable_phy_sleepwalk() argument
1338 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_pmc_utmi_enable_phy_sleepwalk()
1340 unsigned int port = lane->index; in tegra210_pmc_utmi_enable_phy_sleepwalk()
1343 if (!priv->regmap) in tegra210_pmc_utmi_enable_phy_sleepwalk()
1344 return -EOPNOTSUPP; in tegra210_pmc_utmi_enable_phy_sleepwalk()
1347 return -EINVAL; in tegra210_pmc_utmi_enable_phy_sleepwalk()
1443 * Set up the pull-ups and pull-downs of the signals during the four in tegra210_pmc_utmi_enable_phy_sleepwalk()
1454 /* J state: D+/D- = high/low, K state: D+/D- = low/high */ in tegra210_pmc_utmi_enable_phy_sleepwalk()
1461 /* J state: D+/D- = low/high, K state: D+/D- = high/low */ in tegra210_pmc_utmi_enable_phy_sleepwalk()
1508 static int tegra210_pmc_utmi_disable_phy_sleepwalk(struct tegra_xusb_lane *lane) in tegra210_pmc_utmi_disable_phy_sleepwalk() argument
1510 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_pmc_utmi_disable_phy_sleepwalk()
1512 unsigned int port = lane->index; in tegra210_pmc_utmi_disable_phy_sleepwalk()
1515 if (!priv->regmap) in tegra210_pmc_utmi_disable_phy_sleepwalk()
1516 return -EOPNOTSUPP; in tegra210_pmc_utmi_disable_phy_sleepwalk()
1556 static int tegra210_pmc_hsic_enable_phy_sleepwalk(struct tegra_xusb_lane *lane, in tegra210_pmc_hsic_enable_phy_sleepwalk() argument
1559 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_pmc_hsic_enable_phy_sleepwalk()
1563 if (!priv->regmap) in tegra210_pmc_hsic_enable_phy_sleepwalk()
1564 return -EOPNOTSUPP; in tegra210_pmc_hsic_enable_phy_sleepwalk()
1624 * Set up the pull-ups and pull-downs of the signals during the four in tegra210_pmc_hsic_enable_phy_sleepwalk()
1658 static int tegra210_pmc_hsic_disable_phy_sleepwalk(struct tegra_xusb_lane *lane) in tegra210_pmc_hsic_disable_phy_sleepwalk() argument
1660 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_pmc_hsic_disable_phy_sleepwalk()
1664 if (!priv->regmap) in tegra210_pmc_hsic_disable_phy_sleepwalk()
1665 return -EOPNOTSUPP; in tegra210_pmc_hsic_disable_phy_sleepwalk()
1699 struct tegra_xusb_lane *lane; in tegra210_usb3_set_lfps_detect() local
1704 return -ENODEV; in tegra210_usb3_set_lfps_detect()
1706 lane = port->lane; in tegra210_usb3_set_lfps_detect()
1708 if (lane->pad == padctl->pcie) in tegra210_usb3_set_lfps_detect()
1709 offset = XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL1(lane->index); in tegra210_usb3_set_lfps_detect()
1749 TEGRA210_LANE("usb2-0", 0x004, 0, 0x3, usb2),
1750 TEGRA210_LANE("usb2-1", 0x004, 2, 0x3, usb2),
1751 TEGRA210_LANE("usb2-2", 0x004, 4, 0x3, usb2),
1752 TEGRA210_LANE("usb2-3", 0x004, 6, 0x3, usb2),
1764 return ERR_PTR(-ENOMEM); in tegra210_usb2_lane_probe()
1766 INIT_LIST_HEAD(&usb2->base.list); in tegra210_usb2_lane_probe()
1767 usb2->base.soc = &pad->soc->lanes[index]; in tegra210_usb2_lane_probe()
1768 usb2->base.index = index; in tegra210_usb2_lane_probe()
1769 usb2->base.pad = pad; in tegra210_usb2_lane_probe()
1770 usb2->base.np = np; in tegra210_usb2_lane_probe()
1772 err = tegra_xusb_lane_parse_dt(&usb2->base, np); in tegra210_usb2_lane_probe()
1778 return &usb2->base; in tegra210_usb2_lane_probe()
1781 static void tegra210_usb2_lane_remove(struct tegra_xusb_lane *lane) in tegra210_usb2_lane_remove() argument
1783 struct tegra_xusb_usb2_lane *usb2 = to_usb2_lane(lane); in tegra210_usb2_lane_remove()
1800 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_usb2_phy_init() local
1801 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb2_phy_init()
1802 unsigned int index = lane->index; in tegra210_usb2_phy_init()
1809 dev_err(&phy->dev, "no port found for USB2 lane %u\n", index); in tegra210_usb2_phy_init()
1810 return -ENODEV; in tegra210_usb2_phy_init()
1813 if (port->supply && port->mode == USB_DR_MODE_HOST) { in tegra210_usb2_phy_init()
1814 err = regulator_enable(port->supply); in tegra210_usb2_phy_init()
1819 mutex_lock(&padctl->lock); in tegra210_usb2_phy_init()
1828 mutex_unlock(&padctl->lock); in tegra210_usb2_phy_init()
1835 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_usb2_phy_exit() local
1836 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb2_phy_exit()
1840 port = tegra_xusb_find_usb2_port(padctl, lane->index); in tegra210_usb2_phy_exit()
1842 dev_err(&phy->dev, "no port found for USB2 lane %u\n", lane->index); in tegra210_usb2_phy_exit()
1843 return -ENODEV; in tegra210_usb2_phy_exit()
1846 if (port->supply && port->mode == USB_DR_MODE_HOST) { in tegra210_usb2_phy_exit()
1847 err = regulator_disable(port->supply); in tegra210_usb2_phy_exit()
1860 dev_dbg(padctl->dev, "%s vbus override\n", status ? "set" : "clear"); in tegra210_xusb_padctl_vbus_override()
1884 dev_dbg(padctl->dev, "%s id override\n", status ? "set" : "clear"); in tegra210_xusb_padctl_id_override()
1916 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_usb2_phy_set_mode() local
1917 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb2_phy_set_mode()
1919 lane->index); in tegra210_usb2_phy_set_mode()
1922 mutex_lock(&padctl->lock); in tegra210_usb2_phy_set_mode()
1924 dev_dbg(&port->base.dev, "%s: mode %d", __func__, mode); in tegra210_usb2_phy_set_mode()
1930 err = regulator_enable(port->supply); in tegra210_usb2_phy_set_mode()
1939 if (regulator_is_enabled(port->supply)) in tegra210_usb2_phy_set_mode()
1940 regulator_disable(port->supply); in tegra210_usb2_phy_set_mode()
1947 mutex_unlock(&padctl->lock); in tegra210_usb2_phy_set_mode()
1954 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_usb2_phy_power_on() local
1955 struct tegra_xusb_usb2_lane *usb2 = to_usb2_lane(lane); in tegra210_usb2_phy_power_on()
1956 struct tegra_xusb_usb2_pad *pad = to_usb2_pad(lane->pad); in tegra210_usb2_phy_power_on()
1957 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb2_phy_power_on()
1960 unsigned int index = lane->index; in tegra210_usb2_phy_power_on()
1966 dev_err(&phy->dev, "no port found for USB2 lane %u\n", index); in tegra210_usb2_phy_power_on()
1967 return -ENODEV; in tegra210_usb2_phy_power_on()
1972 mutex_lock(&padctl->lock); in tegra210_usb2_phy_power_on()
1974 if (port->usb3_port_fake != -1) { in tegra210_usb2_phy_power_on()
1977 port->usb3_port_fake); in tegra210_usb2_phy_power_on()
1979 port->usb3_port_fake, index); in tegra210_usb2_phy_power_on()
1984 port->usb3_port_fake); in tegra210_usb2_phy_power_on()
1991 port->usb3_port_fake); in tegra210_usb2_phy_power_on()
1998 port->usb3_port_fake); in tegra210_usb2_phy_power_on()
2019 if (port->mode == USB_DR_MODE_UNKNOWN) in tegra210_usb2_phy_power_on()
2021 else if (port->mode == USB_DR_MODE_PERIPHERAL) in tegra210_usb2_phy_power_on()
2023 else if (port->mode == USB_DR_MODE_HOST) in tegra210_usb2_phy_power_on()
2025 else if (port->mode == USB_DR_MODE_OTG) in tegra210_usb2_phy_power_on()
2035 value |= (priv->fuse.hs_curr_level[index] + in tegra210_usb2_phy_power_on()
2036 usb2->hs_curr_level_offset) << in tegra210_usb2_phy_power_on()
2048 value |= (priv->fuse.hs_term_range_adj << in tegra210_usb2_phy_power_on()
2050 (priv->fuse.rpd_ctrl << in tegra210_usb2_phy_power_on()
2058 if (port->mode == USB_DR_MODE_HOST) in tegra210_usb2_phy_power_on()
2067 if (pad->enable > 0) { in tegra210_usb2_phy_power_on()
2068 pad->enable++; in tegra210_usb2_phy_power_on()
2069 mutex_unlock(&padctl->lock); in tegra210_usb2_phy_power_on()
2073 err = clk_prepare_enable(pad->clk); in tegra210_usb2_phy_power_on()
2100 clk_disable_unprepare(pad->clk); in tegra210_usb2_phy_power_on()
2102 pad->enable++; in tegra210_usb2_phy_power_on()
2103 mutex_unlock(&padctl->lock); in tegra210_usb2_phy_power_on()
2108 mutex_unlock(&padctl->lock); in tegra210_usb2_phy_power_on()
2114 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_usb2_phy_power_off() local
2115 struct tegra_xusb_usb2_pad *pad = to_usb2_pad(lane->pad); in tegra210_usb2_phy_power_off()
2116 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb2_phy_power_off()
2120 port = tegra_xusb_find_usb2_port(padctl, lane->index); in tegra210_usb2_phy_power_off()
2122 dev_err(&phy->dev, "no port found for USB2 lane %u\n", in tegra210_usb2_phy_power_off()
2123 lane->index); in tegra210_usb2_phy_power_off()
2124 return -ENODEV; in tegra210_usb2_phy_power_off()
2127 mutex_lock(&padctl->lock); in tegra210_usb2_phy_power_off()
2129 if (port->usb3_port_fake != -1) { in tegra210_usb2_phy_power_off()
2132 port->usb3_port_fake); in tegra210_usb2_phy_power_off()
2139 port->usb3_port_fake); in tegra210_usb2_phy_power_off()
2146 port->usb3_port_fake); in tegra210_usb2_phy_power_off()
2150 value |= XUSB_PADCTL_SS_PORT_MAP_PORTX_MAP(port->usb3_port_fake, in tegra210_usb2_phy_power_off()
2155 if (WARN_ON(pad->enable == 0)) in tegra210_usb2_phy_power_off()
2158 if (--pad->enable > 0) in tegra210_usb2_phy_power_off()
2166 mutex_unlock(&padctl->lock); in tegra210_usb2_phy_power_off()
2190 return ERR_PTR(-ENOMEM); in tegra210_usb2_pad_probe()
2192 pad = &usb2->base; in tegra210_usb2_pad_probe()
2193 pad->ops = &tegra210_usb2_lane_ops; in tegra210_usb2_pad_probe()
2194 pad->soc = soc; in tegra210_usb2_pad_probe()
2202 usb2->clk = devm_clk_get(&pad->dev, "trk"); in tegra210_usb2_pad_probe()
2203 if (IS_ERR(usb2->clk)) { in tegra210_usb2_pad_probe()
2204 err = PTR_ERR(usb2->clk); in tegra210_usb2_pad_probe()
2205 dev_err(&pad->dev, "failed to get trk clock: %d\n", err); in tegra210_usb2_pad_probe()
2213 dev_set_drvdata(&pad->dev, pad); in tegra210_usb2_pad_probe()
2218 device_unregister(&pad->dev); in tegra210_usb2_pad_probe()
2248 TEGRA210_LANE("hsic-0", 0x004, 14, 0x1, hsic),
2260 return ERR_PTR(-ENOMEM); in tegra210_hsic_lane_probe()
2262 INIT_LIST_HEAD(&hsic->base.list); in tegra210_hsic_lane_probe()
2263 hsic->base.soc = &pad->soc->lanes[index]; in tegra210_hsic_lane_probe()
2264 hsic->base.index = index; in tegra210_hsic_lane_probe()
2265 hsic->base.pad = pad; in tegra210_hsic_lane_probe()
2266 hsic->base.np = np; in tegra210_hsic_lane_probe()
2268 err = tegra_xusb_lane_parse_dt(&hsic->base, np); in tegra210_hsic_lane_probe()
2274 return &hsic->base; in tegra210_hsic_lane_probe()
2277 static void tegra210_hsic_lane_remove(struct tegra_xusb_lane *lane) in tegra210_hsic_lane_remove() argument
2279 struct tegra_xusb_hsic_lane *hsic = to_hsic_lane(lane); in tegra210_hsic_lane_remove()
2296 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_hsic_phy_init() local
2297 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_hsic_phy_init()
2317 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_hsic_phy_power_on() local
2318 struct tegra_xusb_hsic_lane *hsic = to_hsic_lane(lane); in tegra210_hsic_phy_power_on()
2319 struct tegra_xusb_hsic_pad *pad = to_hsic_pad(lane->pad); in tegra210_hsic_phy_power_on()
2320 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_hsic_phy_power_on()
2321 unsigned int index = lane->index; in tegra210_hsic_phy_power_on()
2325 err = regulator_enable(pad->supply); in tegra210_hsic_phy_power_on()
2329 padctl_writel(padctl, hsic->strobe_trim, in tegra210_hsic_phy_power_on()
2335 value |= (hsic->tx_rtune_p << in tegra210_hsic_phy_power_on()
2344 value |= (hsic->rx_strobe_trim << in tegra210_hsic_phy_power_on()
2346 (hsic->rx_data_trim << in tegra210_hsic_phy_power_on()
2368 err = clk_prepare_enable(pad->clk); in tegra210_hsic_phy_power_on()
2391 clk_disable_unprepare(pad->clk); in tegra210_hsic_phy_power_on()
2396 regulator_disable(pad->supply); in tegra210_hsic_phy_power_on()
2402 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_hsic_phy_power_off() local
2403 struct tegra_xusb_hsic_pad *pad = to_hsic_pad(lane->pad); in tegra210_hsic_phy_power_off()
2404 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_hsic_phy_power_off()
2405 unsigned int index = lane->index; in tegra210_hsic_phy_power_off()
2420 regulator_disable(pad->supply); in tegra210_hsic_phy_power_off()
2444 return ERR_PTR(-ENOMEM); in tegra210_hsic_pad_probe()
2446 pad = &hsic->base; in tegra210_hsic_pad_probe()
2447 pad->ops = &tegra210_hsic_lane_ops; in tegra210_hsic_pad_probe()
2448 pad->soc = soc; in tegra210_hsic_pad_probe()
2456 hsic->clk = devm_clk_get(&pad->dev, "trk"); in tegra210_hsic_pad_probe()
2457 if (IS_ERR(hsic->clk)) { in tegra210_hsic_pad_probe()
2458 err = PTR_ERR(hsic->clk); in tegra210_hsic_pad_probe()
2459 dev_err(&pad->dev, "failed to get trk clock: %d\n", err); in tegra210_hsic_pad_probe()
2467 dev_set_drvdata(&pad->dev, pad); in tegra210_hsic_pad_probe()
2472 device_unregister(&pad->dev); in tegra210_hsic_pad_probe()
2496 static void tegra210_uphy_lane_iddq_enable(struct tegra_xusb_lane *lane) in tegra210_uphy_lane_iddq_enable() argument
2498 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_uphy_lane_iddq_enable()
2501 value = padctl_readl(padctl, lane->soc->regs.misc_ctl2); in tegra210_uphy_lane_iddq_enable()
2512 padctl_writel(padctl, value, lane->soc->regs.misc_ctl2); in tegra210_uphy_lane_iddq_enable()
2515 static void tegra210_uphy_lane_iddq_disable(struct tegra_xusb_lane *lane) in tegra210_uphy_lane_iddq_disable() argument
2517 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_uphy_lane_iddq_disable()
2520 value = padctl_readl(padctl, lane->soc->regs.misc_ctl2); in tegra210_uphy_lane_iddq_disable()
2531 padctl_writel(padctl, value, lane->soc->regs.misc_ctl2); in tegra210_uphy_lane_iddq_disable()
2546 "pcie-x1",
2547 "usb3-ss",
2549 "pcie-x4",
2553 TEGRA210_UPHY_LANE("pcie-0", 0x028, 12, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL2(0)),
2554 TEGRA210_UPHY_LANE("pcie-1", 0x028, 14, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL2(1)),
2555 TEGRA210_UPHY_LANE("pcie-2", 0x028, 16, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL2(2)),
2556 TEGRA210_UPHY_LANE("pcie-3", 0x028, 18, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL2(3)),
2557 TEGRA210_UPHY_LANE("pcie-4", 0x028, 20, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL2(4)),
2558 TEGRA210_UPHY_LANE("pcie-5", 0x028, 22, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL2(5)),
2559 TEGRA210_UPHY_LANE("pcie-6", 0x028, 24, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_PX_CTL2(6)),
2563 tegra210_lane_to_usb3_port(struct tegra_xusb_lane *lane) in tegra210_lane_to_usb3_port() argument
2567 if (!lane || !lane->pad || !lane->pad->padctl) in tegra210_lane_to_usb3_port()
2570 port = tegra210_usb3_lane_map(lane); in tegra210_lane_to_usb3_port()
2574 return tegra_xusb_find_usb3_port(lane->pad->padctl, port); in tegra210_lane_to_usb3_port()
2579 struct device *dev = &phy->dev; in tegra210_usb3_phy_power_on()
2580 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_usb3_phy_power_on() local
2581 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb3_phy_power_on()
2582 struct tegra_xusb_usb3_port *usb3 = tegra210_lane_to_usb3_port(lane); in tegra210_usb3_phy_power_on()
2587 dev_err(dev, "no USB3 port found for lane %u\n", lane->index); in tegra210_usb3_phy_power_on()
2588 return -ENODEV; in tegra210_usb3_phy_power_on()
2591 index = usb3->base.index; in tegra210_usb3_phy_power_on()
2595 if (!usb3->internal) in tegra210_usb3_phy_power_on()
2601 value |= XUSB_PADCTL_SS_PORT_MAP_PORTX_MAP(index, usb3->port); in tegra210_usb3_phy_power_on()
2652 struct device *dev = &phy->dev; in tegra210_usb3_phy_power_off()
2653 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_usb3_phy_power_off() local
2654 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_usb3_phy_power_off()
2655 struct tegra_xusb_usb3_port *usb3 = tegra210_lane_to_usb3_port(lane); in tegra210_usb3_phy_power_off()
2660 dev_err(dev, "no USB3 port found for lane %u\n", lane->index); in tegra210_usb3_phy_power_off()
2661 return -ENODEV; in tegra210_usb3_phy_power_off()
2664 index = usb3->base.index; in tegra210_usb3_phy_power_off()
2693 return ERR_PTR(-ENOMEM); in tegra210_pcie_lane_probe()
2695 INIT_LIST_HEAD(&pcie->base.list); in tegra210_pcie_lane_probe()
2696 pcie->base.soc = &pad->soc->lanes[index]; in tegra210_pcie_lane_probe()
2697 pcie->base.index = index; in tegra210_pcie_lane_probe()
2698 pcie->base.pad = pad; in tegra210_pcie_lane_probe()
2699 pcie->base.np = np; in tegra210_pcie_lane_probe()
2701 err = tegra_xusb_lane_parse_dt(&pcie->base, np); in tegra210_pcie_lane_probe()
2707 return &pcie->base; in tegra210_pcie_lane_probe()
2710 static void tegra210_pcie_lane_remove(struct tegra_xusb_lane *lane) in tegra210_pcie_lane_remove() argument
2712 struct tegra_xusb_pcie_lane *pcie = to_pcie_lane(lane); in tegra210_pcie_lane_remove()
2731 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_pcie_phy_init() local
2732 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_pcie_phy_init()
2734 mutex_lock(&padctl->lock); in tegra210_pcie_phy_init()
2738 mutex_unlock(&padctl->lock); in tegra210_pcie_phy_init()
2745 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_pcie_phy_power_on() local
2746 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_pcie_phy_power_on()
2749 mutex_lock(&padctl->lock); in tegra210_pcie_phy_power_on()
2751 if (tegra_xusb_lane_check(lane, "usb3-ss")) in tegra210_pcie_phy_power_on()
2754 mutex_unlock(&padctl->lock); in tegra210_pcie_phy_power_on()
2760 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_pcie_phy_power_off() local
2761 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_pcie_phy_power_off()
2764 mutex_lock(&padctl->lock); in tegra210_pcie_phy_power_off()
2766 if (tegra_xusb_lane_check(lane, "usb3-ss")) in tegra210_pcie_phy_power_off()
2769 mutex_unlock(&padctl->lock); in tegra210_pcie_phy_power_off()
2791 return ERR_PTR(-ENOMEM); in tegra210_pcie_pad_probe()
2793 pad = &pcie->base; in tegra210_pcie_pad_probe()
2794 pad->ops = &tegra210_pcie_lane_ops; in tegra210_pcie_pad_probe()
2795 pad->soc = soc; in tegra210_pcie_pad_probe()
2803 pcie->pll = devm_clk_get(&pad->dev, "pll"); in tegra210_pcie_pad_probe()
2804 if (IS_ERR(pcie->pll)) { in tegra210_pcie_pad_probe()
2805 err = PTR_ERR(pcie->pll); in tegra210_pcie_pad_probe()
2806 dev_err(&pad->dev, "failed to get PLL: %d\n", err); in tegra210_pcie_pad_probe()
2810 pcie->rst = devm_reset_control_get(&pad->dev, "phy"); in tegra210_pcie_pad_probe()
2811 if (IS_ERR(pcie->rst)) { in tegra210_pcie_pad_probe()
2812 err = PTR_ERR(pcie->rst); in tegra210_pcie_pad_probe()
2813 dev_err(&pad->dev, "failed to get PCIe pad reset: %d\n", err); in tegra210_pcie_pad_probe()
2821 dev_set_drvdata(&pad->dev, pad); in tegra210_pcie_pad_probe()
2826 device_unregister(&pad->dev); in tegra210_pcie_pad_probe()
2851 TEGRA210_UPHY_LANE("sata-0", 0x028, 30, 0x3, pcie, XUSB_PADCTL_UPHY_MISC_PAD_S0_CTL2),
2863 return ERR_PTR(-ENOMEM); in tegra210_sata_lane_probe()
2865 INIT_LIST_HEAD(&sata->base.list); in tegra210_sata_lane_probe()
2866 sata->base.soc = &pad->soc->lanes[index]; in tegra210_sata_lane_probe()
2867 sata->base.index = index; in tegra210_sata_lane_probe()
2868 sata->base.pad = pad; in tegra210_sata_lane_probe()
2869 sata->base.np = np; in tegra210_sata_lane_probe()
2871 err = tegra_xusb_lane_parse_dt(&sata->base, np); in tegra210_sata_lane_probe()
2877 return &sata->base; in tegra210_sata_lane_probe()
2880 static void tegra210_sata_lane_remove(struct tegra_xusb_lane *lane) in tegra210_sata_lane_remove() argument
2882 struct tegra_xusb_sata_lane *sata = to_sata_lane(lane); in tegra210_sata_lane_remove()
2901 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_sata_phy_init() local
2902 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_sata_phy_init()
2904 mutex_lock(&padctl->lock); in tegra210_sata_phy_init()
2908 mutex_unlock(&padctl->lock); in tegra210_sata_phy_init()
2914 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_sata_phy_power_on() local
2915 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_sata_phy_power_on()
2918 mutex_lock(&padctl->lock); in tegra210_sata_phy_power_on()
2920 if (tegra_xusb_lane_check(lane, "usb3-ss")) in tegra210_sata_phy_power_on()
2923 mutex_unlock(&padctl->lock); in tegra210_sata_phy_power_on()
2929 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra210_sata_phy_power_off() local
2930 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra210_sata_phy_power_off()
2933 mutex_lock(&padctl->lock); in tegra210_sata_phy_power_off()
2935 if (tegra_xusb_lane_check(lane, "usb3-ss")) in tegra210_sata_phy_power_off()
2938 mutex_unlock(&padctl->lock); in tegra210_sata_phy_power_off()
2960 return ERR_PTR(-ENOMEM); in tegra210_sata_pad_probe()
2962 pad = &sata->base; in tegra210_sata_pad_probe()
2963 pad->ops = &tegra210_sata_lane_ops; in tegra210_sata_pad_probe()
2964 pad->soc = soc; in tegra210_sata_pad_probe()
2972 sata->rst = devm_reset_control_get(&pad->dev, "phy"); in tegra210_sata_pad_probe()
2973 if (IS_ERR(sata->rst)) { in tegra210_sata_pad_probe()
2974 err = PTR_ERR(sata->rst); in tegra210_sata_pad_probe()
2975 dev_err(&pad->dev, "failed to get SATA pad reset: %d\n", err); in tegra210_sata_pad_probe()
2983 dev_set_drvdata(&pad->dev, pad); in tegra210_sata_pad_probe()
2988 device_unregister(&pad->dev); in tegra210_sata_pad_probe()
3031 return tegra_xusb_find_lane(port->padctl, "usb2", port->index); in tegra210_usb2_port_map()
3054 return tegra_xusb_find_lane(port->padctl, "hsic", port->index); in tegra210_hsic_port_map()
3076 return tegra_xusb_port_find_lane(port, tegra210_usb3_map, "usb3-ss"); in tegra210_usb3_port_map()
3090 struct tegra_xusb_lane *lane; in tegra210_utmi_port_reset() local
3093 lane = phy_get_drvdata(phy); in tegra210_utmi_port_reset()
3094 padctl = lane->pad->padctl; in tegra210_utmi_port_reset()
3097 XUSB_PADCTL_USB2_BATTERY_CHRG_OTGPADX_CTL0(lane->index)); in tegra210_utmi_port_reset()
3120 for (i = 0; i < ARRAY_SIZE(fuse->hs_curr_level); i++) { in tegra210_xusb_read_fuse_calibration()
3121 fuse->hs_curr_level[i] = in tegra210_xusb_read_fuse_calibration()
3126 fuse->hs_term_range_adj = in tegra210_xusb_read_fuse_calibration()
3134 fuse->rpd_ctrl = in tegra210_xusb_read_fuse_calibration()
3152 return ERR_PTR(-ENOMEM); in tegra210_xusb_padctl_probe()
3154 padctl->base.dev = dev; in tegra210_xusb_padctl_probe()
3155 padctl->base.soc = soc; in tegra210_xusb_padctl_probe()
3157 err = tegra210_xusb_read_fuse_calibration(&padctl->fuse); in tegra210_xusb_padctl_probe()
3161 np = of_parse_phandle(dev->of_node, "nvidia,pmc", 0); in tegra210_xusb_padctl_probe()
3174 return ERR_PTR(-EPROBE_DEFER); in tegra210_xusb_padctl_probe()
3176 padctl->regmap = dev_get_regmap(&pdev->dev, "usb_sleepwalk"); in tegra210_xusb_padctl_probe()
3177 if (!padctl->regmap) in tegra210_xusb_padctl_probe()
3181 return &padctl->base; in tegra210_xusb_padctl_probe()
3192 priv->context.usb2_pad_mux = in tegra210_xusb_padctl_save()
3194 priv->context.usb2_port_cap = in tegra210_xusb_padctl_save()
3196 priv->context.ss_port_map = in tegra210_xusb_padctl_save()
3198 priv->context.usb3_pad_mux = in tegra210_xusb_padctl_save()
3205 struct tegra_xusb_lane *lane; in tegra210_xusb_padctl_restore() local
3207 padctl_writel(padctl, priv->context.usb2_pad_mux, in tegra210_xusb_padctl_restore()
3209 padctl_writel(padctl, priv->context.usb2_port_cap, in tegra210_xusb_padctl_restore()
3211 padctl_writel(padctl, priv->context.ss_port_map, in tegra210_xusb_padctl_restore()
3214 list_for_each_entry(lane, &padctl->lanes, list) { in tegra210_xusb_padctl_restore()
3215 if (lane->pad->ops->iddq_enable) in tegra210_xusb_padctl_restore()
3216 tegra210_uphy_lane_iddq_enable(lane); in tegra210_xusb_padctl_restore()
3219 padctl_writel(padctl, priv->context.usb3_pad_mux, in tegra210_xusb_padctl_restore()
3222 list_for_each_entry(lane, &padctl->lanes, list) { in tegra210_xusb_padctl_restore()
3223 if (lane->pad->ops->iddq_disable) in tegra210_xusb_padctl_restore()
3224 tegra210_uphy_lane_iddq_disable(lane); in tegra210_xusb_padctl_restore()
3230 mutex_lock(&padctl->lock); in tegra210_xusb_padctl_suspend_noirq()
3236 mutex_unlock(&padctl->lock); in tegra210_xusb_padctl_suspend_noirq()
3242 mutex_lock(&padctl->lock); in tegra210_xusb_padctl_resume_noirq()
3248 mutex_unlock(&padctl->lock); in tegra210_xusb_padctl_resume_noirq()
3264 "avdd-pll-utmip",
3265 "avdd-pll-uerefe",
3266 "dvdd-pex-pll",
3267 "hvdd-pex-pll-e",