Blame view
drivers/usb/renesas_usbhs/rcar2.c
1.51 KB
5fd54ace4
|
1 |
// SPDX-License-Identifier: GPL-1.0+ |
8ecef00fe
|
2 3 4 5 |
/* * Renesas USB driver R-Car Gen. 2 initialization and power control * * Copyright (C) 2014 Ulrich Hecht |
be0a42a7d
|
6 |
* Copyright (C) 2019 Renesas Electronics Corporation |
8ecef00fe
|
7 |
*/ |
420974a0e
|
8 |
#include <linux/phy/phy.h> |
8ecef00fe
|
9 10 11 12 13 14 |
#include "common.h" #include "rcar2.h" static int usbhs_rcar2_hardware_init(struct platform_device *pdev) { struct usbhs_priv *priv = usbhs_pdev_to_priv(pdev); |
8ecef00fe
|
15 |
|
420974a0e
|
16 17 18 19 20 21 22 23 24 |
if (IS_ENABLED(CONFIG_GENERIC_PHY)) { struct phy *phy = phy_get(&pdev->dev, "usb"); if (IS_ERR(phy)) return PTR_ERR(phy); priv->phy = phy; return 0; } |
5f6aea345
|
25 |
return -ENXIO; |
8ecef00fe
|
26 27 28 29 30 |
} static int usbhs_rcar2_hardware_exit(struct platform_device *pdev) { struct usbhs_priv *priv = usbhs_pdev_to_priv(pdev); |
420974a0e
|
31 |
if (priv->phy) { |
987351e1e
|
32 |
phy_put(&pdev->dev, priv->phy); |
420974a0e
|
33 34 |
priv->phy = NULL; } |
8ecef00fe
|
35 36 37 38 39 40 41 |
return 0; } static int usbhs_rcar2_power_ctrl(struct platform_device *pdev, void __iomem *base, int enable) { struct usbhs_priv *priv = usbhs_pdev_to_priv(pdev); |
5f6aea345
|
42 |
int retval = -ENODEV; |
8ecef00fe
|
43 |
|
420974a0e
|
44 45 46 47 48 49 50 51 52 53 54 55 |
if (priv->phy) { if (enable) { retval = phy_init(priv->phy); if (!retval) retval = phy_power_on(priv->phy); } else { phy_power_off(priv->phy); phy_exit(priv->phy); retval = 0; } } |
5f6aea345
|
56 |
return retval; |
8ecef00fe
|
57 |
} |
76eff170b
|
58 59 60 61 62 63 64 65 66 67 68 |
const struct renesas_usbhs_platform_info usbhs_rcar_gen2_plat_info = { .platform_callback = { .hardware_init = usbhs_rcar2_hardware_init, .hardware_exit = usbhs_rcar2_hardware_exit, .power_ctrl = usbhs_rcar2_power_ctrl, .get_id = usbhs_get_id_as_gadget, }, .driver_param = { .has_usb_dmac = 1, .has_new_pipe_configs = 1, }, |
8ecef00fe
|
69 |
}; |