Low power software + high power hardware = high power dissipation?

  • Thread starter Thread starter blackhead
  • Start date Start date
B

blackhead

Suppose you have Word2000 which happily ran on a PentiumII/AMD socket
7 system and you now put it on a high powered system with exactly the
same operating system and software installed. The power dissipation is
higher and all because the software is being run faster when it
doesn't need to be. Whereas in the past it might check for a user
response from the mouse or keyboard y times a second, now it's x*y
where x is how much much faster the system is. It's ridiculous, isn't
it?

Is this problem being confronted now, so that software has a speed
rating for all its modues that define how fast they are needed to run?

Module responses requiring user input via the mouse or keyboard might
have a rating of 20 cycles per second, whereas the module that spools
a file for a printer could be done as fast as possible since it is
done only once and doesn't recycle. This way, as systems become
faster, they become more efficient by going into sleep or idle mode
when a module doesn't require servicing yet.

Interested in your views
 
Suppose you have Word2000 which happily ran on a PentiumII/AMD socket
7 system and you now put it on a high powered system with exactly the
same operating system and software installed. The power dissipation is
higher and all because the software is being run faster when it
doesn't need to be. Whereas in the past it might check for a user
response from the mouse or keyboard y times a second, now it's x*y
where x is how much much faster the system is. It's ridiculous, isn't
it?

Is this problem being confronted now, so that software has a speed
rating for all its modues that define how fast they are needed to run?

AFAIK no.
Module responses requiring user input via the mouse or keyboard might
have a rating of 20 cycles per second, whereas the module that spools
a file for a printer could be done as fast as possible since it is
done only once and doesn't recycle. This way, as systems become
faster, they become more efficient by going into sleep or idle mode
when a module doesn't require servicing yet.

Interested in your views

See AMD Cool 'n' Quiet:
http://www.amd.com/us-
en/Processors/ProductInformation/0,,30_118_9485_9487%5E10272,00.html
 
blackhead said:
Suppose you have Word2000 which happily ran on a PentiumII/AMD socket
7 system and you now put it on a high powered system with exactly the
same operating system and software installed. The power dissipation is
higher and all because the software is being run faster when it
doesn't need to be. Whereas in the past it might check for a user
response from the mouse or keyboard y times a second, now it's x*y
where x is how much much faster the system is. It's ridiculous, isn't
it?

Is this problem being confronted now, so that software has a speed
rating for all its modues that define how fast they are needed to run?

Module responses requiring user input via the mouse or keyboard might
have a rating of 20 cycles per second, whereas the module that spools
a file for a printer could be done as fast as possible since it is
done only once and doesn't recycle. This way, as systems become
faster, they become more efficient by going into sleep or idle mode
when a module doesn't require servicing yet.

Interested in your views
Cool and Quiet (AMD) & Speedstep (INTEL), Google is your friend. Both
programs reduce the power consumption when full performance not required.

Mike.
 
Suppose you have Word2000 which happily ran on a PentiumII/AMD socket
7 system and you now put it on a high powered system with exactly the
same operating system and software installed. The power dissipation is
higher and all because the software is being run faster when it
doesn't need to be. Whereas in the past it might check for a user
response from the mouse or keyboard y times a second, now it's x*y
where x is how much much faster the system is. It's ridiculous, isn't
it?

The I/O devices are usually interrupt driven, not polled.
Is this problem being confronted now, so that software has a speed
rating for all its modues that define how fast they are needed to run?

Module responses requiring user input via the mouse or keyboard might
have a rating of 20 cycles per second, whereas the module that spools
a file for a printer could be done as fast as possible since it is
done only once and doesn't recycle. This way, as systems become
faster, they become more efficient by going into sleep or idle mode
when a module doesn't require servicing yet.

Interested in your views

As has already been suggested, try one of these power saving
technologies:

http://en.wikipedia.org/wiki/Cool'n'Quiet
http://en.wikipedia.org/wiki/PowerNow!
http://en.wikipedia.org/wiki/SpeedStep

Or for your socket 7 box try a CPU cooler utility such as CPUidle,
Rain, Waterfall.

- Franc Zabkar
 
blackhead said:
Suppose you have Word2000 which happily ran on a PentiumII/AMD socket
7 system and you now put it on a high powered system with exactly the
same operating system and software installed. The power dissipation is
higher and all because the software is being run faster when it
doesn't need to be. Whereas in the past it might check for a user
response from the mouse or keyboard y times a second, now it's x*y
where x is how much much faster the system is. It's ridiculous, isn't
it?

Is this problem being confronted now, so that software has a speed
rating for all its modues that define how fast they are needed to run?

Module responses requiring user input via the mouse or keyboard might
have a rating of 20 cycles per second, whereas the module that spools
a file for a printer could be done as fast as possible since it is
done only once and doesn't recycle. This way, as systems become
faster, they become more efficient by going into sleep or idle mode
when a module doesn't require servicing yet.

Interested in your views

Obviously, engineers at Intel & AMD had thought about this way before you
did.
 
blackhead said:
Suppose you have Word2000 which happily ran on a PentiumII/AMD socket
7 system and you now put it on a high powered system with exactly the
same operating system and software installed. The power dissipation is
higher and all because the software is being run faster when it
doesn't need to be. Whereas in the past it might check for a user
response from the mouse or keyboard y times a second, now it's x*y
where x is how much much faster the system is. It's ridiculous, isn't
it?

Is this problem being confronted now, so that software has a speed
rating for all its modues that define how fast they are needed to run?

Module responses requiring user input via the mouse or keyboard might
have a rating of 20 cycles per second, whereas the module that spools
a file for a printer could be done as fast as possible since it is
done only once and doesn't recycle. This way, as systems become
faster, they become more efficient by going into sleep or idle mode
when a module doesn't require servicing yet.

Interested in your views

If I were to do a fresh install of the OS, and had no software running,
my processor (3GHz Northwood) would use 13.2 watts at idle. That is
measured with a clamp-on ammeter, and it sees 1.1 amps being drawn
from the 12V rail.

There are several features, which make low power operation like that possible.

1) Programs are interrupt driven, and don't sit in a polling loop.
Only dumb programmers use polling loops. Modern programs "block on I/O",
and the program doesn't do anything, until a significant event, like
a key press or mouse click occurs.

2) The operating system has an "Idle" task. The scheduler runs the Idle task,
when no other process is ready to run. The Idle task can be coded with a
halt (HLT) instruction in it, which will actually cause the processor to
go to sleep. What wakes the processor up, is any hardware interrupt. An
example of a regularly occurring interrupt, is the "Clock Tick Interrupt".
In fact, the Clock Tick is what triggers the Scheduler to run, and then the
Scheduler can check again, to see what process is ready to run. If
nothing is ready to run, then the Idle task runs for another time slice.

3) Features like Cool N' Quiet or Intel Speedstep (EIST), allow Vcore and
Fcore to be dropped, when the OS detects that the load on the system is
low. By using those features, it is possible to further reduce the
operating power.

Can something screw that up ? Yes.

I installed some Antivirus software, and it appears to replace the system
Idle loop with its own. The antivirus software doesn't have a HLT instruction
coded in the Idle loop. This causes the processor to run hotter than it
would otherwise do. (I just checked a few minutes ago, and the processor is
using 54W or 12V @ 4.6amps, and that is due to the antivirus software.)

And there is nothing to see in Task Manager, when HLT is not being used.
Only my power measurement device, can tell the difference.

If I download a copy of RMClock, RMClock can install its own Idle loop, and
it does use a HLT instruction. If I choose to run RMClock right now, my
CPU power drawn drops back to 13.2 watts. So, in this example, there
were three Idle loops involved. The OS has a good one (13.2W). The
antivirus software has a bad one (54W). RMClock has a good one (13.2W).
Naturally, the antivirus software squawks a bit, when I install RMClock :-)

If you want to build a low power computer, there are processors
that would be good for the job. For example, this Conroe-L is 35W
max, and draws a lot less when idle. This would be a good match for your
Pentium II generation processors. It is possible to build a modern
system, that uses less power under all conditions, than your
Pentium II. (Putting a high end video card in the system,
doesn't help. Video can be pretty wasteful. Integrated graphics
can be better, but some chipsets run cooler than others. )

http://www.newegg.com/Product/Product.aspx?Item=N82E16819116039

HTH,
Paul
 
If I were to do a fresh install of the OS, and had no software running,
my processor (3GHz Northwood) would use 13.2 watts at idle. That is
measured with a clamp-on ammeter, and it sees 1.1 amps being drawn
from the 12V rail.

There are several features, which make low power operation like that possible.

1) Programs are interrupt driven, and don't sit in a polling loop.
    Only dumb programmers use polling loops. Modern programs "block onI/O",
    and the program doesn't do anything, until a significant event, like
    a key press or mouse click occurs.

2) The operating system has an "Idle" task. The scheduler runs the Idle task,
    when no other process is ready to run. The Idle task can be coded with a
    halt (HLT) instruction in it, which will actually cause the processor to
    go to sleep. What wakes the processor up, is any hardware interrupt. An
    example of a regularly occurring interrupt, is the "Clock Tick Interrupt".
    In fact, the Clock Tick is what triggers the Scheduler to run, andthen the
    Scheduler can check again, to see what process is ready to run. If
    nothing is ready to run, then the Idle task runs for another time slice.

3) Features like Cool N' Quiet or Intel Speedstep (EIST), allow Vcore and
    Fcore to be dropped, when the OS detects that the load on the system is
    low. By using those features, it is possible to further reduce the
    operating power.

Can something screw that up ? Yes.

I installed some Antivirus software, and it appears to replace the system
Idle loop with its own. The antivirus software doesn't have a HLT instruction
coded in the Idle loop. This causes the processor to run hotter than it
would otherwise do. (I just checked a few minutes ago, and the processor is
using 54W or 12V @ 4.6amps, and that is due to the antivirus software.)

And there is nothing to see in Task Manager, when HLT is not being used.
Only my power measurement device, can tell the difference.

If I download a copy of RMClock, RMClock can install its own Idle loop, and
it does use a HLT instruction. If I choose to run RMClock right now, my
CPU power drawn drops back to 13.2 watts. So, in this example, there
were three Idle loops involved. The OS has a good one (13.2W). The
antivirus software has a bad one (54W). RMClock has a good one (13.2W).
Naturally, the antivirus software squawks a bit, when I install RMClock :-)

If you want to build a low power computer, there are processors
that would be good for the job. For example, this Conroe-L is 35W
max, and draws a lot less when idle. This would be a good match for your
Pentium II generation processors. It is possible to build a modern
system, that uses less power under all conditions, than your
Pentium II. (Putting a high end video card in the system,
doesn't help. Video can be pretty wasteful. Integrated graphics
can be better, but some chipsets run cooler than others. )

http://www.newegg.com/Product/Product.aspx?Item=N82E16819116039

HTH,
      Paul- Hide quoted text -

- Show quoted text -

Nice reply, yet there is still the question of why an idle operating
system still requires a processor to run at 13 watts. Do the modules
really need to be polled and serviced at the rate they're serviced by
the processor?

There is nothing wrong with executing a module at the highest clock
rate, rather the rate at which the module is polled is what leads to
unnecessary power dissipation as you pointed out. If each module had a
maximum service rate associated with it, the processor could go into
sleep mode until another module needs to be polled and serviced if
necessary.
 
Paul said:
blackhead wrote:
There are several features, which make low power operation like that
possible.

1) Programs are interrupt driven, and don't sit in a polling loop.
Only dumb programmers use polling loops. Modern programs "block on
I/O",
and the program doesn't do anything, until a significant event, like
a key press or mouse click occurs.

2) The operating system has an "Idle" task. The scheduler runs the Idle
task,
when no other process is ready to run. The Idle task can be coded with
a
halt (HLT) instruction in it, which will actually cause the processor
to
go to sleep. What wakes the processor up, is any hardware interrupt. An
example of a regularly occurring interrupt, is the "Clock Tick
Interrupt".
In fact, the Clock Tick is what triggers the Scheduler to run, and then
the
Scheduler can check again, to see what process is ready to run. If
nothing is ready to run, then the Idle task runs for another time
slice.

3) Features like Cool N' Quiet or Intel Speedstep (EIST), allow Vcore and
Fcore to be dropped, when the OS detects that the load on the system is
low. By using those features, it is possible to further reduce the
operating power.

Can something screw that up ? Yes.

I installed some Antivirus software, and it appears to replace the system
Idle loop with its own. The antivirus software doesn't have a HLT
instruction
coded in the Idle loop. This causes the processor to run hotter than it
would otherwise do. (I just checked a few minutes ago, and the processor
is
using 54W or 12V @ 4.6amps, and that is due to the antivirus software.)

Which antivirus software did you install?

Charlie
 
Back
Top