[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <87d41lv9b5.fsf@deeprootsystems.com>
Date: Thu, 07 Jan 2010 14:28:46 -0800
From: Kevin Hilman <khilman@...prootsystems.com>
To: mgross@...ux.intel.com
Cc: Daniel Walker <dwalker@...eaurora.org>,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH] pm_qos: Add QoS param, minimum system bus frequency
mark gross <mgross@...ux.intel.com> writes:
> On Thu, Jan 07, 2010 at 08:34:28AM -0800, Kevin Hilman wrote:
>> Daniel Walker <dwalker@...eaurora.org> writes:
>>
>> > From: Praveen Chidambaram <pchidamb@...cinc.com>
>> >
>> > In some systems, the system bus speed can be varied, usually
>> > based on the current CPU frequency. However, various device
>> > drivers and/or applications may need a faster system bus for I/O
>> > even though the CPU itself may be idle.
>> >
>> > Signed-off-by: Praveen Chidambaram <pchidamb@...cinc.com>
>> > Signed-off-by: David Brown <davidb@...cinc.com>
>> > Signed-off-by: Daniel Walker <dwalker@...eaurora.org>
>>
>> I think some type of bus parameter is a good idea and something we
>> would use on TI OMAP as well. However, I also have two concerns with
>> this approach.
>>
>> 1) The constraint should be in throughput, not in frequency
>> 2) It doesn't handle multiple busses (as Mark Gross pointed out)
>>
>> For (1), I don't like the idea of forcing drivers to know about the
>> underlying bus frequency. The same driver could be in use across a
>> family of SoCs (or even different SoCs), each having different bus
>> frequencies. For this driver to be portable, the driver should
>> express its constraints in terms of throughput, not underlying bus
>> frequency.
>
> This makes sense, as throttling constraints should be based on things
> that are invariant to bus width.
>
>>
>> For (2), I'm not sure what the best way to handle this in PM QoS is.
>> Lately, I've been thinking that PM QoS is not the right place for
>> this. My idea (currenly only in my head) is the that busses in the
>> LDM (platform_bus, etc.) should have constraints associated with
>> them. That way, constraints can be set using a 'struct device' and
>> the bus they are attatched to will inherit the constraints directly.
>> This automatically solves the problem of multiple busses and allows
>> the possibility for different bus types to handle the constraints
>> differently.
>
> Sounds a bit like the range timers implementation. One question, what
> would a throttling constraint changes API look like if not pm_qos?
Hmm, good question. I haven't gotten far enough to think of an API. :(
I've been thinking of (and using) PM QoS as an API for system-wide
constraints, and it is fine for this.
However, when it comes to device specific constraints, I don't think
it fits. IMHO, constraints should be something that becomes part of
the driver model, rather than a separate API. Most likely by evolving
the current runtime PM code.
Basically if a device has a constraint, it should register that
constraint with the LDM (API TBD) and it should be associated with the
device and associated bus etc. That way, the PM core code (including
runtime PM layer) can examine device and bus specific constraints and
make localized decisions rather than querying some central repository.
This approach also allows the platform-specific runtime PM
implementations to handle constraints in platform-specific ways, but the
constraints are still tightly coupled to devices and/or busses.
> I think adding a bandwidth throttling constraint to struct device may be
> a good thing, but I'm not sure if there isn't a place for the PM_QOS
> interface yet. i.e. perhaps if this happens, then we should look at
> evolving the pm_qos api to handle multiple constraint's per class and
> multiple buses, multiple nic's etc...
That's one option. But my preferred option would be to see the LDM grow
some notion of per-device and/or per-bus constraints.
We're currenly experimenting with this on ARM/OMAP where we have have
a 'struct omap_device' which is a 'struct device' plus some
arch-specific extentions including constraints. I am working on
runtime PM for OMAP currently, and when something is working there, we
may have some proposals for generalizing this in LDM-generic way.
Kevin
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists