public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* linux-2.6.0-test2: Never using pm_idle (CPU wasting power)
@ 2003-07-31 13:07 Christian Vogel
  2003-07-31 14:12 ` Charles Lepple
                   ` (2 more replies)
  0 siblings, 3 replies; 8+ messages in thread
From: Christian Vogel @ 2003-07-31 13:07 UTC (permalink / raw)
  To: linux-kernel

Hi,

on a Thinkpad 600X I noticed the CPU getting very hot. It turned
out that pm_idle was never called (which invokes the ACPI pm_idle
call in this case) and default_idle was used instead.

	/* arch/i386/kernel/process.c, line 723 */
	void cpu_idle (void)
	{
		/* endless idle loop with no priority at all */
		while (1) {
			void (*idle)(void) = pm_idle;
			if (!idle)
				idle = default_idle; /* once on bootup */
			irq_stat[smp_processor_id()].idle_timestamp = jiffies;
			while (!need_resched())
				idle();
			schedule();  /* never reached */
		}
	}

The schedule() is never reached (need_resched() is never 0) and
so the idle-variable is not updated. pm_idle is NULL on the
first call to cpu_idle on this thinkpad, and so I stay idling
in the default_idle()-function.

By moving the "void *idle = pm_idle; if(!idle)..." in the inner
while()-loop the notebook calls pm_idle (as it get's updated by ACPI)
and stays cool.

	Chris

-- 
Programming today is a race between software engineers striving to build
bigger and better idiot-proof programs, and the Universe trying to
produce bigger and better idiots.  So far, the Universe is winning.
 -- Rich Cook

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2003-08-01  9:18 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-07-31 13:07 linux-2.6.0-test2: Never using pm_idle (CPU wasting power) Christian Vogel
2003-07-31 14:12 ` Charles Lepple
2003-07-31 14:44   ` Christian Vogel
2003-07-31 22:45 ` Roger Larsson
2003-07-31 22:58   ` Robert Love
2003-07-31 23:26     ` Robert Love
2003-07-31 22:59 ` Andrew Morton
2003-08-01  9:18   ` Christian Vogel

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox