blob: b08eedd4d42f8a3600d5136862e8ce74abf5a134 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +02002/*
3 * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
4 * Written by Jean-Jacques Hiblot <jjhiblot@ti.com>
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +02005 */
6
Peng Fan62ee9572020-10-15 18:05:58 +08007#include <clk.h>
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +02008#include <common.h>
9#include <dm.h>
10#include <dm/device.h>
Peng Fan62ee9572020-10-15 18:05:58 +080011#include <dm/device_compat.h>
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +020012#include <generic-phy.h>
Adam Ford3970c822022-01-29 07:27:47 -060013#include <asm-generic/gpio.h>
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +020014
Peng Fan62ee9572020-10-15 18:05:58 +080015struct nop_phy_priv {
16 struct clk_bulk bulk;
Adam Ford3970c822022-01-29 07:27:47 -060017#if CONFIG_IS_ENABLED(DM_GPIO)
18 struct gpio_desc reset_gpio;
19#endif
Peng Fan62ee9572020-10-15 18:05:58 +080020};
21
Adam Ford3970c822022-01-29 07:27:47 -060022#if CONFIG_IS_ENABLED(DM_GPIO)
23static int nop_phy_reset(struct phy *phy)
24{
25 struct nop_phy_priv *priv = dev_get_priv(phy->dev);
26
27 /* Return if there is no gpio since it's optional */
28 if (!dm_gpio_is_valid(&priv->reset_gpio))
29 return 0;
30
31 return dm_gpio_set_value(&priv->reset_gpio, false);
32}
33#endif
34
Peng Fan62ee9572020-10-15 18:05:58 +080035static int nop_phy_init(struct phy *phy)
36{
37 struct nop_phy_priv *priv = dev_get_priv(phy->dev);
Adam Ford3970c822022-01-29 07:27:47 -060038 int ret = 0;
Peng Fan62ee9572020-10-15 18:05:58 +080039
Adam Ford3970c822022-01-29 07:27:47 -060040 if (CONFIG_IS_ENABLED(CLK)) {
41 ret = clk_enable_bulk(&priv->bulk);
42 if (ret)
43 return ret;
44 }
Peng Fan62ee9572020-10-15 18:05:58 +080045
Adam Ford3970c822022-01-29 07:27:47 -060046#if CONFIG_IS_ENABLED(DM_GPIO)
47 ret = nop_phy_reset(phy);
48 if (ret) {
49 if (CONFIG_IS_ENABLED(CLK))
50 clk_disable_bulk(&priv->bulk);
51 return ret;
52 }
53#endif
Peng Fan62ee9572020-10-15 18:05:58 +080054 return 0;
55}
56
57static int nop_phy_probe(struct udevice *dev)
58{
59 struct nop_phy_priv *priv = dev_get_priv(dev);
Adam Ford3970c822022-01-29 07:27:47 -060060 int ret = 0;
Peng Fan62ee9572020-10-15 18:05:58 +080061
62 if (CONFIG_IS_ENABLED(CLK)) {
63 ret = clk_get_bulk(dev, &priv->bulk);
64 if (ret < 0) {
65 dev_err(dev, "Failed to get clk: %d\n", ret);
66 return ret;
67 }
68 }
Adam Ford3970c822022-01-29 07:27:47 -060069#if CONFIG_IS_ENABLED(DM_GPIO)
70 ret = gpio_request_by_name(dev, "reset-gpios", 0,
71 &priv->reset_gpio,
72 GPIOD_IS_OUT);
73#endif
74 if (ret != -ENOENT)
75 return ret;
Peng Fan62ee9572020-10-15 18:05:58 +080076
77 return 0;
78}
79
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +020080static const struct udevice_id nop_phy_ids[] = {
81 { .compatible = "nop-phy" },
Marek Vasut1220aa92021-03-31 11:21:07 +020082 { .compatible = "usb-nop-xceiv" },
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +020083 { }
84};
85
86static struct phy_ops nop_phy_ops = {
Peng Fan62ee9572020-10-15 18:05:58 +080087 .init = nop_phy_init,
Adam Ford3970c822022-01-29 07:27:47 -060088#if CONFIG_IS_ENABLED(DM_GPIO)
89 .reset = nop_phy_reset,
90#endif
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +020091};
92
93U_BOOT_DRIVER(nop_phy) = {
94 .name = "nop_phy",
95 .id = UCLASS_PHY,
96 .of_match = nop_phy_ids,
97 .ops = &nop_phy_ops,
Peng Fan62ee9572020-10-15 18:05:58 +080098 .probe = nop_phy_probe,
Simon Glass41575d82020-12-03 16:55:17 -070099 .priv_auto = sizeof(struct nop_phy_priv),
Jean-Jacques Hiblot3b63db32017-07-24 15:18:15 +0200100};