Skip to content

Commit 5577b31

Browse files
Yong ZhangJulia Cartwright
authored andcommitted
lockdep: selftest: Only do hardirq context test for raw spinlock
On -rt there is no softirq context any more and rwlock is sleepable, disable softirq context test and rwlock+irq test. Signed-off-by: Yong Zhang <yong.zhang0@gmail.com> Cc: Yong Zhang <yong.zhang@windriver.com> Link: http://lkml.kernel.org/r/1334559716-18447-3-git-send-email-yong.zhang0@gmail.com Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
1 parent 133b414 commit 5577b31

File tree

1 file changed

+23
-0
lines changed

1 file changed

+23
-0
lines changed

lib/locking-selftest.c

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1858,6 +1858,7 @@ void locking_selftest(void)
18581858

18591859
printk(" --------------------------------------------------------------------------\n");
18601860

1861+
#ifndef CONFIG_PREEMPT_RT_FULL
18611862
/*
18621863
* irq-context testcases:
18631864
*/
@@ -1870,6 +1871,28 @@ void locking_selftest(void)
18701871

18711872
DO_TESTCASE_6x2("irq read-recursion", irq_read_recursion);
18721873
// DO_TESTCASE_6x2B("irq read-recursion #2", irq_read_recursion2);
1874+
#else
1875+
/* On -rt, we only do hardirq context test for raw spinlock */
1876+
DO_TESTCASE_1B("hard-irqs-on + irq-safe-A", irqsafe1_hard_spin, 12);
1877+
DO_TESTCASE_1B("hard-irqs-on + irq-safe-A", irqsafe1_hard_spin, 21);
1878+
1879+
DO_TESTCASE_1B("hard-safe-A + irqs-on", irqsafe2B_hard_spin, 12);
1880+
DO_TESTCASE_1B("hard-safe-A + irqs-on", irqsafe2B_hard_spin, 21);
1881+
1882+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #1", irqsafe3_hard_spin, 123);
1883+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #1", irqsafe3_hard_spin, 132);
1884+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #1", irqsafe3_hard_spin, 213);
1885+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #1", irqsafe3_hard_spin, 231);
1886+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #1", irqsafe3_hard_spin, 312);
1887+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #1", irqsafe3_hard_spin, 321);
1888+
1889+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #2", irqsafe4_hard_spin, 123);
1890+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #2", irqsafe4_hard_spin, 132);
1891+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #2", irqsafe4_hard_spin, 213);
1892+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #2", irqsafe4_hard_spin, 231);
1893+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #2", irqsafe4_hard_spin, 312);
1894+
DO_TESTCASE_1B("hard-safe-A + unsafe-B #2", irqsafe4_hard_spin, 321);
1895+
#endif
18731896

18741897
ww_tests();
18751898

0 commit comments

Comments
 (0)