|
@@ -151,6 +151,7 @@ int ssusb_host_enable(struct ssusb_mtk *ssusb)
|
|
|
void __iomem *ibase = ssusb->ippc_base;
|
|
|
int num_u3p = ssusb->u3_ports;
|
|
|
int num_u2p = ssusb->u2_ports;
|
|
|
+ int u3_ports_disabed;
|
|
|
u32 check_clk;
|
|
|
u32 value;
|
|
|
int i;
|
|
@@ -158,8 +159,14 @@ int ssusb_host_enable(struct ssusb_mtk *ssusb)
|
|
|
/* power on host ip */
|
|
|
mtu3_clrbits(ibase, U3D_SSUSB_IP_PW_CTRL1, SSUSB_IP_HOST_PDN);
|
|
|
|
|
|
- /* power on and enable all u3 ports */
|
|
|
+ /* power on and enable u3 ports except skipped ones */
|
|
|
+ u3_ports_disabed = 0;
|
|
|
for (i = 0; i < num_u3p; i++) {
|
|
|
+ if ((0x1 << i) & ssusb->u3p_dis_msk) {
|
|
|
+ u3_ports_disabed++;
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+
|
|
|
value = mtu3_readl(ibase, SSUSB_U3_CTRL(i));
|
|
|
value &= ~(SSUSB_U3_PORT_PDN | SSUSB_U3_PORT_DIS);
|
|
|
value |= SSUSB_U3_PORT_HOST_SEL;
|
|
@@ -175,7 +182,7 @@ int ssusb_host_enable(struct ssusb_mtk *ssusb)
|
|
|
}
|
|
|
|
|
|
check_clk = SSUSB_XHCI_RST_B_STS;
|
|
|
- if (num_u3p)
|
|
|
+ if (num_u3p > u3_ports_disabed)
|
|
|
check_clk = SSUSB_U3_MAC_RST_B_STS;
|
|
|
|
|
|
return ssusb_check_clocks(ssusb, check_clk);
|
|
@@ -190,8 +197,11 @@ int ssusb_host_disable(struct ssusb_mtk *ssusb, bool suspend)
|
|
|
int ret;
|
|
|
int i;
|
|
|
|
|
|
- /* power down and disable all u3 ports */
|
|
|
+ /* power down and disable u3 ports except skipped ones */
|
|
|
for (i = 0; i < num_u3p; i++) {
|
|
|
+ if ((0x1 << i) & ssusb->u3p_dis_msk)
|
|
|
+ continue;
|
|
|
+
|
|
|
value = mtu3_readl(ibase, SSUSB_U3_CTRL(i));
|
|
|
value |= SSUSB_U3_PORT_PDN;
|
|
|
value |= suspend ? 0 : SSUSB_U3_PORT_DIS;
|