[PATCH v3 1/6] sched: Introduce the finish_arch_post_lock_switch() scheduler hook
Peter Zijlstra
peterz at infradead.org
Mon Feb 27 09:48:13 EST 2012
On Fri, 2012-01-20 at 17:42 +0000, Catalin Marinas wrote:
> This hook is called by the scheduler after rq->lock has been released
> and interrupts enabled. It will be used in subsequent patches on the ARM
> architecture.
>
> Reviewed-by: Will Deacon <will.deacon at arm.com>
> Reviewed-by: Frank Rowand <frank.rowand at am.sony.com>
> Cc: Russell King <linux at arm.linux.org.uk>
> Cc: Ingo Molnar <mingo at elte.hu>
Acked-by: Peter Zijlstra <peterz at infradead.org>
> Signed-off-by: Catalin Marinas <catalin.marinas at arm.com>
> ---
> kernel/sched/core.c | 1 +
> kernel/sched/sched.h | 3 +++
> 2 files changed, 4 insertions(+), 0 deletions(-)
>
> diff --git a/kernel/sched/core.c b/kernel/sched/core.c
> index df00cb0..f1db6d8 100644
> --- a/kernel/sched/core.c
> +++ b/kernel/sched/core.c
> @@ -1937,6 +1937,7 @@ static void finish_task_switch(struct rq *rq, struct task_struct *prev)
> local_irq_enable();
> #endif /* __ARCH_WANT_INTERRUPTS_ON_CTXSW */
> finish_lock_switch(rq, prev);
> + finish_arch_post_lock_switch();
> trace_sched_stat_sleeptime(current, rq->clock);
>
> fire_sched_in_preempt_notifiers(current);
> diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h
> index 98c0c26..d72483d 100644
> --- a/kernel/sched/sched.h
> +++ b/kernel/sched/sched.h
> @@ -692,6 +692,9 @@ static inline int task_running(struct rq *rq, struct task_struct *p)
> #ifndef finish_arch_switch
> # define finish_arch_switch(prev) do { } while (0)
> #endif
> +#ifndef finish_arch_post_lock_switch
> +# define finish_arch_post_lock_switch() do { } while (0)
> +#endif
>
> #ifndef __ARCH_WANT_UNLOCKED_CTXSW
> static inline void prepare_lock_switch(struct rq *rq, struct task_struct *next)
>
More information about the linux-arm-kernel
mailing list