aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWill Deacon <will.deacon@arm.com>2016-07-19 10:07:38 -0400
committerCatalin Marinas <catalin.marinas@arm.com>2016-07-19 11:58:56 -0400
commit6b68e14e71b0a6811ed776c6261d4e6c0389e2c0 (patch)
treebee3a0bd6eba1080dcd4677ae62aeeff8e8d1949
parent2ce39ad15182604beb6c8fa8bed5e46b59fd1082 (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.c13
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 */
166static void set_regs_spsr_ss(struct pt_regs *regs) 166static 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
176static void clear_regs_spsr_ss(struct pt_regs *regs) 171static 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 */