diff options
author | Will Deacon <will.deacon@arm.com> | 2016-07-19 10:07:38 -0400 |
---|---|---|
committer | Catalin Marinas <catalin.marinas@arm.com> | 2016-07-19 11:58:56 -0400 |
commit | 6b68e14e71b0a6811ed776c6261d4e6c0389e2c0 (patch) | |
tree | bee3a0bd6eba1080dcd4677ae62aeeff8e8d1949 | |
parent | 2ce39ad15182604beb6c8fa8bed5e46b59fd1082 (diff) |
arm64: debug: remove redundant spsr manipulation
There is no need to explicitly clear the SS bit immediately before
setting it unconditionally.
Reported-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
Acked-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
-rw-r--r-- | arch/arm64/kernel/debug-monitors.c | 13 |
1 files changed, 2 insertions, 11 deletions
diff --git a/arch/arm64/kernel/debug-monitors.c b/arch/arm64/kernel/debug-monitors.c index 0800d23e2fdd..f17134d39e6b 100644 --- a/arch/arm64/kernel/debug-monitors.c +++ b/arch/arm64/kernel/debug-monitors.c | |||
@@ -165,21 +165,12 @@ postcore_initcall(debug_monitors_init); | |||
165 | */ | 165 | */ |
166 | static void set_regs_spsr_ss(struct pt_regs *regs) | 166 | static void set_regs_spsr_ss(struct pt_regs *regs) |
167 | { | 167 | { |
168 | unsigned long spsr; | 168 | regs->pstate |= DBG_SPSR_SS; |
169 | |||
170 | spsr = regs->pstate; | ||
171 | spsr &= ~DBG_SPSR_SS; | ||
172 | spsr |= DBG_SPSR_SS; | ||
173 | regs->pstate = spsr; | ||
174 | } | 169 | } |
175 | 170 | ||
176 | static void clear_regs_spsr_ss(struct pt_regs *regs) | 171 | static void clear_regs_spsr_ss(struct pt_regs *regs) |
177 | { | 172 | { |
178 | unsigned long spsr; | 173 | regs->pstate &= ~DBG_SPSR_SS; |
179 | |||
180 | spsr = regs->pstate; | ||
181 | spsr &= ~DBG_SPSR_SS; | ||
182 | regs->pstate = spsr; | ||
183 | } | 174 | } |
184 | 175 | ||
185 | /* EL1 Single Step Handler hooks */ | 176 | /* EL1 Single Step Handler hooks */ |