summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2013-06-05 22:13:05 +0200
committerSascha Hauer <s.hauer@pengutronix.de>2013-06-17 10:16:46 +0200
commit310cb17470cb514600cc1cbc242adc9f02c2145a (patch)
treee00e87841cf5f2cb6b9b1183a7b716b76e526c10
parent0339fe1d37eb9aca688981b49f3e44e87a7aaf87 (diff)
downloadbarebox-310cb17470cb514600cc1cbc242adc9f02c2145a.tar.gz
barebox-310cb17470cb514600cc1cbc242adc9f02c2145a.tar.xz
usb: ulpi: Try more often to detect a phy
Some boards need some more tries to successfully detect a phy. This happens for example on the pcm038. Try up to four times to detect a phy. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
-rw-r--r--drivers/usb/otg/ulpi.c38
1 files changed, 26 insertions, 12 deletions
diff --git a/drivers/usb/otg/ulpi.c b/drivers/usb/otg/ulpi.c
index 19f64e0c76..e0aa201863 100644
--- a/drivers/usb/otg/ulpi.c
+++ b/drivers/usb/otg/ulpi.c
@@ -146,9 +146,9 @@ static struct ulpi_info ulpi_ids[] = {
ULPI_INFO(ULPI_ID(0x0424, 0x0006), "SMSC USB331x"),
};
-int ulpi_probe(void __iomem *view)
+static int ulpi_read_id(void __iomem *view, int *vid, int *pid)
{
- int i, vid, pid, ret;
+ int i, ret;
uint32_t ulpi_id = 0;
for (i = 0; i < 4; i++) {
@@ -157,20 +157,34 @@ int ulpi_probe(void __iomem *view)
return ret;
ulpi_id = (ulpi_id << 8) | ret;
}
- vid = ulpi_id & 0xffff;
- pid = ulpi_id >> 16;
-
- for (i = 0; i < ARRAY_SIZE(ulpi_ids); i++) {
- if (ulpi_ids[i].id == ULPI_ID(vid, pid)) {
- pr_info("Found %s ULPI transceiver (0x%04x:0x%04x).\n",
- ulpi_ids[i].name, vid, pid);
- return 0;
+
+ *vid = ulpi_id & 0xffff;
+ *pid = (ulpi_id >> 16) & 0xffff;
+
+ return 0;
+}
+
+int ulpi_probe(void __iomem *view)
+{
+ int i, j, vid, pid, ret;
+
+ for (i = 0; i < 4; i++) {
+ ret = ulpi_read_id(view, &vid, &pid);
+ if (ret)
+ return ret;
+
+ for (j = 0; j < ARRAY_SIZE(ulpi_ids); j++) {
+ if (ulpi_ids[j].id == ULPI_ID(vid, pid)) {
+ pr_info("Found %s ULPI transceiver (0x%04x:0x%04x).\n",
+ ulpi_ids[j].name, vid, pid);
+ return 0;
+ }
}
}
- pr_err("No ULPI found.\n");
+ pr_err("No ULPI found. vid: 0x%04x pid: 0x%04x\n", vid, pid);
- return -1;
+ return -ENODEV;
}
int ulpi_set_vbus(void __iomem *view, int on)