Re: [PATCH 10/16] phy: rockchip: usbdp: Find phy-id from the io address

2024-05-06 Thread Kever Yang



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 

Reviewed-by: Kever Yang 

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), >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 = {
+   0xfed8,
+   0xfed9,
+   },
.num_rsts = ARRAY_SIZE(rk3588_udphy_rst_l),
.rst_list = rk3588_udphy_rst_l,
.grfcfg = {


[PATCH 10/16] phy: rockchip: usbdp: Find phy-id from the io address

2024-05-04 Thread Jonas Karlman
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 
---
 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), >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 = {
+   0xfed8,
+   0xfed9,
+   },
.num_rsts = ARRAY_SIZE(rk3588_udphy_rst_l),
.rst_list = rk3588_udphy_rst_l,
.grfcfg = {
-- 
2.43.2