ソースを参照

usb: musb: dsps: fix the base address for accessing the mode register

commit 943c13971c08 "usb: musb: dsps: implement ->set_mode()"
should have made it possible to use the driver with boards that have
the USBID pin unconnected. This doesn't actually work, since the
driver uses the wrong base address to access the mode register.
Furthermore it uses different base addresses in different places to
access the same register (phy_utmi).

Signed-off-by: Lothar Waßmann <LW@KARO-electronics.de>
Signed-off-by: Felipe Balbi <balbi@ti.com>
Lothar Waßmann 11 年 前
コミット
8035691365
1 ファイル変更4 行追加5 行削除
  1. 4 5
      drivers/usb/musb/musb_dsps.c

+ 4 - 5
drivers/usb/musb/musb_dsps.c

@@ -494,10 +494,9 @@ static int dsps_musb_set_mode(struct musb *musb, u8 mode)
 	struct dsps_glue *glue = dev_get_drvdata(dev->parent);
 	struct dsps_glue *glue = dev_get_drvdata(dev->parent);
 	const struct dsps_musb_wrapper *wrp = glue->wrp;
 	const struct dsps_musb_wrapper *wrp = glue->wrp;
 	void __iomem *ctrl_base = musb->ctrl_base;
 	void __iomem *ctrl_base = musb->ctrl_base;
-	void __iomem *base = musb->mregs;
 	u32 reg;
 	u32 reg;
 
 
-	reg = dsps_readl(base, wrp->mode);
+	reg = dsps_readl(ctrl_base, wrp->mode);
 
 
 	switch (mode) {
 	switch (mode) {
 	case MUSB_HOST:
 	case MUSB_HOST:
@@ -510,7 +509,7 @@ static int dsps_musb_set_mode(struct musb *musb, u8 mode)
 		 */
 		 */
 		reg |= (1 << wrp->iddig_mux);
 		reg |= (1 << wrp->iddig_mux);
 
 
-		dsps_writel(base, wrp->mode, reg);
+		dsps_writel(ctrl_base, wrp->mode, reg);
 		dsps_writel(ctrl_base, wrp->phy_utmi, 0x02);
 		dsps_writel(ctrl_base, wrp->phy_utmi, 0x02);
 		break;
 		break;
 	case MUSB_PERIPHERAL:
 	case MUSB_PERIPHERAL:
@@ -523,10 +522,10 @@ static int dsps_musb_set_mode(struct musb *musb, u8 mode)
 		 */
 		 */
 		reg |= (1 << wrp->iddig_mux);
 		reg |= (1 << wrp->iddig_mux);
 
 
-		dsps_writel(base, wrp->mode, reg);
+		dsps_writel(ctrl_base, wrp->mode, reg);
 		break;
 		break;
 	case MUSB_OTG:
 	case MUSB_OTG:
-		dsps_writel(base, wrp->phy_utmi, 0x02);
+		dsps_writel(ctrl_base, wrp->phy_utmi, 0x02);
 		break;
 		break;
 	default:
 	default:
 		dev_err(glue->dev, "unsupported mode %d\n", mode);
 		dev_err(glue->dev, "unsupported mode %d\n", mode);