aboutsummaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorJoe Perches <joe@perches.com>2019-01-03 18:26:59 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2019-01-04 16:13:46 -0500
commit77b8c0a8e47484e205b01dfedcd224770aa9d800 (patch)
tree6c330016a11944d5dd5f9f0dd5b5e7651e1b35ae /scripts
parent05391772a72d49c37e6e4cb8e871be57beb66155 (diff)
checkpatch: warn on const char foo[] = "bar"; declarations
These declarations should generally be static const to avoid poor compilation and runtime performance where compilers tend to initialize the const declaration for every call instead of using .rodata for the string. Miscellanea: - Convert spaces to tabs for indentation in 2 adjacent checks Link: http://lkml.kernel.org/r/10ea5f4b087dc911e41e187a4a2b5e79c7529aa3.camel@perches.com Signed-off-by: Joe Perches <joe@perches.com> Cc: Rasmus Villemoes <linux@rasmusvillemoes.dk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/checkpatch.pl13
1 files changed, 11 insertions, 2 deletions
diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
index 377f373db6c0..93e84c9504a1 100755
--- a/scripts/checkpatch.pl
+++ b/scripts/checkpatch.pl
@@ -3890,14 +3890,23 @@ sub process {
3890 WARN("STATIC_CONST_CHAR_ARRAY", 3890 WARN("STATIC_CONST_CHAR_ARRAY",
3891 "static const char * array should probably be static const char * const\n" . 3891 "static const char * array should probably be static const char * const\n" .
3892 $herecurr); 3892 $herecurr);
3893 } 3893 }
3894
3895# check for initialized const char arrays that should be static const
3896 if ($line =~ /^\+\s*const\s+(char|unsigned\s+char|_*u8|(?:[us]_)?int8_t)\s+\w+\s*\[\s*(?:\w+\s*)?\]\s*=\s*"/) {
3897 if (WARN("STATIC_CONST_CHAR_ARRAY",
3898 "const array should probably be static const\n" . $herecurr) &&
3899 $fix) {
3900 $fixed[$fixlinenr] =~ s/(^.\s*)const\b/${1}static const/;
3901 }
3902 }
3894 3903
3895# check for static char foo[] = "bar" declarations. 3904# check for static char foo[] = "bar" declarations.
3896 if ($line =~ /\bstatic\s+char\s+(\w+)\s*\[\s*\]\s*=\s*"/) { 3905 if ($line =~ /\bstatic\s+char\s+(\w+)\s*\[\s*\]\s*=\s*"/) {
3897 WARN("STATIC_CONST_CHAR_ARRAY", 3906 WARN("STATIC_CONST_CHAR_ARRAY",
3898 "static char array declaration should probably be static const char\n" . 3907 "static char array declaration should probably be static const char\n" .
3899 $herecurr); 3908 $herecurr);
3900 } 3909 }
3901 3910
3902# check for const <foo> const where <foo> is not a pointer or array type 3911# check for const <foo> const where <foo> is not a pointer or array type
3903 if ($sline =~ /\bconst\s+($BasicType)\s+const\b/) { 3912 if ($sline =~ /\bconst\s+($BasicType)\s+const\b/) {