diff options
author | Alan Stern <stern@rowland.harvard.edu> | 2012-07-11 11:21:48 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-07-16 19:50:14 -0400 |
commit | c0c53dbc32ea05a1e1dd9dba4772327da9a11750 (patch) | |
tree | c292857a1d2c6e1c4b16bb08649df71fd92178e2 /drivers/usb/host/ehci-sched.c | |
parent | 2f5bb665ba7a14c5842fa2e1cde2be039843a2a2 (diff) |
USB: EHCI: add new root-hub state: STOPPING
This patch (as1571) adds a new state for ehci-hcd's root hubs:
EHCI_RH_STOPPING. This value is used at times when the root hub is
being stopped and we don't know whether or not the hardware has
finished all its DMA yet.
Although the purpose may not be apparent, this distinction will come
in useful later on. Future patches will avoid actions that depend on
the root hub being operational (like turning on the async or periodic
schedules) when they see the state is EHCI_RH_STOPPING.
Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/host/ehci-sched.c')
-rw-r--r-- | drivers/usb/host/ehci-sched.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/drivers/usb/host/ehci-sched.c b/drivers/usb/host/ehci-sched.c index 027df3de2dc9..3429b8a33c58 100644 --- a/drivers/usb/host/ehci-sched.c +++ b/drivers/usb/host/ehci-sched.c | |||
@@ -2299,7 +2299,7 @@ scan_periodic (struct ehci_hcd *ehci) | |||
2299 | * Touches as few pages as possible: cache-friendly. | 2299 | * Touches as few pages as possible: cache-friendly. |
2300 | */ | 2300 | */ |
2301 | now_uframe = ehci->next_uframe; | 2301 | now_uframe = ehci->next_uframe; |
2302 | if (ehci->rh_state == EHCI_RH_RUNNING) { | 2302 | if (ehci->rh_state >= EHCI_RH_RUNNING) { |
2303 | clock = ehci_read_frame_index(ehci); | 2303 | clock = ehci_read_frame_index(ehci); |
2304 | clock_frame = (clock >> 3) & (ehci->periodic_size - 1); | 2304 | clock_frame = (clock >> 3) & (ehci->periodic_size - 1); |
2305 | } else { | 2305 | } else { |
@@ -2334,7 +2334,7 @@ restart: | |||
2334 | union ehci_shadow temp; | 2334 | union ehci_shadow temp; |
2335 | int live; | 2335 | int live; |
2336 | 2336 | ||
2337 | live = (ehci->rh_state == EHCI_RH_RUNNING); | 2337 | live = (ehci->rh_state >= EHCI_RH_RUNNING); |
2338 | switch (hc32_to_cpu(ehci, type)) { | 2338 | switch (hc32_to_cpu(ehci, type)) { |
2339 | case Q_TYPE_QH: | 2339 | case Q_TYPE_QH: |
2340 | /* handle any completions */ | 2340 | /* handle any completions */ |
@@ -2459,7 +2459,7 @@ restart: | |||
2459 | * We can't advance our scan without collecting the ISO | 2459 | * We can't advance our scan without collecting the ISO |
2460 | * transfers that are still pending in this frame. | 2460 | * transfers that are still pending in this frame. |
2461 | */ | 2461 | */ |
2462 | if (incomplete && ehci->rh_state == EHCI_RH_RUNNING) { | 2462 | if (incomplete && ehci->rh_state >= EHCI_RH_RUNNING) { |
2463 | ehci->next_uframe = now_uframe; | 2463 | ehci->next_uframe = now_uframe; |
2464 | break; | 2464 | break; |
2465 | } | 2465 | } |
@@ -2475,7 +2475,7 @@ restart: | |||
2475 | if (now_uframe == clock) { | 2475 | if (now_uframe == clock) { |
2476 | unsigned now; | 2476 | unsigned now; |
2477 | 2477 | ||
2478 | if (ehci->rh_state != EHCI_RH_RUNNING | 2478 | if (ehci->rh_state < EHCI_RH_RUNNING |
2479 | || ehci->periodic_sched == 0) | 2479 | || ehci->periodic_sched == 0) |
2480 | break; | 2480 | break; |
2481 | ehci->next_uframe = now_uframe; | 2481 | ehci->next_uframe = now_uframe; |