aboutsummaryrefslogtreecommitdiffstats
path: root/scripts/checkpatch.pl
diff options
context:
space:
mode:
authorJoe Perches <joe@perches.com>2014-04-03 17:49:11 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2014-04-03 19:21:12 -0400
commit43c1d77c393205645cdd6337e657341a5216a7a8 (patch)
tree32d46fe129f6be4b2a225e381617ab2e0ce082ed /scripts/checkpatch.pl
parentaf661e836039cbc2aadb3bccfd7d3ddfc1bcc456 (diff)
checkpatch: add test for long udelay
Holger reported: : The macro udelay cannot handle large values because of loss-of-precision. : : IMHO udelay on ARM is broken, because it also cannot work with fast : ARM processors (where bogomips >= 3355, which is in sight now). It's : just not broken enough that someone did something against it ... so : the current kludge is good enough. Until then, warn on long udelay uses. Also fix uses of $line that should have been $herecurr. Signed-off-by: Joe Perches <joe@perches.com> Reported-by: Holger Schurig <holgerschurig@gmail.com> Cc: Sujith Manoharan <sujith@msujith.org> Cc: John Linville <linville@tuxdriver.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'scripts/checkpatch.pl')
-rwxr-xr-xscripts/checkpatch.pl11
1 files changed, 8 insertions, 3 deletions
diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
index 464dcef79b35..7d3bc2f3c326 100755
--- a/scripts/checkpatch.pl
+++ b/scripts/checkpatch.pl
@@ -3912,10 +3912,15 @@ sub process {
3912 3912
3913# prefer usleep_range over udelay 3913# prefer usleep_range over udelay
3914 if ($line =~ /\budelay\s*\(\s*(\d+)\s*\)/) { 3914 if ($line =~ /\budelay\s*\(\s*(\d+)\s*\)/) {
3915 my $delay = $1;
3915 # ignore udelay's < 10, however 3916 # ignore udelay's < 10, however
3916 if (! ($1 < 10) ) { 3917 if (! ($delay < 10) ) {
3917 CHK("USLEEP_RANGE", 3918 CHK("USLEEP_RANGE",
3918 "usleep_range is preferred over udelay; see Documentation/timers/timers-howto.txt\n" . $line); 3919 "usleep_range is preferred over udelay; see Documentation/timers/timers-howto.txt\n" . $herecurr);
3920 }
3921 if ($delay > 2000) {
3922 WARN("LONG_UDELAY",
3923 "long udelay - prefer mdelay; see arch/arm/include/asm/delay.h\n" . $herecurr);
3919 } 3924 }
3920 } 3925 }
3921 3926
@@ -3923,7 +3928,7 @@ sub process {
3923 if ($line =~ /\bmsleep\s*\((\d+)\);/) { 3928 if ($line =~ /\bmsleep\s*\((\d+)\);/) {
3924 if ($1 < 20) { 3929 if ($1 < 20) {
3925 WARN("MSLEEP", 3930 WARN("MSLEEP",
3926 "msleep < 20ms can sleep for up to 20ms; see Documentation/timers/timers-howto.txt\n" . $line); 3931 "msleep < 20ms can sleep for up to 20ms; see Documentation/timers/timers-howto.txt\n" . $herecurr);
3927 } 3932 }
3928 } 3933 }
3929 3934