We obviously need to mask off the interrupt threshold value before overwriting
it with our new setting. Otherwise we might end up with an illegal value as the interrupt threshold which might inhibit interrupt generation alltogether depending on the controller implementation. This was the case for the ATI/AMD SBx00 chipsets. Therefore fixes #5551. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@41690 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
fe81732aca
commit
c05a3fa6a7
@ -552,9 +552,14 @@ EHCI::Start()
|
|||||||
|
|
||||||
bool hasPerPortChangeEvent = (ReadCapReg32(EHCI_HCCPARAMS)
|
bool hasPerPortChangeEvent = (ReadCapReg32(EHCI_HCCPARAMS)
|
||||||
& EHCI_HCCPARAMS_PPCEC) != 0;
|
& EHCI_HCCPARAMS_PPCEC) != 0;
|
||||||
uint32 frameListSize = (ReadOpReg(EHCI_USBCMD) >> EHCI_USBCMD_FLS_SHIFT)
|
|
||||||
|
uint32 config = ReadOpReg(EHCI_USBCMD);
|
||||||
|
config &= ~((EHCI_USBCMD_ITC_MASK << EHCI_USBCMD_ITC_SHIFT)
|
||||||
|
| EHCI_USBCMD_PPCEE);
|
||||||
|
uint32 frameListSize = (config >> EHCI_USBCMD_FLS_SHIFT)
|
||||||
& EHCI_USBCMD_FLS_MASK;
|
& EHCI_USBCMD_FLS_MASK;
|
||||||
WriteOpReg(EHCI_USBCMD, ReadOpReg(EHCI_USBCMD) | EHCI_USBCMD_RUNSTOP
|
|
||||||
|
WriteOpReg(EHCI_USBCMD, config | EHCI_USBCMD_RUNSTOP
|
||||||
| (hasPerPortChangeEvent ? EHCI_USBCMD_PPCEE : 0)
|
| (hasPerPortChangeEvent ? EHCI_USBCMD_PPCEE : 0)
|
||||||
| EHCI_USBCMD_ASENABLE | EHCI_USBCMD_PSENABLE
|
| EHCI_USBCMD_ASENABLE | EHCI_USBCMD_PSENABLE
|
||||||
| (frameListSize << EHCI_USBCMD_FLS_SHIFT)
|
| (frameListSize << EHCI_USBCMD_FLS_SHIFT)
|
||||||
|
Loading…
Reference in New Issue
Block a user