diff options
author | Chris Metcalf <cmetcalf@ezchip.com> | 2015-12-23 17:13:04 -0500 |
---|---|---|
committer | Chris Metcalf <cmetcalf@ezchip.com> | 2016-01-18 14:49:30 -0500 |
commit | 1bb50cad45f4a3fb9a339006d76efc50f70eed5b (patch) | |
tree | 91e00be5d5852acdb7c5c9ba9707b9f7926e6bc6 /arch/tile/mm | |
parent | 9ce815ed50bbc518526106071f395deacaf94ad7 (diff) |
arch/tile: move user_exit() to early kernel entry sequence
This ensures that we always notify context tracking that we
have exited from user space no matter how we enter the kernel.
It is similar to how arm64 handles context tracking, for example.
This allows the removal of all the exception_enter() calls that
were added in commit 49e4e15619cd ("tile: support CONTEXT_TRACKING and
thus NOHZ_FULL").
Signed-off-by: Chris Metcalf <cmetcalf@ezchip.com>
Diffstat (limited to 'arch/tile/mm')
-rw-r--r-- | arch/tile/mm/fault.c | 3 |
1 files changed, 0 insertions, 3 deletions
diff --git a/arch/tile/mm/fault.c b/arch/tile/mm/fault.c index 13eac59bf16a..26734214818c 100644 --- a/arch/tile/mm/fault.c +++ b/arch/tile/mm/fault.c | |||
@@ -35,7 +35,6 @@ | |||
35 | #include <linux/syscalls.h> | 35 | #include <linux/syscalls.h> |
36 | #include <linux/uaccess.h> | 36 | #include <linux/uaccess.h> |
37 | #include <linux/kdebug.h> | 37 | #include <linux/kdebug.h> |
38 | #include <linux/context_tracking.h> | ||
39 | 38 | ||
40 | #include <asm/pgalloc.h> | 39 | #include <asm/pgalloc.h> |
41 | #include <asm/sections.h> | 40 | #include <asm/sections.h> |
@@ -845,9 +844,7 @@ static inline void __do_page_fault(struct pt_regs *regs, int fault_num, | |||
845 | void do_page_fault(struct pt_regs *regs, int fault_num, | 844 | void do_page_fault(struct pt_regs *regs, int fault_num, |
846 | unsigned long address, unsigned long write) | 845 | unsigned long address, unsigned long write) |
847 | { | 846 | { |
848 | enum ctx_state prev_state = exception_enter(); | ||
849 | __do_page_fault(regs, fault_num, address, write); | 847 | __do_page_fault(regs, fault_num, address, write); |
850 | exception_exit(prev_state); | ||
851 | } | 848 | } |
852 | 849 | ||
853 | #if CHIP_HAS_TILE_DMA() | 850 | #if CHIP_HAS_TILE_DMA() |