diff options
author | Huang Rui <ray.huang@amd.com> | 2013-10-03 11:37:12 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2013-10-03 18:44:50 -0400 |
commit | 3ad145b62a15c86150dd0cc229a39a3120d462f9 (patch) | |
tree | 2b0a5f63b7dd1cf5269dde34406861ebd5e8526c /drivers | |
parent | cccd3a258eef7a8451e25b7bf55503973de4e9f5 (diff) |
usb: ehci: use amd_chipset_type to filter for usb subsystem hang bug
Commit "usb: pci-quirks: refactor AMD quirk to abstract AMD chipset types"
introduced a new AMD chipset type to filter AMD platforms with different
chipsets.
According to a recent thread [1], this patch updates USB subsystem hang
symptom quirk which is observed on AMD all SB600 and SB700 revision
0x3a/0x3b. And make it use the new chipset type to represent.
[1] http://marc.info/?l=linux-usb&m=138012321616452&w=2
Signed-off-by: Huang Rui <ray.huang@amd.com>
Acked-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/usb/host/ehci-pci.c | 24 | ||||
-rw-r--r-- | drivers/usb/host/pci-quirks.c | 13 | ||||
-rw-r--r-- | drivers/usb/host/pci-quirks.h | 1 |
3 files changed, 20 insertions, 18 deletions
diff --git a/drivers/usb/host/ehci-pci.c b/drivers/usb/host/ehci-pci.c index 854c2ec7b699..3e86bf4371b3 100644 --- a/drivers/usb/host/ehci-pci.c +++ b/drivers/usb/host/ehci-pci.c | |||
@@ -58,8 +58,6 @@ static int ehci_pci_setup(struct usb_hcd *hcd) | |||
58 | { | 58 | { |
59 | struct ehci_hcd *ehci = hcd_to_ehci(hcd); | 59 | struct ehci_hcd *ehci = hcd_to_ehci(hcd); |
60 | struct pci_dev *pdev = to_pci_dev(hcd->self.controller); | 60 | struct pci_dev *pdev = to_pci_dev(hcd->self.controller); |
61 | struct pci_dev *p_smbus; | ||
62 | u8 rev; | ||
63 | u32 temp; | 61 | u32 temp; |
64 | int retval; | 62 | int retval; |
65 | 63 | ||
@@ -175,22 +173,12 @@ static int ehci_pci_setup(struct usb_hcd *hcd) | |||
175 | /* SB600 and old version of SB700 have a bug in EHCI controller, | 173 | /* SB600 and old version of SB700 have a bug in EHCI controller, |
176 | * which causes usb devices lose response in some cases. | 174 | * which causes usb devices lose response in some cases. |
177 | */ | 175 | */ |
178 | if ((pdev->device == 0x4386) || (pdev->device == 0x4396)) { | 176 | if ((pdev->device == 0x4386 || pdev->device == 0x4396) && |
179 | p_smbus = pci_get_device(PCI_VENDOR_ID_ATI, | 177 | usb_amd_hang_symptom_quirk()) { |
180 | PCI_DEVICE_ID_ATI_SBX00_SMBUS, | 178 | u8 tmp; |
181 | NULL); | 179 | ehci_info(ehci, "applying AMD SB600/SB700 USB freeze workaround\n"); |
182 | if (!p_smbus) | 180 | pci_read_config_byte(pdev, 0x53, &tmp); |
183 | break; | 181 | pci_write_config_byte(pdev, 0x53, tmp | (1<<3)); |
184 | rev = p_smbus->revision; | ||
185 | if ((pdev->device == 0x4386) || (rev == 0x3a) | ||
186 | || (rev == 0x3b)) { | ||
187 | u8 tmp; | ||
188 | ehci_info(ehci, "applying AMD SB600/SB700 USB " | ||
189 | "freeze workaround\n"); | ||
190 | pci_read_config_byte(pdev, 0x53, &tmp); | ||
191 | pci_write_config_byte(pdev, 0x53, tmp | (1<<3)); | ||
192 | } | ||
193 | pci_dev_put(p_smbus); | ||
194 | } | 182 | } |
195 | break; | 183 | break; |
196 | case PCI_VENDOR_ID_NETMOS: | 184 | case PCI_VENDOR_ID_NETMOS: |
diff --git a/drivers/usb/host/pci-quirks.c b/drivers/usb/host/pci-quirks.c index 9eec463c73c5..138a55536d97 100644 --- a/drivers/usb/host/pci-quirks.c +++ b/drivers/usb/host/pci-quirks.c | |||
@@ -262,6 +262,19 @@ int usb_hcd_amd_remote_wakeup_quirk(struct pci_dev *pdev) | |||
262 | } | 262 | } |
263 | EXPORT_SYMBOL_GPL(usb_hcd_amd_remote_wakeup_quirk); | 263 | EXPORT_SYMBOL_GPL(usb_hcd_amd_remote_wakeup_quirk); |
264 | 264 | ||
265 | bool usb_amd_hang_symptom_quirk(void) | ||
266 | { | ||
267 | u8 rev; | ||
268 | |||
269 | usb_amd_find_chipset_info(); | ||
270 | rev = amd_chipset.sb_type.rev; | ||
271 | /* SB600 and old version of SB700 have hang symptom bug */ | ||
272 | return amd_chipset.sb_type.gen == AMD_CHIPSET_SB600 || | ||
273 | (amd_chipset.sb_type.gen == AMD_CHIPSET_SB700 && | ||
274 | rev >= 0x3a && rev <= 0x3b); | ||
275 | } | ||
276 | EXPORT_SYMBOL_GPL(usb_amd_hang_symptom_quirk); | ||
277 | |||
265 | /* | 278 | /* |
266 | * The hardware normally enables the A-link power management feature, which | 279 | * The hardware normally enables the A-link power management feature, which |
267 | * lets the system lower the power consumption in idle states. | 280 | * lets the system lower the power consumption in idle states. |
diff --git a/drivers/usb/host/pci-quirks.h b/drivers/usb/host/pci-quirks.h index ed6700d00fe6..820f532f7c1c 100644 --- a/drivers/usb/host/pci-quirks.h +++ b/drivers/usb/host/pci-quirks.h | |||
@@ -5,6 +5,7 @@ | |||
5 | void uhci_reset_hc(struct pci_dev *pdev, unsigned long base); | 5 | void uhci_reset_hc(struct pci_dev *pdev, unsigned long base); |
6 | int uhci_check_and_reset_hc(struct pci_dev *pdev, unsigned long base); | 6 | int uhci_check_and_reset_hc(struct pci_dev *pdev, unsigned long base); |
7 | int usb_amd_find_chipset_info(void); | 7 | int usb_amd_find_chipset_info(void); |
8 | bool usb_amd_hang_symptom_quirk(void); | ||
8 | void usb_amd_dev_put(void); | 9 | void usb_amd_dev_put(void); |
9 | void usb_amd_quirk_pll_disable(void); | 10 | void usb_amd_quirk_pll_disable(void); |
10 | void usb_amd_quirk_pll_enable(void); | 11 | void usb_amd_quirk_pll_enable(void); |