Lines Matching refs:params

141 #define USB_CTRL_MASK_FAMILY(params, reg, field)			\  argument
142 (params->usb_reg_bits_map[USB_CTRL_##reg##_##field##_SELECTOR])
144 #define USB_CTRL_SET_FAMILY(params, reg, field) \ argument
145 usb_ctrl_set_family(params, USB_CTRL_##reg, \
147 #define USB_CTRL_UNSET_FAMILY(params, reg, field) \ argument
148 usb_ctrl_unset_family(params, USB_CTRL_##reg, \
445 void usb_ctrl_unset_family(struct brcm_usb_init_params *params, in usb_ctrl_unset_family() argument
450 mask = params->usb_reg_bits_map[field]; in usb_ctrl_unset_family()
451 brcm_usb_ctrl_unset(params->regs[BRCM_REGS_CTRL] + reg_offset, mask); in usb_ctrl_unset_family()
455 void usb_ctrl_set_family(struct brcm_usb_init_params *params, in usb_ctrl_set_family() argument
460 mask = params->usb_reg_bits_map[field]; in usb_ctrl_set_family()
461 brcm_usb_ctrl_set(params->regs[BRCM_REGS_CTRL] + reg_offset, mask); in usb_ctrl_set_family()
590 static void brcmusb_usb3_pll_54mhz(struct brcm_usb_init_params *params) in brcmusb_usb3_pll_54mhz() argument
594 void __iomem *ctrl_base = params->regs[BRCM_REGS_CTRL]; in brcmusb_usb3_pll_54mhz()
607 switch (params->selected_family) { in brcmusb_usb3_pll_54mhz()
618 if (BRCM_REV(params->family_id) < 0x20) in brcmusb_usb3_pll_54mhz()
674 static void brcmusb_usb3_phy_workarounds(struct brcm_usb_init_params *params) in brcmusb_usb3_phy_workarounds() argument
676 void __iomem *ctrl_base = params->regs[BRCM_REGS_CTRL]; in brcmusb_usb3_phy_workarounds()
679 brcmusb_usb3_pll_54mhz(params); in brcmusb_usb3_phy_workarounds()
687 static void brcmusb_memc_fix(struct brcm_usb_init_params *params) in brcmusb_memc_fix() argument
691 if (params->selected_family != BRCM_FAMILY_7445D0) in brcmusb_memc_fix()
704 prid = params->product_id & 0xfffff000; in brcmusb_memc_fix()
712 USB_CTRL_UNSET_FAMILY(params, SETUP, SCB2_EN); in brcmusb_memc_fix()
716 static void brcmusb_usb3_otp_fix(struct brcm_usb_init_params *params) in brcmusb_usb3_otp_fix() argument
718 void __iomem *xhci_ec_base = params->regs[BRCM_REGS_XHCI_EC]; in brcmusb_usb3_otp_fix()
721 if (params->family_id != 0x74371000 || !xhci_ec_base) in brcmusb_usb3_otp_fix()
731 USB_CTRL_UNSET(params->regs[BRCM_REGS_CTRL], USB30_CTL1, PHY3_RESETB); in brcmusb_usb3_otp_fix()
732 USB_CTRL_SET(params->regs[BRCM_REGS_CTRL], USB30_CTL1, PHY3_RESETB); in brcmusb_usb3_otp_fix()
735 static void brcmusb_xhci_soft_reset(struct brcm_usb_init_params *params, in brcmusb_xhci_soft_reset() argument
740 if (USB_CTRL_MASK_FAMILY(params, USB_PM, XHC_SOFT_RESETB)) in brcmusb_xhci_soft_reset()
741 USB_CTRL_UNSET_FAMILY(params, USB_PM, XHC_SOFT_RESETB); in brcmusb_xhci_soft_reset()
743 USB_CTRL_UNSET_FAMILY(params, in brcmusb_xhci_soft_reset()
746 if (USB_CTRL_MASK_FAMILY(params, USB_PM, XHC_SOFT_RESETB)) in brcmusb_xhci_soft_reset()
747 USB_CTRL_SET_FAMILY(params, USB_PM, XHC_SOFT_RESETB); in brcmusb_xhci_soft_reset()
749 USB_CTRL_SET_FAMILY(params, USB30_CTL1, in brcmusb_xhci_soft_reset()
762 struct brcm_usb_init_params *params) in get_family_type() argument
770 family = params->family_id & 0xfffffff0; in get_family_type()
771 family_no_major = params->family_id & 0xffffff00; in get_family_type()
789 static void usb_init_ipp(struct brcm_usb_init_params *params) in usb_init_ipp() argument
791 void __iomem *ctrl = params->regs[BRCM_REGS_CTRL]; in usb_init_ipp()
798 if (USB_CTRL_MASK_FAMILY(params, USB30_CTL1, USB3_IOC)) { in usb_init_ipp()
799 if (params->ioc) in usb_init_ipp()
800 USB_CTRL_SET_FAMILY(params, USB30_CTL1, USB3_IOC); in usb_init_ipp()
801 if (params->ipp == 1) in usb_init_ipp()
802 USB_CTRL_SET_FAMILY(params, USB30_CTL1, USB3_IPP); in usb_init_ipp()
807 if (USB_CTRL_MASK_FAMILY(params, SETUP, STRAP_CC_DRD_MODE_ENABLE_SEL)) in usb_init_ipp()
809 reg &= ~(USB_CTRL_MASK_FAMILY(params, in usb_init_ipp()
812 if (USB_CTRL_MASK_FAMILY(params, SETUP, STRAP_IPP_SEL)) in usb_init_ipp()
814 if (params->ipp != 2) in usb_init_ipp()
815 reg &= ~(USB_CTRL_MASK_FAMILY(params, SETUP, in usb_init_ipp()
820 if (params->ioc) in usb_init_ipp()
822 if (params->ipp == 1) in usb_init_ipp()
834 static void usb_wake_enable(struct brcm_usb_init_params *params, in usb_wake_enable() argument
837 void __iomem *ctrl = params->regs[BRCM_REGS_CTRL]; in usb_wake_enable()
845 static void usb_init_common(struct brcm_usb_init_params *params) in usb_init_common() argument
848 void __iomem *ctrl = params->regs[BRCM_REGS_CTRL]; in usb_init_common()
851 usb_wake_enable(params, false); in usb_init_common()
856 if (USB_CTRL_MASK_FAMILY(params, PLL_CTL, PLL_IDDQ_PWRDN)) { in usb_init_common()
857 USB_CTRL_UNSET_FAMILY(params, PLL_CTL, PLL_IDDQ_PWRDN); in usb_init_common()
862 if (USB_CTRL_MASK_FAMILY(params, USB_PM, USB_PWRDN)) { in usb_init_common()
863 USB_CTRL_UNSET_FAMILY(params, USB_PM, USB_PWRDN); in usb_init_common()
868 if (params->selected_family != BRCM_FAMILY_74371A0 && in usb_init_common()
869 (BRCM_ID(params->family_id) != 0x7364)) in usb_init_common()
874 USB_CTRL_SET_FAMILY(params, SETUP, SS_EHCI64BIT_EN); in usb_init_common()
880 if (params->selected_family == BRCM_FAMILY_7364A0) in usb_init_common()
882 reg |= USB_CTRL_MASK_FAMILY(params, SETUP, OC3_DISABLE); in usb_init_common()
891 if (USB_CTRL_MASK_FAMILY(params, SETUP, SCB1_EN)) in usb_init_common()
892 reg |= USB_CTRL_MASK_FAMILY(params, SETUP, SCB1_EN); in usb_init_common()
893 if (USB_CTRL_MASK_FAMILY(params, SETUP, SCB2_EN)) in usb_init_common()
894 reg |= USB_CTRL_MASK_FAMILY(params, SETUP, SCB2_EN); in usb_init_common()
897 brcmusb_memc_fix(params); in usb_init_common()
900 if ((params->family_id == 0x74390012) && in usb_init_common()
901 (params->supported_port_modes != USB_CTLR_MODE_HOST)) { in usb_init_common()
903 USB_CTRL_SET_FAMILY(params, SETUP, OC3_DISABLE_PORT1); in usb_init_common()
906 if (USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1, PORT_MODE)) { in usb_init_common()
908 reg &= ~USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1, in usb_init_common()
910 reg |= params->port_mode; in usb_init_common()
913 if (USB_CTRL_MASK_FAMILY(params, USB_PM, BDC_SOFT_RESETB)) { in usb_init_common()
914 switch (params->supported_port_modes) { in usb_init_common()
916 USB_CTRL_UNSET_FAMILY(params, USB_PM, BDC_SOFT_RESETB); in usb_init_common()
919 USB_CTRL_UNSET_FAMILY(params, USB_PM, BDC_SOFT_RESETB); in usb_init_common()
920 USB_CTRL_SET_FAMILY(params, USB_PM, BDC_SOFT_RESETB); in usb_init_common()
924 if (USB_CTRL_MASK_FAMILY(params, SETUP, CC_DRD_MODE_ENABLE)) { in usb_init_common()
925 if (params->supported_port_modes == USB_CTLR_MODE_TYPEC_PD) in usb_init_common()
926 USB_CTRL_SET_FAMILY(params, SETUP, CC_DRD_MODE_ENABLE); in usb_init_common()
928 USB_CTRL_UNSET_FAMILY(params, SETUP, in usb_init_common()
933 static void usb_init_eohci(struct brcm_usb_init_params *params) in usb_init_eohci() argument
936 void __iomem *ctrl = params->regs[BRCM_REGS_CTRL]; in usb_init_eohci()
938 if (USB_CTRL_MASK_FAMILY(params, USB_PM, USB20_HC_RESETB)) in usb_init_eohci()
939 USB_CTRL_SET_FAMILY(params, USB_PM, USB20_HC_RESETB); in usb_init_eohci()
941 if (params->selected_family == BRCM_FAMILY_7366C0) in usb_init_eohci()
951 reg |= USB_CTRL_MASK_FAMILY(params, SETUP, ENDIAN); in usb_init_eohci()
954 if (params->selected_family == BRCM_FAMILY_7271A0) in usb_init_eohci()
958 if (params->family_id == 0x72550000) { in usb_init_eohci()
970 static void usb_init_xhci(struct brcm_usb_init_params *params) in usb_init_xhci() argument
972 void __iomem *ctrl = params->regs[BRCM_REGS_CTRL]; in usb_init_xhci()
978 if (BRCM_ID(params->family_id) == 0x7366) { in usb_init_xhci()
993 brcmusb_usb3_phy_workarounds(params); in usb_init_xhci()
994 brcmusb_xhci_soft_reset(params, 0); in usb_init_xhci()
995 brcmusb_usb3_otp_fix(params); in usb_init_xhci()
998 static void usb_uninit_common(struct brcm_usb_init_params *params) in usb_uninit_common() argument
1000 if (USB_CTRL_MASK_FAMILY(params, USB_PM, USB_PWRDN)) in usb_uninit_common()
1001 USB_CTRL_SET_FAMILY(params, USB_PM, USB_PWRDN); in usb_uninit_common()
1003 if (USB_CTRL_MASK_FAMILY(params, PLL_CTL, PLL_IDDQ_PWRDN)) in usb_uninit_common()
1004 USB_CTRL_SET_FAMILY(params, PLL_CTL, PLL_IDDQ_PWRDN); in usb_uninit_common()
1005 if (params->wake_enabled) in usb_uninit_common()
1006 usb_wake_enable(params, true); in usb_uninit_common()
1009 static void usb_uninit_eohci(struct brcm_usb_init_params *params) in usb_uninit_eohci() argument
1013 static void usb_uninit_xhci(struct brcm_usb_init_params *params) in usb_uninit_xhci() argument
1015 brcmusb_xhci_soft_reset(params, 1); in usb_uninit_xhci()
1016 USB_CTRL_SET(params->regs[BRCM_REGS_CTRL], USB30_PCTL, in usb_uninit_xhci()
1020 static int usb_get_dual_select(struct brcm_usb_init_params *params) in usb_get_dual_select() argument
1022 void __iomem *ctrl = params->regs[BRCM_REGS_CTRL]; in usb_get_dual_select()
1026 if (USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1, PORT_MODE)) { in usb_get_dual_select()
1028 reg &= USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1, in usb_get_dual_select()
1034 static void usb_set_dual_select(struct brcm_usb_init_params *params) in usb_set_dual_select() argument
1036 void __iomem *ctrl = params->regs[BRCM_REGS_CTRL]; in usb_set_dual_select()
1041 if (USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1, PORT_MODE)) { in usb_set_dual_select()
1043 reg &= ~USB_CTRL_MASK_FAMILY(params, USB_DEVICE_CTL1, in usb_set_dual_select()
1045 reg |= params->port_mode; in usb_set_dual_select()
1062 void brcm_usb_dvr_init_4908(struct brcm_usb_init_params *params) in brcm_usb_dvr_init_4908() argument
1067 params->selected_family = fam; in brcm_usb_dvr_init_4908()
1068 params->usb_reg_bits_map = in brcm_usb_dvr_init_4908()
1070 params->family_name = family_names[fam]; in brcm_usb_dvr_init_4908()
1071 params->ops = &bcm7445_ops; in brcm_usb_dvr_init_4908()
1074 void brcm_usb_dvr_init_7445(struct brcm_usb_init_params *params) in brcm_usb_dvr_init_7445() argument
1080 fam = get_family_type(params); in brcm_usb_dvr_init_7445()
1081 params->selected_family = fam; in brcm_usb_dvr_init_7445()
1082 params->usb_reg_bits_map = in brcm_usb_dvr_init_7445()
1084 params->family_name = family_names[fam]; in brcm_usb_dvr_init_7445()
1085 params->ops = &bcm7445_ops; in brcm_usb_dvr_init_7445()