Quoting Russell King (Oracle) (2021-08-02 09:38:24) > On Mon, Aug 02, 2021 at 05:27:55PM +0200, Uwe Kleine-Konig wrote: > > Hello Russell, > > > > On Mon, Aug 02, 2021 at 10:48:10AM +0100, Russell King (Oracle) wrote: > > > > There have been several different approaches to wrapping things up, > > > but here's a question: should we make it easier to do the lazy thing > > > (get+enable) or should we make it easier to be power efficient? > > > Shouldn't we be encouraging people to write power efficient drivers? > > > > Yeah, sounds compelling, but I wonder if that's of practical importance. > > How many driver authors do you expect to lure into making a better > > driver just because devm_clk_get_prepared() doesn't exist? In contrast: > > How many drivers become simpler with devm_clk_get_prepared() and so > > it becomes easier to maintain them and easier to spot bugs? > > In the absence of devm_clk_get_prepared(), is it better that several > > frameworks (or drivers) open code it? > > It probably depends on where you stand on power management and power > efficiency issues. Personally, I would like to see more effort put > into drivers to make them more power efficient, and I believe in the > coming years, power efficiency is going to become a big issue. > I agree we should put more effort into power efficiency in the kernel. I've occasionally heard from driver writers that they never will turn the clk off even in low power modes though. They feel like it's a nuisance to have to do anything with the clk framework in their driver. When I say "why not use runtime PM?" I get told that they're not turning the clk off because it needs to be on all the time, so using runtime PM makes the driver more complicated, not less, and adds no value. I think some touchscreens are this way, and watchdogs too. Looking at the drivers being converted in this series I suspect RTC is one of those sorts of devices as well. But SPI and I2C most likely could benefit from using runtime PM and so those ones don't feel appropriate to convert. Maybe this series would be more compelling if those various drivers that are hand rolling the devm action were converted to the consolidated official devm function. The truth is it's already happening in various subsystems so consolidating that logic into one place would be a win code size wise and very hard to ignore. Doing $ git grep devm_add_action | grep clk seems to catch quite a few of them.