Message ID | 1953902.drhraqW2It@vostro.rjw.lan (mailing list archive) |
---|---|
State | Superseded, archived |
Headers | show |
On Fri, May 06, 2016 at 02:25:16AM +0200, Rafael J. Wysocki wrote: > On Friday, May 06, 2016 02:09:07 AM Rafael J. Wysocki wrote: > > On Thursday, May 05, 2016 04:49:22 PM Steve Muckle wrote: > > > While working on a few patches for schedutil I noticed that the CFS > > > cpufreq hooks depend on PELT, which depends on CONFIG_SMP. > > For governors other than schedutil fixing that would be a matter of > > adding a !CONFIG_SMP variant of update_load_avg() that will call > > cpufreq_update_util() and do nothing else. It doesn't matter what > > is passed via util and max then. > > Maybe something like the below, FWIW, as a quick fix for 4.6? Right; I suppose that'll have to do for 4.6. > --- > kernel/sched/fair.c | 9 ++++++++- > 1 file changed, 8 insertions(+), 1 deletion(-) > > Index: linux-pm/kernel/sched/fair.c > =================================================================== > --- linux-pm.orig/kernel/sched/fair.c > +++ linux-pm/kernel/sched/fair.c > @@ -3030,7 +3030,14 @@ static int idle_balance(struct rq *this_ > > #else /* CONFIG_SMP */ > > -static inline void update_load_avg(struct sched_entity *se, int update_tg) {} > +static inline void update_load_avg(struct sched_entity *se, int not_used) > +{ > + struct cfs_rq *cfs_rq = cfs_rq_of(se); > + struct rq *rq = rq_of(cfs_rq); > + > + cpufreq_trigger_update(rq_clock(rq)); > +} > + > static inline void > enqueue_entity_load_avg(struct cfs_rq *cfs_rq, struct sched_entity *se) {} > static inline void > -- To unsubscribe from this list: send the line "unsubscribe linux-pm" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Fri, May 6, 2016 at 1:46 PM, Peter Zijlstra <peterz@infradead.org> wrote: > On Fri, May 06, 2016 at 02:25:16AM +0200, Rafael J. Wysocki wrote: >> On Friday, May 06, 2016 02:09:07 AM Rafael J. Wysocki wrote: >> > On Thursday, May 05, 2016 04:49:22 PM Steve Muckle wrote: >> > > While working on a few patches for schedutil I noticed that the CFS >> > > cpufreq hooks depend on PELT, which depends on CONFIG_SMP. > >> > For governors other than schedutil fixing that would be a matter of >> > adding a !CONFIG_SMP variant of update_load_avg() that will call >> > cpufreq_update_util() and do nothing else. It doesn't matter what >> > is passed via util and max then. >> >> Maybe something like the below, FWIW, as a quick fix for 4.6? > > Right; I suppose that'll have to do for 4.6. OK, thanks! I'll resend it with a changelog and stuff then. -- To unsubscribe from this list: send the line "unsubscribe linux-pm" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Index: linux-pm/kernel/sched/fair.c =================================================================== --- linux-pm.orig/kernel/sched/fair.c +++ linux-pm/kernel/sched/fair.c @@ -3030,7 +3030,14 @@ static int idle_balance(struct rq *this_ #else /* CONFIG_SMP */ -static inline void update_load_avg(struct sched_entity *se, int update_tg) {} +static inline void update_load_avg(struct sched_entity *se, int not_used) +{ + struct cfs_rq *cfs_rq = cfs_rq_of(se); + struct rq *rq = rq_of(cfs_rq); + + cpufreq_trigger_update(rq_clock(rq)); +} + static inline void enqueue_entity_load_avg(struct cfs_rq *cfs_rq, struct sched_entity *se) {} static inline void