[PATCH 10/16] phy: rockchip: usbdp: Find phy-id from the io address
Kever Yang
kever.yang at rock-chips.com
Tue May 7 05:34:21 CEST 2024
On 2024/5/5 03:43, Jonas Karlman wrote:
> The upstream Linux kernel driver find the phy-id from the io address.
>
> Change to use a similar method as the U-Boot inno-usb2 phy driver and
> the Linux kernel driver to set correct phy-id.
>
> This is based on the linux-phy next commit 2f70bbddeb45 ("phy: rockchip:
> add usbdp combo phy driver").
>
> Signed-off-by: Jonas Karlman <jonas at kwiboo.se>
Reviewed-by: Kever Yang <kever.yang at rock-chips.com>
Thanks,
- Kever
> ---
> drivers/phy/rockchip/phy-rockchip-usbdp.c | 39 ++++++++++++++++++++---
> 1 file changed, 34 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/phy/rockchip/phy-rockchip-usbdp.c b/drivers/phy/rockchip/phy-rockchip-usbdp.c
> index baf92529348c..8e5821069757 100644
> --- a/drivers/phy/rockchip/phy-rockchip-usbdp.c
> +++ b/drivers/phy/rockchip/phy-rockchip-usbdp.c
> @@ -74,6 +74,8 @@ struct udphy_grf_cfg {
> struct rockchip_udphy;
>
> struct rockchip_udphy_cfg {
> + unsigned int num_phys;
> + unsigned int phy_ids[2];
> /* resets to be requested */
> const char * const *rst_list;
> int num_rsts;
> @@ -640,17 +642,25 @@ int rockchip_u3phy_uboot_init(void)
>
> static int rockchip_udphy_probe(struct udevice *dev)
> {
> - const struct device_node *np = ofnode_to_np(dev_ofnode(dev));
> struct rockchip_udphy *udphy = dev_get_priv(dev);
> const struct rockchip_udphy_cfg *phy_cfgs;
> + unsigned int reg;
> int id, ret;
>
> udphy->dev = dev;
>
> - id = of_alias_get_id(np, "usbdp");
> - if (id < 0)
> - id = 0;
> - udphy->id = id;
> + ret = ofnode_read_u32_index(dev_ofnode(dev), "reg", 0, ®);
> + if (ret) {
> + dev_err(dev, "failed to read reg[0] property\n");
> + return ret;
> + }
> + if (reg == 0 && dev_read_addr_cells(dev) == 2) {
> + ret = ofnode_read_u32_index(dev_ofnode(dev), "reg", 1, ®);
> + if (ret) {
> + dev_err(dev, "failed to read reg[1] property\n");
> + return ret;
> + }
> + }
>
> phy_cfgs = (const struct rockchip_udphy_cfg *)dev_get_driver_data(dev);
> if (!phy_cfgs) {
> @@ -659,6 +669,20 @@ static int rockchip_udphy_probe(struct udevice *dev)
> }
> udphy->cfgs = phy_cfgs;
>
> + /* find the phy-id from the io address */
> + udphy->id = -ENODEV;
> + for (id = 0; id < udphy->cfgs->num_phys; id++) {
> + if (reg == udphy->cfgs->phy_ids[id]) {
> + udphy->id = id;
> + break;
> + }
> + }
> +
> + if (udphy->id < 0) {
> + dev_err(dev, "no matching device found\n");
> + return -ENODEV;
> + }
> +
> ret = regmap_init_mem(dev_ofnode(dev), &udphy->pma_regmap);
> if (ret)
> return ret;
> @@ -838,6 +862,11 @@ static const char * const rk3588_udphy_rst_l[] = {
> };
>
> static const struct rockchip_udphy_cfg rk3588_udphy_cfgs = {
> + .num_phys = 2,
> + .phy_ids = {
> + 0xfed80000,
> + 0xfed90000,
> + },
> .num_rsts = ARRAY_SIZE(rk3588_udphy_rst_l),
> .rst_list = rk3588_udphy_rst_l,
> .grfcfg = {
More information about the U-Boot
mailing list