diff options
author | Chris Metcalf <cmetcalf@ezchip.com> | 2015-07-30 12:32:46 -0400 |
---|---|---|
committer | Chris Metcalf <cmetcalf@ezchip.com> | 2015-08-03 12:14:48 -0400 |
commit | 232ff5eb2bf304fc699b132134437a7cb9b2ec16 (patch) | |
tree | ed92e241ee1a96418ccf4a91200bd63ebb4d5567 /arch/tile/kernel | |
parent | a0ddef81f4aeeeec3326f6b6a255d8ea13b41908 (diff) | |
download | talos-op-linux-232ff5eb2bf304fc699b132134437a7cb9b2ec16.tar.gz talos-op-linux-232ff5eb2bf304fc699b132134437a7cb9b2ec16.zip |
tile: Remove finish_arch_switch
Move the simulator bits into switch_to() and use
finish_arch_post_lock_switch() for the homecache migration bits.
Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: Chris Metcalf <cmetcalf@ezchip.com>
Diffstat (limited to 'arch/tile/kernel')
-rw-r--r-- | arch/tile/kernel/process.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/arch/tile/kernel/process.c b/arch/tile/kernel/process.c index a45213781ad0..7d5769310bef 100644 --- a/arch/tile/kernel/process.c +++ b/arch/tile/kernel/process.c @@ -446,6 +446,11 @@ struct task_struct *__sched _switch_to(struct task_struct *prev, hardwall_switch_tasks(prev, next); #endif + /* Notify the simulator of task exit. */ + if (unlikely(prev->state == TASK_DEAD)) + __insn_mtspr(SPR_SIM_CONTROL, SIM_CONTROL_OS_EXIT | + (prev->pid << _SIM_CONTROL_OPERATOR_BITS)); + /* * Switch kernel SP, PC, and callee-saved registers. * In the context of the new task, return the old task pointer |