diff options
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/events/core.c | 14 | ||||
| -rw-r--r-- | kernel/sched/core.c | 9 | 
2 files changed, 11 insertions, 12 deletions
diff --git a/kernel/events/core.c b/kernel/events/core.c index 00c58df9f4e2..e82c7a1face9 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c  | |||
| @@ -2039,8 +2039,8 @@ static void perf_event_context_sched_out(struct task_struct *task, int ctxn, | |||
| 2039 | * accessing the event control register. If a NMI hits, then it will | 2039 | * accessing the event control register. If a NMI hits, then it will | 
| 2040 | * not restart the event. | 2040 | * not restart the event. | 
| 2041 | */ | 2041 | */ | 
| 2042 | void __perf_event_task_sched_out(struct task_struct *task, | 2042 | static void __perf_event_task_sched_out(struct task_struct *task, | 
| 2043 | struct task_struct *next) | 2043 | struct task_struct *next) | 
| 2044 | { | 2044 | { | 
| 2045 | int ctxn; | 2045 | int ctxn; | 
| 2046 | 2046 | ||
| @@ -2279,8 +2279,8 @@ static void perf_branch_stack_sched_in(struct task_struct *prev, | |||
| 2279 | * accessing the event control register. If a NMI hits, then it will | 2279 | * accessing the event control register. If a NMI hits, then it will | 
| 2280 | * keep the event running. | 2280 | * keep the event running. | 
| 2281 | */ | 2281 | */ | 
| 2282 | void __perf_event_task_sched_in(struct task_struct *prev, | 2282 | static void __perf_event_task_sched_in(struct task_struct *prev, | 
| 2283 | struct task_struct *task) | 2283 | struct task_struct *task) | 
| 2284 | { | 2284 | { | 
| 2285 | struct perf_event_context *ctx; | 2285 | struct perf_event_context *ctx; | 
| 2286 | int ctxn; | 2286 | int ctxn; | 
| @@ -2305,6 +2305,12 @@ void __perf_event_task_sched_in(struct task_struct *prev, | |||
| 2305 | perf_branch_stack_sched_in(prev, task); | 2305 | perf_branch_stack_sched_in(prev, task); | 
| 2306 | } | 2306 | } | 
| 2307 | 2307 | ||
| 2308 | void __perf_event_task_sched(struct task_struct *prev, struct task_struct *next) | ||
| 2309 | { | ||
| 2310 | __perf_event_task_sched_out(prev, next); | ||
| 2311 | __perf_event_task_sched_in(prev, next); | ||
| 2312 | } | ||
| 2313 | |||
| 2308 | static u64 perf_calculate_period(struct perf_event *event, u64 nsec, u64 count) | 2314 | static u64 perf_calculate_period(struct perf_event *event, u64 nsec, u64 count) | 
| 2309 | { | 2315 | { | 
| 2310 | u64 frequency = event->attr.sample_freq; | 2316 | u64 frequency = event->attr.sample_freq; | 
diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 4603b9d8f30a..5c692a0a555d 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_out(prev, next); | 1916 | perf_event_task_sched(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,13 +1956,6 @@ 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 */ | ||
| 1966 | finish_lock_switch(rq, prev); | 1959 | finish_lock_switch(rq, prev); | 
| 1967 | finish_arch_post_lock_switch(); | 1960 | finish_arch_post_lock_switch(); | 
| 1968 | 1961 | ||
