RE: Dual Core on Linux questions

From: Pallipadi, Venkatesh
Date: Wed Mar 22 2006 - 22:34:04 EST




>-----Original Message-----
>From: linux-kernel-owner@xxxxxxxxxxxxxxx
>[mailto:linux-kernel-owner@xxxxxxxxxxxxxxx] On Behalf Of Mattia Dongili
>Sent: Saturday, March 18, 2006 2:49 AM
>To: Alejandro Bonilla
>Cc: Jeff Garzik; linux-kernel@xxxxxxxxxxxxxxx
>Subject: Re: Dual Core on Linux questions
>
>On Sat, Mar 18, 2006 at 03:03:40AM -0600, Alejandro Bonilla wrote:
>> On Sat, 18 Mar 2006 03:58:22 -0500, Jeff Garzik wrote
>> > Alejandro Bonilla wrote:
>> > > Hi,
>> > >
>> > > I have a few questions about the PM Dual Core and how
>could it really work
>> > > with Linux. Sorry if there are new patches on LKML about
>any of these things:
>> > >
>> > > Could each processor or die, have it's own cpufreq
>scaling governor?
>> >
>> > Sure. On a laptop, if you don't need dual core power, it makes
>> > sense to turn off the unused core, even.
>> >
>> > Jeff
>>
>> Jeff,
>>
>> For some reason, while I was writing this email, I knew you
>would be the first
>> to reply. LOL. Anyway. Does this need new patches sent to
>LKML or nice
>> commands to make this work or any idea if stock cpufreqd
>should manage the
>> cores separatelly? I haven't got that to work on 2.6.15 so
>far. How flexible
>
>no, currently cpufreqd applies the governor and limits to all available
>cpus. Is it really possible to run the 2 cores at different speeds?
>I definitely need to upgrade my hardware and get one of those dual core
>babies to play with.
>Oh, and BTW patches to cpufreqd are welcome in the meantime :)
>

>From cpufreq perspective multiple things are possible in the way
processor will support the multi-core frequency changing. and most of
the things are handled at cpufreq inside kernel. I think there should be
minima changes required in cpufreqd if any.
Options:
1) Multiple core can manage frequency independently: In this case,
cpufreq exports separate interfaces for each cpu in
/sys/devices/system/cpu/cpuX. So, cpufreqd should work as it would work
on an SMP system (Assuming that cpufreqd works fine on an SMP system
today ;-))

2) Multiple cores can be at a single frequency, but hardware will
coordinate between two cores internally (pick the highest frequency
request from two cores and run both of them at that frequency). This
will be very much similar to 1, in the way in which cpufreq and kernel
handles it.

3) Multiple cores can be at a single frequency and hardware depends on
OS to do the coordination, pick the maximum of all the requests from the
cores and set the frequency using appropriate hardware interface. This
is the case, where cpufreqd may need a change. In this case, say CPU 0
and 1 are two different cores on same package and they share frequency
and OS has to coordinate the freq request from these two CPUs. In this
case, /sys/devices/system/cpu/cpu1/cpufreq will be kind of a symbolic
link to /sys/devices/system/cpu/cpu0/cpufreq. Cpufreq tells that these
two are dependent by using "affected_cpus" in the same sysfs directory
(in this case "0 1"). Now, if cpufreqd does a set_speed on cpu0 and
cpu1, both CPUs will be affected. Cpufreqd should be aware that these
CPUs are dependent and change freq based on maximum utilization of these
two CPUs.

Thanks,
Venki
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/