phy: usb: suppress OC condition for 7439b2
authorJustin Chen <justin.chen@broadcom.com>
Thu, 15 Jun 2023 20:06:17 +0000 (13:06 -0700)
committerVinod Koul <vkoul@kernel.org>
Wed, 21 Jun 2023 12:13:27 +0000 (17:43 +0530)
We hit a false positive OC for 7439b2 in DRD/device mode for the
second port. So disable the OC check for this use case. Add capability
to suppress OC condition for specific ports.

Signed-off-by: Justin Chen <justin.chen@broadcom.com>
Reviewed-by: Florian Fainelli <florian.fainelli@broadcom.com>
Link: https://lore.kernel.org/r/1686859578-45242-3-git-send-email-justin.chen@broadcom.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/phy/broadcom/phy-brcm-usb-init.c

index a1ca833..39536b6 100644 (file)
 #define   USB_CTRL_SETUP_STRAP_IPP_SEL_MASK            BIT(25) /* option */
 #define   USB_CTRL_SETUP_CC_DRD_MODE_ENABLE_MASK       BIT(26) /* option */
 #define   USB_CTRL_SETUP_STRAP_CC_DRD_MODE_ENABLE_SEL_MASK BIT(27) /* opt */
+#define   USB_CTRL_SETUP_OC_DISABLE_PORT0_MASK         BIT(28)
+#define   USB_CTRL_SETUP_OC_DISABLE_PORT1_MASK         BIT(29)
+#define   USB_CTRL_SETUP_OC_DISABLE_MASK               GENMASK(29, 28) /* option */
+#define   USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK                BIT(30)
+#define   USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK                BIT(31)
 #define   USB_CTRL_SETUP_OC3_DISABLE_MASK              GENMASK(31, 30) /* option */
 #define USB_CTRL_PLL_CTL               0x04
 #define   USB_CTRL_PLL_CTL_PLL_SUSPEND_EN_MASK         BIT(27)
@@ -114,6 +119,8 @@ enum {
        USB_CTRL_SETUP_SCB2_EN_SELECTOR,
        USB_CTRL_SETUP_SS_EHCI64BIT_EN_SELECTOR,
        USB_CTRL_SETUP_STRAP_IPP_SEL_SELECTOR,
+       USB_CTRL_SETUP_OC3_DISABLE_PORT0_SELECTOR,
+       USB_CTRL_SETUP_OC3_DISABLE_PORT1_SELECTOR,
        USB_CTRL_SETUP_OC3_DISABLE_SELECTOR,
        USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_SELECTOR,
        USB_CTRL_USB_PM_BDC_SOFT_RESETB_SELECTOR,
@@ -190,6 +197,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                USB_CTRL_SETUP_SCB2_EN_MASK,
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK,
                USB_CTRL_SETUP_STRAP_IPP_SEL_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                0, /* USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK */
                0, /* USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK */
@@ -232,6 +241,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                USB_CTRL_SETUP_SCB2_EN_MASK,
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK,
                0, /* USB_CTRL_SETUP_STRAP_IPP_SEL_MASK */
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK,
                0, /* USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK */
@@ -253,6 +264,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                0, /* USB_CTRL_SETUP_SCB2_EN_MASK */
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK,
                USB_CTRL_SETUP_STRAP_IPP_SEL_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                0, /* USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK */
                USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK,
@@ -274,6 +287,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                USB_CTRL_SETUP_SCB2_EN_MASK,
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK,
                0, /* USB_CTRL_SETUP_STRAP_IPP_SEL_MASK */
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK,
                0, /* USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK */
@@ -295,6 +310,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                USB_CTRL_SETUP_SCB2_EN_MASK,
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK,
                0, /* USB_CTRL_SETUP_STRAP_IPP_SEL_MASK */
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                0, /* USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK */
                0, /* USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK */
@@ -316,6 +333,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                USB_CTRL_SETUP_SCB2_EN_MASK,
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_VAR_MASK,
                0, /* USB_CTRL_SETUP_STRAP_IPP_SEL_MASK */
+               0, /* USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK */
+               0, /* USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK */
                0, /* USB_CTRL_SETUP_OC3_DISABLE_MASK */
                USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK,
                0, /* USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK */
@@ -337,6 +356,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                USB_CTRL_SETUP_SCB2_EN_MASK,
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK,
                USB_CTRL_SETUP_STRAP_IPP_SEL_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                0, /* USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK */
                USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK,
@@ -358,6 +379,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                USB_CTRL_SETUP_SCB2_EN_MASK,
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_VAR_MASK,
                0, /* USB_CTRL_SETUP_STRAP_IPP_SEL_MASK */
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK,
                0, /* USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK */
@@ -379,6 +402,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                0, /* USB_CTRL_SETUP_SCB2_EN_MASK */
                USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK,
                USB_CTRL_SETUP_STRAP_IPP_SEL_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                0, /* USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK */
                USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK,
@@ -400,6 +425,8 @@ usb_reg_bits_map_table[BRCM_FAMILY_COUNT][USB_CTRL_SELECTOR_COUNT] = {
                0, /* USB_CTRL_SETUP_SCB2_EN_MASK */
                0, /*USB_CTRL_SETUP_SS_EHCI64BIT_EN_MASK */
                USB_CTRL_SETUP_STRAP_IPP_SEL_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT0_MASK,
+               USB_CTRL_SETUP_OC3_DISABLE_PORT1_MASK,
                USB_CTRL_SETUP_OC3_DISABLE_MASK,
                0, /* USB_CTRL_PLL_CTL_PLL_IDDQ_PWRDN_MASK */
                USB_CTRL_USB_PM_BDC_SOFT_RESETB_MASK,
@@ -872,6 +899,13 @@ static void usb_init_common(struct brcm_usb_init_params *params)
 
        brcmusb_memc_fix(params);
 
+       /* Workaround for false positive OC for 7439b2 in DRD/Device mode */
+       if ((params->family_id == 0x74390012) &&
+           (params->supported_port_modes != USB_CTLR_MODE_HOST)) {
+               USB_CTRL_SET(ctrl, SETUP, OC_DISABLE_PORT1);
+               USB_CTRL_SET_FAMILY(params, SETUP, OC3_DISABLE_PORT1);
+       }
+
        if (USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1, PORT_MODE)) {
                reg = brcm_usb_readl(USB_CTRL_REG(ctrl, USB_DEVICE_CTL1));
                reg &= ~USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1,