Lines Matching full:lane

109 int tegra_xusb_lane_parse_dt(struct tegra_xusb_lane *lane,  in tegra_xusb_lane_parse_dt()  argument
112 struct device *dev = &lane->pad->dev; in tegra_xusb_lane_parse_dt()
120 err = match_string(lane->soc->funcs, lane->soc->num_funcs, function); in tegra_xusb_lane_parse_dt()
122 dev_err(dev, "invalid function \"%s\" for lane \"%pOFn\"\n", in tegra_xusb_lane_parse_dt()
127 lane->function = err; in tegra_xusb_lane_parse_dt()
135 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra_xusb_lane_destroy() local
137 lane->pad->ops->remove(lane); in tegra_xusb_lane_destroy()
185 struct phy *lane; in tegra_xusb_pad_register() local
193 pad->lanes = devm_kcalloc(&pad->dev, pad->soc->num_lanes, sizeof(lane), in tegra_xusb_pad_register()
202 struct tegra_xusb_lane *lane; in tegra_xusb_pad_register() local
217 lane = pad->ops->probe(pad, np, i); in tegra_xusb_pad_register()
218 if (IS_ERR(lane)) { in tegra_xusb_pad_register()
220 err = PTR_ERR(lane); in tegra_xusb_pad_register()
224 list_add_tail(&lane->list, &pad->padctl->lanes); in tegra_xusb_pad_register()
225 phy_set_drvdata(pad->lanes[i], lane); in tegra_xusb_pad_register()
314 static void tegra_xusb_lane_program(struct tegra_xusb_lane *lane) in tegra_xusb_lane_program() argument
316 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra_xusb_lane_program()
317 const struct tegra_xusb_lane_soc *soc = lane->soc; in tegra_xusb_lane_program()
324 if (lane->pad->ops->iddq_enable) in tegra_xusb_lane_program()
325 lane->pad->ops->iddq_enable(lane); in tegra_xusb_lane_program()
330 value |= lane->function << soc->shift; in tegra_xusb_lane_program()
333 if (lane->pad->ops->iddq_disable) in tegra_xusb_lane_program()
334 lane->pad->ops->iddq_disable(lane); in tegra_xusb_lane_program()
342 struct tegra_xusb_lane *lane; in tegra_xusb_pad_program() local
345 lane = phy_get_drvdata(pad->lanes[i]); in tegra_xusb_pad_program()
346 tegra_xusb_lane_program(lane); in tegra_xusb_pad_program()
385 bool tegra_xusb_lane_check(struct tegra_xusb_lane *lane, in tegra_xusb_lane_check() argument
388 const char *func = lane->soc->funcs[lane->function]; in tegra_xusb_lane_check()
397 struct tegra_xusb_lane *lane, *hit = ERR_PTR(-ENODEV); in tegra_xusb_find_lane() local
404 list_for_each_entry(lane, &padctl->lanes, list) { in tegra_xusb_find_lane()
405 if (strcmp(lane->soc->name, name) == 0) { in tegra_xusb_find_lane()
406 hit = lane; in tegra_xusb_find_lane()
420 struct tegra_xusb_lane *lane, *match = ERR_PTR(-ENODEV); in tegra_xusb_port_find_lane() local
426 lane = tegra_xusb_find_lane(port->padctl, map->type, in tegra_xusb_port_find_lane()
428 if (IS_ERR(lane)) in tegra_xusb_port_find_lane()
431 if (!tegra_xusb_lane_check(lane, function)) in tegra_xusb_port_find_lane()
438 match = lane; in tegra_xusb_port_find_lane()
655 struct tegra_xusb_lane *lane; in tegra_xusb_setup_usb_role_switch() local
691 lane = tegra_xusb_find_lane(port->padctl, "usb2", port->index); in tegra_xusb_setup_usb_role_switch()
697 port->usb_phy.dev = &lane->pad->lanes[port->index]->dev; in tegra_xusb_setup_usb_role_switch()
782 usb2->base.lane = usb2->base.ops->map(&usb2->base); in tegra_xusb_add_usb2_port()
783 if (IS_ERR(usb2->base.lane)) { in tegra_xusb_add_usb2_port()
784 err = PTR_ERR(usb2->base.lane); in tegra_xusb_add_usb2_port()
848 ulpi->base.lane = ulpi->base.ops->map(&ulpi->base); in tegra_xusb_add_ulpi_port()
849 if (IS_ERR(ulpi->base.lane)) { in tegra_xusb_add_ulpi_port()
850 err = PTR_ERR(ulpi->base.lane); in tegra_xusb_add_ulpi_port()
903 hsic->base.lane = hsic->base.ops->map(&hsic->base); in tegra_xusb_add_hsic_port()
904 if (IS_ERR(hsic->base.lane)) { in tegra_xusb_add_hsic_port()
905 err = PTR_ERR(hsic->base.lane); in tegra_xusb_add_hsic_port()
989 usb3->base.lane = usb3->base.ops->map(&usb3->base); in tegra_xusb_add_usb3_port()
990 if (IS_ERR(usb3->base.lane)) { in tegra_xusb_add_usb3_port()
991 err = PTR_ERR(usb3->base.lane); in tegra_xusb_add_usb3_port()
1376 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra_xusb_padctl_enable_phy_sleepwalk() local
1378 if (lane->pad->ops->enable_phy_sleepwalk) in tegra_xusb_padctl_enable_phy_sleepwalk()
1379 return lane->pad->ops->enable_phy_sleepwalk(lane, speed); in tegra_xusb_padctl_enable_phy_sleepwalk()
1387 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra_xusb_padctl_disable_phy_sleepwalk() local
1389 if (lane->pad->ops->disable_phy_sleepwalk) in tegra_xusb_padctl_disable_phy_sleepwalk()
1390 return lane->pad->ops->disable_phy_sleepwalk(lane); in tegra_xusb_padctl_disable_phy_sleepwalk()
1398 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra_xusb_padctl_enable_phy_wake() local
1400 if (lane->pad->ops->enable_phy_wake) in tegra_xusb_padctl_enable_phy_wake()
1401 return lane->pad->ops->enable_phy_wake(lane); in tegra_xusb_padctl_enable_phy_wake()
1409 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra_xusb_padctl_disable_phy_wake() local
1411 if (lane->pad->ops->disable_phy_wake) in tegra_xusb_padctl_disable_phy_wake()
1412 return lane->pad->ops->disable_phy_wake(lane); in tegra_xusb_padctl_disable_phy_wake()
1420 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra_xusb_padctl_remote_wake_detected() local
1422 if (lane->pad->ops->remote_wake_detected) in tegra_xusb_padctl_remote_wake_detected()
1423 return lane->pad->ops->remote_wake_detected(lane); in tegra_xusb_padctl_remote_wake_detected()
1452 struct tegra_xusb_lane *lane = phy_get_drvdata(phy); in tegra_phy_xusb_utmi_port_reset() local
1453 struct tegra_xusb_padctl *padctl = lane->pad->padctl; in tegra_phy_xusb_utmi_port_reset()
1464 struct tegra_xusb_lane *lane; in tegra_phy_xusb_utmi_pad_power_on() local
1470 lane = phy_get_drvdata(phy); in tegra_phy_xusb_utmi_pad_power_on()
1471 padctl = lane->pad->padctl; in tegra_phy_xusb_utmi_pad_power_on()
1480 struct tegra_xusb_lane *lane; in tegra_phy_xusb_utmi_pad_power_down() local
1486 lane = phy_get_drvdata(phy); in tegra_phy_xusb_utmi_pad_power_down()
1487 padctl = lane->pad->padctl; in tegra_phy_xusb_utmi_pad_power_down()