X-Git-Url: http://git.cascardo.info/?a=blobdiff_plain;f=kernel%2Fkcov.c;h=30e6d05aa5a9f726422c7968dabbff5e1c590c2a;hb=14970f204b1993af7459d5bd34aaff38dfee6670;hp=8d44b3fea9d08f901e3b24ed4a619a4883d4042f;hpb=affe8a2abd0d7815bb2653eea2717d0e0f8ac7e3;p=cascardo%2Flinux.git diff --git a/kernel/kcov.c b/kernel/kcov.c index 8d44b3fea9d0..30e6d05aa5a9 100644 --- a/kernel/kcov.c +++ b/kernel/kcov.c @@ -53,8 +53,15 @@ void notrace __sanitizer_cov_trace_pc(void) /* * We are interested in code coverage as a function of a syscall inputs, * so we ignore code executed in interrupts. + * The checks for whether we are in an interrupt are open-coded, because + * 1. We can't use in_interrupt() here, since it also returns true + * when we are inside local_bh_disable() section. + * 2. We don't want to use (in_irq() | in_serving_softirq() | in_nmi()), + * since that leads to slower generated code (three separate tests, + * one for each of the flags). */ - if (!t || in_interrupt()) + if (!t || (preempt_count() & (HARDIRQ_MASK | SOFTIRQ_OFFSET + | NMI_MASK))) return; mode = READ_ONCE(t->kcov_mode); if (mode == KCOV_MODE_TRACE) {