Skip to content

Commit 69d517e

Browse files
davidhildenbrandJonathan Corbet
authored andcommitted
checkpatch: warn on usage of VM_BUG_ON() and other BUG variants
checkpatch does not point out that VM_BUG_ON() and friends should be avoided, however, Linus notes: VM_BUG_ON() has the exact same semantics as BUG_ON. It is literally no different, the only difference is "we can make the code smaller because these are less important". [1] So let's warn on VM_BUG_ON() and other BUG variants as well. While at it, make it clearer that the kernel really shouldn't be crashed. As there are some subsystem BUG macros that actually don't end up crashing the kernel -- for example, KVM_BUG_ON() -- exclude these manually. [1] https://lore.kernel.org/r/CAHk-=wg40EAZofO16Eviaj7mfqDhZ2gVEbvfsMf6gYzspRjYvw@mail.gmail.com Signed-off-by: David Hildenbrand <david@redhat.com> Link: https://lore.kernel.org/r/20220923113426.52871-3-david@redhat.com Signed-off-by: Jonathan Corbet <corbet@lwn.net>
1 parent 1cfd9d7 commit 69d517e

File tree

1 file changed

+3
-3
lines changed

1 file changed

+3
-3
lines changed

scripts/checkpatch.pl

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -4695,12 +4695,12 @@ sub process {
46954695
}
46964696
}
46974697

4698-
# avoid BUG() or BUG_ON()
4699-
if ($line =~ /\b(?:BUG|BUG_ON)\b/) {
4698+
# do not use BUG() or variants
4699+
if ($line =~ /\b(?!AA_|BUILD_|DCCP_|IDA_|KVM_|RWLOCK_|snd_|SPIN_)(?:[a-zA-Z_]*_)?BUG(?:_ON)?(?:_[A-Z_]+)?\s*\(/) {
47004700
my $msg_level = \&WARN;
47014701
$msg_level = \&CHK if ($file);
47024702
&{$msg_level}("AVOID_BUG",
4703-
"Avoid crashing the kernel - try using WARN_ON & recovery code rather than BUG() or BUG_ON()\n" . $herecurr);
4703+
"Do not crash the kernel unless it is absolutely unavoidable--use WARN_ON_ONCE() plus recovery code (if feasible) instead of BUG() or variants\n" . $herecurr);
47044704
}
47054705

47064706
# avoid LINUX_VERSION_CODE

0 commit comments

Comments
 (0)