aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/acpi/processor_idle.c
diff options
context:
space:
mode:
authorDominik Brodowski <linux@dominikbrodowski.net>2006-06-24 19:37:00 -0400
committerLen Brown <len.brown@intel.com>2006-06-28 03:14:50 -0400
commitc4a001b1ea32e09f7556178249b8885418858b5c (patch)
tree29abe5b8088968cdc28de3bd6888d05366f2478a /drivers/acpi/processor_idle.c
parentc5ab81ca01ad4a8870b456f93dd2fb3d815f91d9 (diff)
ACPI: C-States: only demote on current bus mastering activity
Only if bus master activity is going on at the present, we should avoid entering C3-type sleep, as it might be a faulty transition. As long as the bm_activity bitmask was based on the number of calls to the ACPI idle function, looking at previous moments made sense. Now, with it being based on what happened this jiffy, looking at this jiffy should be sufficient. Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers/acpi/processor_idle.c')
-rw-r--r--drivers/acpi/processor_idle.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c
index af9f2afd72da..f8d2b2f47fd4 100644
--- a/drivers/acpi/processor_idle.c
+++ b/drivers/acpi/processor_idle.c
@@ -287,10 +287,10 @@ static void acpi_processor_idle(void)
287 pr->power.bm_check_timestamp = jiffies; 287 pr->power.bm_check_timestamp = jiffies;
288 288
289 /* 289 /*
290 * Apply bus mastering demotion policy. Automatically demote 290 * If bus mastering is or was active this jiffy, demote
291 * to avoid a faulty transition. Note that the processor 291 * to avoid a faulty transition. Note that the processor
292 * won't enter a low-power state during this call (to this 292 * won't enter a low-power state during this call (to this
293 * funciton) but should upon the next. 293 * function) but should upon the next.
294 * 294 *
295 * TBD: A better policy might be to fallback to the demotion 295 * TBD: A better policy might be to fallback to the demotion
296 * state (use it for this quantum only) istead of 296 * state (use it for this quantum only) istead of
@@ -298,7 +298,8 @@ static void acpi_processor_idle(void)
298 * qualification. This may, however, introduce DMA 298 * qualification. This may, however, introduce DMA
299 * issues (e.g. floppy DMA transfer overrun/underrun). 299 * issues (e.g. floppy DMA transfer overrun/underrun).
300 */ 300 */
301 if (pr->power.bm_activity & cx->demotion.threshold.bm) { 301 if ((pr->power.bm_activity & 0x1) &&
302 cx->demotion.threshold.bm) {
302 local_irq_enable(); 303 local_irq_enable();
303 next_state = cx->demotion.state; 304 next_state = cx->demotion.state;
304 goto end; 305 goto end;