Skip to content

Commit 143c2a8

Browse files
Yang ShiRussell King
authored andcommitted
ARM: 8839/1: kprobe: make patch_lock a raw_spinlock_t
When running kprobe on -rt kernel, the below bug is caught: |BUG: sleeping function called from invalid context at kernel/locking/rtmutex.c:931 |in_atomic(): 1, irqs_disabled(): 128, pid: 14, name: migration/0 |Preemption disabled at:[<802f2b98>] cpu_stopper_thread+0xc0/0x140 |CPU: 0 PID: 14 Comm: migration/0 Tainted: G O 4.8.3-rt2 #1 |Hardware name: Freescale LS1021A |[<8025a43c>] (___might_sleep) |[<80b5b324>] (rt_spin_lock) |[<80b5c31c>] (__patch_text_real) |[<80b5c3ac>] (patch_text_stop_machine) |[<802f2920>] (multi_cpu_stop) Since patch_text_stop_machine() is called in stop_machine() which disables IRQ, sleepable lock should be not used in this atomic context, so replace patch_lock to raw lock. Signed-off-by: Yang Shi <yang.shi@linaro.org> Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Reviewed-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
1 parent fc67e6f commit 143c2a8

File tree

1 file changed

+3
-3
lines changed

1 file changed

+3
-3
lines changed

arch/arm/kernel/patch.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ struct patch {
1616
unsigned int insn;
1717
};
1818

19-
static DEFINE_SPINLOCK(patch_lock);
19+
static DEFINE_RAW_SPINLOCK(patch_lock);
2020

2121
static void __kprobes *patch_map(void *addr, int fixmap, unsigned long *flags)
2222
__acquires(&patch_lock)
@@ -33,7 +33,7 @@ static void __kprobes *patch_map(void *addr, int fixmap, unsigned long *flags)
3333
return addr;
3434

3535
if (flags)
36-
spin_lock_irqsave(&patch_lock, *flags);
36+
raw_spin_lock_irqsave(&patch_lock, *flags);
3737
else
3838
__acquire(&patch_lock);
3939

@@ -48,7 +48,7 @@ static void __kprobes patch_unmap(int fixmap, unsigned long *flags)
4848
clear_fixmap(fixmap);
4949

5050
if (flags)
51-
spin_unlock_irqrestore(&patch_lock, *flags);
51+
raw_spin_unlock_irqrestore(&patch_lock, *flags);
5252
else
5353
__release(&patch_lock);
5454
}

0 commit comments

Comments
 (0)