diff options
Diffstat (limited to 'kernel/sched/core.c')
-rw-r--r-- | kernel/sched/core.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 13c38837f2cd..0533a688ce22 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c | |||
@@ -1913,7 +1913,7 @@ prepare_task_switch(struct rq *rq, struct task_struct *prev, | |||
1913 | struct task_struct *next) | 1913 | struct task_struct *next) |
1914 | { | 1914 | { |
1915 | sched_info_switch(prev, next); | 1915 | sched_info_switch(prev, next); |
1916 | perf_event_task_sched(prev, next); | 1916 | perf_event_task_sched_out(prev, next); |
1917 | fire_sched_out_preempt_notifiers(prev, next); | 1917 | fire_sched_out_preempt_notifiers(prev, next); |
1918 | prepare_lock_switch(rq, next); | 1918 | prepare_lock_switch(rq, next); |
1919 | prepare_arch_switch(next); | 1919 | prepare_arch_switch(next); |
@@ -1956,6 +1956,13 @@ static void finish_task_switch(struct rq *rq, struct task_struct *prev) | |||
1956 | */ | 1956 | */ |
1957 | prev_state = prev->state; | 1957 | prev_state = prev->state; |
1958 | finish_arch_switch(prev); | 1958 | finish_arch_switch(prev); |
1959 | #ifdef __ARCH_WANT_INTERRUPTS_ON_CTXSW | ||
1960 | local_irq_disable(); | ||
1961 | #endif /* __ARCH_WANT_INTERRUPTS_ON_CTXSW */ | ||
1962 | perf_event_task_sched_in(prev, current); | ||
1963 | #ifdef __ARCH_WANT_INTERRUPTS_ON_CTXSW | ||
1964 | local_irq_enable(); | ||
1965 | #endif /* __ARCH_WANT_INTERRUPTS_ON_CTXSW */ | ||
1959 | finish_lock_switch(rq, prev); | 1966 | finish_lock_switch(rq, prev); |
1960 | finish_arch_post_lock_switch(); | 1967 | finish_arch_post_lock_switch(); |
1961 | 1968 | ||