提交 98cae42d 编写于 作者: A Alan Stern 提交者: Greg Kroah-Hartman

EHCI: use the isochronous scheduling threshold

This patch (as1609) changes the way ehci-hcd uses the "Isochronous
Scheduling Threshold" in its calculations.  Until now the code has
ignored the threshold except for certain Intel PCI-based controllers.
This violates the EHCI spec.

The new code takes the threshold into account always, removing the
need for the fs_i_thresh quirk flag.  In addition it implements the
"full frame cache" setting more efficiently, moving forward only as
far as the next frame boundary instead of always moving forward 8
microframes.
Signed-off-by: NAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 c3ee9b76
...@@ -503,7 +503,7 @@ static int ehci_init(struct usb_hcd *hcd) ...@@ -503,7 +503,7 @@ static int ehci_init(struct usb_hcd *hcd)
/* controllers may cache some of the periodic schedule ... */ /* controllers may cache some of the periodic schedule ... */
if (HCC_ISOC_CACHE(hcc_params)) // full frame cache if (HCC_ISOC_CACHE(hcc_params)) // full frame cache
ehci->i_thresh = 2 + 8; ehci->i_thresh = 0;
else // N microframes cached else // N microframes cached
ehci->i_thresh = 2 + HCC_ISOC_THRES(hcc_params); ehci->i_thresh = 2 + HCC_ISOC_THRES(hcc_params);
......
...@@ -103,7 +103,6 @@ static int ehci_pci_setup(struct usb_hcd *hcd) ...@@ -103,7 +103,6 @@ static int ehci_pci_setup(struct usb_hcd *hcd)
} }
break; break;
case PCI_VENDOR_ID_INTEL: case PCI_VENDOR_ID_INTEL:
ehci->fs_i_thresh = 1;
if (pdev->device == PCI_DEVICE_ID_INTEL_CE4100_USB) if (pdev->device == PCI_DEVICE_ID_INTEL_CE4100_USB)
hcd->has_tt = 1; hcd->has_tt = 1;
break; break;
......
...@@ -1391,15 +1391,11 @@ iso_stream_schedule ( ...@@ -1391,15 +1391,11 @@ iso_stream_schedule (
*/ */
if (likely (!list_empty (&stream->td_list))) { if (likely (!list_empty (&stream->td_list))) {
/* For high speed devices, allow scheduling within the /* Take the isochronous scheduling threshold into account */
* isochronous scheduling threshold. For full speed devices if (ehci->i_thresh)
* and Intel PCI-based controllers, don't (work around for next = now + ehci->i_thresh; /* uframe cache */
* Intel ICH9 bug).
*/
if (!stream->highspeed && ehci->fs_i_thresh)
next = now + ehci->i_thresh;
else else
next = now; next = (now + 2 + 7) & ~0x07; /* full frame cache */
/* /*
* Use ehci->last_iso_frame as the base. There can't be any * Use ehci->last_iso_frame as the base. There can't be any
......
...@@ -193,7 +193,6 @@ struct ehci_hcd { /* one per controller */ ...@@ -193,7 +193,6 @@ struct ehci_hcd { /* one per controller */
unsigned has_amcc_usb23:1; unsigned has_amcc_usb23:1;
unsigned need_io_watchdog:1; unsigned need_io_watchdog:1;
unsigned amd_pll_fix:1; unsigned amd_pll_fix:1;
unsigned fs_i_thresh:1; /* Intel iso scheduling */
unsigned use_dummy_qh:1; /* AMD Frame List table quirk*/ unsigned use_dummy_qh:1; /* AMD Frame List table quirk*/
unsigned has_synopsys_hc_bug:1; /* Synopsys HC */ unsigned has_synopsys_hc_bug:1; /* Synopsys HC */
unsigned frame_index_bug:1; /* MosChip (AKA NetMos) */ unsigned frame_index_bug:1; /* MosChip (AKA NetMos) */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册