usb/mtu3: power down device ip at setup
authorHsin-Yi, Wang <hsinyi@chromium.org>
Thu, 29 Nov 2018 03:16:27 +0000 (11:16 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 5 Dec 2018 09:13:39 +0000 (10:13 +0100)
Originally, when dr_mode is USB_DR_MODE_HOST, it didn't power down device ip,
so host ip sleep will fail at ssusb_host_disable.

Power down device ip at ssusb_host_setup.

Signed-off-by: Hsin-Yi, Wang <hsinyi@chromium.org>
Acked-by: Chunfeng Yun <chunfeng.yun@mediatek.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/mtu3/mtu3_plat.c

index 46551f6d16fd0459baca61a0a31a87b55cb36a63..e086630e41a906b0dc8d2cdf6d17a48d8f95b1bc 100644 (file)
@@ -200,6 +200,14 @@ static void ssusb_ip_sw_reset(struct ssusb_mtk *ssusb)
        mtu3_setbits(ssusb->ippc_base, U3D_SSUSB_IP_PW_CTRL0, SSUSB_IP_SW_RST);
        udelay(1);
        mtu3_clrbits(ssusb->ippc_base, U3D_SSUSB_IP_PW_CTRL0, SSUSB_IP_SW_RST);
+
+       /*
+        * device ip may be powered on in firmware/BROM stage before entering
+        * kernel stage;
+        * power down device ip, otherwise ip-sleep will fail when working as
+        * host only mode
+        */
+       mtu3_setbits(ssusb->ippc_base, U3D_SSUSB_IP_PW_CTRL2, SSUSB_IP_DEV_PDN);
 }
 
 /* ignore the error if the clock does not exist */