On 11 November 2014 05:29, Alexandre Courbot <acourbot@xxxxxxxxxx> wrote: > On 11/07/2014 09:35 PM, Tomeu Vizoso wrote: >> >> On 11/07/2014 10:07 AM, Alexandre Courbot wrote: >>> >>> On 10/29/2014 11:50 PM, Tomeu Vizoso wrote: >>>> >>>> Hello, >>>> >>>> these patches implement support for setting the rate of the EMC clock >>>> based on >>>> stats collected from the ACTMON, a piece of hw in the Tegra124 that >>>> counts >>>> memory accesses (among others). >>>> >>>> It depends on the following in-flight patches: >>>> >>>> * MC driver: http://thread.gmane.org/gmane.linux.ports.tegra/19623 >>>> * EMC driver: >>>> http://thread.gmane.org/gmane.linux.ports.arm.kernel/365125 >>>> * CPUFreq driver: http://thread.gmane.org/gmane.linux.kernel/1812962 >>>> >>>> I have pushed a branch here for testing: >>> >>> >>> I am not too familiar with DVFS, but after going through this series it >>> really seems to me that this could use devfreq. In its current form this >>> driver mixes control and policy and lacks flexibility, preventing e.g. >>> to switch to a performance or power-saving profile. Could you study the >>> feasibility of using devfreq for this? >> >> >> Yeah, I started writing a devfreq driver, but then I looked in more >> detail to the downstream driver and realized that most of the >> functionality that devfreq provides overlaps with the hw. >> >> The ACTMON can be configured to fire an interrupt when a set of >> thresholds are crossed, similar to the simple-ondemand governor but a >> bit more sophisticated. > > > I think (after a quick look at devfreq's source) that you can avoid polling > altogether if you set polling_ms to 0 in your devfreq_dev_profile instance. > Then it is up to you to call update_devfreq() from your custom governor > whenever it sees fit. > > ACTMON support seems to overlap between being a governor (which reacts to > ACTMON interrupts and calls update_devfreq() when needed) and part of a > devfreq_dev_profile (get_dev_status() needs to use the actmon counters). If > we keep your current design where the driver simply controls a clock, you > could have the ACTMON driver obtain that clock, register its governor, > create a non-polling devfreq_dev_profile that controls that clock, and just > call devfreq_add_device() with both. Then we will have the benefit of being > able to use ACTMON as well as the performance and powersave governors on > EMC, and switch policies dynamically. > > Another benefit is that you will have a placeholder in the governor to > implement suspend/resume for the ACTMON IP, in case this becomes necessary > in the future. > > Do you think that would work? Apart from the polling which doesn't seem to > be an issue, have you seen any other redundancy between devfreq and ACTMON? I don't think there's any obstacle to having this as a devfreq driver, it's just that it won't use much/any functionality of it so I don't really see the point. I think it will be better if I send a version of the driver that uses the devfreq framework, so we can better compare (and maybe I will change my opinion). Regards, Tomeu -- To unsubscribe from this list: send the line "unsubscribe linux-tegra" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html