xref: /openbmc/linux/scripts/checkpatch.pl (revision a2cce7a9)
1#!/usr/bin/perl -w
2# (c) 2001, Dave Jones. (the file handling bit)
3# (c) 2005, Joel Schopp <jschopp@austin.ibm.com> (the ugly bit)
4# (c) 2007,2008, Andy Whitcroft <apw@uk.ibm.com> (new conditions, test suite)
5# (c) 2008-2010 Andy Whitcroft <apw@canonical.com>
6# Licensed under the terms of the GNU GPL License version 2
7
8use strict;
9use POSIX;
10use File::Basename;
11use Cwd 'abs_path';
12use Term::ANSIColor qw(:constants);
13
14my $P = $0;
15my $D = dirname(abs_path($P));
16
17my $V = '0.32';
18
19use Getopt::Long qw(:config no_auto_abbrev);
20
21my $quiet = 0;
22my $tree = 1;
23my $chk_signoff = 1;
24my $chk_patch = 1;
25my $tst_only;
26my $emacs = 0;
27my $terse = 0;
28my $showfile = 0;
29my $file = 0;
30my $check = 0;
31my $check_orig = 0;
32my $summary = 1;
33my $mailback = 0;
34my $summary_file = 0;
35my $show_types = 0;
36my $fix = 0;
37my $fix_inplace = 0;
38my $root;
39my %debug;
40my %camelcase = ();
41my %use_type = ();
42my @use = ();
43my %ignore_type = ();
44my @ignore = ();
45my $help = 0;
46my $configuration_file = ".checkpatch.conf";
47my $max_line_length = 80;
48my $ignore_perl_version = 0;
49my $minimum_perl_version = 5.10.0;
50my $min_conf_desc_length = 4;
51my $spelling_file = "$D/spelling.txt";
52my $codespell = 0;
53my $codespellfile = "/usr/share/codespell/dictionary.txt";
54my $color = 1;
55
56sub help {
57	my ($exitcode) = @_;
58
59	print << "EOM";
60Usage: $P [OPTION]... [FILE]...
61Version: $V
62
63Options:
64  -q, --quiet                quiet
65  --no-tree                  run without a kernel tree
66  --no-signoff               do not check for 'Signed-off-by' line
67  --patch                    treat FILE as patchfile (default)
68  --emacs                    emacs compile window format
69  --terse                    one line per report
70  --showfile                 emit diffed file position, not input file position
71  -f, --file                 treat FILE as regular source file
72  --subjective, --strict     enable more subjective tests
73  --types TYPE(,TYPE2...)    show only these comma separated message types
74  --ignore TYPE(,TYPE2...)   ignore various comma separated message types
75  --max-line-length=n        set the maximum line length, if exceeded, warn
76  --min-conf-desc-length=n   set the min description length, if shorter, warn
77  --show-types               show the message "types" in the output
78  --root=PATH                PATH to the kernel tree root
79  --no-summary               suppress the per-file summary
80  --mailback                 only produce a report in case of warnings/errors
81  --summary-file             include the filename in summary
82  --debug KEY=[0|1]          turn on/off debugging of KEY, where KEY is one of
83                             'values', 'possible', 'type', and 'attr' (default
84                             is all off)
85  --test-only=WORD           report only warnings/errors containing WORD
86                             literally
87  --fix                      EXPERIMENTAL - may create horrible results
88                             If correctable single-line errors exist, create
89                             "<inputfile>.EXPERIMENTAL-checkpatch-fixes"
90                             with potential errors corrected to the preferred
91                             checkpatch style
92  --fix-inplace              EXPERIMENTAL - may create horrible results
93                             Is the same as --fix, but overwrites the input
94                             file.  It's your fault if there's no backup or git
95  --ignore-perl-version      override checking of perl version.  expect
96                             runtime errors.
97  --codespell                Use the codespell dictionary for spelling/typos
98                             (default:/usr/share/codespell/dictionary.txt)
99  --codespellfile            Use this codespell dictionary
100  --color                    Use colors when output is STDOUT (default: on)
101  -h, --help, --version      display this help and exit
102
103When FILE is - read standard input.
104EOM
105
106	exit($exitcode);
107}
108
109my $conf = which_conf($configuration_file);
110if (-f $conf) {
111	my @conf_args;
112	open(my $conffile, '<', "$conf")
113	    or warn "$P: Can't find a readable $configuration_file file $!\n";
114
115	while (<$conffile>) {
116		my $line = $_;
117
118		$line =~ s/\s*\n?$//g;
119		$line =~ s/^\s*//g;
120		$line =~ s/\s+/ /g;
121
122		next if ($line =~ m/^\s*#/);
123		next if ($line =~ m/^\s*$/);
124
125		my @words = split(" ", $line);
126		foreach my $word (@words) {
127			last if ($word =~ m/^#/);
128			push (@conf_args, $word);
129		}
130	}
131	close($conffile);
132	unshift(@ARGV, @conf_args) if @conf_args;
133}
134
135GetOptions(
136	'q|quiet+'	=> \$quiet,
137	'tree!'		=> \$tree,
138	'signoff!'	=> \$chk_signoff,
139	'patch!'	=> \$chk_patch,
140	'emacs!'	=> \$emacs,
141	'terse!'	=> \$terse,
142	'showfile!'	=> \$showfile,
143	'f|file!'	=> \$file,
144	'subjective!'	=> \$check,
145	'strict!'	=> \$check,
146	'ignore=s'	=> \@ignore,
147	'types=s'	=> \@use,
148	'show-types!'	=> \$show_types,
149	'max-line-length=i' => \$max_line_length,
150	'min-conf-desc-length=i' => \$min_conf_desc_length,
151	'root=s'	=> \$root,
152	'summary!'	=> \$summary,
153	'mailback!'	=> \$mailback,
154	'summary-file!'	=> \$summary_file,
155	'fix!'		=> \$fix,
156	'fix-inplace!'	=> \$fix_inplace,
157	'ignore-perl-version!' => \$ignore_perl_version,
158	'debug=s'	=> \%debug,
159	'test-only=s'	=> \$tst_only,
160	'codespell!'	=> \$codespell,
161	'codespellfile=s'	=> \$codespellfile,
162	'color!'	=> \$color,
163	'h|help'	=> \$help,
164	'version'	=> \$help
165) or help(1);
166
167help(0) if ($help);
168
169$fix = 1 if ($fix_inplace);
170$check_orig = $check;
171
172my $exit = 0;
173
174if ($^V && $^V lt $minimum_perl_version) {
175	printf "$P: requires at least perl version %vd\n", $minimum_perl_version;
176	if (!$ignore_perl_version) {
177		exit(1);
178	}
179}
180
181if ($#ARGV < 0) {
182	print "$P: no input files\n";
183	exit(1);
184}
185
186sub hash_save_array_words {
187	my ($hashRef, $arrayRef) = @_;
188
189	my @array = split(/,/, join(',', @$arrayRef));
190	foreach my $word (@array) {
191		$word =~ s/\s*\n?$//g;
192		$word =~ s/^\s*//g;
193		$word =~ s/\s+/ /g;
194		$word =~ tr/[a-z]/[A-Z]/;
195
196		next if ($word =~ m/^\s*#/);
197		next if ($word =~ m/^\s*$/);
198
199		$hashRef->{$word}++;
200	}
201}
202
203sub hash_show_words {
204	my ($hashRef, $prefix) = @_;
205
206	if (keys %$hashRef) {
207		print "\nNOTE: $prefix message types:";
208		foreach my $word (sort keys %$hashRef) {
209			print " $word";
210		}
211		print "\n";
212	}
213}
214
215hash_save_array_words(\%ignore_type, \@ignore);
216hash_save_array_words(\%use_type, \@use);
217
218my $dbg_values = 0;
219my $dbg_possible = 0;
220my $dbg_type = 0;
221my $dbg_attr = 0;
222for my $key (keys %debug) {
223	## no critic
224	eval "\${dbg_$key} = '$debug{$key}';";
225	die "$@" if ($@);
226}
227
228my $rpt_cleaners = 0;
229
230if ($terse) {
231	$emacs = 1;
232	$quiet++;
233}
234
235if ($tree) {
236	if (defined $root) {
237		if (!top_of_kernel_tree($root)) {
238			die "$P: $root: --root does not point at a valid tree\n";
239		}
240	} else {
241		if (top_of_kernel_tree('.')) {
242			$root = '.';
243		} elsif ($0 =~ m@(.*)/scripts/[^/]*$@ &&
244						top_of_kernel_tree($1)) {
245			$root = $1;
246		}
247	}
248
249	if (!defined $root) {
250		print "Must be run from the top-level dir. of a kernel tree\n";
251		exit(2);
252	}
253}
254
255my $emitted_corrupt = 0;
256
257our $Ident	= qr{
258			[A-Za-z_][A-Za-z\d_]*
259			(?:\s*\#\#\s*[A-Za-z_][A-Za-z\d_]*)*
260		}x;
261our $Storage	= qr{extern|static|asmlinkage};
262our $Sparse	= qr{
263			__user|
264			__kernel|
265			__force|
266			__iomem|
267			__pmem|
268			__must_check|
269			__init_refok|
270			__kprobes|
271			__ref|
272			__rcu
273		}x;
274our $InitAttributePrefix = qr{__(?:mem|cpu|dev|net_|)};
275our $InitAttributeData = qr{$InitAttributePrefix(?:initdata\b)};
276our $InitAttributeConst = qr{$InitAttributePrefix(?:initconst\b)};
277our $InitAttributeInit = qr{$InitAttributePrefix(?:init\b)};
278our $InitAttribute = qr{$InitAttributeData|$InitAttributeConst|$InitAttributeInit};
279
280# Notes to $Attribute:
281# We need \b after 'init' otherwise 'initconst' will cause a false positive in a check
282our $Attribute	= qr{
283			const|
284			__percpu|
285			__nocast|
286			__safe|
287			__bitwise__|
288			__packed__|
289			__packed2__|
290			__naked|
291			__maybe_unused|
292			__always_unused|
293			__noreturn|
294			__used|
295			__cold|
296			__pure|
297			__noclone|
298			__deprecated|
299			__read_mostly|
300			__kprobes|
301			$InitAttribute|
302			____cacheline_aligned|
303			____cacheline_aligned_in_smp|
304			____cacheline_internodealigned_in_smp|
305			__weak
306		  }x;
307our $Modifier;
308our $Inline	= qr{inline|__always_inline|noinline|__inline|__inline__};
309our $Member	= qr{->$Ident|\.$Ident|\[[^]]*\]};
310our $Lval	= qr{$Ident(?:$Member)*};
311
312our $Int_type	= qr{(?i)llu|ull|ll|lu|ul|l|u};
313our $Binary	= qr{(?i)0b[01]+$Int_type?};
314our $Hex	= qr{(?i)0x[0-9a-f]+$Int_type?};
315our $Int	= qr{[0-9]+$Int_type?};
316our $Octal	= qr{0[0-7]+$Int_type?};
317our $String	= qr{"[X\t]*"};
318our $Float_hex	= qr{(?i)0x[0-9a-f]+p-?[0-9]+[fl]?};
319our $Float_dec	= qr{(?i)(?:[0-9]+\.[0-9]*|[0-9]*\.[0-9]+)(?:e-?[0-9]+)?[fl]?};
320our $Float_int	= qr{(?i)[0-9]+e-?[0-9]+[fl]?};
321our $Float	= qr{$Float_hex|$Float_dec|$Float_int};
322our $Constant	= qr{$Float|$Binary|$Octal|$Hex|$Int};
323our $Assignment	= qr{\*\=|/=|%=|\+=|-=|<<=|>>=|&=|\^=|\|=|=};
324our $Compare    = qr{<=|>=|==|!=|<|(?<!-)>};
325our $Arithmetic = qr{\+|-|\*|\/|%};
326our $Operators	= qr{
327			<=|>=|==|!=|
328			=>|->|<<|>>|<|>|!|~|
329			&&|\|\||,|\^|\+\+|--|&|\||$Arithmetic
330		  }x;
331
332our $c90_Keywords = qr{do|for|while|if|else|return|goto|continue|switch|default|case|break}x;
333
334our $BasicType;
335our $NonptrType;
336our $NonptrTypeMisordered;
337our $NonptrTypeWithAttr;
338our $Type;
339our $TypeMisordered;
340our $Declare;
341our $DeclareMisordered;
342
343our $NON_ASCII_UTF8	= qr{
344	[\xC2-\xDF][\x80-\xBF]               # non-overlong 2-byte
345	|  \xE0[\xA0-\xBF][\x80-\xBF]        # excluding overlongs
346	| [\xE1-\xEC\xEE\xEF][\x80-\xBF]{2}  # straight 3-byte
347	|  \xED[\x80-\x9F][\x80-\xBF]        # excluding surrogates
348	|  \xF0[\x90-\xBF][\x80-\xBF]{2}     # planes 1-3
349	| [\xF1-\xF3][\x80-\xBF]{3}          # planes 4-15
350	|  \xF4[\x80-\x8F][\x80-\xBF]{2}     # plane 16
351}x;
352
353our $UTF8	= qr{
354	[\x09\x0A\x0D\x20-\x7E]              # ASCII
355	| $NON_ASCII_UTF8
356}x;
357
358our $typeC99Typedefs = qr{(?:__)?(?:[us]_?)?int_?(?:8|16|32|64)_t};
359our $typeOtherOSTypedefs = qr{(?x:
360	u_(?:char|short|int|long) |          # bsd
361	u(?:nchar|short|int|long)            # sysv
362)};
363our $typeKernelTypedefs = qr{(?x:
364	(?:__)?(?:u|s|be|le)(?:8|16|32|64)|
365	atomic_t
366)};
367our $typeTypedefs = qr{(?x:
368	$typeC99Typedefs\b|
369	$typeOtherOSTypedefs\b|
370	$typeKernelTypedefs\b
371)};
372
373our $logFunctions = qr{(?x:
374	printk(?:_ratelimited|_once|)|
375	(?:[a-z0-9]+_){1,2}(?:printk|emerg|alert|crit|err|warning|warn|notice|info|debug|dbg|vdbg|devel|cont|WARN)(?:_ratelimited|_once|)|
376	WARN(?:_RATELIMIT|_ONCE|)|
377	panic|
378	MODULE_[A-Z_]+|
379	seq_vprintf|seq_printf|seq_puts
380)};
381
382our $signature_tags = qr{(?xi:
383	Signed-off-by:|
384	Acked-by:|
385	Tested-by:|
386	Reviewed-by:|
387	Reported-by:|
388	Suggested-by:|
389	To:|
390	Cc:
391)};
392
393our @typeListMisordered = (
394	qr{char\s+(?:un)?signed},
395	qr{int\s+(?:(?:un)?signed\s+)?short\s},
396	qr{int\s+short(?:\s+(?:un)?signed)},
397	qr{short\s+int(?:\s+(?:un)?signed)},
398	qr{(?:un)?signed\s+int\s+short},
399	qr{short\s+(?:un)?signed},
400	qr{long\s+int\s+(?:un)?signed},
401	qr{int\s+long\s+(?:un)?signed},
402	qr{long\s+(?:un)?signed\s+int},
403	qr{int\s+(?:un)?signed\s+long},
404	qr{int\s+(?:un)?signed},
405	qr{int\s+long\s+long\s+(?:un)?signed},
406	qr{long\s+long\s+int\s+(?:un)?signed},
407	qr{long\s+long\s+(?:un)?signed\s+int},
408	qr{long\s+long\s+(?:un)?signed},
409	qr{long\s+(?:un)?signed},
410);
411
412our @typeList = (
413	qr{void},
414	qr{(?:(?:un)?signed\s+)?char},
415	qr{(?:(?:un)?signed\s+)?short\s+int},
416	qr{(?:(?:un)?signed\s+)?short},
417	qr{(?:(?:un)?signed\s+)?int},
418	qr{(?:(?:un)?signed\s+)?long\s+int},
419	qr{(?:(?:un)?signed\s+)?long\s+long\s+int},
420	qr{(?:(?:un)?signed\s+)?long\s+long},
421	qr{(?:(?:un)?signed\s+)?long},
422	qr{(?:un)?signed},
423	qr{float},
424	qr{double},
425	qr{bool},
426	qr{struct\s+$Ident},
427	qr{union\s+$Ident},
428	qr{enum\s+$Ident},
429	qr{${Ident}_t},
430	qr{${Ident}_handler},
431	qr{${Ident}_handler_fn},
432	@typeListMisordered,
433);
434our @typeListFile = ();
435our @typeListWithAttr = (
436	@typeList,
437	qr{struct\s+$InitAttribute\s+$Ident},
438	qr{union\s+$InitAttribute\s+$Ident},
439);
440
441our @modifierList = (
442	qr{fastcall},
443);
444our @modifierListFile = ();
445
446our @mode_permission_funcs = (
447	["module_param", 3],
448	["module_param_(?:array|named|string)", 4],
449	["module_param_array_named", 5],
450	["debugfs_create_(?:file|u8|u16|u32|u64|x8|x16|x32|x64|size_t|atomic_t|bool|blob|regset32|u32_array)", 2],
451	["proc_create(?:_data|)", 2],
452	["(?:CLASS|DEVICE|SENSOR)_ATTR", 2],
453);
454
455#Create a search pattern for all these functions to speed up a loop below
456our $mode_perms_search = "";
457foreach my $entry (@mode_permission_funcs) {
458	$mode_perms_search .= '|' if ($mode_perms_search ne "");
459	$mode_perms_search .= $entry->[0];
460}
461
462our $mode_perms_world_writable = qr{
463	S_IWUGO		|
464	S_IWOTH		|
465	S_IRWXUGO	|
466	S_IALLUGO	|
467	0[0-7][0-7][2367]
468}x;
469
470our $allowed_asm_includes = qr{(?x:
471	irq|
472	memory|
473	time|
474	reboot
475)};
476# memory.h: ARM has a custom one
477
478# Load common spelling mistakes and build regular expression list.
479my $misspellings;
480my %spelling_fix;
481
482if (open(my $spelling, '<', $spelling_file)) {
483	while (<$spelling>) {
484		my $line = $_;
485
486		$line =~ s/\s*\n?$//g;
487		$line =~ s/^\s*//g;
488
489		next if ($line =~ m/^\s*#/);
490		next if ($line =~ m/^\s*$/);
491
492		my ($suspect, $fix) = split(/\|\|/, $line);
493
494		$spelling_fix{$suspect} = $fix;
495	}
496	close($spelling);
497} else {
498	warn "No typos will be found - file '$spelling_file': $!\n";
499}
500
501if ($codespell) {
502	if (open(my $spelling, '<', $codespellfile)) {
503		while (<$spelling>) {
504			my $line = $_;
505
506			$line =~ s/\s*\n?$//g;
507			$line =~ s/^\s*//g;
508
509			next if ($line =~ m/^\s*#/);
510			next if ($line =~ m/^\s*$/);
511			next if ($line =~ m/, disabled/i);
512
513			$line =~ s/,.*$//;
514
515			my ($suspect, $fix) = split(/->/, $line);
516
517			$spelling_fix{$suspect} = $fix;
518		}
519		close($spelling);
520	} else {
521		warn "No codespell typos will be found - file '$codespellfile': $!\n";
522	}
523}
524
525$misspellings = join("|", sort keys %spelling_fix) if keys %spelling_fix;
526
527sub build_types {
528	my $mods = "(?x:  \n" . join("|\n  ", (@modifierList, @modifierListFile)) . "\n)";
529	my $all = "(?x:  \n" . join("|\n  ", (@typeList, @typeListFile)) . "\n)";
530	my $Misordered = "(?x:  \n" . join("|\n  ", @typeListMisordered) . "\n)";
531	my $allWithAttr = "(?x:  \n" . join("|\n  ", @typeListWithAttr) . "\n)";
532	$Modifier	= qr{(?:$Attribute|$Sparse|$mods)};
533	$BasicType	= qr{
534				(?:$typeTypedefs\b)|
535				(?:${all}\b)
536		}x;
537	$NonptrType	= qr{
538			(?:$Modifier\s+|const\s+)*
539			(?:
540				(?:typeof|__typeof__)\s*\([^\)]*\)|
541				(?:$typeTypedefs\b)|
542				(?:${all}\b)
543			)
544			(?:\s+$Modifier|\s+const)*
545		  }x;
546	$NonptrTypeMisordered	= qr{
547			(?:$Modifier\s+|const\s+)*
548			(?:
549				(?:${Misordered}\b)
550			)
551			(?:\s+$Modifier|\s+const)*
552		  }x;
553	$NonptrTypeWithAttr	= qr{
554			(?:$Modifier\s+|const\s+)*
555			(?:
556				(?:typeof|__typeof__)\s*\([^\)]*\)|
557				(?:$typeTypedefs\b)|
558				(?:${allWithAttr}\b)
559			)
560			(?:\s+$Modifier|\s+const)*
561		  }x;
562	$Type	= qr{
563			$NonptrType
564			(?:(?:\s|\*|\[\])+\s*const|(?:\s|\*\s*(?:const\s*)?|\[\])+|(?:\s*\[\s*\])+)?
565			(?:\s+$Inline|\s+$Modifier)*
566		  }x;
567	$TypeMisordered	= qr{
568			$NonptrTypeMisordered
569			(?:(?:\s|\*|\[\])+\s*const|(?:\s|\*\s*(?:const\s*)?|\[\])+|(?:\s*\[\s*\])+)?
570			(?:\s+$Inline|\s+$Modifier)*
571		  }x;
572	$Declare	= qr{(?:$Storage\s+(?:$Inline\s+)?)?$Type};
573	$DeclareMisordered	= qr{(?:$Storage\s+(?:$Inline\s+)?)?$TypeMisordered};
574}
575build_types();
576
577our $Typecast	= qr{\s*(\(\s*$NonptrType\s*\)){0,1}\s*};
578
579# Using $balanced_parens, $LvalOrFunc, or $FuncArg
580# requires at least perl version v5.10.0
581# Any use must be runtime checked with $^V
582
583our $balanced_parens = qr/(\((?:[^\(\)]++|(?-1))*\))/;
584our $LvalOrFunc	= qr{((?:[\&\*]\s*)?$Lval)\s*($balanced_parens{0,1})\s*};
585our $FuncArg = qr{$Typecast{0,1}($LvalOrFunc|$Constant|$String)};
586
587our $declaration_macros = qr{(?x:
588	(?:$Storage\s+)?(?:[A-Z_][A-Z0-9]*_){0,2}(?:DEFINE|DECLARE)(?:_[A-Z0-9]+){1,6}\s*\(|
589	(?:$Storage\s+)?LIST_HEAD\s*\(|
590	(?:$Storage\s+)?${Type}\s+uninitialized_var\s*\(
591)};
592
593sub deparenthesize {
594	my ($string) = @_;
595	return "" if (!defined($string));
596
597	while ($string =~ /^\s*\(.*\)\s*$/) {
598		$string =~ s@^\s*\(\s*@@;
599		$string =~ s@\s*\)\s*$@@;
600	}
601
602	$string =~ s@\s+@ @g;
603
604	return $string;
605}
606
607sub seed_camelcase_file {
608	my ($file) = @_;
609
610	return if (!(-f $file));
611
612	local $/;
613
614	open(my $include_file, '<', "$file")
615	    or warn "$P: Can't read '$file' $!\n";
616	my $text = <$include_file>;
617	close($include_file);
618
619	my @lines = split('\n', $text);
620
621	foreach my $line (@lines) {
622		next if ($line !~ /(?:[A-Z][a-z]|[a-z][A-Z])/);
623		if ($line =~ /^[ \t]*(?:#[ \t]*define|typedef\s+$Type)\s+(\w*(?:[A-Z][a-z]|[a-z][A-Z])\w*)/) {
624			$camelcase{$1} = 1;
625		} elsif ($line =~ /^\s*$Declare\s+(\w*(?:[A-Z][a-z]|[a-z][A-Z])\w*)\s*[\(\[,;]/) {
626			$camelcase{$1} = 1;
627		} elsif ($line =~ /^\s*(?:union|struct|enum)\s+(\w*(?:[A-Z][a-z]|[a-z][A-Z])\w*)\s*[;\{]/) {
628			$camelcase{$1} = 1;
629		}
630	}
631}
632
633my $camelcase_seeded = 0;
634sub seed_camelcase_includes {
635	return if ($camelcase_seeded);
636
637	my $files;
638	my $camelcase_cache = "";
639	my @include_files = ();
640
641	$camelcase_seeded = 1;
642
643	if (-e ".git") {
644		my $git_last_include_commit = `git log --no-merges --pretty=format:"%h%n" -1 -- include`;
645		chomp $git_last_include_commit;
646		$camelcase_cache = ".checkpatch-camelcase.git.$git_last_include_commit";
647	} else {
648		my $last_mod_date = 0;
649		$files = `find $root/include -name "*.h"`;
650		@include_files = split('\n', $files);
651		foreach my $file (@include_files) {
652			my $date = POSIX::strftime("%Y%m%d%H%M",
653						   localtime((stat $file)[9]));
654			$last_mod_date = $date if ($last_mod_date < $date);
655		}
656		$camelcase_cache = ".checkpatch-camelcase.date.$last_mod_date";
657	}
658
659	if ($camelcase_cache ne "" && -f $camelcase_cache) {
660		open(my $camelcase_file, '<', "$camelcase_cache")
661		    or warn "$P: Can't read '$camelcase_cache' $!\n";
662		while (<$camelcase_file>) {
663			chomp;
664			$camelcase{$_} = 1;
665		}
666		close($camelcase_file);
667
668		return;
669	}
670
671	if (-e ".git") {
672		$files = `git ls-files "include/*.h"`;
673		@include_files = split('\n', $files);
674	}
675
676	foreach my $file (@include_files) {
677		seed_camelcase_file($file);
678	}
679
680	if ($camelcase_cache ne "") {
681		unlink glob ".checkpatch-camelcase.*";
682		open(my $camelcase_file, '>', "$camelcase_cache")
683		    or warn "$P: Can't write '$camelcase_cache' $!\n";
684		foreach (sort { lc($a) cmp lc($b) } keys(%camelcase)) {
685			print $camelcase_file ("$_\n");
686		}
687		close($camelcase_file);
688	}
689}
690
691sub git_commit_info {
692	my ($commit, $id, $desc) = @_;
693
694	return ($id, $desc) if ((which("git") eq "") || !(-e ".git"));
695
696	my $output = `git log --no-color --format='%H %s' -1 $commit 2>&1`;
697	$output =~ s/^\s*//gm;
698	my @lines = split("\n", $output);
699
700	return ($id, $desc) if ($#lines < 0);
701
702	if ($lines[0] =~ /^error: short SHA1 $commit is ambiguous\./) {
703# Maybe one day convert this block of bash into something that returns
704# all matching commit ids, but it's very slow...
705#
706#		echo "checking commits $1..."
707#		git rev-list --remotes | grep -i "^$1" |
708#		while read line ; do
709#		    git log --format='%H %s' -1 $line |
710#		    echo "commit $(cut -c 1-12,41-)"
711#		done
712	} elsif ($lines[0] =~ /^fatal: ambiguous argument '$commit': unknown revision or path not in the working tree\./) {
713	} else {
714		$id = substr($lines[0], 0, 12);
715		$desc = substr($lines[0], 41);
716	}
717
718	return ($id, $desc);
719}
720
721$chk_signoff = 0 if ($file);
722
723my @rawlines = ();
724my @lines = ();
725my @fixed = ();
726my @fixed_inserted = ();
727my @fixed_deleted = ();
728my $fixlinenr = -1;
729
730my $vname;
731for my $filename (@ARGV) {
732	my $FILE;
733	if ($file) {
734		open($FILE, '-|', "diff -u /dev/null $filename") ||
735			die "$P: $filename: diff failed - $!\n";
736	} elsif ($filename eq '-') {
737		open($FILE, '<&STDIN');
738	} else {
739		open($FILE, '<', "$filename") ||
740			die "$P: $filename: open failed - $!\n";
741	}
742	if ($filename eq '-') {
743		$vname = 'Your patch';
744	} else {
745		$vname = $filename;
746	}
747	while (<$FILE>) {
748		chomp;
749		push(@rawlines, $_);
750	}
751	close($FILE);
752
753	if ($#ARGV > 0 && $quiet == 0) {
754		print '-' x length($vname) . "\n";
755		print "$vname\n";
756		print '-' x length($vname) . "\n";
757	}
758
759	if (!process($filename)) {
760		$exit = 1;
761	}
762	@rawlines = ();
763	@lines = ();
764	@fixed = ();
765	@fixed_inserted = ();
766	@fixed_deleted = ();
767	$fixlinenr = -1;
768	@modifierListFile = ();
769	@typeListFile = ();
770	build_types();
771}
772
773if (!$quiet) {
774	hash_show_words(\%use_type, "Used");
775	hash_show_words(\%ignore_type, "Ignored");
776
777	if ($^V lt 5.10.0) {
778		print << "EOM"
779
780NOTE: perl $^V is not modern enough to detect all possible issues.
781      An upgrade to at least perl v5.10.0 is suggested.
782EOM
783	}
784	if ($exit) {
785		print << "EOM"
786
787NOTE: If any of the errors are false positives, please report
788      them to the maintainer, see CHECKPATCH in MAINTAINERS.
789EOM
790	}
791}
792
793exit($exit);
794
795sub top_of_kernel_tree {
796	my ($root) = @_;
797
798	my @tree_check = (
799		"COPYING", "CREDITS", "Kbuild", "MAINTAINERS", "Makefile",
800		"README", "Documentation", "arch", "include", "drivers",
801		"fs", "init", "ipc", "kernel", "lib", "scripts",
802	);
803
804	foreach my $check (@tree_check) {
805		if (! -e $root . '/' . $check) {
806			return 0;
807		}
808	}
809	return 1;
810}
811
812sub parse_email {
813	my ($formatted_email) = @_;
814
815	my $name = "";
816	my $address = "";
817	my $comment = "";
818
819	if ($formatted_email =~ /^(.*)<(\S+\@\S+)>(.*)$/) {
820		$name = $1;
821		$address = $2;
822		$comment = $3 if defined $3;
823	} elsif ($formatted_email =~ /^\s*<(\S+\@\S+)>(.*)$/) {
824		$address = $1;
825		$comment = $2 if defined $2;
826	} elsif ($formatted_email =~ /(\S+\@\S+)(.*)$/) {
827		$address = $1;
828		$comment = $2 if defined $2;
829		$formatted_email =~ s/$address.*$//;
830		$name = $formatted_email;
831		$name = trim($name);
832		$name =~ s/^\"|\"$//g;
833		# If there's a name left after stripping spaces and
834		# leading quotes, and the address doesn't have both
835		# leading and trailing angle brackets, the address
836		# is invalid. ie:
837		#   "joe smith joe@smith.com" bad
838		#   "joe smith <joe@smith.com" bad
839		if ($name ne "" && $address !~ /^<[^>]+>$/) {
840			$name = "";
841			$address = "";
842			$comment = "";
843		}
844	}
845
846	$name = trim($name);
847	$name =~ s/^\"|\"$//g;
848	$address = trim($address);
849	$address =~ s/^\<|\>$//g;
850
851	if ($name =~ /[^\w \-]/i) { ##has "must quote" chars
852		$name =~ s/(?<!\\)"/\\"/g; ##escape quotes
853		$name = "\"$name\"";
854	}
855
856	return ($name, $address, $comment);
857}
858
859sub format_email {
860	my ($name, $address) = @_;
861
862	my $formatted_email;
863
864	$name = trim($name);
865	$name =~ s/^\"|\"$//g;
866	$address = trim($address);
867
868	if ($name =~ /[^\w \-]/i) { ##has "must quote" chars
869		$name =~ s/(?<!\\)"/\\"/g; ##escape quotes
870		$name = "\"$name\"";
871	}
872
873	if ("$name" eq "") {
874		$formatted_email = "$address";
875	} else {
876		$formatted_email = "$name <$address>";
877	}
878
879	return $formatted_email;
880}
881
882sub which {
883	my ($bin) = @_;
884
885	foreach my $path (split(/:/, $ENV{PATH})) {
886		if (-e "$path/$bin") {
887			return "$path/$bin";
888		}
889	}
890
891	return "";
892}
893
894sub which_conf {
895	my ($conf) = @_;
896
897	foreach my $path (split(/:/, ".:$ENV{HOME}:.scripts")) {
898		if (-e "$path/$conf") {
899			return "$path/$conf";
900		}
901	}
902
903	return "";
904}
905
906sub expand_tabs {
907	my ($str) = @_;
908
909	my $res = '';
910	my $n = 0;
911	for my $c (split(//, $str)) {
912		if ($c eq "\t") {
913			$res .= ' ';
914			$n++;
915			for (; ($n % 8) != 0; $n++) {
916				$res .= ' ';
917			}
918			next;
919		}
920		$res .= $c;
921		$n++;
922	}
923
924	return $res;
925}
926sub copy_spacing {
927	(my $res = shift) =~ tr/\t/ /c;
928	return $res;
929}
930
931sub line_stats {
932	my ($line) = @_;
933
934	# Drop the diff line leader and expand tabs
935	$line =~ s/^.//;
936	$line = expand_tabs($line);
937
938	# Pick the indent from the front of the line.
939	my ($white) = ($line =~ /^(\s*)/);
940
941	return (length($line), length($white));
942}
943
944my $sanitise_quote = '';
945
946sub sanitise_line_reset {
947	my ($in_comment) = @_;
948
949	if ($in_comment) {
950		$sanitise_quote = '*/';
951	} else {
952		$sanitise_quote = '';
953	}
954}
955sub sanitise_line {
956	my ($line) = @_;
957
958	my $res = '';
959	my $l = '';
960
961	my $qlen = 0;
962	my $off = 0;
963	my $c;
964
965	# Always copy over the diff marker.
966	$res = substr($line, 0, 1);
967
968	for ($off = 1; $off < length($line); $off++) {
969		$c = substr($line, $off, 1);
970
971		# Comments we are wacking completly including the begin
972		# and end, all to $;.
973		if ($sanitise_quote eq '' && substr($line, $off, 2) eq '/*') {
974			$sanitise_quote = '*/';
975
976			substr($res, $off, 2, "$;$;");
977			$off++;
978			next;
979		}
980		if ($sanitise_quote eq '*/' && substr($line, $off, 2) eq '*/') {
981			$sanitise_quote = '';
982			substr($res, $off, 2, "$;$;");
983			$off++;
984			next;
985		}
986		if ($sanitise_quote eq '' && substr($line, $off, 2) eq '//') {
987			$sanitise_quote = '//';
988
989			substr($res, $off, 2, $sanitise_quote);
990			$off++;
991			next;
992		}
993
994		# A \ in a string means ignore the next character.
995		if (($sanitise_quote eq "'" || $sanitise_quote eq '"') &&
996		    $c eq "\\") {
997			substr($res, $off, 2, 'XX');
998			$off++;
999			next;
1000		}
1001		# Regular quotes.
1002		if ($c eq "'" || $c eq '"') {
1003			if ($sanitise_quote eq '') {
1004				$sanitise_quote = $c;
1005
1006				substr($res, $off, 1, $c);
1007				next;
1008			} elsif ($sanitise_quote eq $c) {
1009				$sanitise_quote = '';
1010			}
1011		}
1012
1013		#print "c<$c> SQ<$sanitise_quote>\n";
1014		if ($off != 0 && $sanitise_quote eq '*/' && $c ne "\t") {
1015			substr($res, $off, 1, $;);
1016		} elsif ($off != 0 && $sanitise_quote eq '//' && $c ne "\t") {
1017			substr($res, $off, 1, $;);
1018		} elsif ($off != 0 && $sanitise_quote && $c ne "\t") {
1019			substr($res, $off, 1, 'X');
1020		} else {
1021			substr($res, $off, 1, $c);
1022		}
1023	}
1024
1025	if ($sanitise_quote eq '//') {
1026		$sanitise_quote = '';
1027	}
1028
1029	# The pathname on a #include may be surrounded by '<' and '>'.
1030	if ($res =~ /^.\s*\#\s*include\s+\<(.*)\>/) {
1031		my $clean = 'X' x length($1);
1032		$res =~ s@\<.*\>@<$clean>@;
1033
1034	# The whole of a #error is a string.
1035	} elsif ($res =~ /^.\s*\#\s*(?:error|warning)\s+(.*)\b/) {
1036		my $clean = 'X' x length($1);
1037		$res =~ s@(\#\s*(?:error|warning)\s+).*@$1$clean@;
1038	}
1039
1040	return $res;
1041}
1042
1043sub get_quoted_string {
1044	my ($line, $rawline) = @_;
1045
1046	return "" if ($line !~ m/($String)/g);
1047	return substr($rawline, $-[0], $+[0] - $-[0]);
1048}
1049
1050sub ctx_statement_block {
1051	my ($linenr, $remain, $off) = @_;
1052	my $line = $linenr - 1;
1053	my $blk = '';
1054	my $soff = $off;
1055	my $coff = $off - 1;
1056	my $coff_set = 0;
1057
1058	my $loff = 0;
1059
1060	my $type = '';
1061	my $level = 0;
1062	my @stack = ();
1063	my $p;
1064	my $c;
1065	my $len = 0;
1066
1067	my $remainder;
1068	while (1) {
1069		@stack = (['', 0]) if ($#stack == -1);
1070
1071		#warn "CSB: blk<$blk> remain<$remain>\n";
1072		# If we are about to drop off the end, pull in more
1073		# context.
1074		if ($off >= $len) {
1075			for (; $remain > 0; $line++) {
1076				last if (!defined $lines[$line]);
1077				next if ($lines[$line] =~ /^-/);
1078				$remain--;
1079				$loff = $len;
1080				$blk .= $lines[$line] . "\n";
1081				$len = length($blk);
1082				$line++;
1083				last;
1084			}
1085			# Bail if there is no further context.
1086			#warn "CSB: blk<$blk> off<$off> len<$len>\n";
1087			if ($off >= $len) {
1088				last;
1089			}
1090			if ($level == 0 && substr($blk, $off) =~ /^.\s*#\s*define/) {
1091				$level++;
1092				$type = '#';
1093			}
1094		}
1095		$p = $c;
1096		$c = substr($blk, $off, 1);
1097		$remainder = substr($blk, $off);
1098
1099		#warn "CSB: c<$c> type<$type> level<$level> remainder<$remainder> coff_set<$coff_set>\n";
1100
1101		# Handle nested #if/#else.
1102		if ($remainder =~ /^#\s*(?:ifndef|ifdef|if)\s/) {
1103			push(@stack, [ $type, $level ]);
1104		} elsif ($remainder =~ /^#\s*(?:else|elif)\b/) {
1105			($type, $level) = @{$stack[$#stack - 1]};
1106		} elsif ($remainder =~ /^#\s*endif\b/) {
1107			($type, $level) = @{pop(@stack)};
1108		}
1109
1110		# Statement ends at the ';' or a close '}' at the
1111		# outermost level.
1112		if ($level == 0 && $c eq ';') {
1113			last;
1114		}
1115
1116		# An else is really a conditional as long as its not else if
1117		if ($level == 0 && $coff_set == 0 &&
1118				(!defined($p) || $p =~ /(?:\s|\}|\+)/) &&
1119				$remainder =~ /^(else)(?:\s|{)/ &&
1120				$remainder !~ /^else\s+if\b/) {
1121			$coff = $off + length($1) - 1;
1122			$coff_set = 1;
1123			#warn "CSB: mark coff<$coff> soff<$soff> 1<$1>\n";
1124			#warn "[" . substr($blk, $soff, $coff - $soff + 1) . "]\n";
1125		}
1126
1127		if (($type eq '' || $type eq '(') && $c eq '(') {
1128			$level++;
1129			$type = '(';
1130		}
1131		if ($type eq '(' && $c eq ')') {
1132			$level--;
1133			$type = ($level != 0)? '(' : '';
1134
1135			if ($level == 0 && $coff < $soff) {
1136				$coff = $off;
1137				$coff_set = 1;
1138				#warn "CSB: mark coff<$coff>\n";
1139			}
1140		}
1141		if (($type eq '' || $type eq '{') && $c eq '{') {
1142			$level++;
1143			$type = '{';
1144		}
1145		if ($type eq '{' && $c eq '}') {
1146			$level--;
1147			$type = ($level != 0)? '{' : '';
1148
1149			if ($level == 0) {
1150				if (substr($blk, $off + 1, 1) eq ';') {
1151					$off++;
1152				}
1153				last;
1154			}
1155		}
1156		# Preprocessor commands end at the newline unless escaped.
1157		if ($type eq '#' && $c eq "\n" && $p ne "\\") {
1158			$level--;
1159			$type = '';
1160			$off++;
1161			last;
1162		}
1163		$off++;
1164	}
1165	# We are truly at the end, so shuffle to the next line.
1166	if ($off == $len) {
1167		$loff = $len + 1;
1168		$line++;
1169		$remain--;
1170	}
1171
1172	my $statement = substr($blk, $soff, $off - $soff + 1);
1173	my $condition = substr($blk, $soff, $coff - $soff + 1);
1174
1175	#warn "STATEMENT<$statement>\n";
1176	#warn "CONDITION<$condition>\n";
1177
1178	#print "coff<$coff> soff<$off> loff<$loff>\n";
1179
1180	return ($statement, $condition,
1181			$line, $remain + 1, $off - $loff + 1, $level);
1182}
1183
1184sub statement_lines {
1185	my ($stmt) = @_;
1186
1187	# Strip the diff line prefixes and rip blank lines at start and end.
1188	$stmt =~ s/(^|\n)./$1/g;
1189	$stmt =~ s/^\s*//;
1190	$stmt =~ s/\s*$//;
1191
1192	my @stmt_lines = ($stmt =~ /\n/g);
1193
1194	return $#stmt_lines + 2;
1195}
1196
1197sub statement_rawlines {
1198	my ($stmt) = @_;
1199
1200	my @stmt_lines = ($stmt =~ /\n/g);
1201
1202	return $#stmt_lines + 2;
1203}
1204
1205sub statement_block_size {
1206	my ($stmt) = @_;
1207
1208	$stmt =~ s/(^|\n)./$1/g;
1209	$stmt =~ s/^\s*{//;
1210	$stmt =~ s/}\s*$//;
1211	$stmt =~ s/^\s*//;
1212	$stmt =~ s/\s*$//;
1213
1214	my @stmt_lines = ($stmt =~ /\n/g);
1215	my @stmt_statements = ($stmt =~ /;/g);
1216
1217	my $stmt_lines = $#stmt_lines + 2;
1218	my $stmt_statements = $#stmt_statements + 1;
1219
1220	if ($stmt_lines > $stmt_statements) {
1221		return $stmt_lines;
1222	} else {
1223		return $stmt_statements;
1224	}
1225}
1226
1227sub ctx_statement_full {
1228	my ($linenr, $remain, $off) = @_;
1229	my ($statement, $condition, $level);
1230
1231	my (@chunks);
1232
1233	# Grab the first conditional/block pair.
1234	($statement, $condition, $linenr, $remain, $off, $level) =
1235				ctx_statement_block($linenr, $remain, $off);
1236	#print "F: c<$condition> s<$statement> remain<$remain>\n";
1237	push(@chunks, [ $condition, $statement ]);
1238	if (!($remain > 0 && $condition =~ /^\s*(?:\n[+-])?\s*(?:if|else|do)\b/s)) {
1239		return ($level, $linenr, @chunks);
1240	}
1241
1242	# Pull in the following conditional/block pairs and see if they
1243	# could continue the statement.
1244	for (;;) {
1245		($statement, $condition, $linenr, $remain, $off, $level) =
1246				ctx_statement_block($linenr, $remain, $off);
1247		#print "C: c<$condition> s<$statement> remain<$remain>\n";
1248		last if (!($remain > 0 && $condition =~ /^(?:\s*\n[+-])*\s*(?:else|do)\b/s));
1249		#print "C: push\n";
1250		push(@chunks, [ $condition, $statement ]);
1251	}
1252
1253	return ($level, $linenr, @chunks);
1254}
1255
1256sub ctx_block_get {
1257	my ($linenr, $remain, $outer, $open, $close, $off) = @_;
1258	my $line;
1259	my $start = $linenr - 1;
1260	my $blk = '';
1261	my @o;
1262	my @c;
1263	my @res = ();
1264
1265	my $level = 0;
1266	my @stack = ($level);
1267	for ($line = $start; $remain > 0; $line++) {
1268		next if ($rawlines[$line] =~ /^-/);
1269		$remain--;
1270
1271		$blk .= $rawlines[$line];
1272
1273		# Handle nested #if/#else.
1274		if ($lines[$line] =~ /^.\s*#\s*(?:ifndef|ifdef|if)\s/) {
1275			push(@stack, $level);
1276		} elsif ($lines[$line] =~ /^.\s*#\s*(?:else|elif)\b/) {
1277			$level = $stack[$#stack - 1];
1278		} elsif ($lines[$line] =~ /^.\s*#\s*endif\b/) {
1279			$level = pop(@stack);
1280		}
1281
1282		foreach my $c (split(//, $lines[$line])) {
1283			##print "C<$c>L<$level><$open$close>O<$off>\n";
1284			if ($off > 0) {
1285				$off--;
1286				next;
1287			}
1288
1289			if ($c eq $close && $level > 0) {
1290				$level--;
1291				last if ($level == 0);
1292			} elsif ($c eq $open) {
1293				$level++;
1294			}
1295		}
1296
1297		if (!$outer || $level <= 1) {
1298			push(@res, $rawlines[$line]);
1299		}
1300
1301		last if ($level == 0);
1302	}
1303
1304	return ($level, @res);
1305}
1306sub ctx_block_outer {
1307	my ($linenr, $remain) = @_;
1308
1309	my ($level, @r) = ctx_block_get($linenr, $remain, 1, '{', '}', 0);
1310	return @r;
1311}
1312sub ctx_block {
1313	my ($linenr, $remain) = @_;
1314
1315	my ($level, @r) = ctx_block_get($linenr, $remain, 0, '{', '}', 0);
1316	return @r;
1317}
1318sub ctx_statement {
1319	my ($linenr, $remain, $off) = @_;
1320
1321	my ($level, @r) = ctx_block_get($linenr, $remain, 0, '(', ')', $off);
1322	return @r;
1323}
1324sub ctx_block_level {
1325	my ($linenr, $remain) = @_;
1326
1327	return ctx_block_get($linenr, $remain, 0, '{', '}', 0);
1328}
1329sub ctx_statement_level {
1330	my ($linenr, $remain, $off) = @_;
1331
1332	return ctx_block_get($linenr, $remain, 0, '(', ')', $off);
1333}
1334
1335sub ctx_locate_comment {
1336	my ($first_line, $end_line) = @_;
1337
1338	# Catch a comment on the end of the line itself.
1339	my ($current_comment) = ($rawlines[$end_line - 1] =~ m@.*(/\*.*\*/)\s*(?:\\\s*)?$@);
1340	return $current_comment if (defined $current_comment);
1341
1342	# Look through the context and try and figure out if there is a
1343	# comment.
1344	my $in_comment = 0;
1345	$current_comment = '';
1346	for (my $linenr = $first_line; $linenr < $end_line; $linenr++) {
1347		my $line = $rawlines[$linenr - 1];
1348		#warn "           $line\n";
1349		if ($linenr == $first_line and $line =~ m@^.\s*\*@) {
1350			$in_comment = 1;
1351		}
1352		if ($line =~ m@/\*@) {
1353			$in_comment = 1;
1354		}
1355		if (!$in_comment && $current_comment ne '') {
1356			$current_comment = '';
1357		}
1358		$current_comment .= $line . "\n" if ($in_comment);
1359		if ($line =~ m@\*/@) {
1360			$in_comment = 0;
1361		}
1362	}
1363
1364	chomp($current_comment);
1365	return($current_comment);
1366}
1367sub ctx_has_comment {
1368	my ($first_line, $end_line) = @_;
1369	my $cmt = ctx_locate_comment($first_line, $end_line);
1370
1371	##print "LINE: $rawlines[$end_line - 1 ]\n";
1372	##print "CMMT: $cmt\n";
1373
1374	return ($cmt ne '');
1375}
1376
1377sub raw_line {
1378	my ($linenr, $cnt) = @_;
1379
1380	my $offset = $linenr - 1;
1381	$cnt++;
1382
1383	my $line;
1384	while ($cnt) {
1385		$line = $rawlines[$offset++];
1386		next if (defined($line) && $line =~ /^-/);
1387		$cnt--;
1388	}
1389
1390	return $line;
1391}
1392
1393sub cat_vet {
1394	my ($vet) = @_;
1395	my ($res, $coded);
1396
1397	$res = '';
1398	while ($vet =~ /([^[:cntrl:]]*)([[:cntrl:]]|$)/g) {
1399		$res .= $1;
1400		if ($2 ne '') {
1401			$coded = sprintf("^%c", unpack('C', $2) + 64);
1402			$res .= $coded;
1403		}
1404	}
1405	$res =~ s/$/\$/;
1406
1407	return $res;
1408}
1409
1410my $av_preprocessor = 0;
1411my $av_pending;
1412my @av_paren_type;
1413my $av_pend_colon;
1414
1415sub annotate_reset {
1416	$av_preprocessor = 0;
1417	$av_pending = '_';
1418	@av_paren_type = ('E');
1419	$av_pend_colon = 'O';
1420}
1421
1422sub annotate_values {
1423	my ($stream, $type) = @_;
1424
1425	my $res;
1426	my $var = '_' x length($stream);
1427	my $cur = $stream;
1428
1429	print "$stream\n" if ($dbg_values > 1);
1430
1431	while (length($cur)) {
1432		@av_paren_type = ('E') if ($#av_paren_type < 0);
1433		print " <" . join('', @av_paren_type) .
1434				"> <$type> <$av_pending>" if ($dbg_values > 1);
1435		if ($cur =~ /^(\s+)/o) {
1436			print "WS($1)\n" if ($dbg_values > 1);
1437			if ($1 =~ /\n/ && $av_preprocessor) {
1438				$type = pop(@av_paren_type);
1439				$av_preprocessor = 0;
1440			}
1441
1442		} elsif ($cur =~ /^(\(\s*$Type\s*)\)/ && $av_pending eq '_') {
1443			print "CAST($1)\n" if ($dbg_values > 1);
1444			push(@av_paren_type, $type);
1445			$type = 'c';
1446
1447		} elsif ($cur =~ /^($Type)\s*(?:$Ident|,|\)|\(|\s*$)/) {
1448			print "DECLARE($1)\n" if ($dbg_values > 1);
1449			$type = 'T';
1450
1451		} elsif ($cur =~ /^($Modifier)\s*/) {
1452			print "MODIFIER($1)\n" if ($dbg_values > 1);
1453			$type = 'T';
1454
1455		} elsif ($cur =~ /^(\#\s*define\s*$Ident)(\(?)/o) {
1456			print "DEFINE($1,$2)\n" if ($dbg_values > 1);
1457			$av_preprocessor = 1;
1458			push(@av_paren_type, $type);
1459			if ($2 ne '') {
1460				$av_pending = 'N';
1461			}
1462			$type = 'E';
1463
1464		} elsif ($cur =~ /^(\#\s*(?:undef\s*$Ident|include\b))/o) {
1465			print "UNDEF($1)\n" if ($dbg_values > 1);
1466			$av_preprocessor = 1;
1467			push(@av_paren_type, $type);
1468
1469		} elsif ($cur =~ /^(\#\s*(?:ifdef|ifndef|if))/o) {
1470			print "PRE_START($1)\n" if ($dbg_values > 1);
1471			$av_preprocessor = 1;
1472
1473			push(@av_paren_type, $type);
1474			push(@av_paren_type, $type);
1475			$type = 'E';
1476
1477		} elsif ($cur =~ /^(\#\s*(?:else|elif))/o) {
1478			print "PRE_RESTART($1)\n" if ($dbg_values > 1);
1479			$av_preprocessor = 1;
1480
1481			push(@av_paren_type, $av_paren_type[$#av_paren_type]);
1482
1483			$type = 'E';
1484
1485		} elsif ($cur =~ /^(\#\s*(?:endif))/o) {
1486			print "PRE_END($1)\n" if ($dbg_values > 1);
1487
1488			$av_preprocessor = 1;
1489
1490			# Assume all arms of the conditional end as this
1491			# one does, and continue as if the #endif was not here.
1492			pop(@av_paren_type);
1493			push(@av_paren_type, $type);
1494			$type = 'E';
1495
1496		} elsif ($cur =~ /^(\\\n)/o) {
1497			print "PRECONT($1)\n" if ($dbg_values > 1);
1498
1499		} elsif ($cur =~ /^(__attribute__)\s*\(?/o) {
1500			print "ATTR($1)\n" if ($dbg_values > 1);
1501			$av_pending = $type;
1502			$type = 'N';
1503
1504		} elsif ($cur =~ /^(sizeof)\s*(\()?/o) {
1505			print "SIZEOF($1)\n" if ($dbg_values > 1);
1506			if (defined $2) {
1507				$av_pending = 'V';
1508			}
1509			$type = 'N';
1510
1511		} elsif ($cur =~ /^(if|while|for)\b/o) {
1512			print "COND($1)\n" if ($dbg_values > 1);
1513			$av_pending = 'E';
1514			$type = 'N';
1515
1516		} elsif ($cur =~/^(case)/o) {
1517			print "CASE($1)\n" if ($dbg_values > 1);
1518			$av_pend_colon = 'C';
1519			$type = 'N';
1520
1521		} elsif ($cur =~/^(return|else|goto|typeof|__typeof__)\b/o) {
1522			print "KEYWORD($1)\n" if ($dbg_values > 1);
1523			$type = 'N';
1524
1525		} elsif ($cur =~ /^(\()/o) {
1526			print "PAREN('$1')\n" if ($dbg_values > 1);
1527			push(@av_paren_type, $av_pending);
1528			$av_pending = '_';
1529			$type = 'N';
1530
1531		} elsif ($cur =~ /^(\))/o) {
1532			my $new_type = pop(@av_paren_type);
1533			if ($new_type ne '_') {
1534				$type = $new_type;
1535				print "PAREN('$1') -> $type\n"
1536							if ($dbg_values > 1);
1537			} else {
1538				print "PAREN('$1')\n" if ($dbg_values > 1);
1539			}
1540
1541		} elsif ($cur =~ /^($Ident)\s*\(/o) {
1542			print "FUNC($1)\n" if ($dbg_values > 1);
1543			$type = 'V';
1544			$av_pending = 'V';
1545
1546		} elsif ($cur =~ /^($Ident\s*):(?:\s*\d+\s*(,|=|;))?/) {
1547			if (defined $2 && $type eq 'C' || $type eq 'T') {
1548				$av_pend_colon = 'B';
1549			} elsif ($type eq 'E') {
1550				$av_pend_colon = 'L';
1551			}
1552			print "IDENT_COLON($1,$type>$av_pend_colon)\n" if ($dbg_values > 1);
1553			$type = 'V';
1554
1555		} elsif ($cur =~ /^($Ident|$Constant)/o) {
1556			print "IDENT($1)\n" if ($dbg_values > 1);
1557			$type = 'V';
1558
1559		} elsif ($cur =~ /^($Assignment)/o) {
1560			print "ASSIGN($1)\n" if ($dbg_values > 1);
1561			$type = 'N';
1562
1563		} elsif ($cur =~/^(;|{|})/) {
1564			print "END($1)\n" if ($dbg_values > 1);
1565			$type = 'E';
1566			$av_pend_colon = 'O';
1567
1568		} elsif ($cur =~/^(,)/) {
1569			print "COMMA($1)\n" if ($dbg_values > 1);
1570			$type = 'C';
1571
1572		} elsif ($cur =~ /^(\?)/o) {
1573			print "QUESTION($1)\n" if ($dbg_values > 1);
1574			$type = 'N';
1575
1576		} elsif ($cur =~ /^(:)/o) {
1577			print "COLON($1,$av_pend_colon)\n" if ($dbg_values > 1);
1578
1579			substr($var, length($res), 1, $av_pend_colon);
1580			if ($av_pend_colon eq 'C' || $av_pend_colon eq 'L') {
1581				$type = 'E';
1582			} else {
1583				$type = 'N';
1584			}
1585			$av_pend_colon = 'O';
1586
1587		} elsif ($cur =~ /^(\[)/o) {
1588			print "CLOSE($1)\n" if ($dbg_values > 1);
1589			$type = 'N';
1590
1591		} elsif ($cur =~ /^(-(?![->])|\+(?!\+)|\*|\&\&|\&)/o) {
1592			my $variant;
1593
1594			print "OPV($1)\n" if ($dbg_values > 1);
1595			if ($type eq 'V') {
1596				$variant = 'B';
1597			} else {
1598				$variant = 'U';
1599			}
1600
1601			substr($var, length($res), 1, $variant);
1602			$type = 'N';
1603
1604		} elsif ($cur =~ /^($Operators)/o) {
1605			print "OP($1)\n" if ($dbg_values > 1);
1606			if ($1 ne '++' && $1 ne '--') {
1607				$type = 'N';
1608			}
1609
1610		} elsif ($cur =~ /(^.)/o) {
1611			print "C($1)\n" if ($dbg_values > 1);
1612		}
1613		if (defined $1) {
1614			$cur = substr($cur, length($1));
1615			$res .= $type x length($1);
1616		}
1617	}
1618
1619	return ($res, $var);
1620}
1621
1622sub possible {
1623	my ($possible, $line) = @_;
1624	my $notPermitted = qr{(?:
1625		^(?:
1626			$Modifier|
1627			$Storage|
1628			$Type|
1629			DEFINE_\S+
1630		)$|
1631		^(?:
1632			goto|
1633			return|
1634			case|
1635			else|
1636			asm|__asm__|
1637			do|
1638			\#|
1639			\#\#|
1640		)(?:\s|$)|
1641		^(?:typedef|struct|enum)\b
1642	    )}x;
1643	warn "CHECK<$possible> ($line)\n" if ($dbg_possible > 2);
1644	if ($possible !~ $notPermitted) {
1645		# Check for modifiers.
1646		$possible =~ s/\s*$Storage\s*//g;
1647		$possible =~ s/\s*$Sparse\s*//g;
1648		if ($possible =~ /^\s*$/) {
1649
1650		} elsif ($possible =~ /\s/) {
1651			$possible =~ s/\s*$Type\s*//g;
1652			for my $modifier (split(' ', $possible)) {
1653				if ($modifier !~ $notPermitted) {
1654					warn "MODIFIER: $modifier ($possible) ($line)\n" if ($dbg_possible);
1655					push(@modifierListFile, $modifier);
1656				}
1657			}
1658
1659		} else {
1660			warn "POSSIBLE: $possible ($line)\n" if ($dbg_possible);
1661			push(@typeListFile, $possible);
1662		}
1663		build_types();
1664	} else {
1665		warn "NOTPOSS: $possible ($line)\n" if ($dbg_possible > 1);
1666	}
1667}
1668
1669my $prefix = '';
1670
1671sub show_type {
1672	my ($type) = @_;
1673
1674	return defined $use_type{$type} if (scalar keys %use_type > 0);
1675
1676	return !defined $ignore_type{$type};
1677}
1678
1679sub report {
1680	my ($level, $type, $msg) = @_;
1681
1682	if (!show_type($type) ||
1683	    (defined $tst_only && $msg !~ /\Q$tst_only\E/)) {
1684		return 0;
1685	}
1686	my $output = '';
1687	if (-t STDOUT && $color) {
1688		if ($level eq 'ERROR') {
1689			$output .= RED;
1690		} elsif ($level eq 'WARNING') {
1691			$output .= YELLOW;
1692		} else {
1693			$output .= GREEN;
1694		}
1695	}
1696	$output .= $prefix . $level . ':';
1697	if ($show_types) {
1698		$output .= BLUE if (-t STDOUT && $color);
1699		$output .= "$type:";
1700	}
1701	$output .= RESET if (-t STDOUT && $color);
1702	$output .= ' ' . $msg . "\n";
1703
1704	if ($showfile) {
1705		my @lines = split("\n", $output, -1);
1706		splice(@lines, 1, 1);
1707		$output = join("\n", @lines);
1708	}
1709	$output = (split('\n', $output))[0] . "\n" if ($terse);
1710
1711	push(our @report, $output);
1712
1713	return 1;
1714}
1715
1716sub report_dump {
1717	our @report;
1718}
1719
1720sub fixup_current_range {
1721	my ($lineRef, $offset, $length) = @_;
1722
1723	if ($$lineRef =~ /^\@\@ -\d+,\d+ \+(\d+),(\d+) \@\@/) {
1724		my $o = $1;
1725		my $l = $2;
1726		my $no = $o + $offset;
1727		my $nl = $l + $length;
1728		$$lineRef =~ s/\+$o,$l \@\@/\+$no,$nl \@\@/;
1729	}
1730}
1731
1732sub fix_inserted_deleted_lines {
1733	my ($linesRef, $insertedRef, $deletedRef) = @_;
1734
1735	my $range_last_linenr = 0;
1736	my $delta_offset = 0;
1737
1738	my $old_linenr = 0;
1739	my $new_linenr = 0;
1740
1741	my $next_insert = 0;
1742	my $next_delete = 0;
1743
1744	my @lines = ();
1745
1746	my $inserted = @{$insertedRef}[$next_insert++];
1747	my $deleted = @{$deletedRef}[$next_delete++];
1748
1749	foreach my $old_line (@{$linesRef}) {
1750		my $save_line = 1;
1751		my $line = $old_line;	#don't modify the array
1752		if ($line =~ /^(?:\+\+\+|\-\-\-)\s+\S+/) {	#new filename
1753			$delta_offset = 0;
1754		} elsif ($line =~ /^\@\@ -\d+,\d+ \+\d+,\d+ \@\@/) {	#new hunk
1755			$range_last_linenr = $new_linenr;
1756			fixup_current_range(\$line, $delta_offset, 0);
1757		}
1758
1759		while (defined($deleted) && ${$deleted}{'LINENR'} == $old_linenr) {
1760			$deleted = @{$deletedRef}[$next_delete++];
1761			$save_line = 0;
1762			fixup_current_range(\$lines[$range_last_linenr], $delta_offset--, -1);
1763		}
1764
1765		while (defined($inserted) && ${$inserted}{'LINENR'} == $old_linenr) {
1766			push(@lines, ${$inserted}{'LINE'});
1767			$inserted = @{$insertedRef}[$next_insert++];
1768			$new_linenr++;
1769			fixup_current_range(\$lines[$range_last_linenr], $delta_offset++, 1);
1770		}
1771
1772		if ($save_line) {
1773			push(@lines, $line);
1774			$new_linenr++;
1775		}
1776
1777		$old_linenr++;
1778	}
1779
1780	return @lines;
1781}
1782
1783sub fix_insert_line {
1784	my ($linenr, $line) = @_;
1785
1786	my $inserted = {
1787		LINENR => $linenr,
1788		LINE => $line,
1789	};
1790	push(@fixed_inserted, $inserted);
1791}
1792
1793sub fix_delete_line {
1794	my ($linenr, $line) = @_;
1795
1796	my $deleted = {
1797		LINENR => $linenr,
1798		LINE => $line,
1799	};
1800
1801	push(@fixed_deleted, $deleted);
1802}
1803
1804sub ERROR {
1805	my ($type, $msg) = @_;
1806
1807	if (report("ERROR", $type, $msg)) {
1808		our $clean = 0;
1809		our $cnt_error++;
1810		return 1;
1811	}
1812	return 0;
1813}
1814sub WARN {
1815	my ($type, $msg) = @_;
1816
1817	if (report("WARNING", $type, $msg)) {
1818		our $clean = 0;
1819		our $cnt_warn++;
1820		return 1;
1821	}
1822	return 0;
1823}
1824sub CHK {
1825	my ($type, $msg) = @_;
1826
1827	if ($check && report("CHECK", $type, $msg)) {
1828		our $clean = 0;
1829		our $cnt_chk++;
1830		return 1;
1831	}
1832	return 0;
1833}
1834
1835sub check_absolute_file {
1836	my ($absolute, $herecurr) = @_;
1837	my $file = $absolute;
1838
1839	##print "absolute<$absolute>\n";
1840
1841	# See if any suffix of this path is a path within the tree.
1842	while ($file =~ s@^[^/]*/@@) {
1843		if (-f "$root/$file") {
1844			##print "file<$file>\n";
1845			last;
1846		}
1847	}
1848	if (! -f _)  {
1849		return 0;
1850	}
1851
1852	# It is, so see if the prefix is acceptable.
1853	my $prefix = $absolute;
1854	substr($prefix, -length($file)) = '';
1855
1856	##print "prefix<$prefix>\n";
1857	if ($prefix ne ".../") {
1858		WARN("USE_RELATIVE_PATH",
1859		     "use relative pathname instead of absolute in changelog text\n" . $herecurr);
1860	}
1861}
1862
1863sub trim {
1864	my ($string) = @_;
1865
1866	$string =~ s/^\s+|\s+$//g;
1867
1868	return $string;
1869}
1870
1871sub ltrim {
1872	my ($string) = @_;
1873
1874	$string =~ s/^\s+//;
1875
1876	return $string;
1877}
1878
1879sub rtrim {
1880	my ($string) = @_;
1881
1882	$string =~ s/\s+$//;
1883
1884	return $string;
1885}
1886
1887sub string_find_replace {
1888	my ($string, $find, $replace) = @_;
1889
1890	$string =~ s/$find/$replace/g;
1891
1892	return $string;
1893}
1894
1895sub tabify {
1896	my ($leading) = @_;
1897
1898	my $source_indent = 8;
1899	my $max_spaces_before_tab = $source_indent - 1;
1900	my $spaces_to_tab = " " x $source_indent;
1901
1902	#convert leading spaces to tabs
1903	1 while $leading =~ s@^([\t]*)$spaces_to_tab@$1\t@g;
1904	#Remove spaces before a tab
1905	1 while $leading =~ s@^([\t]*)( {1,$max_spaces_before_tab})\t@$1\t@g;
1906
1907	return "$leading";
1908}
1909
1910sub pos_last_openparen {
1911	my ($line) = @_;
1912
1913	my $pos = 0;
1914
1915	my $opens = $line =~ tr/\(/\(/;
1916	my $closes = $line =~ tr/\)/\)/;
1917
1918	my $last_openparen = 0;
1919
1920	if (($opens == 0) || ($closes >= $opens)) {
1921		return -1;
1922	}
1923
1924	my $len = length($line);
1925
1926	for ($pos = 0; $pos < $len; $pos++) {
1927		my $string = substr($line, $pos);
1928		if ($string =~ /^($FuncArg|$balanced_parens)/) {
1929			$pos += length($1) - 1;
1930		} elsif (substr($line, $pos, 1) eq '(') {
1931			$last_openparen = $pos;
1932		} elsif (index($string, '(') == -1) {
1933			last;
1934		}
1935	}
1936
1937	return length(expand_tabs(substr($line, 0, $last_openparen))) + 1;
1938}
1939
1940sub process {
1941	my $filename = shift;
1942
1943	my $linenr=0;
1944	my $prevline="";
1945	my $prevrawline="";
1946	my $stashline="";
1947	my $stashrawline="";
1948
1949	my $length;
1950	my $indent;
1951	my $previndent=0;
1952	my $stashindent=0;
1953
1954	our $clean = 1;
1955	my $signoff = 0;
1956	my $is_patch = 0;
1957	my $in_header_lines = $file ? 0 : 1;
1958	my $in_commit_log = 0;		#Scanning lines before patch
1959       my $commit_log_possible_stack_dump = 0;
1960	my $commit_log_long_line = 0;
1961	my $commit_log_has_diff = 0;
1962	my $reported_maintainer_file = 0;
1963	my $non_utf8_charset = 0;
1964
1965	my $last_blank_line = 0;
1966	my $last_coalesced_string_linenr = -1;
1967
1968	our @report = ();
1969	our $cnt_lines = 0;
1970	our $cnt_error = 0;
1971	our $cnt_warn = 0;
1972	our $cnt_chk = 0;
1973
1974	# Trace the real file/line as we go.
1975	my $realfile = '';
1976	my $realline = 0;
1977	my $realcnt = 0;
1978	my $here = '';
1979	my $in_comment = 0;
1980	my $comment_edge = 0;
1981	my $first_line = 0;
1982	my $p1_prefix = '';
1983
1984	my $prev_values = 'E';
1985
1986	# suppression flags
1987	my %suppress_ifbraces;
1988	my %suppress_whiletrailers;
1989	my %suppress_export;
1990	my $suppress_statement = 0;
1991
1992	my %signatures = ();
1993
1994	# Pre-scan the patch sanitizing the lines.
1995	# Pre-scan the patch looking for any __setup documentation.
1996	#
1997	my @setup_docs = ();
1998	my $setup_docs = 0;
1999
2000	my $camelcase_file_seeded = 0;
2001
2002	sanitise_line_reset();
2003	my $line;
2004	foreach my $rawline (@rawlines) {
2005		$linenr++;
2006		$line = $rawline;
2007
2008		push(@fixed, $rawline) if ($fix);
2009
2010		if ($rawline=~/^\+\+\+\s+(\S+)/) {
2011			$setup_docs = 0;
2012			if ($1 =~ m@Documentation/kernel-parameters.txt$@) {
2013				$setup_docs = 1;
2014			}
2015			#next;
2016		}
2017		if ($rawline=~/^\@\@ -\d+(?:,\d+)? \+(\d+)(,(\d+))? \@\@/) {
2018			$realline=$1-1;
2019			if (defined $2) {
2020				$realcnt=$3+1;
2021			} else {
2022				$realcnt=1+1;
2023			}
2024			$in_comment = 0;
2025
2026			# Guestimate if this is a continuing comment.  Run
2027			# the context looking for a comment "edge".  If this
2028			# edge is a close comment then we must be in a comment
2029			# at context start.
2030			my $edge;
2031			my $cnt = $realcnt;
2032			for (my $ln = $linenr + 1; $cnt > 0; $ln++) {
2033				next if (defined $rawlines[$ln - 1] &&
2034					 $rawlines[$ln - 1] =~ /^-/);
2035				$cnt--;
2036				#print "RAW<$rawlines[$ln - 1]>\n";
2037				last if (!defined $rawlines[$ln - 1]);
2038				if ($rawlines[$ln - 1] =~ m@(/\*|\*/)@ &&
2039				    $rawlines[$ln - 1] !~ m@"[^"]*(?:/\*|\*/)[^"]*"@) {
2040					($edge) = $1;
2041					last;
2042				}
2043			}
2044			if (defined $edge && $edge eq '*/') {
2045				$in_comment = 1;
2046			}
2047
2048			# Guestimate if this is a continuing comment.  If this
2049			# is the start of a diff block and this line starts
2050			# ' *' then it is very likely a comment.
2051			if (!defined $edge &&
2052			    $rawlines[$linenr] =~ m@^.\s*(?:\*\*+| \*)(?:\s|$)@)
2053			{
2054				$in_comment = 1;
2055			}
2056
2057			##print "COMMENT:$in_comment edge<$edge> $rawline\n";
2058			sanitise_line_reset($in_comment);
2059
2060		} elsif ($realcnt && $rawline =~ /^(?:\+| |$)/) {
2061			# Standardise the strings and chars within the input to
2062			# simplify matching -- only bother with positive lines.
2063			$line = sanitise_line($rawline);
2064		}
2065		push(@lines, $line);
2066
2067		if ($realcnt > 1) {
2068			$realcnt-- if ($line =~ /^(?:\+| |$)/);
2069		} else {
2070			$realcnt = 0;
2071		}
2072
2073		#print "==>$rawline\n";
2074		#print "-->$line\n";
2075
2076		if ($setup_docs && $line =~ /^\+/) {
2077			push(@setup_docs, $line);
2078		}
2079	}
2080
2081	$prefix = '';
2082
2083	$realcnt = 0;
2084	$linenr = 0;
2085	$fixlinenr = -1;
2086	foreach my $line (@lines) {
2087		$linenr++;
2088		$fixlinenr++;
2089		my $sline = $line;	#copy of $line
2090		$sline =~ s/$;/ /g;	#with comments as spaces
2091
2092		my $rawline = $rawlines[$linenr - 1];
2093
2094#extract the line range in the file after the patch is applied
2095		if (!$in_commit_log &&
2096		    $line =~ /^\@\@ -\d+(?:,\d+)? \+(\d+)(,(\d+))? \@\@/) {
2097			$is_patch = 1;
2098			$first_line = $linenr + 1;
2099			$realline=$1-1;
2100			if (defined $2) {
2101				$realcnt=$3+1;
2102			} else {
2103				$realcnt=1+1;
2104			}
2105			annotate_reset();
2106			$prev_values = 'E';
2107
2108			%suppress_ifbraces = ();
2109			%suppress_whiletrailers = ();
2110			%suppress_export = ();
2111			$suppress_statement = 0;
2112			next;
2113
2114# track the line number as we move through the hunk, note that
2115# new versions of GNU diff omit the leading space on completely
2116# blank context lines so we need to count that too.
2117		} elsif ($line =~ /^( |\+|$)/) {
2118			$realline++;
2119			$realcnt-- if ($realcnt != 0);
2120
2121			# Measure the line length and indent.
2122			($length, $indent) = line_stats($rawline);
2123
2124			# Track the previous line.
2125			($prevline, $stashline) = ($stashline, $line);
2126			($previndent, $stashindent) = ($stashindent, $indent);
2127			($prevrawline, $stashrawline) = ($stashrawline, $rawline);
2128
2129			#warn "line<$line>\n";
2130
2131		} elsif ($realcnt == 1) {
2132			$realcnt--;
2133		}
2134
2135		my $hunk_line = ($realcnt != 0);
2136
2137		$here = "#$linenr: " if (!$file);
2138		$here = "#$realline: " if ($file);
2139
2140		my $found_file = 0;
2141		# extract the filename as it passes
2142		if ($line =~ /^diff --git.*?(\S+)$/) {
2143			$realfile = $1;
2144			$realfile =~ s@^([^/]*)/@@ if (!$file);
2145			$in_commit_log = 0;
2146			$found_file = 1;
2147		} elsif ($line =~ /^\+\+\+\s+(\S+)/) {
2148			$realfile = $1;
2149			$realfile =~ s@^([^/]*)/@@ if (!$file);
2150			$in_commit_log = 0;
2151
2152			$p1_prefix = $1;
2153			if (!$file && $tree && $p1_prefix ne '' &&
2154			    -e "$root/$p1_prefix") {
2155				WARN("PATCH_PREFIX",
2156				     "patch prefix '$p1_prefix' exists, appears to be a -p0 patch\n");
2157			}
2158
2159			if ($realfile =~ m@^include/asm/@) {
2160				ERROR("MODIFIED_INCLUDE_ASM",
2161				      "do not modify files in include/asm, change architecture specific files in include/asm-<architecture>\n" . "$here$rawline\n");
2162			}
2163			$found_file = 1;
2164		}
2165
2166#make up the handle for any error we report on this line
2167		if ($showfile) {
2168			$prefix = "$realfile:$realline: "
2169		} elsif ($emacs) {
2170			if ($file) {
2171				$prefix = "$filename:$realline: ";
2172			} else {
2173				$prefix = "$filename:$linenr: ";
2174			}
2175		}
2176
2177		if ($found_file) {
2178			if ($realfile =~ m@^(?:drivers/net/|net/|drivers/staging/)@) {
2179				$check = 1;
2180			} else {
2181				$check = $check_orig;
2182			}
2183			next;
2184		}
2185
2186		$here .= "FILE: $realfile:$realline:" if ($realcnt != 0);
2187
2188		my $hereline = "$here\n$rawline\n";
2189		my $herecurr = "$here\n$rawline\n";
2190		my $hereprev = "$here\n$prevrawline\n$rawline\n";
2191
2192		$cnt_lines++ if ($realcnt != 0);
2193
2194# Check if the commit log has what seems like a diff which can confuse patch
2195		if ($in_commit_log && !$commit_log_has_diff &&
2196		    (($line =~ m@^\s+diff\b.*a/[\w/]+@ &&
2197		      $line =~ m@^\s+diff\b.*a/([\w/]+)\s+b/$1\b@) ||
2198		     $line =~ m@^\s*(?:\-\-\-\s+a/|\+\+\+\s+b/)@ ||
2199		     $line =~ m/^\s*\@\@ \-\d+,\d+ \+\d+,\d+ \@\@/)) {
2200			ERROR("DIFF_IN_COMMIT_MSG",
2201			      "Avoid using diff content in the commit message - patch(1) might not work\n" . $herecurr);
2202			$commit_log_has_diff = 1;
2203		}
2204
2205# Check for incorrect file permissions
2206		if ($line =~ /^new (file )?mode.*[7531]\d{0,2}$/) {
2207			my $permhere = $here . "FILE: $realfile\n";
2208			if ($realfile !~ m@scripts/@ &&
2209			    $realfile !~ /\.(py|pl|awk|sh)$/) {
2210				ERROR("EXECUTE_PERMISSIONS",
2211				      "do not set execute permissions for source files\n" . $permhere);
2212			}
2213		}
2214
2215# Check the patch for a signoff:
2216		if ($line =~ /^\s*signed-off-by:/i) {
2217			$signoff++;
2218			$in_commit_log = 0;
2219		}
2220
2221# Check if MAINTAINERS is being updated.  If so, there's probably no need to
2222# emit the "does MAINTAINERS need updating?" message on file add/move/delete
2223		if ($line =~ /^\s*MAINTAINERS\s*\|/) {
2224			$reported_maintainer_file = 1;
2225		}
2226
2227# Check signature styles
2228		if (!$in_header_lines &&
2229		    $line =~ /^(\s*)([a-z0-9_-]+by:|$signature_tags)(\s*)(.*)/i) {
2230			my $space_before = $1;
2231			my $sign_off = $2;
2232			my $space_after = $3;
2233			my $email = $4;
2234			my $ucfirst_sign_off = ucfirst(lc($sign_off));
2235
2236			if ($sign_off !~ /$signature_tags/) {
2237				WARN("BAD_SIGN_OFF",
2238				     "Non-standard signature: $sign_off\n" . $herecurr);
2239			}
2240			if (defined $space_before && $space_before ne "") {
2241				if (WARN("BAD_SIGN_OFF",
2242					 "Do not use whitespace before $ucfirst_sign_off\n" . $herecurr) &&
2243				    $fix) {
2244					$fixed[$fixlinenr] =
2245					    "$ucfirst_sign_off $email";
2246				}
2247			}
2248			if ($sign_off =~ /-by:$/i && $sign_off ne $ucfirst_sign_off) {
2249				if (WARN("BAD_SIGN_OFF",
2250					 "'$ucfirst_sign_off' is the preferred signature form\n" . $herecurr) &&
2251				    $fix) {
2252					$fixed[$fixlinenr] =
2253					    "$ucfirst_sign_off $email";
2254				}
2255
2256			}
2257			if (!defined $space_after || $space_after ne " ") {
2258				if (WARN("BAD_SIGN_OFF",
2259					 "Use a single space after $ucfirst_sign_off\n" . $herecurr) &&
2260				    $fix) {
2261					$fixed[$fixlinenr] =
2262					    "$ucfirst_sign_off $email";
2263				}
2264			}
2265
2266			my ($email_name, $email_address, $comment) = parse_email($email);
2267			my $suggested_email = format_email(($email_name, $email_address));
2268			if ($suggested_email eq "") {
2269				ERROR("BAD_SIGN_OFF",
2270				      "Unrecognized email address: '$email'\n" . $herecurr);
2271			} else {
2272				my $dequoted = $suggested_email;
2273				$dequoted =~ s/^"//;
2274				$dequoted =~ s/" </ </;
2275				# Don't force email to have quotes
2276				# Allow just an angle bracketed address
2277				if ("$dequoted$comment" ne $email &&
2278				    "<$email_address>$comment" ne $email &&
2279				    "$suggested_email$comment" ne $email) {
2280					WARN("BAD_SIGN_OFF",
2281					     "email address '$email' might be better as '$suggested_email$comment'\n" . $herecurr);
2282				}
2283			}
2284
2285# Check for duplicate signatures
2286			my $sig_nospace = $line;
2287			$sig_nospace =~ s/\s//g;
2288			$sig_nospace = lc($sig_nospace);
2289			if (defined $signatures{$sig_nospace}) {
2290				WARN("BAD_SIGN_OFF",
2291				     "Duplicate signature\n" . $herecurr);
2292			} else {
2293				$signatures{$sig_nospace} = 1;
2294			}
2295		}
2296
2297# Check email subject for common tools that don't need to be mentioned
2298		if ($in_header_lines &&
2299		    $line =~ /^Subject:.*\b(?:checkpatch|sparse|smatch)\b[^:]/i) {
2300			WARN("EMAIL_SUBJECT",
2301			     "A patch subject line should describe the change not the tool that found it\n" . $herecurr);
2302		}
2303
2304# Check for old stable address
2305		if ($line =~ /^\s*cc:\s*.*<?\bstable\@kernel\.org\b>?.*$/i) {
2306			ERROR("STABLE_ADDRESS",
2307			      "The 'stable' address should be 'stable\@vger.kernel.org'\n" . $herecurr);
2308		}
2309
2310# Check for unwanted Gerrit info
2311		if ($in_commit_log && $line =~ /^\s*change-id:/i) {
2312			ERROR("GERRIT_CHANGE_ID",
2313			      "Remove Gerrit Change-Id's before submitting upstream.\n" . $herecurr);
2314		}
2315
2316# Check for line lengths > 75 in commit log, warn once
2317		if ($in_commit_log && !$commit_log_long_line &&
2318                   length($line) > 75 &&
2319                   !($line =~ /^\s*[a-zA-Z0-9_\/\.]+\s+\|\s+\d+/ ||
2320                                       # file delta changes
2321                     $line =~ /^\s*(?:[\w\.\-]+\/)++[\w\.\-]+:/ ||
2322                                       # filename then :
2323                     $line =~ /^\s*(?:Fixes:|Link:)/i ||
2324                                       # A Fixes: or Link: line
2325                     $commit_log_possible_stack_dump)) {
2326			WARN("COMMIT_LOG_LONG_LINE",
2327			     "Possible unwrapped commit description (prefer a maximum 75 chars per line)\n" . $herecurr);
2328			$commit_log_long_line = 1;
2329		}
2330
2331# Check if the commit log is in a possible stack dump
2332               if ($in_commit_log && !$commit_log_possible_stack_dump &&
2333                   ($line =~ /^\s*(?:WARNING:|BUG:)/ ||
2334                    $line =~ /^\s*\[\s*\d+\.\d{6,6}\s*\]/ ||
2335                               # timestamp
2336                    $line =~ /^\s*\[\<[0-9a-fA-F]{8,}\>\]/)) {
2337                               # stack dump address
2338                       $commit_log_possible_stack_dump = 1;
2339               }
2340
2341# Reset possible stack dump if a blank line is found
2342               if ($in_commit_log && $commit_log_possible_stack_dump &&
2343                   $line =~ /^\s*$/) {
2344                       $commit_log_possible_stack_dump = 0;
2345               }
2346
2347# Check for git id commit length and improperly formed commit descriptions
2348		if ($in_commit_log &&
2349		    ($line =~ /\bcommit\s+[0-9a-f]{5,}\b/i ||
2350                    ($line =~ /\b[0-9a-f]{12,40}\b/i &&
2351                     $line !~ /\bfixes:\s*[0-9a-f]{12,40}/i))) {
2352			my $init_char = "c";
2353			my $orig_commit = "";
2354			my $short = 1;
2355			my $long = 0;
2356			my $case = 1;
2357			my $space = 1;
2358			my $hasdesc = 0;
2359			my $hasparens = 0;
2360			my $id = '0123456789ab';
2361			my $orig_desc = "commit description";
2362			my $description = "";
2363
2364			if ($line =~ /\b(c)ommit\s+([0-9a-f]{5,})\b/i) {
2365				$init_char = $1;
2366				$orig_commit = lc($2);
2367			} elsif ($line =~ /\b([0-9a-f]{12,40})\b/i) {
2368				$orig_commit = lc($1);
2369			}
2370
2371			$short = 0 if ($line =~ /\bcommit\s+[0-9a-f]{12,40}/i);
2372			$long = 1 if ($line =~ /\bcommit\s+[0-9a-f]{41,}/i);
2373			$space = 0 if ($line =~ /\bcommit [0-9a-f]/i);
2374			$case = 0 if ($line =~ /\b[Cc]ommit\s+[0-9a-f]{5,40}[^A-F]/);
2375			if ($line =~ /\bcommit\s+[0-9a-f]{5,}\s+\("([^"]+)"\)/i) {
2376				$orig_desc = $1;
2377				$hasparens = 1;
2378			} elsif ($line =~ /\bcommit\s+[0-9a-f]{5,}\s*$/i &&
2379				 defined $rawlines[$linenr] &&
2380				 $rawlines[$linenr] =~ /^\s*\("([^"]+)"\)/) {
2381				$orig_desc = $1;
2382				$hasparens = 1;
2383			} elsif ($line =~ /\bcommit\s+[0-9a-f]{5,}\s+\("[^"]+$/i &&
2384				 defined $rawlines[$linenr] &&
2385				 $rawlines[$linenr] =~ /^\s*[^"]+"\)/) {
2386				$line =~ /\bcommit\s+[0-9a-f]{5,}\s+\("([^"]+)$/i;
2387				$orig_desc = $1;
2388				$rawlines[$linenr] =~ /^\s*([^"]+)"\)/;
2389				$orig_desc .= " " . $1;
2390				$hasparens = 1;
2391			}
2392
2393			($id, $description) = git_commit_info($orig_commit,
2394							      $id, $orig_desc);
2395
2396			if ($short || $long || $space || $case || ($orig_desc ne $description) || !$hasparens) {
2397				ERROR("GIT_COMMIT_ID",
2398				      "Please use git commit description style 'commit <12+ chars of sha1> (\"<title line>\")' - ie: '${init_char}ommit $id (\"$description\")'\n" . $herecurr);
2399			}
2400		}
2401
2402# Check for added, moved or deleted files
2403		if (!$reported_maintainer_file && !$in_commit_log &&
2404		    ($line =~ /^(?:new|deleted) file mode\s*\d+\s*$/ ||
2405		     $line =~ /^rename (?:from|to) [\w\/\.\-]+\s*$/ ||
2406		     ($line =~ /\{\s*([\w\/\.\-]*)\s*\=\>\s*([\w\/\.\-]*)\s*\}/ &&
2407		      (defined($1) || defined($2))))) {
2408			$reported_maintainer_file = 1;
2409			WARN("FILE_PATH_CHANGES",
2410			     "added, moved or deleted file(s), does MAINTAINERS need updating?\n" . $herecurr);
2411		}
2412
2413# Check for wrappage within a valid hunk of the file
2414		if ($realcnt != 0 && $line !~ m{^(?:\+|-| |\\ No newline|$)}) {
2415			ERROR("CORRUPTED_PATCH",
2416			      "patch seems to be corrupt (line wrapped?)\n" .
2417				$herecurr) if (!$emitted_corrupt++);
2418		}
2419
2420# Check for absolute kernel paths.
2421		if ($tree) {
2422			while ($line =~ m{(?:^|\s)(/\S*)}g) {
2423				my $file = $1;
2424
2425				if ($file =~ m{^(.*?)(?::\d+)+:?$} &&
2426				    check_absolute_file($1, $herecurr)) {
2427					#
2428				} else {
2429					check_absolute_file($file, $herecurr);
2430				}
2431			}
2432		}
2433
2434# UTF-8 regex found at http://www.w3.org/International/questions/qa-forms-utf-8.en.php
2435		if (($realfile =~ /^$/ || $line =~ /^\+/) &&
2436		    $rawline !~ m/^$UTF8*$/) {
2437			my ($utf8_prefix) = ($rawline =~ /^($UTF8*)/);
2438
2439			my $blank = copy_spacing($rawline);
2440			my $ptr = substr($blank, 0, length($utf8_prefix)) . "^";
2441			my $hereptr = "$hereline$ptr\n";
2442
2443			CHK("INVALID_UTF8",
2444			    "Invalid UTF-8, patch and commit message should be encoded in UTF-8\n" . $hereptr);
2445		}
2446
2447# Check if it's the start of a commit log
2448# (not a header line and we haven't seen the patch filename)
2449		if ($in_header_lines && $realfile =~ /^$/ &&
2450		    !($rawline =~ /^\s+\S/ ||
2451		      $rawline =~ /^(commit\b|from\b|[\w-]+:).*$/i)) {
2452			$in_header_lines = 0;
2453			$in_commit_log = 1;
2454		}
2455
2456# Check if there is UTF-8 in a commit log when a mail header has explicitly
2457# declined it, i.e defined some charset where it is missing.
2458		if ($in_header_lines &&
2459		    $rawline =~ /^Content-Type:.+charset="(.+)".*$/ &&
2460		    $1 !~ /utf-8/i) {
2461			$non_utf8_charset = 1;
2462		}
2463
2464		if ($in_commit_log && $non_utf8_charset && $realfile =~ /^$/ &&
2465		    $rawline =~ /$NON_ASCII_UTF8/) {
2466			WARN("UTF8_BEFORE_PATCH",
2467			    "8-bit UTF-8 used in possible commit log\n" . $herecurr);
2468		}
2469
2470# Check for various typo / spelling mistakes
2471		if (defined($misspellings) &&
2472		    ($in_commit_log || $line =~ /^(?:\+|Subject:)/i)) {
2473			while ($rawline =~ /(?:^|[^a-z@])($misspellings)(?:\b|$|[^a-z@])/gi) {
2474				my $typo = $1;
2475				my $typo_fix = $spelling_fix{lc($typo)};
2476				$typo_fix = ucfirst($typo_fix) if ($typo =~ /^[A-Z]/);
2477				$typo_fix = uc($typo_fix) if ($typo =~ /^[A-Z]+$/);
2478				my $msg_type = \&WARN;
2479				$msg_type = \&CHK if ($file);
2480				if (&{$msg_type}("TYPO_SPELLING",
2481						 "'$typo' may be misspelled - perhaps '$typo_fix'?\n" . $herecurr) &&
2482				    $fix) {
2483					$fixed[$fixlinenr] =~ s/(^|[^A-Za-z@])($typo)($|[^A-Za-z@])/$1$typo_fix$3/;
2484				}
2485			}
2486		}
2487
2488# ignore non-hunk lines and lines being removed
2489		next if (!$hunk_line || $line =~ /^-/);
2490
2491#trailing whitespace
2492		if ($line =~ /^\+.*\015/) {
2493			my $herevet = "$here\n" . cat_vet($rawline) . "\n";
2494			if (ERROR("DOS_LINE_ENDINGS",
2495				  "DOS line endings\n" . $herevet) &&
2496			    $fix) {
2497				$fixed[$fixlinenr] =~ s/[\s\015]+$//;
2498			}
2499		} elsif ($rawline =~ /^\+.*\S\s+$/ || $rawline =~ /^\+\s+$/) {
2500			my $herevet = "$here\n" . cat_vet($rawline) . "\n";
2501			if (ERROR("TRAILING_WHITESPACE",
2502				  "trailing whitespace\n" . $herevet) &&
2503			    $fix) {
2504				$fixed[$fixlinenr] =~ s/\s+$//;
2505			}
2506
2507			$rpt_cleaners = 1;
2508		}
2509
2510# Check for FSF mailing addresses.
2511		if ($rawline =~ /\bwrite to the Free/i ||
2512		    $rawline =~ /\b59\s+Temple\s+Pl/i ||
2513		    $rawline =~ /\b51\s+Franklin\s+St/i) {
2514			my $herevet = "$here\n" . cat_vet($rawline) . "\n";
2515			my $msg_type = \&ERROR;
2516			$msg_type = \&CHK if ($file);
2517			&{$msg_type}("FSF_MAILING_ADDRESS",
2518				     "Do not include the paragraph about writing to the Free Software Foundation's mailing address from the sample GPL notice. The FSF has changed addresses in the past, and may do so again. Linux already includes a copy of the GPL.\n" . $herevet)
2519		}
2520
2521# check for Kconfig help text having a real description
2522# Only applies when adding the entry originally, after that we do not have
2523# sufficient context to determine whether it is indeed long enough.
2524		if ($realfile =~ /Kconfig/ &&
2525		    $line =~ /^\+\s*config\s+/) {
2526			my $length = 0;
2527			my $cnt = $realcnt;
2528			my $ln = $linenr + 1;
2529			my $f;
2530			my $is_start = 0;
2531			my $is_end = 0;
2532			for (; $cnt > 0 && defined $lines[$ln - 1]; $ln++) {
2533				$f = $lines[$ln - 1];
2534				$cnt-- if ($lines[$ln - 1] !~ /^-/);
2535				$is_end = $lines[$ln - 1] =~ /^\+/;
2536
2537				next if ($f =~ /^-/);
2538				last if (!$file && $f =~ /^\@\@/);
2539
2540				if ($lines[$ln - 1] =~ /^\+\s*(?:bool|tristate)\s*\"/) {
2541					$is_start = 1;
2542				} elsif ($lines[$ln - 1] =~ /^\+\s*(?:---)?help(?:---)?$/) {
2543					$length = -1;
2544				}
2545
2546				$f =~ s/^.//;
2547				$f =~ s/#.*//;
2548				$f =~ s/^\s+//;
2549				next if ($f =~ /^$/);
2550				if ($f =~ /^\s*config\s/) {
2551					$is_end = 1;
2552					last;
2553				}
2554				$length++;
2555			}
2556			if ($is_start && $is_end && $length < $min_conf_desc_length) {
2557				WARN("CONFIG_DESCRIPTION",
2558				     "please write a paragraph that describes the config symbol fully\n" . $herecurr);
2559			}
2560			#print "is_start<$is_start> is_end<$is_end> length<$length>\n";
2561		}
2562
2563# discourage the addition of CONFIG_EXPERIMENTAL in Kconfig.
2564		if ($realfile =~ /Kconfig/ &&
2565		    $line =~ /.\s*depends on\s+.*\bEXPERIMENTAL\b/) {
2566			WARN("CONFIG_EXPERIMENTAL",
2567			     "Use of CONFIG_EXPERIMENTAL is deprecated. For alternatives, see https://lkml.org/lkml/2012/10/23/580\n");
2568		}
2569
2570# discourage the use of boolean for type definition attributes of Kconfig options
2571		if ($realfile =~ /Kconfig/ &&
2572		    $line =~ /^\+\s*\bboolean\b/) {
2573			WARN("CONFIG_TYPE_BOOLEAN",
2574			     "Use of boolean is deprecated, please use bool instead.\n" . $herecurr);
2575		}
2576
2577		if (($realfile =~ /Makefile.*/ || $realfile =~ /Kbuild.*/) &&
2578		    ($line =~ /\+(EXTRA_[A-Z]+FLAGS).*/)) {
2579			my $flag = $1;
2580			my $replacement = {
2581				'EXTRA_AFLAGS' =>   'asflags-y',
2582				'EXTRA_CFLAGS' =>   'ccflags-y',
2583				'EXTRA_CPPFLAGS' => 'cppflags-y',
2584				'EXTRA_LDFLAGS' =>  'ldflags-y',
2585			};
2586
2587			WARN("DEPRECATED_VARIABLE",
2588			     "Use of $flag is deprecated, please use \`$replacement->{$flag} instead.\n" . $herecurr) if ($replacement->{$flag});
2589		}
2590
2591# check for DT compatible documentation
2592		if (defined $root &&
2593			(($realfile =~ /\.dtsi?$/ && $line =~ /^\+\s*compatible\s*=\s*\"/) ||
2594			 ($realfile =~ /\.[ch]$/ && $line =~ /^\+.*\.compatible\s*=\s*\"/))) {
2595
2596			my @compats = $rawline =~ /\"([a-zA-Z0-9\-\,\.\+_]+)\"/g;
2597
2598			my $dt_path = $root . "/Documentation/devicetree/bindings/";
2599			my $vp_file = $dt_path . "vendor-prefixes.txt";
2600
2601			foreach my $compat (@compats) {
2602				my $compat2 = $compat;
2603				$compat2 =~ s/\,[a-zA-Z0-9]*\-/\,<\.\*>\-/;
2604				my $compat3 = $compat;
2605				$compat3 =~ s/\,([a-z]*)[0-9]*\-/\,$1<\.\*>\-/;
2606				`grep -Erq "$compat|$compat2|$compat3" $dt_path`;
2607				if ( $? >> 8 ) {
2608					WARN("UNDOCUMENTED_DT_STRING",
2609					     "DT compatible string \"$compat\" appears un-documented -- check $dt_path\n" . $herecurr);
2610				}
2611
2612				next if $compat !~ /^([a-zA-Z0-9\-]+)\,/;
2613				my $vendor = $1;
2614				`grep -Eq "^$vendor\\b" $vp_file`;
2615				if ( $? >> 8 ) {
2616					WARN("UNDOCUMENTED_DT_STRING",
2617					     "DT compatible string vendor \"$vendor\" appears un-documented -- check $vp_file\n" . $herecurr);
2618				}
2619			}
2620		}
2621
2622# check we are in a valid source file if not then ignore this hunk
2623		next if ($realfile !~ /\.(h|c|s|S|pl|sh|dtsi|dts)$/);
2624
2625# line length limit (with some exclusions)
2626#
2627# There are a few types of lines that may extend beyond $max_line_length:
2628#	logging functions like pr_info that end in a string
2629#	lines with a single string
2630#	#defines that are a single string
2631#
2632# There are 3 different line length message types:
2633# LONG_LINE_COMMENT	a comment starts before but extends beyond $max_linelength
2634# LONG_LINE_STRING	a string starts before but extends beyond $max_line_length
2635# LONG_LINE		all other lines longer than $max_line_length
2636#
2637# if LONG_LINE is ignored, the other 2 types are also ignored
2638#
2639
2640		if ($line =~ /^\+/ && $length > $max_line_length) {
2641			my $msg_type = "LONG_LINE";
2642
2643			# Check the allowed long line types first
2644
2645			# logging functions that end in a string that starts
2646			# before $max_line_length
2647			if ($line =~ /^\+\s*$logFunctions\s*\(\s*(?:(?:KERN_\S+\s*|[^"]*))?($String\s*(?:|,|\)\s*;)\s*)$/ &&
2648			    length(expand_tabs(substr($line, 1, length($line) - length($1) - 1))) <= $max_line_length) {
2649				$msg_type = "";
2650
2651			# lines with only strings (w/ possible termination)
2652			# #defines with only strings
2653			} elsif ($line =~ /^\+\s*$String\s*(?:\s*|,|\)\s*;)\s*$/ ||
2654				 $line =~ /^\+\s*#\s*define\s+\w+\s+$String$/) {
2655				$msg_type = "";
2656
2657			# Otherwise set the alternate message types
2658
2659			# a comment starts before $max_line_length
2660			} elsif ($line =~ /($;[\s$;]*)$/ &&
2661				 length(expand_tabs(substr($line, 1, length($line) - length($1) - 1))) <= $max_line_length) {
2662				$msg_type = "LONG_LINE_COMMENT"
2663
2664			# a quoted string starts before $max_line_length
2665			} elsif ($sline =~ /\s*($String(?:\s*(?:\\|,\s*|\)\s*;\s*))?)$/ &&
2666				 length(expand_tabs(substr($line, 1, length($line) - length($1) - 1))) <= $max_line_length) {
2667				$msg_type = "LONG_LINE_STRING"
2668			}
2669
2670			if ($msg_type ne "" &&
2671			    (show_type("LONG_LINE") || show_type($msg_type))) {
2672				WARN($msg_type,
2673				     "line over $max_line_length characters\n" . $herecurr);
2674			}
2675		}
2676
2677# check for adding lines without a newline.
2678		if ($line =~ /^\+/ && defined $lines[$linenr] && $lines[$linenr] =~ /^\\ No newline at end of file/) {
2679			WARN("MISSING_EOF_NEWLINE",
2680			     "adding a line without newline at end of file\n" . $herecurr);
2681		}
2682
2683# Blackfin: use hi/lo macros
2684		if ($realfile =~ m@arch/blackfin/.*\.S$@) {
2685			if ($line =~ /\.[lL][[:space:]]*=.*&[[:space:]]*0x[fF][fF][fF][fF]/) {
2686				my $herevet = "$here\n" . cat_vet($line) . "\n";
2687				ERROR("LO_MACRO",
2688				      "use the LO() macro, not (... & 0xFFFF)\n" . $herevet);
2689			}
2690			if ($line =~ /\.[hH][[:space:]]*=.*>>[[:space:]]*16/) {
2691				my $herevet = "$here\n" . cat_vet($line) . "\n";
2692				ERROR("HI_MACRO",
2693				      "use the HI() macro, not (... >> 16)\n" . $herevet);
2694			}
2695		}
2696
2697# check we are in a valid source file C or perl if not then ignore this hunk
2698		next if ($realfile !~ /\.(h|c|pl|dtsi|dts)$/);
2699
2700# at the beginning of a line any tabs must come first and anything
2701# more than 8 must use tabs.
2702		if ($rawline =~ /^\+\s* \t\s*\S/ ||
2703		    $rawline =~ /^\+\s*        \s*/) {
2704			my $herevet = "$here\n" . cat_vet($rawline) . "\n";
2705			$rpt_cleaners = 1;
2706			if (ERROR("CODE_INDENT",
2707				  "code indent should use tabs where possible\n" . $herevet) &&
2708			    $fix) {
2709				$fixed[$fixlinenr] =~ s/^\+([ \t]+)/"\+" . tabify($1)/e;
2710			}
2711		}
2712
2713# check for space before tabs.
2714		if ($rawline =~ /^\+/ && $rawline =~ / \t/) {
2715			my $herevet = "$here\n" . cat_vet($rawline) . "\n";
2716			if (WARN("SPACE_BEFORE_TAB",
2717				"please, no space before tabs\n" . $herevet) &&
2718			    $fix) {
2719				while ($fixed[$fixlinenr] =~
2720					   s/(^\+.*) {8,8}\t/$1\t\t/) {}
2721				while ($fixed[$fixlinenr] =~
2722					   s/(^\+.*) +\t/$1\t/) {}
2723			}
2724		}
2725
2726# check for && or || at the start of a line
2727		if ($rawline =~ /^\+\s*(&&|\|\|)/) {
2728			CHK("LOGICAL_CONTINUATIONS",
2729			    "Logical continuations should be on the previous line\n" . $hereprev);
2730		}
2731
2732# check multi-line statement indentation matches previous line
2733		if ($^V && $^V ge 5.10.0 &&
2734		    $prevline =~ /^\+([ \t]*)((?:$c90_Keywords(?:\s+if)\s*)|(?:$Declare\s*)?(?:$Ident|\(\s*\*\s*$Ident\s*\))\s*|$Ident\s*=\s*$Ident\s*)\(.*(\&\&|\|\||,)\s*$/) {
2735			$prevline =~ /^\+(\t*)(.*)$/;
2736			my $oldindent = $1;
2737			my $rest = $2;
2738
2739			my $pos = pos_last_openparen($rest);
2740			if ($pos >= 0) {
2741				$line =~ /^(\+| )([ \t]*)/;
2742				my $newindent = $2;
2743
2744				my $goodtabindent = $oldindent .
2745					"\t" x ($pos / 8) .
2746					" "  x ($pos % 8);
2747				my $goodspaceindent = $oldindent . " "  x $pos;
2748
2749				if ($newindent ne $goodtabindent &&
2750				    $newindent ne $goodspaceindent) {
2751
2752					if (CHK("PARENTHESIS_ALIGNMENT",
2753						"Alignment should match open parenthesis\n" . $hereprev) &&
2754					    $fix && $line =~ /^\+/) {
2755						$fixed[$fixlinenr] =~
2756						    s/^\+[ \t]*/\+$goodtabindent/;
2757					}
2758				}
2759			}
2760		}
2761
2762# check for space after cast like "(int) foo" or "(struct foo) bar"
2763# avoid checking a few false positives:
2764#   "sizeof(<type>)" or "__alignof__(<type>)"
2765#   function pointer declarations like "(*foo)(int) = bar;"
2766#   structure definitions like "(struct foo) { 0 };"
2767#   multiline macros that define functions
2768#   known attributes or the __attribute__ keyword
2769		if ($line =~ /^\+(.*)\(\s*$Type\s*\)([ \t]++)((?![={]|\\$|$Attribute|__attribute__))/ &&
2770		    (!defined($1) || $1 !~ /\b(?:sizeof|__alignof__)\s*$/)) {
2771			if (CHK("SPACING",
2772				"No space is necessary after a cast\n" . $herecurr) &&
2773			    $fix) {
2774				$fixed[$fixlinenr] =~
2775				    s/(\(\s*$Type\s*\))[ \t]+/$1/;
2776			}
2777		}
2778
2779# Block comment styles
2780# Networking with an initial /*
2781		if ($realfile =~ m@^(drivers/net/|net/)@ &&
2782		    $prevrawline =~ /^\+[ \t]*\/\*[ \t]*$/ &&
2783		    $rawline =~ /^\+[ \t]*\*/ &&
2784		    $realline > 2) {
2785			WARN("NETWORKING_BLOCK_COMMENT_STYLE",
2786			     "networking block comments don't use an empty /* line, use /* Comment...\n" . $hereprev);
2787		}
2788
2789# Block comments use * on subsequent lines
2790		if ($prevline =~ /$;[ \t]*$/ &&			#ends in comment
2791		    $prevrawline =~ /^\+.*?\/\*/ &&		#starting /*
2792		    $prevrawline !~ /\*\/[ \t]*$/ &&		#no trailing */
2793		    $rawline =~ /^\+/ &&			#line is new
2794		    $rawline !~ /^\+[ \t]*\*/) {		#no leading *
2795			WARN("BLOCK_COMMENT_STYLE",
2796			     "Block comments use * on subsequent lines\n" . $hereprev);
2797		}
2798
2799# Block comments use */ on trailing lines
2800		if ($rawline !~ m@^\+[ \t]*\*/[ \t]*$@ &&	#trailing */
2801		    $rawline !~ m@^\+.*/\*.*\*/[ \t]*$@ &&	#inline /*...*/
2802		    $rawline !~ m@^\+.*\*{2,}/[ \t]*$@ &&	#trailing **/
2803		    $rawline =~ m@^\+[ \t]*.+\*\/[ \t]*$@) {	#non blank */
2804			WARN("BLOCK_COMMENT_STYLE",
2805			     "Block comments use a trailing */ on a separate line\n" . $herecurr);
2806		}
2807
2808# check for missing blank lines after struct/union declarations
2809# with exceptions for various attributes and macros
2810		if ($prevline =~ /^[\+ ]};?\s*$/ &&
2811		    $line =~ /^\+/ &&
2812		    !($line =~ /^\+\s*$/ ||
2813		      $line =~ /^\+\s*EXPORT_SYMBOL/ ||
2814		      $line =~ /^\+\s*MODULE_/i ||
2815		      $line =~ /^\+\s*\#\s*(?:end|elif|else)/ ||
2816		      $line =~ /^\+[a-z_]*init/ ||
2817		      $line =~ /^\+\s*(?:static\s+)?[A-Z_]*ATTR/ ||
2818		      $line =~ /^\+\s*DECLARE/ ||
2819		      $line =~ /^\+\s*__setup/)) {
2820			if (CHK("LINE_SPACING",
2821				"Please use a blank line after function/struct/union/enum declarations\n" . $hereprev) &&
2822			    $fix) {
2823				fix_insert_line($fixlinenr, "\+");
2824			}
2825		}
2826
2827# check for multiple consecutive blank lines
2828		if ($prevline =~ /^[\+ ]\s*$/ &&
2829		    $line =~ /^\+\s*$/ &&
2830		    $last_blank_line != ($linenr - 1)) {
2831			if (CHK("LINE_SPACING",
2832				"Please don't use multiple blank lines\n" . $hereprev) &&
2833			    $fix) {
2834				fix_delete_line($fixlinenr, $rawline);
2835			}
2836
2837			$last_blank_line = $linenr;
2838		}
2839
2840# check for missing blank lines after declarations
2841		if ($sline =~ /^\+\s+\S/ &&			#Not at char 1
2842			# actual declarations
2843		    ($prevline =~ /^\+\s+$Declare\s*$Ident\s*[=,;:\[]/ ||
2844			# function pointer declarations
2845		     $prevline =~ /^\+\s+$Declare\s*\(\s*\*\s*$Ident\s*\)\s*[=,;:\[\(]/ ||
2846			# foo bar; where foo is some local typedef or #define
2847		     $prevline =~ /^\+\s+$Ident(?:\s+|\s*\*\s*)$Ident\s*[=,;\[]/ ||
2848			# known declaration macros
2849		     $prevline =~ /^\+\s+$declaration_macros/) &&
2850			# for "else if" which can look like "$Ident $Ident"
2851		    !($prevline =~ /^\+\s+$c90_Keywords\b/ ||
2852			# other possible extensions of declaration lines
2853		      $prevline =~ /(?:$Compare|$Assignment|$Operators)\s*$/ ||
2854			# not starting a section or a macro "\" extended line
2855		      $prevline =~ /(?:\{\s*|\\)$/) &&
2856			# looks like a declaration
2857		    !($sline =~ /^\+\s+$Declare\s*$Ident\s*[=,;:\[]/ ||
2858			# function pointer declarations
2859		      $sline =~ /^\+\s+$Declare\s*\(\s*\*\s*$Ident\s*\)\s*[=,;:\[\(]/ ||
2860			# foo bar; where foo is some local typedef or #define
2861		      $sline =~ /^\+\s+$Ident(?:\s+|\s*\*\s*)$Ident\s*[=,;\[]/ ||
2862			# known declaration macros
2863		      $sline =~ /^\+\s+$declaration_macros/ ||
2864			# start of struct or union or enum
2865		      $sline =~ /^\+\s+(?:union|struct|enum|typedef)\b/ ||
2866			# start or end of block or continuation of declaration
2867		      $sline =~ /^\+\s+(?:$|[\{\}\.\#\"\?\:\(\[])/ ||
2868			# bitfield continuation
2869		      $sline =~ /^\+\s+$Ident\s*:\s*\d+\s*[,;]/ ||
2870			# other possible extensions of declaration lines
2871		      $sline =~ /^\+\s+\(?\s*(?:$Compare|$Assignment|$Operators)/) &&
2872			# indentation of previous and current line are the same
2873		    (($prevline =~ /\+(\s+)\S/) && $sline =~ /^\+$1\S/)) {
2874			if (WARN("LINE_SPACING",
2875				 "Missing a blank line after declarations\n" . $hereprev) &&
2876			    $fix) {
2877				fix_insert_line($fixlinenr, "\+");
2878			}
2879		}
2880
2881# check for spaces at the beginning of a line.
2882# Exceptions:
2883#  1) within comments
2884#  2) indented preprocessor commands
2885#  3) hanging labels
2886		if ($rawline =~ /^\+ / && $line !~ /^\+ *(?:$;|#|$Ident:)/)  {
2887			my $herevet = "$here\n" . cat_vet($rawline) . "\n";
2888			if (WARN("LEADING_SPACE",
2889				 "please, no spaces at the start of a line\n" . $herevet) &&
2890			    $fix) {
2891				$fixed[$fixlinenr] =~ s/^\+([ \t]+)/"\+" . tabify($1)/e;
2892			}
2893		}
2894
2895# check we are in a valid C source file if not then ignore this hunk
2896		next if ($realfile !~ /\.(h|c)$/);
2897
2898# check indentation of any line with a bare else
2899# (but not if it is a multiple line "if (foo) return bar; else return baz;")
2900# if the previous line is a break or return and is indented 1 tab more...
2901		if ($sline =~ /^\+([\t]+)(?:}[ \t]*)?else(?:[ \t]*{)?\s*$/) {
2902			my $tabs = length($1) + 1;
2903			if ($prevline =~ /^\+\t{$tabs,$tabs}break\b/ ||
2904			    ($prevline =~ /^\+\t{$tabs,$tabs}return\b/ &&
2905			     defined $lines[$linenr] &&
2906			     $lines[$linenr] !~ /^[ \+]\t{$tabs,$tabs}return/)) {
2907				WARN("UNNECESSARY_ELSE",
2908				     "else is not generally useful after a break or return\n" . $hereprev);
2909			}
2910		}
2911
2912# check indentation of a line with a break;
2913# if the previous line is a goto or return and is indented the same # of tabs
2914		if ($sline =~ /^\+([\t]+)break\s*;\s*$/) {
2915			my $tabs = $1;
2916			if ($prevline =~ /^\+$tabs(?:goto|return)\b/) {
2917				WARN("UNNECESSARY_BREAK",
2918				     "break is not useful after a goto or return\n" . $hereprev);
2919			}
2920		}
2921
2922# discourage the addition of CONFIG_EXPERIMENTAL in #if(def).
2923		if ($line =~ /^\+\s*\#\s*if.*\bCONFIG_EXPERIMENTAL\b/) {
2924			WARN("CONFIG_EXPERIMENTAL",
2925			     "Use of CONFIG_EXPERIMENTAL is deprecated. For alternatives, see https://lkml.org/lkml/2012/10/23/580\n");
2926		}
2927
2928# check for RCS/CVS revision markers
2929		if ($rawline =~ /^\+.*\$(Revision|Log|Id)(?:\$|)/) {
2930			WARN("CVS_KEYWORD",
2931			     "CVS style keyword markers, these will _not_ be updated\n". $herecurr);
2932		}
2933
2934# Blackfin: don't use __builtin_bfin_[cs]sync
2935		if ($line =~ /__builtin_bfin_csync/) {
2936			my $herevet = "$here\n" . cat_vet($line) . "\n";
2937			ERROR("CSYNC",
2938			      "use the CSYNC() macro in asm/blackfin.h\n" . $herevet);
2939		}
2940		if ($line =~ /__builtin_bfin_ssync/) {
2941			my $herevet = "$here\n" . cat_vet($line) . "\n";
2942			ERROR("SSYNC",
2943			      "use the SSYNC() macro in asm/blackfin.h\n" . $herevet);
2944		}
2945
2946# check for old HOTPLUG __dev<foo> section markings
2947		if ($line =~ /\b(__dev(init|exit)(data|const|))\b/) {
2948			WARN("HOTPLUG_SECTION",
2949			     "Using $1 is unnecessary\n" . $herecurr);
2950		}
2951
2952# Check for potential 'bare' types
2953		my ($stat, $cond, $line_nr_next, $remain_next, $off_next,
2954		    $realline_next);
2955#print "LINE<$line>\n";
2956		if ($linenr >= $suppress_statement &&
2957		    $realcnt && $sline =~ /.\s*\S/) {
2958			($stat, $cond, $line_nr_next, $remain_next, $off_next) =
2959				ctx_statement_block($linenr, $realcnt, 0);
2960			$stat =~ s/\n./\n /g;
2961			$cond =~ s/\n./\n /g;
2962
2963#print "linenr<$linenr> <$stat>\n";
2964			# If this statement has no statement boundaries within
2965			# it there is no point in retrying a statement scan
2966			# until we hit end of it.
2967			my $frag = $stat; $frag =~ s/;+\s*$//;
2968			if ($frag !~ /(?:{|;)/) {
2969#print "skip<$line_nr_next>\n";
2970				$suppress_statement = $line_nr_next;
2971			}
2972
2973			# Find the real next line.
2974			$realline_next = $line_nr_next;
2975			if (defined $realline_next &&
2976			    (!defined $lines[$realline_next - 1] ||
2977			     substr($lines[$realline_next - 1], $off_next) =~ /^\s*$/)) {
2978				$realline_next++;
2979			}
2980
2981			my $s = $stat;
2982			$s =~ s/{.*$//s;
2983
2984			# Ignore goto labels.
2985			if ($s =~ /$Ident:\*$/s) {
2986
2987			# Ignore functions being called
2988			} elsif ($s =~ /^.\s*$Ident\s*\(/s) {
2989
2990			} elsif ($s =~ /^.\s*else\b/s) {
2991
2992			# declarations always start with types
2993			} elsif ($prev_values eq 'E' && $s =~ /^.\s*(?:$Storage\s+)?(?:$Inline\s+)?(?:const\s+)?((?:\s*$Ident)+?)\b(?:\s+$Sparse)?\s*\**\s*(?:$Ident|\(\*[^\)]*\))(?:\s*$Modifier)?\s*(?:;|=|,|\()/s) {
2994				my $type = $1;
2995				$type =~ s/\s+/ /g;
2996				possible($type, "A:" . $s);
2997
2998			# definitions in global scope can only start with types
2999			} elsif ($s =~ /^.(?:$Storage\s+)?(?:$Inline\s+)?(?:const\s+)?($Ident)\b\s*(?!:)/s) {
3000				possible($1, "B:" . $s);
3001			}
3002
3003			# any (foo ... *) is a pointer cast, and foo is a type
3004			while ($s =~ /\(($Ident)(?:\s+$Sparse)*[\s\*]+\s*\)/sg) {
3005				possible($1, "C:" . $s);
3006			}
3007
3008			# Check for any sort of function declaration.
3009			# int foo(something bar, other baz);
3010			# void (*store_gdt)(x86_descr_ptr *);
3011			if ($prev_values eq 'E' && $s =~ /^(.(?:typedef\s*)?(?:(?:$Storage|$Inline)\s*)*\s*$Type\s*(?:\b$Ident|\(\*\s*$Ident\))\s*)\(/s) {
3012				my ($name_len) = length($1);
3013
3014				my $ctx = $s;
3015				substr($ctx, 0, $name_len + 1, '');
3016				$ctx =~ s/\)[^\)]*$//;
3017
3018				for my $arg (split(/\s*,\s*/, $ctx)) {
3019					if ($arg =~ /^(?:const\s+)?($Ident)(?:\s+$Sparse)*\s*\**\s*(:?\b$Ident)?$/s || $arg =~ /^($Ident)$/s) {
3020
3021						possible($1, "D:" . $s);
3022					}
3023				}
3024			}
3025
3026		}
3027
3028#
3029# Checks which may be anchored in the context.
3030#
3031
3032# Check for switch () and associated case and default
3033# statements should be at the same indent.
3034		if ($line=~/\bswitch\s*\(.*\)/) {
3035			my $err = '';
3036			my $sep = '';
3037			my @ctx = ctx_block_outer($linenr, $realcnt);
3038			shift(@ctx);
3039			for my $ctx (@ctx) {
3040				my ($clen, $cindent) = line_stats($ctx);
3041				if ($ctx =~ /^\+\s*(case\s+|default:)/ &&
3042							$indent != $cindent) {
3043					$err .= "$sep$ctx\n";
3044					$sep = '';
3045				} else {
3046					$sep = "[...]\n";
3047				}
3048			}
3049			if ($err ne '') {
3050				ERROR("SWITCH_CASE_INDENT_LEVEL",
3051				      "switch and case should be at the same indent\n$hereline$err");
3052			}
3053		}
3054
3055# if/while/etc brace do not go on next line, unless defining a do while loop,
3056# or if that brace on the next line is for something else
3057		if ($line =~ /(.*)\b((?:if|while|for|switch|(?:[a-z_]+|)for_each[a-z_]+)\s*\(|do\b|else\b)/ && $line !~ /^.\s*\#/) {
3058			my $pre_ctx = "$1$2";
3059
3060			my ($level, @ctx) = ctx_statement_level($linenr, $realcnt, 0);
3061
3062			if ($line =~ /^\+\t{6,}/) {
3063				WARN("DEEP_INDENTATION",
3064				     "Too many leading tabs - consider code refactoring\n" . $herecurr);
3065			}
3066
3067			my $ctx_cnt = $realcnt - $#ctx - 1;
3068			my $ctx = join("\n", @ctx);
3069
3070			my $ctx_ln = $linenr;
3071			my $ctx_skip = $realcnt;
3072
3073			while ($ctx_skip > $ctx_cnt || ($ctx_skip == $ctx_cnt &&
3074					defined $lines[$ctx_ln - 1] &&
3075					$lines[$ctx_ln - 1] =~ /^-/)) {
3076				##print "SKIP<$ctx_skip> CNT<$ctx_cnt>\n";
3077				$ctx_skip-- if (!defined $lines[$ctx_ln - 1] || $lines[$ctx_ln - 1] !~ /^-/);
3078				$ctx_ln++;
3079			}
3080
3081			#print "realcnt<$realcnt> ctx_cnt<$ctx_cnt>\n";
3082			#print "pre<$pre_ctx>\nline<$line>\nctx<$ctx>\nnext<$lines[$ctx_ln - 1]>\n";
3083
3084			if ($ctx !~ /{\s*/ && defined($lines[$ctx_ln - 1]) && $lines[$ctx_ln - 1] =~ /^\+\s*{/) {
3085				ERROR("OPEN_BRACE",
3086				      "that open brace { should be on the previous line\n" .
3087					"$here\n$ctx\n$rawlines[$ctx_ln - 1]\n");
3088			}
3089			if ($level == 0 && $pre_ctx !~ /}\s*while\s*\($/ &&
3090			    $ctx =~ /\)\s*\;\s*$/ &&
3091			    defined $lines[$ctx_ln - 1])
3092			{
3093				my ($nlength, $nindent) = line_stats($lines[$ctx_ln - 1]);
3094				if ($nindent > $indent) {
3095					WARN("TRAILING_SEMICOLON",
3096					     "trailing semicolon indicates no statements, indent implies otherwise\n" .
3097						"$here\n$ctx\n$rawlines[$ctx_ln - 1]\n");
3098				}
3099			}
3100		}
3101
3102# Check relative indent for conditionals and blocks.
3103		if ($line =~ /\b(?:(?:if|while|for|(?:[a-z_]+|)for_each[a-z_]+)\s*\(|do\b)/ && $line !~ /^.\s*#/ && $line !~ /\}\s*while\s*/) {
3104			($stat, $cond, $line_nr_next, $remain_next, $off_next) =
3105				ctx_statement_block($linenr, $realcnt, 0)
3106					if (!defined $stat);
3107			my ($s, $c) = ($stat, $cond);
3108
3109			substr($s, 0, length($c), '');
3110
3111			# remove inline comments
3112			$s =~ s/$;/ /g;
3113			$c =~ s/$;/ /g;
3114
3115			# Find out how long the conditional actually is.
3116			my @newlines = ($c =~ /\n/gs);
3117			my $cond_lines = 1 + $#newlines;
3118
3119			# Make sure we remove the line prefixes as we have
3120			# none on the first line, and are going to readd them
3121			# where necessary.
3122			$s =~ s/\n./\n/gs;
3123			while ($s =~ /\n\s+\\\n/) {
3124				$cond_lines += $s =~ s/\n\s+\\\n/\n/g;
3125			}
3126
3127			# We want to check the first line inside the block
3128			# starting at the end of the conditional, so remove:
3129			#  1) any blank line termination
3130			#  2) any opening brace { on end of the line
3131			#  3) any do (...) {
3132			my $continuation = 0;
3133			my $check = 0;
3134			$s =~ s/^.*\bdo\b//;
3135			$s =~ s/^\s*{//;
3136			if ($s =~ s/^\s*\\//) {
3137				$continuation = 1;
3138			}
3139			if ($s =~ s/^\s*?\n//) {
3140				$check = 1;
3141				$cond_lines++;
3142			}
3143
3144			# Also ignore a loop construct at the end of a
3145			# preprocessor statement.
3146			if (($prevline =~ /^.\s*#\s*define\s/ ||
3147			    $prevline =~ /\\\s*$/) && $continuation == 0) {
3148				$check = 0;
3149			}
3150
3151			my $cond_ptr = -1;
3152			$continuation = 0;
3153			while ($cond_ptr != $cond_lines) {
3154				$cond_ptr = $cond_lines;
3155
3156				# If we see an #else/#elif then the code
3157				# is not linear.
3158				if ($s =~ /^\s*\#\s*(?:else|elif)/) {
3159					$check = 0;
3160				}
3161
3162				# Ignore:
3163				#  1) blank lines, they should be at 0,
3164				#  2) preprocessor lines, and
3165				#  3) labels.
3166				if ($continuation ||
3167				    $s =~ /^\s*?\n/ ||
3168				    $s =~ /^\s*#\s*?/ ||
3169				    $s =~ /^\s*$Ident\s*:/) {
3170					$continuation = ($s =~ /^.*?\\\n/) ? 1 : 0;
3171					if ($s =~ s/^.*?\n//) {
3172						$cond_lines++;
3173					}
3174				}
3175			}
3176
3177			my (undef, $sindent) = line_stats("+" . $s);
3178			my $stat_real = raw_line($linenr, $cond_lines);
3179
3180			# Check if either of these lines are modified, else
3181			# this is not this patch's fault.
3182			if (!defined($stat_real) ||
3183			    $stat !~ /^\+/ && $stat_real !~ /^\+/) {
3184				$check = 0;
3185			}
3186			if (defined($stat_real) && $cond_lines > 1) {
3187				$stat_real = "[...]\n$stat_real";
3188			}
3189
3190			#print "line<$line> prevline<$prevline> indent<$indent> sindent<$sindent> check<$check> continuation<$continuation> s<$s> cond_lines<$cond_lines> stat_real<$stat_real> stat<$stat>\n";
3191
3192			if ($check && $s ne '' &&
3193			    (($sindent % 8) != 0 ||
3194			     ($sindent < $indent) ||
3195			     ($sindent > $indent + 8))) {
3196				WARN("SUSPECT_CODE_INDENT",
3197				     "suspect code indent for conditional statements ($indent, $sindent)\n" . $herecurr . "$stat_real\n");
3198			}
3199		}
3200
3201		# Track the 'values' across context and added lines.
3202		my $opline = $line; $opline =~ s/^./ /;
3203		my ($curr_values, $curr_vars) =
3204				annotate_values($opline . "\n", $prev_values);
3205		$curr_values = $prev_values . $curr_values;
3206		if ($dbg_values) {
3207			my $outline = $opline; $outline =~ s/\t/ /g;
3208			print "$linenr > .$outline\n";
3209			print "$linenr > $curr_values\n";
3210			print "$linenr >  $curr_vars\n";
3211		}
3212		$prev_values = substr($curr_values, -1);
3213
3214#ignore lines not being added
3215		next if ($line =~ /^[^\+]/);
3216
3217# TEST: allow direct testing of the type matcher.
3218		if ($dbg_type) {
3219			if ($line =~ /^.\s*$Declare\s*$/) {
3220				ERROR("TEST_TYPE",
3221				      "TEST: is type\n" . $herecurr);
3222			} elsif ($dbg_type > 1 && $line =~ /^.+($Declare)/) {
3223				ERROR("TEST_NOT_TYPE",
3224				      "TEST: is not type ($1 is)\n". $herecurr);
3225			}
3226			next;
3227		}
3228# TEST: allow direct testing of the attribute matcher.
3229		if ($dbg_attr) {
3230			if ($line =~ /^.\s*$Modifier\s*$/) {
3231				ERROR("TEST_ATTR",
3232				      "TEST: is attr\n" . $herecurr);
3233			} elsif ($dbg_attr > 1 && $line =~ /^.+($Modifier)/) {
3234				ERROR("TEST_NOT_ATTR",
3235				      "TEST: is not attr ($1 is)\n". $herecurr);
3236			}
3237			next;
3238		}
3239
3240# check for initialisation to aggregates open brace on the next line
3241		if ($line =~ /^.\s*{/ &&
3242		    $prevline =~ /(?:^|[^=])=\s*$/) {
3243			if (ERROR("OPEN_BRACE",
3244				  "that open brace { should be on the previous line\n" . $hereprev) &&
3245			    $fix && $prevline =~ /^\+/ && $line =~ /^\+/) {
3246				fix_delete_line($fixlinenr - 1, $prevrawline);
3247				fix_delete_line($fixlinenr, $rawline);
3248				my $fixedline = $prevrawline;
3249				$fixedline =~ s/\s*=\s*$/ = {/;
3250				fix_insert_line($fixlinenr, $fixedline);
3251				$fixedline = $line;
3252				$fixedline =~ s/^(.\s*){\s*/$1/;
3253				fix_insert_line($fixlinenr, $fixedline);
3254			}
3255		}
3256
3257#
3258# Checks which are anchored on the added line.
3259#
3260
3261# check for malformed paths in #include statements (uses RAW line)
3262		if ($rawline =~ m{^.\s*\#\s*include\s+[<"](.*)[">]}) {
3263			my $path = $1;
3264			if ($path =~ m{//}) {
3265				ERROR("MALFORMED_INCLUDE",
3266				      "malformed #include filename\n" . $herecurr);
3267			}
3268			if ($path =~ "^uapi/" && $realfile =~ m@\binclude/uapi/@) {
3269				ERROR("UAPI_INCLUDE",
3270				      "No #include in ...include/uapi/... should use a uapi/ path prefix\n" . $herecurr);
3271			}
3272		}
3273
3274# no C99 // comments
3275		if ($line =~ m{//}) {
3276			if (ERROR("C99_COMMENTS",
3277				  "do not use C99 // comments\n" . $herecurr) &&
3278			    $fix) {
3279				my $line = $fixed[$fixlinenr];
3280				if ($line =~ /\/\/(.*)$/) {
3281					my $comment = trim($1);
3282					$fixed[$fixlinenr] =~ s@\/\/(.*)$@/\* $comment \*/@;
3283				}
3284			}
3285		}
3286		# Remove C99 comments.
3287		$line =~ s@//.*@@;
3288		$opline =~ s@//.*@@;
3289
3290# EXPORT_SYMBOL should immediately follow the thing it is exporting, consider
3291# the whole statement.
3292#print "APW <$lines[$realline_next - 1]>\n";
3293		if (defined $realline_next &&
3294		    exists $lines[$realline_next - 1] &&
3295		    !defined $suppress_export{$realline_next} &&
3296		    ($lines[$realline_next - 1] =~ /EXPORT_SYMBOL.*\((.*)\)/ ||
3297		     $lines[$realline_next - 1] =~ /EXPORT_UNUSED_SYMBOL.*\((.*)\)/)) {
3298			# Handle definitions which produce identifiers with
3299			# a prefix:
3300			#   XXX(foo);
3301			#   EXPORT_SYMBOL(something_foo);
3302			my $name = $1;
3303			if ($stat =~ /^(?:.\s*}\s*\n)?.([A-Z_]+)\s*\(\s*($Ident)/ &&
3304			    $name =~ /^${Ident}_$2/) {
3305#print "FOO C name<$name>\n";
3306				$suppress_export{$realline_next} = 1;
3307
3308			} elsif ($stat !~ /(?:
3309				\n.}\s*$|
3310				^.DEFINE_$Ident\(\Q$name\E\)|
3311				^.DECLARE_$Ident\(\Q$name\E\)|
3312				^.LIST_HEAD\(\Q$name\E\)|
3313				^.(?:$Storage\s+)?$Type\s*\(\s*\*\s*\Q$name\E\s*\)\s*\(|
3314				\b\Q$name\E(?:\s+$Attribute)*\s*(?:;|=|\[|\()
3315			    )/x) {
3316#print "FOO A<$lines[$realline_next - 1]> stat<$stat> name<$name>\n";
3317				$suppress_export{$realline_next} = 2;
3318			} else {
3319				$suppress_export{$realline_next} = 1;
3320			}
3321		}
3322		if (!defined $suppress_export{$linenr} &&
3323		    $prevline =~ /^.\s*$/ &&
3324		    ($line =~ /EXPORT_SYMBOL.*\((.*)\)/ ||
3325		     $line =~ /EXPORT_UNUSED_SYMBOL.*\((.*)\)/)) {
3326#print "FOO B <$lines[$linenr - 1]>\n";
3327			$suppress_export{$linenr} = 2;
3328		}
3329		if (defined $suppress_export{$linenr} &&
3330		    $suppress_export{$linenr} == 2) {
3331			WARN("EXPORT_SYMBOL",
3332			     "EXPORT_SYMBOL(foo); should immediately follow its function/variable\n" . $herecurr);
3333		}
3334
3335# check for global initialisers.
3336		if ($line =~ /^\+$Type\s*$Ident(?:\s+$Modifier)*\s*=\s*(?:0|NULL|false)\s*;/) {
3337			if (ERROR("GLOBAL_INITIALISERS",
3338				  "do not initialise globals to 0 or NULL\n" .
3339				      $herecurr) &&
3340			    $fix) {
3341				$fixed[$fixlinenr] =~ s/(^.$Type\s*$Ident(?:\s+$Modifier)*)\s*=\s*(0|NULL|false)\s*;/$1;/;
3342			}
3343		}
3344# check for static initialisers.
3345		if ($line =~ /^\+.*\bstatic\s.*=\s*(0|NULL|false)\s*;/) {
3346			if (ERROR("INITIALISED_STATIC",
3347				  "do not initialise statics to 0 or NULL\n" .
3348				      $herecurr) &&
3349			    $fix) {
3350				$fixed[$fixlinenr] =~ s/(\bstatic\s.*?)\s*=\s*(0|NULL|false)\s*;/$1;/;
3351			}
3352		}
3353
3354# check for misordered declarations of char/short/int/long with signed/unsigned
3355		while ($sline =~ m{(\b$TypeMisordered\b)}g) {
3356			my $tmp = trim($1);
3357			WARN("MISORDERED_TYPE",
3358			     "type '$tmp' should be specified in [[un]signed] [short|int|long|long long] order\n" . $herecurr);
3359		}
3360
3361# check for static const char * arrays.
3362		if ($line =~ /\bstatic\s+const\s+char\s*\*\s*(\w+)\s*\[\s*\]\s*=\s*/) {
3363			WARN("STATIC_CONST_CHAR_ARRAY",
3364			     "static const char * array should probably be static const char * const\n" .
3365				$herecurr);
3366               }
3367
3368# check for static char foo[] = "bar" declarations.
3369		if ($line =~ /\bstatic\s+char\s+(\w+)\s*\[\s*\]\s*=\s*"/) {
3370			WARN("STATIC_CONST_CHAR_ARRAY",
3371			     "static char array declaration should probably be static const char\n" .
3372				$herecurr);
3373               }
3374
3375# check for const <foo> const where <foo> is not a pointer or array type
3376		if ($sline =~ /\bconst\s+($BasicType)\s+const\b/) {
3377			my $found = $1;
3378			if ($sline =~ /\bconst\s+\Q$found\E\s+const\b\s*\*/) {
3379				WARN("CONST_CONST",
3380				     "'const $found const *' should probably be 'const $found * const'\n" . $herecurr);
3381			} elsif ($sline !~ /\bconst\s+\Q$found\E\s+const\s+\w+\s*\[/) {
3382				WARN("CONST_CONST",
3383				     "'const $found const' should probably be 'const $found'\n" . $herecurr);
3384			}
3385		}
3386
3387# check for non-global char *foo[] = {"bar", ...} declarations.
3388		if ($line =~ /^.\s+(?:static\s+|const\s+)?char\s+\*\s*\w+\s*\[\s*\]\s*=\s*\{/) {
3389			WARN("STATIC_CONST_CHAR_ARRAY",
3390			     "char * array declaration might be better as static const\n" .
3391				$herecurr);
3392               }
3393
3394# check for sizeof(foo)/sizeof(foo[0]) that could be ARRAY_SIZE(foo)
3395		if ($line =~ m@\bsizeof\s*\(\s*($Lval)\s*\)@) {
3396			my $array = $1;
3397			if ($line =~ m@\b(sizeof\s*\(\s*\Q$array\E\s*\)\s*/\s*sizeof\s*\(\s*\Q$array\E\s*\[\s*0\s*\]\s*\))@) {
3398				my $array_div = $1;
3399				if (WARN("ARRAY_SIZE",
3400					 "Prefer ARRAY_SIZE($array)\n" . $herecurr) &&
3401				    $fix) {
3402					$fixed[$fixlinenr] =~ s/\Q$array_div\E/ARRAY_SIZE($array)/;
3403				}
3404			}
3405		}
3406
3407# check for function declarations without arguments like "int foo()"
3408		if ($line =~ /(\b$Type\s+$Ident)\s*\(\s*\)/) {
3409			if (ERROR("FUNCTION_WITHOUT_ARGS",
3410				  "Bad function definition - $1() should probably be $1(void)\n" . $herecurr) &&
3411			    $fix) {
3412				$fixed[$fixlinenr] =~ s/(\b($Type)\s+($Ident))\s*\(\s*\)/$2 $3(void)/;
3413			}
3414		}
3415
3416# check for uses of DEFINE_PCI_DEVICE_TABLE
3417		if ($line =~ /\bDEFINE_PCI_DEVICE_TABLE\s*\(\s*(\w+)\s*\)\s*=/) {
3418			if (WARN("DEFINE_PCI_DEVICE_TABLE",
3419				 "Prefer struct pci_device_id over deprecated DEFINE_PCI_DEVICE_TABLE\n" . $herecurr) &&
3420			    $fix) {
3421				$fixed[$fixlinenr] =~ s/\b(?:static\s+|)DEFINE_PCI_DEVICE_TABLE\s*\(\s*(\w+)\s*\)\s*=\s*/static const struct pci_device_id $1\[\] = /;
3422			}
3423		}
3424
3425# check for new typedefs, only function parameters and sparse annotations
3426# make sense.
3427		if ($line =~ /\btypedef\s/ &&
3428		    $line !~ /\btypedef\s+$Type\s*\(\s*\*?$Ident\s*\)\s*\(/ &&
3429		    $line !~ /\btypedef\s+$Type\s+$Ident\s*\(/ &&
3430		    $line !~ /\b$typeTypedefs\b/ &&
3431		    $line !~ /\b__bitwise(?:__|)\b/) {
3432			WARN("NEW_TYPEDEFS",
3433			     "do not add new typedefs\n" . $herecurr);
3434		}
3435
3436# * goes on variable not on type
3437		# (char*[ const])
3438		while ($line =~ m{(\($NonptrType(\s*(?:$Modifier\b\s*|\*\s*)+)\))}g) {
3439			#print "AA<$1>\n";
3440			my ($ident, $from, $to) = ($1, $2, $2);
3441
3442			# Should start with a space.
3443			$to =~ s/^(\S)/ $1/;
3444			# Should not end with a space.
3445			$to =~ s/\s+$//;
3446			# '*'s should not have spaces between.
3447			while ($to =~ s/\*\s+\*/\*\*/) {
3448			}
3449
3450##			print "1: from<$from> to<$to> ident<$ident>\n";
3451			if ($from ne $to) {
3452				if (ERROR("POINTER_LOCATION",
3453					  "\"(foo$from)\" should be \"(foo$to)\"\n" .  $herecurr) &&
3454				    $fix) {
3455					my $sub_from = $ident;
3456					my $sub_to = $ident;
3457					$sub_to =~ s/\Q$from\E/$to/;
3458					$fixed[$fixlinenr] =~
3459					    s@\Q$sub_from\E@$sub_to@;
3460				}
3461			}
3462		}
3463		while ($line =~ m{(\b$NonptrType(\s*(?:$Modifier\b\s*|\*\s*)+)($Ident))}g) {
3464			#print "BB<$1>\n";
3465			my ($match, $from, $to, $ident) = ($1, $2, $2, $3);
3466
3467			# Should start with a space.
3468			$to =~ s/^(\S)/ $1/;
3469			# Should not end with a space.
3470			$to =~ s/\s+$//;
3471			# '*'s should not have spaces between.
3472			while ($to =~ s/\*\s+\*/\*\*/) {
3473			}
3474			# Modifiers should have spaces.
3475			$to =~ s/(\b$Modifier$)/$1 /;
3476
3477##			print "2: from<$from> to<$to> ident<$ident>\n";
3478			if ($from ne $to && $ident !~ /^$Modifier$/) {
3479				if (ERROR("POINTER_LOCATION",
3480					  "\"foo${from}bar\" should be \"foo${to}bar\"\n" .  $herecurr) &&
3481				    $fix) {
3482
3483					my $sub_from = $match;
3484					my $sub_to = $match;
3485					$sub_to =~ s/\Q$from\E/$to/;
3486					$fixed[$fixlinenr] =~
3487					    s@\Q$sub_from\E@$sub_to@;
3488				}
3489			}
3490		}
3491
3492# avoid BUG() or BUG_ON()
3493		if ($line =~ /\b(?:BUG|BUG_ON)\b/) {
3494			my $msg_type = \&WARN;
3495			$msg_type = \&CHK if ($file);
3496			&{$msg_type}("AVOID_BUG",
3497				     "Avoid crashing the kernel - try using WARN_ON & recovery code rather than BUG() or BUG_ON()\n" . $herecurr);
3498		}
3499
3500# avoid LINUX_VERSION_CODE
3501		if ($line =~ /\bLINUX_VERSION_CODE\b/) {
3502			WARN("LINUX_VERSION_CODE",
3503			     "LINUX_VERSION_CODE should be avoided, code should be for the version to which it is merged\n" . $herecurr);
3504		}
3505
3506# check for uses of printk_ratelimit
3507		if ($line =~ /\bprintk_ratelimit\s*\(/) {
3508			WARN("PRINTK_RATELIMITED",
3509			     "Prefer printk_ratelimited or pr_<level>_ratelimited to printk_ratelimit\n" . $herecurr);
3510		}
3511
3512# printk should use KERN_* levels.  Note that follow on printk's on the
3513# same line do not need a level, so we use the current block context
3514# to try and find and validate the current printk.  In summary the current
3515# printk includes all preceding printk's which have no newline on the end.
3516# we assume the first bad printk is the one to report.
3517		if ($line =~ /\bprintk\((?!KERN_)\s*"/) {
3518			my $ok = 0;
3519			for (my $ln = $linenr - 1; $ln >= $first_line; $ln--) {
3520				#print "CHECK<$lines[$ln - 1]\n";
3521				# we have a preceding printk if it ends
3522				# with "\n" ignore it, else it is to blame
3523				if ($lines[$ln - 1] =~ m{\bprintk\(}) {
3524					if ($rawlines[$ln - 1] !~ m{\\n"}) {
3525						$ok = 1;
3526					}
3527					last;
3528				}
3529			}
3530			if ($ok == 0) {
3531				WARN("PRINTK_WITHOUT_KERN_LEVEL",
3532				     "printk() should include KERN_ facility level\n" . $herecurr);
3533			}
3534		}
3535
3536		if ($line =~ /\bprintk\s*\(\s*KERN_([A-Z]+)/) {
3537			my $orig = $1;
3538			my $level = lc($orig);
3539			$level = "warn" if ($level eq "warning");
3540			my $level2 = $level;
3541			$level2 = "dbg" if ($level eq "debug");
3542			WARN("PREFER_PR_LEVEL",
3543			     "Prefer [subsystem eg: netdev]_$level2([subsystem]dev, ... then dev_$level2(dev, ... then pr_$level(...  to printk(KERN_$orig ...\n" . $herecurr);
3544		}
3545
3546		if ($line =~ /\bpr_warning\s*\(/) {
3547			if (WARN("PREFER_PR_LEVEL",
3548				 "Prefer pr_warn(... to pr_warning(...\n" . $herecurr) &&
3549			    $fix) {
3550				$fixed[$fixlinenr] =~
3551				    s/\bpr_warning\b/pr_warn/;
3552			}
3553		}
3554
3555		if ($line =~ /\bdev_printk\s*\(\s*KERN_([A-Z]+)/) {
3556			my $orig = $1;
3557			my $level = lc($orig);
3558			$level = "warn" if ($level eq "warning");
3559			$level = "dbg" if ($level eq "debug");
3560			WARN("PREFER_DEV_LEVEL",
3561			     "Prefer dev_$level(... to dev_printk(KERN_$orig, ...\n" . $herecurr);
3562		}
3563
3564# ENOSYS means "bad syscall nr" and nothing else.  This will have a small
3565# number of false positives, but assembly files are not checked, so at
3566# least the arch entry code will not trigger this warning.
3567		if ($line =~ /\bENOSYS\b/) {
3568			WARN("ENOSYS",
3569			     "ENOSYS means 'invalid syscall nr' and nothing else\n" . $herecurr);
3570		}
3571
3572# function brace can't be on same line, except for #defines of do while,
3573# or if closed on same line
3574		if (($line=~/$Type\s*$Ident\(.*\).*\s*{/) and
3575		    !($line=~/\#\s*define.*do\s\{/) and !($line=~/}/)) {
3576			if (ERROR("OPEN_BRACE",
3577				  "open brace '{' following function declarations go on the next line\n" . $herecurr) &&
3578			    $fix) {
3579				fix_delete_line($fixlinenr, $rawline);
3580				my $fixed_line = $rawline;
3581				$fixed_line =~ /(^..*$Type\s*$Ident\(.*\)\s*){(.*)$/;
3582				my $line1 = $1;
3583				my $line2 = $2;
3584				fix_insert_line($fixlinenr, ltrim($line1));
3585				fix_insert_line($fixlinenr, "\+{");
3586				if ($line2 !~ /^\s*$/) {
3587					fix_insert_line($fixlinenr, "\+\t" . trim($line2));
3588				}
3589			}
3590		}
3591
3592# open braces for enum, union and struct go on the same line.
3593		if ($line =~ /^.\s*{/ &&
3594		    $prevline =~ /^.\s*(?:typedef\s+)?(enum|union|struct)(?:\s+$Ident)?\s*$/) {
3595			if (ERROR("OPEN_BRACE",
3596				  "open brace '{' following $1 go on the same line\n" . $hereprev) &&
3597			    $fix && $prevline =~ /^\+/ && $line =~ /^\+/) {
3598				fix_delete_line($fixlinenr - 1, $prevrawline);
3599				fix_delete_line($fixlinenr, $rawline);
3600				my $fixedline = rtrim($prevrawline) . " {";
3601				fix_insert_line($fixlinenr, $fixedline);
3602				$fixedline = $rawline;
3603				$fixedline =~ s/^(.\s*){\s*/$1\t/;
3604				if ($fixedline !~ /^\+\s*$/) {
3605					fix_insert_line($fixlinenr, $fixedline);
3606				}
3607			}
3608		}
3609
3610# missing space after union, struct or enum definition
3611		if ($line =~ /^.\s*(?:typedef\s+)?(enum|union|struct)(?:\s+$Ident){1,2}[=\{]/) {
3612			if (WARN("SPACING",
3613				 "missing space after $1 definition\n" . $herecurr) &&
3614			    $fix) {
3615				$fixed[$fixlinenr] =~
3616				    s/^(.\s*(?:typedef\s+)?(?:enum|union|struct)(?:\s+$Ident){1,2})([=\{])/$1 $2/;
3617			}
3618		}
3619
3620# Function pointer declarations
3621# check spacing between type, funcptr, and args
3622# canonical declaration is "type (*funcptr)(args...)"
3623		if ($line =~ /^.\s*($Declare)\((\s*)\*(\s*)($Ident)(\s*)\)(\s*)\(/) {
3624			my $declare = $1;
3625			my $pre_pointer_space = $2;
3626			my $post_pointer_space = $3;
3627			my $funcname = $4;
3628			my $post_funcname_space = $5;
3629			my $pre_args_space = $6;
3630
3631# the $Declare variable will capture all spaces after the type
3632# so check it for a missing trailing missing space but pointer return types
3633# don't need a space so don't warn for those.
3634			my $post_declare_space = "";
3635			if ($declare =~ /(\s+)$/) {
3636				$post_declare_space = $1;
3637				$declare = rtrim($declare);
3638			}
3639			if ($declare !~ /\*$/ && $post_declare_space =~ /^$/) {
3640				WARN("SPACING",
3641				     "missing space after return type\n" . $herecurr);
3642				$post_declare_space = " ";
3643			}
3644
3645# unnecessary space "type  (*funcptr)(args...)"
3646# This test is not currently implemented because these declarations are
3647# equivalent to
3648#	int  foo(int bar, ...)
3649# and this is form shouldn't/doesn't generate a checkpatch warning.
3650#
3651#			elsif ($declare =~ /\s{2,}$/) {
3652#				WARN("SPACING",
3653#				     "Multiple spaces after return type\n" . $herecurr);
3654#			}
3655
3656# unnecessary space "type ( *funcptr)(args...)"
3657			if (defined $pre_pointer_space &&
3658			    $pre_pointer_space =~ /^\s/) {
3659				WARN("SPACING",
3660				     "Unnecessary space after function pointer open parenthesis\n" . $herecurr);
3661			}
3662
3663# unnecessary space "type (* funcptr)(args...)"
3664			if (defined $post_pointer_space &&
3665			    $post_pointer_space =~ /^\s/) {
3666				WARN("SPACING",
3667				     "Unnecessary space before function pointer name\n" . $herecurr);
3668			}
3669
3670# unnecessary space "type (*funcptr )(args...)"
3671			if (defined $post_funcname_space &&
3672			    $post_funcname_space =~ /^\s/) {
3673				WARN("SPACING",
3674				     "Unnecessary space after function pointer name\n" . $herecurr);
3675			}
3676
3677# unnecessary space "type (*funcptr) (args...)"
3678			if (defined $pre_args_space &&
3679			    $pre_args_space =~ /^\s/) {
3680				WARN("SPACING",
3681				     "Unnecessary space before function pointer arguments\n" . $herecurr);
3682			}
3683
3684			if (show_type("SPACING") && $fix) {
3685				$fixed[$fixlinenr] =~
3686				    s/^(.\s*)$Declare\s*\(\s*\*\s*$Ident\s*\)\s*\(/$1 . $declare . $post_declare_space . '(*' . $funcname . ')('/ex;
3687			}
3688		}
3689
3690# check for spacing round square brackets; allowed:
3691#  1. with a type on the left -- int [] a;
3692#  2. at the beginning of a line for slice initialisers -- [0...10] = 5,
3693#  3. inside a curly brace -- = { [0...10] = 5 }
3694		while ($line =~ /(.*?\s)\[/g) {
3695			my ($where, $prefix) = ($-[1], $1);
3696			if ($prefix !~ /$Type\s+$/ &&
3697			    ($where != 0 || $prefix !~ /^.\s+$/) &&
3698			    $prefix !~ /[{,]\s+$/) {
3699				if (ERROR("BRACKET_SPACE",
3700					  "space prohibited before open square bracket '['\n" . $herecurr) &&
3701				    $fix) {
3702				    $fixed[$fixlinenr] =~
3703					s/^(\+.*?)\s+\[/$1\[/;
3704				}
3705			}
3706		}
3707
3708# check for spaces between functions and their parentheses.
3709		while ($line =~ /($Ident)\s+\(/g) {
3710			my $name = $1;
3711			my $ctx_before = substr($line, 0, $-[1]);
3712			my $ctx = "$ctx_before$name";
3713
3714			# Ignore those directives where spaces _are_ permitted.
3715			if ($name =~ /^(?:
3716				if|for|while|switch|return|case|
3717				volatile|__volatile__|
3718				__attribute__|format|__extension__|
3719				asm|__asm__)$/x)
3720			{
3721			# cpp #define statements have non-optional spaces, ie
3722			# if there is a space between the name and the open
3723			# parenthesis it is simply not a parameter group.
3724			} elsif ($ctx_before =~ /^.\s*\#\s*define\s*$/) {
3725
3726			# cpp #elif statement condition may start with a (
3727			} elsif ($ctx =~ /^.\s*\#\s*elif\s*$/) {
3728
3729			# If this whole things ends with a type its most
3730			# likely a typedef for a function.
3731			} elsif ($ctx =~ /$Type$/) {
3732
3733			} else {
3734				if (WARN("SPACING",
3735					 "space prohibited between function name and open parenthesis '('\n" . $herecurr) &&
3736					     $fix) {
3737					$fixed[$fixlinenr] =~
3738					    s/\b$name\s+\(/$name\(/;
3739				}
3740			}
3741		}
3742
3743# Check operator spacing.
3744		if (!($line=~/\#\s*include/)) {
3745			my $fixed_line = "";
3746			my $line_fixed = 0;
3747
3748			my $ops = qr{
3749				<<=|>>=|<=|>=|==|!=|
3750				\+=|-=|\*=|\/=|%=|\^=|\|=|&=|
3751				=>|->|<<|>>|<|>|=|!|~|
3752				&&|\|\||,|\^|\+\+|--|&|\||\+|-|\*|\/|%|
3753				\?:|\?|:
3754			}x;
3755			my @elements = split(/($ops|;)/, $opline);
3756
3757##			print("element count: <" . $#elements . ">\n");
3758##			foreach my $el (@elements) {
3759##				print("el: <$el>\n");
3760##			}
3761
3762			my @fix_elements = ();
3763			my $off = 0;
3764
3765			foreach my $el (@elements) {
3766				push(@fix_elements, substr($rawline, $off, length($el)));
3767				$off += length($el);
3768			}
3769
3770			$off = 0;
3771
3772			my $blank = copy_spacing($opline);
3773			my $last_after = -1;
3774
3775			for (my $n = 0; $n < $#elements; $n += 2) {
3776
3777				my $good = $fix_elements[$n] . $fix_elements[$n + 1];
3778
3779##				print("n: <$n> good: <$good>\n");
3780
3781				$off += length($elements[$n]);
3782
3783				# Pick up the preceding and succeeding characters.
3784				my $ca = substr($opline, 0, $off);
3785				my $cc = '';
3786				if (length($opline) >= ($off + length($elements[$n + 1]))) {
3787					$cc = substr($opline, $off + length($elements[$n + 1]));
3788				}
3789				my $cb = "$ca$;$cc";
3790
3791				my $a = '';
3792				$a = 'V' if ($elements[$n] ne '');
3793				$a = 'W' if ($elements[$n] =~ /\s$/);
3794				$a = 'C' if ($elements[$n] =~ /$;$/);
3795				$a = 'B' if ($elements[$n] =~ /(\[|\()$/);
3796				$a = 'O' if ($elements[$n] eq '');
3797				$a = 'E' if ($ca =~ /^\s*$/);
3798
3799				my $op = $elements[$n + 1];
3800
3801				my $c = '';
3802				if (defined $elements[$n + 2]) {
3803					$c = 'V' if ($elements[$n + 2] ne '');
3804					$c = 'W' if ($elements[$n + 2] =~ /^\s/);
3805					$c = 'C' if ($elements[$n + 2] =~ /^$;/);
3806					$c = 'B' if ($elements[$n + 2] =~ /^(\)|\]|;)/);
3807					$c = 'O' if ($elements[$n + 2] eq '');
3808					$c = 'E' if ($elements[$n + 2] =~ /^\s*\\$/);
3809				} else {
3810					$c = 'E';
3811				}
3812
3813				my $ctx = "${a}x${c}";
3814
3815				my $at = "(ctx:$ctx)";
3816
3817				my $ptr = substr($blank, 0, $off) . "^";
3818				my $hereptr = "$hereline$ptr\n";
3819
3820				# Pull out the value of this operator.
3821				my $op_type = substr($curr_values, $off + 1, 1);
3822
3823				# Get the full operator variant.
3824				my $opv = $op . substr($curr_vars, $off, 1);
3825
3826				# Ignore operators passed as parameters.
3827				if ($op_type ne 'V' &&
3828				    $ca =~ /\s$/ && $cc =~ /^\s*[,\)]/) {
3829
3830#				# Ignore comments
3831#				} elsif ($op =~ /^$;+$/) {
3832
3833				# ; should have either the end of line or a space or \ after it
3834				} elsif ($op eq ';') {
3835					if ($ctx !~ /.x[WEBC]/ &&
3836					    $cc !~ /^\\/ && $cc !~ /^;/) {
3837						if (ERROR("SPACING",
3838							  "space required after that '$op' $at\n" . $hereptr)) {
3839							$good = $fix_elements[$n] . trim($fix_elements[$n + 1]) . " ";
3840							$line_fixed = 1;
3841						}
3842					}
3843
3844				# // is a comment
3845				} elsif ($op eq '//') {
3846
3847				#   :   when part of a bitfield
3848				} elsif ($opv eq ':B') {
3849					# skip the bitfield test for now
3850
3851				# No spaces for:
3852				#   ->
3853				} elsif ($op eq '->') {
3854					if ($ctx =~ /Wx.|.xW/) {
3855						if (ERROR("SPACING",
3856							  "spaces prohibited around that '$op' $at\n" . $hereptr)) {
3857							$good = rtrim($fix_elements[$n]) . trim($fix_elements[$n + 1]);
3858							if (defined $fix_elements[$n + 2]) {
3859								$fix_elements[$n + 2] =~ s/^\s+//;
3860							}
3861							$line_fixed = 1;
3862						}
3863					}
3864
3865				# , must not have a space before and must have a space on the right.
3866				} elsif ($op eq ',') {
3867					my $rtrim_before = 0;
3868					my $space_after = 0;
3869					if ($ctx =~ /Wx./) {
3870						if (ERROR("SPACING",
3871							  "space prohibited before that '$op' $at\n" . $hereptr)) {
3872							$line_fixed = 1;
3873							$rtrim_before = 1;
3874						}
3875					}
3876					if ($ctx !~ /.x[WEC]/ && $cc !~ /^}/) {
3877						if (ERROR("SPACING",
3878							  "space required after that '$op' $at\n" . $hereptr)) {
3879							$line_fixed = 1;
3880							$last_after = $n;
3881							$space_after = 1;
3882						}
3883					}
3884					if ($rtrim_before || $space_after) {
3885						if ($rtrim_before) {
3886							$good = rtrim($fix_elements[$n]) . trim($fix_elements[$n + 1]);
3887						} else {
3888							$good = $fix_elements[$n] . trim($fix_elements[$n + 1]);
3889						}
3890						if ($space_after) {
3891							$good .= " ";
3892						}
3893					}
3894
3895				# '*' as part of a type definition -- reported already.
3896				} elsif ($opv eq '*_') {
3897					#warn "'*' is part of type\n";
3898
3899				# unary operators should have a space before and
3900				# none after.  May be left adjacent to another
3901				# unary operator, or a cast
3902				} elsif ($op eq '!' || $op eq '~' ||
3903					 $opv eq '*U' || $opv eq '-U' ||
3904					 $opv eq '&U' || $opv eq '&&U') {
3905					if ($ctx !~ /[WEBC]x./ && $ca !~ /(?:\)|!|~|\*|-|\&|\||\+\+|\-\-|\{)$/) {
3906						if (ERROR("SPACING",
3907							  "space required before that '$op' $at\n" . $hereptr)) {
3908							if ($n != $last_after + 2) {
3909								$good = $fix_elements[$n] . " " . ltrim($fix_elements[$n + 1]);
3910								$line_fixed = 1;
3911							}
3912						}
3913					}
3914					if ($op eq '*' && $cc =~/\s*$Modifier\b/) {
3915						# A unary '*' may be const
3916
3917					} elsif ($ctx =~ /.xW/) {
3918						if (ERROR("SPACING",
3919							  "space prohibited after that '$op' $at\n" . $hereptr)) {
3920							$good = $fix_elements[$n] . rtrim($fix_elements[$n + 1]);
3921							if (defined $fix_elements[$n + 2]) {
3922								$fix_elements[$n + 2] =~ s/^\s+//;
3923							}
3924							$line_fixed = 1;
3925						}
3926					}
3927
3928				# unary ++ and unary -- are allowed no space on one side.
3929				} elsif ($op eq '++' or $op eq '--') {
3930					if ($ctx !~ /[WEOBC]x[^W]/ && $ctx !~ /[^W]x[WOBEC]/) {
3931						if (ERROR("SPACING",
3932							  "space required one side of that '$op' $at\n" . $hereptr)) {
3933							$good = $fix_elements[$n] . trim($fix_elements[$n + 1]) . " ";
3934							$line_fixed = 1;
3935						}
3936					}
3937					if ($ctx =~ /Wx[BE]/ ||
3938					    ($ctx =~ /Wx./ && $cc =~ /^;/)) {
3939						if (ERROR("SPACING",
3940							  "space prohibited before that '$op' $at\n" . $hereptr)) {
3941							$good = rtrim($fix_elements[$n]) . trim($fix_elements[$n + 1]);
3942							$line_fixed = 1;
3943						}
3944					}
3945					if ($ctx =~ /ExW/) {
3946						if (ERROR("SPACING",
3947							  "space prohibited after that '$op' $at\n" . $hereptr)) {
3948							$good = $fix_elements[$n] . trim($fix_elements[$n + 1]);
3949							if (defined $fix_elements[$n + 2]) {
3950								$fix_elements[$n + 2] =~ s/^\s+//;
3951							}
3952							$line_fixed = 1;
3953						}
3954					}
3955
3956				# << and >> may either have or not have spaces both sides
3957				} elsif ($op eq '<<' or $op eq '>>' or
3958					 $op eq '&' or $op eq '^' or $op eq '|' or
3959					 $op eq '+' or $op eq '-' or
3960					 $op eq '*' or $op eq '/' or
3961					 $op eq '%')
3962				{
3963					if ($check) {
3964						if (defined $fix_elements[$n + 2] && $ctx !~ /[EW]x[EW]/) {
3965							if (CHK("SPACING",
3966								"spaces preferred around that '$op' $at\n" . $hereptr)) {
3967								$good = rtrim($fix_elements[$n]) . " " . trim($fix_elements[$n + 1]) . " ";
3968								$fix_elements[$n + 2] =~ s/^\s+//;
3969								$line_fixed = 1;
3970							}
3971						} elsif (!defined $fix_elements[$n + 2] && $ctx !~ /Wx[OE]/) {
3972							if (CHK("SPACING",
3973								"space preferred before that '$op' $at\n" . $hereptr)) {
3974								$good = rtrim($fix_elements[$n]) . " " . trim($fix_elements[$n + 1]);
3975								$line_fixed = 1;
3976							}
3977						}
3978					} elsif ($ctx =~ /Wx[^WCE]|[^WCE]xW/) {
3979						if (ERROR("SPACING",
3980							  "need consistent spacing around '$op' $at\n" . $hereptr)) {
3981							$good = rtrim($fix_elements[$n]) . " " . trim($fix_elements[$n + 1]) . " ";
3982							if (defined $fix_elements[$n + 2]) {
3983								$fix_elements[$n + 2] =~ s/^\s+//;
3984							}
3985							$line_fixed = 1;
3986						}
3987					}
3988
3989				# A colon needs no spaces before when it is
3990				# terminating a case value or a label.
3991				} elsif ($opv eq ':C' || $opv eq ':L') {
3992					if ($ctx =~ /Wx./) {
3993						if (ERROR("SPACING",
3994							  "space prohibited before that '$op' $at\n" . $hereptr)) {
3995							$good = rtrim($fix_elements[$n]) . trim($fix_elements[$n + 1]);
3996							$line_fixed = 1;
3997						}
3998					}
3999
4000				# All the others need spaces both sides.
4001				} elsif ($ctx !~ /[EWC]x[CWE]/) {
4002					my $ok = 0;
4003
4004					# Ignore email addresses <foo@bar>
4005					if (($op eq '<' &&
4006					     $cc =~ /^\S+\@\S+>/) ||
4007					    ($op eq '>' &&
4008					     $ca =~ /<\S+\@\S+$/))
4009					{
4010					    	$ok = 1;
4011					}
4012
4013					# for asm volatile statements
4014					# ignore a colon with another
4015					# colon immediately before or after
4016					if (($op eq ':') &&
4017					    ($ca =~ /:$/ || $cc =~ /^:/)) {
4018						$ok = 1;
4019					}
4020
4021					# messages are ERROR, but ?: are CHK
4022					if ($ok == 0) {
4023						my $msg_type = \&ERROR;
4024						$msg_type = \&CHK if (($op eq '?:' || $op eq '?' || $op eq ':') && $ctx =~ /VxV/);
4025
4026						if (&{$msg_type}("SPACING",
4027								 "spaces required around that '$op' $at\n" . $hereptr)) {
4028							$good = rtrim($fix_elements[$n]) . " " . trim($fix_elements[$n + 1]) . " ";
4029							if (defined $fix_elements[$n + 2]) {
4030								$fix_elements[$n + 2] =~ s/^\s+//;
4031							}
4032							$line_fixed = 1;
4033						}
4034					}
4035				}
4036				$off += length($elements[$n + 1]);
4037
4038##				print("n: <$n> GOOD: <$good>\n");
4039
4040				$fixed_line = $fixed_line . $good;
4041			}
4042
4043			if (($#elements % 2) == 0) {
4044				$fixed_line = $fixed_line . $fix_elements[$#elements];
4045			}
4046
4047			if ($fix && $line_fixed && $fixed_line ne $fixed[$fixlinenr]) {
4048				$fixed[$fixlinenr] = $fixed_line;
4049			}
4050
4051
4052		}
4053
4054# check for whitespace before a non-naked semicolon
4055		if ($line =~ /^\+.*\S\s+;\s*$/) {
4056			if (WARN("SPACING",
4057				 "space prohibited before semicolon\n" . $herecurr) &&
4058			    $fix) {
4059				1 while $fixed[$fixlinenr] =~
4060				    s/^(\+.*\S)\s+;/$1;/;
4061			}
4062		}
4063
4064# check for multiple assignments
4065		if ($line =~ /^.\s*$Lval\s*=\s*$Lval\s*=(?!=)/) {
4066			CHK("MULTIPLE_ASSIGNMENTS",
4067			    "multiple assignments should be avoided\n" . $herecurr);
4068		}
4069
4070## # check for multiple declarations, allowing for a function declaration
4071## # continuation.
4072## 		if ($line =~ /^.\s*$Type\s+$Ident(?:\s*=[^,{]*)?\s*,\s*$Ident.*/ &&
4073## 		    $line !~ /^.\s*$Type\s+$Ident(?:\s*=[^,{]*)?\s*,\s*$Type\s*$Ident.*/) {
4074##
4075## 			# Remove any bracketed sections to ensure we do not
4076## 			# falsly report the parameters of functions.
4077## 			my $ln = $line;
4078## 			while ($ln =~ s/\([^\(\)]*\)//g) {
4079## 			}
4080## 			if ($ln =~ /,/) {
4081## 				WARN("MULTIPLE_DECLARATION",
4082##				     "declaring multiple variables together should be avoided\n" . $herecurr);
4083## 			}
4084## 		}
4085
4086#need space before brace following if, while, etc
4087		if (($line =~ /\(.*\)\{/ && $line !~ /\($Type\){/) ||
4088		    $line =~ /do\{/) {
4089			if (ERROR("SPACING",
4090				  "space required before the open brace '{'\n" . $herecurr) &&
4091			    $fix) {
4092				$fixed[$fixlinenr] =~ s/^(\+.*(?:do|\))){/$1 {/;
4093			}
4094		}
4095
4096## # check for blank lines before declarations
4097##		if ($line =~ /^.\t+$Type\s+$Ident(?:\s*=.*)?;/ &&
4098##		    $prevrawline =~ /^.\s*$/) {
4099##			WARN("SPACING",
4100##			     "No blank lines before declarations\n" . $hereprev);
4101##		}
4102##
4103
4104# closing brace should have a space following it when it has anything
4105# on the line
4106		if ($line =~ /}(?!(?:,|;|\)))\S/) {
4107			if (ERROR("SPACING",
4108				  "space required after that close brace '}'\n" . $herecurr) &&
4109			    $fix) {
4110				$fixed[$fixlinenr] =~
4111				    s/}((?!(?:,|;|\)))\S)/} $1/;
4112			}
4113		}
4114
4115# check spacing on square brackets
4116		if ($line =~ /\[\s/ && $line !~ /\[\s*$/) {
4117			if (ERROR("SPACING",
4118				  "space prohibited after that open square bracket '['\n" . $herecurr) &&
4119			    $fix) {
4120				$fixed[$fixlinenr] =~
4121				    s/\[\s+/\[/;
4122			}
4123		}
4124		if ($line =~ /\s\]/) {
4125			if (ERROR("SPACING",
4126				  "space prohibited before that close square bracket ']'\n" . $herecurr) &&
4127			    $fix) {
4128				$fixed[$fixlinenr] =~
4129				    s/\s+\]/\]/;
4130			}
4131		}
4132
4133# check spacing on parentheses
4134		if ($line =~ /\(\s/ && $line !~ /\(\s*(?:\\)?$/ &&
4135		    $line !~ /for\s*\(\s+;/) {
4136			if (ERROR("SPACING",
4137				  "space prohibited after that open parenthesis '('\n" . $herecurr) &&
4138			    $fix) {
4139				$fixed[$fixlinenr] =~
4140				    s/\(\s+/\(/;
4141			}
4142		}
4143		if ($line =~ /(\s+)\)/ && $line !~ /^.\s*\)/ &&
4144		    $line !~ /for\s*\(.*;\s+\)/ &&
4145		    $line !~ /:\s+\)/) {
4146			if (ERROR("SPACING",
4147				  "space prohibited before that close parenthesis ')'\n" . $herecurr) &&
4148			    $fix) {
4149				$fixed[$fixlinenr] =~
4150				    s/\s+\)/\)/;
4151			}
4152		}
4153
4154# check unnecessary parentheses around addressof/dereference single $Lvals
4155# ie: &(foo->bar) should be &foo->bar and *(foo->bar) should be *foo->bar
4156
4157		while ($line =~ /(?:[^&]&\s*|\*)\(\s*($Ident\s*(?:$Member\s*)+)\s*\)/g) {
4158			my $var = $1;
4159			if (CHK("UNNECESSARY_PARENTHESES",
4160				"Unnecessary parentheses around $var\n" . $herecurr) &&
4161			    $fix) {
4162				$fixed[$fixlinenr] =~ s/\(\s*\Q$var\E\s*\)/$var/;
4163			}
4164		}
4165
4166# check for unnecessary parentheses around function pointer uses
4167# ie: (foo->bar)(); should be foo->bar();
4168# but not "if (foo->bar) (" to avoid some false positives
4169		if ($line =~ /(\bif\s*|)(\(\s*$Ident\s*(?:$Member\s*)+\))[ \t]*\(/ && $1 !~ /^if/) {
4170			my $var = $2;
4171			if (CHK("UNNECESSARY_PARENTHESES",
4172				"Unnecessary parentheses around function pointer $var\n" . $herecurr) &&
4173			    $fix) {
4174				my $var2 = deparenthesize($var);
4175				$var2 =~ s/\s//g;
4176				$fixed[$fixlinenr] =~ s/\Q$var\E/$var2/;
4177			}
4178		}
4179
4180#goto labels aren't indented, allow a single space however
4181		if ($line=~/^.\s+[A-Za-z\d_]+:(?![0-9]+)/ and
4182		   !($line=~/^. [A-Za-z\d_]+:/) and !($line=~/^.\s+default:/)) {
4183			if (WARN("INDENTED_LABEL",
4184				 "labels should not be indented\n" . $herecurr) &&
4185			    $fix) {
4186				$fixed[$fixlinenr] =~
4187				    s/^(.)\s+/$1/;
4188			}
4189		}
4190
4191# return is not a function
4192		if (defined($stat) && $stat =~ /^.\s*return(\s*)\(/s) {
4193			my $spacing = $1;
4194			if ($^V && $^V ge 5.10.0 &&
4195			    $stat =~ /^.\s*return\s*($balanced_parens)\s*;\s*$/) {
4196				my $value = $1;
4197				$value = deparenthesize($value);
4198				if ($value =~ m/^\s*$FuncArg\s*(?:\?|$)/) {
4199					ERROR("RETURN_PARENTHESES",
4200					      "return is not a function, parentheses are not required\n" . $herecurr);
4201				}
4202			} elsif ($spacing !~ /\s+/) {
4203				ERROR("SPACING",
4204				      "space required before the open parenthesis '('\n" . $herecurr);
4205			}
4206		}
4207
4208# unnecessary return in a void function
4209# at end-of-function, with the previous line a single leading tab, then return;
4210# and the line before that not a goto label target like "out:"
4211		if ($sline =~ /^[ \+]}\s*$/ &&
4212		    $prevline =~ /^\+\treturn\s*;\s*$/ &&
4213		    $linenr >= 3 &&
4214		    $lines[$linenr - 3] =~ /^[ +]/ &&
4215		    $lines[$linenr - 3] !~ /^[ +]\s*$Ident\s*:/) {
4216			WARN("RETURN_VOID",
4217			     "void function return statements are not generally useful\n" . $hereprev);
4218               }
4219
4220# if statements using unnecessary parentheses - ie: if ((foo == bar))
4221		if ($^V && $^V ge 5.10.0 &&
4222		    $line =~ /\bif\s*((?:\(\s*){2,})/) {
4223			my $openparens = $1;
4224			my $count = $openparens =~ tr@\(@\(@;
4225			my $msg = "";
4226			if ($line =~ /\bif\s*(?:\(\s*){$count,$count}$LvalOrFunc\s*($Compare)\s*$LvalOrFunc(?:\s*\)){$count,$count}/) {
4227				my $comp = $4;	#Not $1 because of $LvalOrFunc
4228				$msg = " - maybe == should be = ?" if ($comp eq "==");
4229				WARN("UNNECESSARY_PARENTHESES",
4230				     "Unnecessary parentheses$msg\n" . $herecurr);
4231			}
4232		}
4233
4234# comparisons with a constant or upper case identifier on the left
4235#	avoid cases like "foo + BAR < baz"
4236#	only fix matches surrounded by parentheses to avoid incorrect
4237#	conversions like "FOO < baz() + 5" being "misfixed" to "baz() > FOO + 5"
4238		if ($^V && $^V ge 5.10.0 &&
4239		    $line =~ /^\+(.*)\b($Constant|[A-Z_][A-Z0-9_]*)\s*($Compare)\s*($LvalOrFunc)/) {
4240			my $lead = $1;
4241			my $const = $2;
4242			my $comp = $3;
4243			my $to = $4;
4244			my $newcomp = $comp;
4245			if ($lead !~ /$Operators\s*$/ &&
4246			    $to !~ /^(?:Constant|[A-Z_][A-Z0-9_]*)$/ &&
4247			    WARN("CONSTANT_COMPARISON",
4248				 "Comparisons should place the constant on the right side of the test\n" . $herecurr) &&
4249			    $fix) {
4250				if ($comp eq "<") {
4251					$newcomp = ">";
4252				} elsif ($comp eq "<=") {
4253					$newcomp = ">=";
4254				} elsif ($comp eq ">") {
4255					$newcomp = "<";
4256				} elsif ($comp eq ">=") {
4257					$newcomp = "<=";
4258				}
4259				$fixed[$fixlinenr] =~ s/\(\s*\Q$const\E\s*$Compare\s*\Q$to\E\s*\)/($to $newcomp $const)/;
4260			}
4261		}
4262
4263# Return of what appears to be an errno should normally be negative
4264		if ($sline =~ /\breturn(?:\s*\(+\s*|\s+)(E[A-Z]+)(?:\s*\)+\s*|\s*)[;:,]/) {
4265			my $name = $1;
4266			if ($name ne 'EOF' && $name ne 'ERROR') {
4267				WARN("USE_NEGATIVE_ERRNO",
4268				     "return of an errno should typically be negative (ie: return -$1)\n" . $herecurr);
4269			}
4270		}
4271
4272# Need a space before open parenthesis after if, while etc
4273		if ($line =~ /\b(if|while|for|switch)\(/) {
4274			if (ERROR("SPACING",
4275				  "space required before the open parenthesis '('\n" . $herecurr) &&
4276			    $fix) {
4277				$fixed[$fixlinenr] =~
4278				    s/\b(if|while|for|switch)\(/$1 \(/;
4279			}
4280		}
4281
4282# Check for illegal assignment in if conditional -- and check for trailing
4283# statements after the conditional.
4284		if ($line =~ /do\s*(?!{)/) {
4285			($stat, $cond, $line_nr_next, $remain_next, $off_next) =
4286				ctx_statement_block($linenr, $realcnt, 0)
4287					if (!defined $stat);
4288			my ($stat_next) = ctx_statement_block($line_nr_next,
4289						$remain_next, $off_next);
4290			$stat_next =~ s/\n./\n /g;
4291			##print "stat<$stat> stat_next<$stat_next>\n";
4292
4293			if ($stat_next =~ /^\s*while\b/) {
4294				# If the statement carries leading newlines,
4295				# then count those as offsets.
4296				my ($whitespace) =
4297					($stat_next =~ /^((?:\s*\n[+-])*\s*)/s);
4298				my $offset =
4299					statement_rawlines($whitespace) - 1;
4300
4301				$suppress_whiletrailers{$line_nr_next +
4302								$offset} = 1;
4303			}
4304		}
4305		if (!defined $suppress_whiletrailers{$linenr} &&
4306		    defined($stat) && defined($cond) &&
4307		    $line =~ /\b(?:if|while|for)\s*\(/ && $line !~ /^.\s*#/) {
4308			my ($s, $c) = ($stat, $cond);
4309
4310			if ($c =~ /\bif\s*\(.*[^<>!=]=[^=].*/s) {
4311				ERROR("ASSIGN_IN_IF",
4312				      "do not use assignment in if condition\n" . $herecurr);
4313			}
4314
4315			# Find out what is on the end of the line after the
4316			# conditional.
4317			substr($s, 0, length($c), '');
4318			$s =~ s/\n.*//g;
4319			$s =~ s/$;//g; 	# Remove any comments
4320			if (length($c) && $s !~ /^\s*{?\s*\\*\s*$/ &&
4321			    $c !~ /}\s*while\s*/)
4322			{
4323				# Find out how long the conditional actually is.
4324				my @newlines = ($c =~ /\n/gs);
4325				my $cond_lines = 1 + $#newlines;
4326				my $stat_real = '';
4327
4328				$stat_real = raw_line($linenr, $cond_lines)
4329							. "\n" if ($cond_lines);
4330				if (defined($stat_real) && $cond_lines > 1) {
4331					$stat_real = "[...]\n$stat_real";
4332				}
4333
4334				ERROR("TRAILING_STATEMENTS",
4335				      "trailing statements should be on next line\n" . $herecurr . $stat_real);
4336			}
4337		}
4338
4339# Check for bitwise tests written as boolean
4340		if ($line =~ /
4341			(?:
4342				(?:\[|\(|\&\&|\|\|)
4343				\s*0[xX][0-9]+\s*
4344				(?:\&\&|\|\|)
4345			|
4346				(?:\&\&|\|\|)
4347				\s*0[xX][0-9]+\s*
4348				(?:\&\&|\|\||\)|\])
4349			)/x)
4350		{
4351			WARN("HEXADECIMAL_BOOLEAN_TEST",
4352			     "boolean test with hexadecimal, perhaps just 1 \& or \|?\n" . $herecurr);
4353		}
4354
4355# if and else should not have general statements after it
4356		if ($line =~ /^.\s*(?:}\s*)?else\b(.*)/) {
4357			my $s = $1;
4358			$s =~ s/$;//g; 	# Remove any comments
4359			if ($s !~ /^\s*(?:\sif|(?:{|)\s*\\?\s*$)/) {
4360				ERROR("TRAILING_STATEMENTS",
4361				      "trailing statements should be on next line\n" . $herecurr);
4362			}
4363		}
4364# if should not continue a brace
4365		if ($line =~ /}\s*if\b/) {
4366			ERROR("TRAILING_STATEMENTS",
4367			      "trailing statements should be on next line (or did you mean 'else if'?)\n" .
4368				$herecurr);
4369		}
4370# case and default should not have general statements after them
4371		if ($line =~ /^.\s*(?:case\s*.*|default\s*):/g &&
4372		    $line !~ /\G(?:
4373			(?:\s*$;*)(?:\s*{)?(?:\s*$;*)(?:\s*\\)?\s*$|
4374			\s*return\s+
4375		    )/xg)
4376		{
4377			ERROR("TRAILING_STATEMENTS",
4378			      "trailing statements should be on next line\n" . $herecurr);
4379		}
4380
4381		# Check for }<nl>else {, these must be at the same
4382		# indent level to be relevant to each other.
4383		if ($prevline=~/}\s*$/ and $line=~/^.\s*else\s*/ &&
4384		    $previndent == $indent) {
4385			if (ERROR("ELSE_AFTER_BRACE",
4386				  "else should follow close brace '}'\n" . $hereprev) &&
4387			    $fix && $prevline =~ /^\+/ && $line =~ /^\+/) {
4388				fix_delete_line($fixlinenr - 1, $prevrawline);
4389				fix_delete_line($fixlinenr, $rawline);
4390				my $fixedline = $prevrawline;
4391				$fixedline =~ s/}\s*$//;
4392				if ($fixedline !~ /^\+\s*$/) {
4393					fix_insert_line($fixlinenr, $fixedline);
4394				}
4395				$fixedline = $rawline;
4396				$fixedline =~ s/^(.\s*)else/$1} else/;
4397				fix_insert_line($fixlinenr, $fixedline);
4398			}
4399		}
4400
4401		if ($prevline=~/}\s*$/ and $line=~/^.\s*while\s*/ &&
4402		    $previndent == $indent) {
4403			my ($s, $c) = ctx_statement_block($linenr, $realcnt, 0);
4404
4405			# Find out what is on the end of the line after the
4406			# conditional.
4407			substr($s, 0, length($c), '');
4408			$s =~ s/\n.*//g;
4409
4410			if ($s =~ /^\s*;/) {
4411				if (ERROR("WHILE_AFTER_BRACE",
4412					  "while should follow close brace '}'\n" . $hereprev) &&
4413				    $fix && $prevline =~ /^\+/ && $line =~ /^\+/) {
4414					fix_delete_line($fixlinenr - 1, $prevrawline);
4415					fix_delete_line($fixlinenr, $rawline);
4416					my $fixedline = $prevrawline;
4417					my $trailing = $rawline;
4418					$trailing =~ s/^\+//;
4419					$trailing = trim($trailing);
4420					$fixedline =~ s/}\s*$/} $trailing/;
4421					fix_insert_line($fixlinenr, $fixedline);
4422				}
4423			}
4424		}
4425
4426#Specific variable tests
4427		while ($line =~ m{($Constant|$Lval)}g) {
4428			my $var = $1;
4429
4430#gcc binary extension
4431			if ($var =~ /^$Binary$/) {
4432				if (WARN("GCC_BINARY_CONSTANT",
4433					 "Avoid gcc v4.3+ binary constant extension: <$var>\n" . $herecurr) &&
4434				    $fix) {
4435					my $hexval = sprintf("0x%x", oct($var));
4436					$fixed[$fixlinenr] =~
4437					    s/\b$var\b/$hexval/;
4438				}
4439			}
4440
4441#CamelCase
4442			if ($var !~ /^$Constant$/ &&
4443			    $var =~ /[A-Z][a-z]|[a-z][A-Z]/ &&
4444#Ignore Page<foo> variants
4445			    $var !~ /^(?:Clear|Set|TestClear|TestSet|)Page[A-Z]/ &&
4446#Ignore SI style variants like nS, mV and dB (ie: max_uV, regulator_min_uA_show)
4447			    $var !~ /^(?:[a-z_]*?)_?[a-z][A-Z](?:_[a-z_]+)?$/ &&
4448#Ignore some three character SI units explicitly, like MiB and KHz
4449			    $var !~ /^(?:[a-z_]*?)_?(?:[KMGT]iB|[KMGT]?Hz)(?:_[a-z_]+)?$/) {
4450				while ($var =~ m{($Ident)}g) {
4451					my $word = $1;
4452					next if ($word !~ /[A-Z][a-z]|[a-z][A-Z]/);
4453					if ($check) {
4454						seed_camelcase_includes();
4455						if (!$file && !$camelcase_file_seeded) {
4456							seed_camelcase_file($realfile);
4457							$camelcase_file_seeded = 1;
4458						}
4459					}
4460					if (!defined $camelcase{$word}) {
4461						$camelcase{$word} = 1;
4462						CHK("CAMELCASE",
4463						    "Avoid CamelCase: <$word>\n" . $herecurr);
4464					}
4465				}
4466			}
4467		}
4468
4469#no spaces allowed after \ in define
4470		if ($line =~ /\#\s*define.*\\\s+$/) {
4471			if (WARN("WHITESPACE_AFTER_LINE_CONTINUATION",
4472				 "Whitespace after \\ makes next lines useless\n" . $herecurr) &&
4473			    $fix) {
4474				$fixed[$fixlinenr] =~ s/\s+$//;
4475			}
4476		}
4477
4478# warn if <asm/foo.h> is #included and <linux/foo.h> is available and includes
4479# itself <asm/foo.h> (uses RAW line)
4480		if ($tree && $rawline =~ m{^.\s*\#\s*include\s*\<asm\/(.*)\.h\>}) {
4481			my $file = "$1.h";
4482			my $checkfile = "include/linux/$file";
4483			if (-f "$root/$checkfile" &&
4484			    $realfile ne $checkfile &&
4485			    $1 !~ /$allowed_asm_includes/)
4486			{
4487				my $asminclude = `grep -Ec "#include\\s+<asm/$file>" $root/$checkfile`;
4488				if ($asminclude > 0) {
4489					if ($realfile =~ m{^arch/}) {
4490						CHK("ARCH_INCLUDE_LINUX",
4491						    "Consider using #include <linux/$file> instead of <asm/$file>\n" . $herecurr);
4492					} else {
4493						WARN("INCLUDE_LINUX",
4494						     "Use #include <linux/$file> instead of <asm/$file>\n" . $herecurr);
4495					}
4496				}
4497			}
4498		}
4499
4500# multi-statement macros should be enclosed in a do while loop, grab the
4501# first statement and ensure its the whole macro if its not enclosed
4502# in a known good container
4503		if ($realfile !~ m@/vmlinux.lds.h$@ &&
4504		    $line =~ /^.\s*\#\s*define\s*$Ident(\()?/) {
4505			my $ln = $linenr;
4506			my $cnt = $realcnt;
4507			my ($off, $dstat, $dcond, $rest);
4508			my $ctx = '';
4509			my $has_flow_statement = 0;
4510			my $has_arg_concat = 0;
4511			($dstat, $dcond, $ln, $cnt, $off) =
4512				ctx_statement_block($linenr, $realcnt, 0);
4513			$ctx = $dstat;
4514			#print "dstat<$dstat> dcond<$dcond> cnt<$cnt> off<$off>\n";
4515			#print "LINE<$lines[$ln-1]> len<" . length($lines[$ln-1]) . "\n";
4516
4517			$has_flow_statement = 1 if ($ctx =~ /\b(goto|return)\b/);
4518			$has_arg_concat = 1 if ($ctx =~ /\#\#/);
4519
4520			$dstat =~ s/^.\s*\#\s*define\s+$Ident(?:\([^\)]*\))?\s*//;
4521			$dstat =~ s/$;//g;
4522			$dstat =~ s/\\\n.//g;
4523			$dstat =~ s/^\s*//s;
4524			$dstat =~ s/\s*$//s;
4525
4526			# Flatten any parentheses and braces
4527			while ($dstat =~ s/\([^\(\)]*\)/1/ ||
4528			       $dstat =~ s/\{[^\{\}]*\}/1/ ||
4529			       $dstat =~ s/\[[^\[\]]*\]/1/)
4530			{
4531			}
4532
4533			# Flatten any obvious string concatentation.
4534			while ($dstat =~ s/($String)\s*$Ident/$1/ ||
4535			       $dstat =~ s/$Ident\s*($String)/$1/)
4536			{
4537			}
4538
4539			my $exceptions = qr{
4540				$Declare|
4541				module_param_named|
4542				MODULE_PARM_DESC|
4543				DECLARE_PER_CPU|
4544				DEFINE_PER_CPU|
4545				__typeof__\(|
4546				union|
4547				struct|
4548				\.$Ident\s*=\s*|
4549				^\"|\"$
4550			}x;
4551			#print "REST<$rest> dstat<$dstat> ctx<$ctx>\n";
4552			if ($dstat ne '' &&
4553			    $dstat !~ /^(?:$Ident|-?$Constant),$/ &&			# 10, // foo(),
4554			    $dstat !~ /^(?:$Ident|-?$Constant);$/ &&			# foo();
4555			    $dstat !~ /^[!~-]?(?:$Lval|$Constant)$/ &&		# 10 // foo() // !foo // ~foo // -foo // foo->bar // foo.bar->baz
4556			    $dstat !~ /^'X'$/ && $dstat !~ /^'XX'$/ &&			# character constants
4557			    $dstat !~ /$exceptions/ &&
4558			    $dstat !~ /^\.$Ident\s*=/ &&				# .foo =
4559			    $dstat !~ /^(?:\#\s*$Ident|\#\s*$Constant)\s*$/ &&		# stringification #foo
4560			    $dstat !~ /^do\s*$Constant\s*while\s*$Constant;?$/ &&	# do {...} while (...); // do {...} while (...)
4561			    $dstat !~ /^for\s*$Constant$/ &&				# for (...)
4562			    $dstat !~ /^for\s*$Constant\s+(?:$Ident|-?$Constant)$/ &&	# for (...) bar()
4563			    $dstat !~ /^do\s*{/ &&					# do {...
4564			    $dstat !~ /^\(\{/ &&						# ({...
4565			    $ctx !~ /^.\s*#\s*define\s+TRACE_(?:SYSTEM|INCLUDE_FILE|INCLUDE_PATH)\b/)
4566			{
4567				$ctx =~ s/\n*$//;
4568				my $herectx = $here . "\n";
4569				my $cnt = statement_rawlines($ctx);
4570
4571				for (my $n = 0; $n < $cnt; $n++) {
4572					$herectx .= raw_line($linenr, $n) . "\n";
4573				}
4574
4575				if ($dstat =~ /;/) {
4576					ERROR("MULTISTATEMENT_MACRO_USE_DO_WHILE",
4577					      "Macros with multiple statements should be enclosed in a do - while loop\n" . "$herectx");
4578				} else {
4579					ERROR("COMPLEX_MACRO",
4580					      "Macros with complex values should be enclosed in parentheses\n" . "$herectx");
4581				}
4582			}
4583
4584# check for macros with flow control, but without ## concatenation
4585# ## concatenation is commonly a macro that defines a function so ignore those
4586			if ($has_flow_statement && !$has_arg_concat) {
4587				my $herectx = $here . "\n";
4588				my $cnt = statement_rawlines($ctx);
4589
4590				for (my $n = 0; $n < $cnt; $n++) {
4591					$herectx .= raw_line($linenr, $n) . "\n";
4592				}
4593				WARN("MACRO_WITH_FLOW_CONTROL",
4594				     "Macros with flow control statements should be avoided\n" . "$herectx");
4595			}
4596
4597# check for line continuations outside of #defines, preprocessor #, and asm
4598
4599		} else {
4600			if ($prevline !~ /^..*\\$/ &&
4601			    $line !~ /^\+\s*\#.*\\$/ &&		# preprocessor
4602			    $line !~ /^\+.*\b(__asm__|asm)\b.*\\$/ &&	# asm
4603			    $line =~ /^\+.*\\$/) {
4604				WARN("LINE_CONTINUATIONS",
4605				     "Avoid unnecessary line continuations\n" . $herecurr);
4606			}
4607		}
4608
4609# do {} while (0) macro tests:
4610# single-statement macros do not need to be enclosed in do while (0) loop,
4611# macro should not end with a semicolon
4612		if ($^V && $^V ge 5.10.0 &&
4613		    $realfile !~ m@/vmlinux.lds.h$@ &&
4614		    $line =~ /^.\s*\#\s*define\s+$Ident(\()?/) {
4615			my $ln = $linenr;
4616			my $cnt = $realcnt;
4617			my ($off, $dstat, $dcond, $rest);
4618			my $ctx = '';
4619			($dstat, $dcond, $ln, $cnt, $off) =
4620				ctx_statement_block($linenr, $realcnt, 0);
4621			$ctx = $dstat;
4622
4623			$dstat =~ s/\\\n.//g;
4624			$dstat =~ s/$;/ /g;
4625
4626			if ($dstat =~ /^\+\s*#\s*define\s+$Ident\s*${balanced_parens}\s*do\s*{(.*)\s*}\s*while\s*\(\s*0\s*\)\s*([;\s]*)\s*$/) {
4627				my $stmts = $2;
4628				my $semis = $3;
4629
4630				$ctx =~ s/\n*$//;
4631				my $cnt = statement_rawlines($ctx);
4632				my $herectx = $here . "\n";
4633
4634				for (my $n = 0; $n < $cnt; $n++) {
4635					$herectx .= raw_line($linenr, $n) . "\n";
4636				}
4637
4638				if (($stmts =~ tr/;/;/) == 1 &&
4639				    $stmts !~ /^\s*(if|while|for|switch)\b/) {
4640					WARN("SINGLE_STATEMENT_DO_WHILE_MACRO",
4641					     "Single statement macros should not use a do {} while (0) loop\n" . "$herectx");
4642				}
4643				if (defined $semis && $semis ne "") {
4644					WARN("DO_WHILE_MACRO_WITH_TRAILING_SEMICOLON",
4645					     "do {} while (0) macros should not be semicolon terminated\n" . "$herectx");
4646				}
4647			} elsif ($dstat =~ /^\+\s*#\s*define\s+$Ident.*;\s*$/) {
4648				$ctx =~ s/\n*$//;
4649				my $cnt = statement_rawlines($ctx);
4650				my $herectx = $here . "\n";
4651
4652				for (my $n = 0; $n < $cnt; $n++) {
4653					$herectx .= raw_line($linenr, $n) . "\n";
4654				}
4655
4656				WARN("TRAILING_SEMICOLON",
4657				     "macros should not use a trailing semicolon\n" . "$herectx");
4658			}
4659		}
4660
4661# make sure symbols are always wrapped with VMLINUX_SYMBOL() ...
4662# all assignments may have only one of the following with an assignment:
4663#	.
4664#	ALIGN(...)
4665#	VMLINUX_SYMBOL(...)
4666		if ($realfile eq 'vmlinux.lds.h' && $line =~ /(?:(?:^|\s)$Ident\s*=|=\s*$Ident(?:\s|$))/) {
4667			WARN("MISSING_VMLINUX_SYMBOL",
4668			     "vmlinux.lds.h needs VMLINUX_SYMBOL() around C-visible symbols\n" . $herecurr);
4669		}
4670
4671# check for redundant bracing round if etc
4672		if ($line =~ /(^.*)\bif\b/ && $1 !~ /else\s*$/) {
4673			my ($level, $endln, @chunks) =
4674				ctx_statement_full($linenr, $realcnt, 1);
4675			#print "chunks<$#chunks> linenr<$linenr> endln<$endln> level<$level>\n";
4676			#print "APW: <<$chunks[1][0]>><<$chunks[1][1]>>\n";
4677			if ($#chunks > 0 && $level == 0) {
4678				my @allowed = ();
4679				my $allow = 0;
4680				my $seen = 0;
4681				my $herectx = $here . "\n";
4682				my $ln = $linenr - 1;
4683				for my $chunk (@chunks) {
4684					my ($cond, $block) = @{$chunk};
4685
4686					# If the condition carries leading newlines, then count those as offsets.
4687					my ($whitespace) = ($cond =~ /^((?:\s*\n[+-])*\s*)/s);
4688					my $offset = statement_rawlines($whitespace) - 1;
4689
4690					$allowed[$allow] = 0;
4691					#print "COND<$cond> whitespace<$whitespace> offset<$offset>\n";
4692
4693					# We have looked at and allowed this specific line.
4694					$suppress_ifbraces{$ln + $offset} = 1;
4695
4696					$herectx .= "$rawlines[$ln + $offset]\n[...]\n";
4697					$ln += statement_rawlines($block) - 1;
4698
4699					substr($block, 0, length($cond), '');
4700
4701					$seen++ if ($block =~ /^\s*{/);
4702
4703					#print "cond<$cond> block<$block> allowed<$allowed[$allow]>\n";
4704					if (statement_lines($cond) > 1) {
4705						#print "APW: ALLOWED: cond<$cond>\n";
4706						$allowed[$allow] = 1;
4707					}
4708					if ($block =~/\b(?:if|for|while)\b/) {
4709						#print "APW: ALLOWED: block<$block>\n";
4710						$allowed[$allow] = 1;
4711					}
4712					if (statement_block_size($block) > 1) {
4713						#print "APW: ALLOWED: lines block<$block>\n";
4714						$allowed[$allow] = 1;
4715					}
4716					$allow++;
4717				}
4718				if ($seen) {
4719					my $sum_allowed = 0;
4720					foreach (@allowed) {
4721						$sum_allowed += $_;
4722					}
4723					if ($sum_allowed == 0) {
4724						WARN("BRACES",
4725						     "braces {} are not necessary for any arm of this statement\n" . $herectx);
4726					} elsif ($sum_allowed != $allow &&
4727						 $seen != $allow) {
4728						CHK("BRACES",
4729						    "braces {} should be used on all arms of this statement\n" . $herectx);
4730					}
4731				}
4732			}
4733		}
4734		if (!defined $suppress_ifbraces{$linenr - 1} &&
4735					$line =~ /\b(if|while|for|else)\b/) {
4736			my $allowed = 0;
4737
4738			# Check the pre-context.
4739			if (substr($line, 0, $-[0]) =~ /(\}\s*)$/) {
4740				#print "APW: ALLOWED: pre<$1>\n";
4741				$allowed = 1;
4742			}
4743
4744			my ($level, $endln, @chunks) =
4745				ctx_statement_full($linenr, $realcnt, $-[0]);
4746
4747			# Check the condition.
4748			my ($cond, $block) = @{$chunks[0]};
4749			#print "CHECKING<$linenr> cond<$cond> block<$block>\n";
4750			if (defined $cond) {
4751				substr($block, 0, length($cond), '');
4752			}
4753			if (statement_lines($cond) > 1) {
4754				#print "APW: ALLOWED: cond<$cond>\n";
4755				$allowed = 1;
4756			}
4757			if ($block =~/\b(?:if|for|while)\b/) {
4758				#print "APW: ALLOWED: block<$block>\n";
4759				$allowed = 1;
4760			}
4761			if (statement_block_size($block) > 1) {
4762				#print "APW: ALLOWED: lines block<$block>\n";
4763				$allowed = 1;
4764			}
4765			# Check the post-context.
4766			if (defined $chunks[1]) {
4767				my ($cond, $block) = @{$chunks[1]};
4768				if (defined $cond) {
4769					substr($block, 0, length($cond), '');
4770				}
4771				if ($block =~ /^\s*\{/) {
4772					#print "APW: ALLOWED: chunk-1 block<$block>\n";
4773					$allowed = 1;
4774				}
4775			}
4776			if ($level == 0 && $block =~ /^\s*\{/ && !$allowed) {
4777				my $herectx = $here . "\n";
4778				my $cnt = statement_rawlines($block);
4779
4780				for (my $n = 0; $n < $cnt; $n++) {
4781					$herectx .= raw_line($linenr, $n) . "\n";
4782				}
4783
4784				WARN("BRACES",
4785				     "braces {} are not necessary for single statement blocks\n" . $herectx);
4786			}
4787		}
4788
4789# check for unnecessary blank lines around braces
4790		if (($line =~ /^.\s*}\s*$/ && $prevrawline =~ /^.\s*$/)) {
4791			if (CHK("BRACES",
4792				"Blank lines aren't necessary before a close brace '}'\n" . $hereprev) &&
4793			    $fix && $prevrawline =~ /^\+/) {
4794				fix_delete_line($fixlinenr - 1, $prevrawline);
4795			}
4796		}
4797		if (($rawline =~ /^.\s*$/ && $prevline =~ /^..*{\s*$/)) {
4798			if (CHK("BRACES",
4799				"Blank lines aren't necessary after an open brace '{'\n" . $hereprev) &&
4800			    $fix) {
4801				fix_delete_line($fixlinenr, $rawline);
4802			}
4803		}
4804
4805# no volatiles please
4806		my $asm_volatile = qr{\b(__asm__|asm)\s+(__volatile__|volatile)\b};
4807		if ($line =~ /\bvolatile\b/ && $line !~ /$asm_volatile/) {
4808			WARN("VOLATILE",
4809			     "Use of volatile is usually wrong: see Documentation/volatile-considered-harmful.txt\n" . $herecurr);
4810		}
4811
4812# Check for user-visible strings broken across lines, which breaks the ability
4813# to grep for the string.  Make exceptions when the previous string ends in a
4814# newline (multiple lines in one string constant) or '\t', '\r', ';', or '{'
4815# (common in inline assembly) or is a octal \123 or hexadecimal \xaf value
4816		if ($line =~ /^\+\s*$String/ &&
4817		    $prevline =~ /"\s*$/ &&
4818		    $prevrawline !~ /(?:\\(?:[ntr]|[0-7]{1,3}|x[0-9a-fA-F]{1,2})|;\s*|\{\s*)"\s*$/) {
4819			if (WARN("SPLIT_STRING",
4820				 "quoted string split across lines\n" . $hereprev) &&
4821				     $fix &&
4822				     $prevrawline =~ /^\+.*"\s*$/ &&
4823				     $last_coalesced_string_linenr != $linenr - 1) {
4824				my $extracted_string = get_quoted_string($line, $rawline);
4825				my $comma_close = "";
4826				if ($rawline =~ /\Q$extracted_string\E(\s*\)\s*;\s*$|\s*,\s*)/) {
4827					$comma_close = $1;
4828				}
4829
4830				fix_delete_line($fixlinenr - 1, $prevrawline);
4831				fix_delete_line($fixlinenr, $rawline);
4832				my $fixedline = $prevrawline;
4833				$fixedline =~ s/"\s*$//;
4834				$fixedline .= substr($extracted_string, 1) . trim($comma_close);
4835				fix_insert_line($fixlinenr - 1, $fixedline);
4836				$fixedline = $rawline;
4837				$fixedline =~ s/\Q$extracted_string\E\Q$comma_close\E//;
4838				if ($fixedline !~ /\+\s*$/) {
4839					fix_insert_line($fixlinenr, $fixedline);
4840				}
4841				$last_coalesced_string_linenr = $linenr;
4842			}
4843		}
4844
4845# check for missing a space in a string concatenation
4846		if ($prevrawline =~ /[^\\]\w"$/ && $rawline =~ /^\+[\t ]+"\w/) {
4847			WARN('MISSING_SPACE',
4848			     "break quoted strings at a space character\n" . $hereprev);
4849		}
4850
4851# check for spaces before a quoted newline
4852		if ($rawline =~ /^.*\".*\s\\n/) {
4853			if (WARN("QUOTED_WHITESPACE_BEFORE_NEWLINE",
4854				 "unnecessary whitespace before a quoted newline\n" . $herecurr) &&
4855			    $fix) {
4856				$fixed[$fixlinenr] =~ s/^(\+.*\".*)\s+\\n/$1\\n/;
4857			}
4858
4859		}
4860
4861# concatenated string without spaces between elements
4862		if ($line =~ /$String[A-Z_]/ || $line =~ /[A-Za-z0-9_]$String/) {
4863			CHK("CONCATENATED_STRING",
4864			    "Concatenated strings should use spaces between elements\n" . $herecurr);
4865		}
4866
4867# uncoalesced string fragments
4868		if ($line =~ /$String\s*"/) {
4869			WARN("STRING_FRAGMENTS",
4870			     "Consecutive strings are generally better as a single string\n" . $herecurr);
4871		}
4872
4873# check for %L{u,d,i} and 0x%[udi] in strings
4874		my $string;
4875		while ($line =~ /(?:^|")([X\t]*)(?:"|$)/g) {
4876			$string = substr($rawline, $-[1], $+[1] - $-[1]);
4877			$string =~ s/%%/__/g;
4878			if ($string =~ /(?<!%)%[\*\d\.\$]*L[udi]/) {
4879				WARN("PRINTF_L",
4880				     "\%Ld/%Lu are not-standard C, use %lld/%llu\n" . $herecurr);
4881				last;
4882			}
4883			if ($string =~ /0x%[\*\d\.\$\Llzth]*[udi]/) {
4884				ERROR("PRINTF_0xDECIMAL",
4885				      "Prefixing 0x with decimal output is defective\n" . $herecurr);
4886			}
4887		}
4888
4889# check for line continuations in quoted strings with odd counts of "
4890		if ($rawline =~ /\\$/ && $rawline =~ tr/"/"/ % 2) {
4891			WARN("LINE_CONTINUATIONS",
4892			     "Avoid line continuations in quoted strings\n" . $herecurr);
4893		}
4894
4895# warn about #if 0
4896		if ($line =~ /^.\s*\#\s*if\s+0\b/) {
4897			CHK("REDUNDANT_CODE",
4898			    "if this code is redundant consider removing it\n" .
4899				$herecurr);
4900		}
4901
4902# check for needless "if (<foo>) fn(<foo>)" uses
4903		if ($prevline =~ /\bif\s*\(\s*($Lval)\s*\)/) {
4904			my $tested = quotemeta($1);
4905			my $expr = '\s*\(\s*' . $tested . '\s*\)\s*;';
4906			if ($line =~ /\b(kfree|usb_free_urb|debugfs_remove(?:_recursive)?|(?:kmem_cache|mempool|dma_pool)_destroy)$expr/) {
4907				my $func = $1;
4908				if (WARN('NEEDLESS_IF',
4909					 "$func(NULL) is safe and this check is probably not required\n" . $hereprev) &&
4910				    $fix) {
4911					my $do_fix = 1;
4912					my $leading_tabs = "";
4913					my $new_leading_tabs = "";
4914					if ($lines[$linenr - 2] =~ /^\+(\t*)if\s*\(\s*$tested\s*\)\s*$/) {
4915						$leading_tabs = $1;
4916					} else {
4917						$do_fix = 0;
4918					}
4919					if ($lines[$linenr - 1] =~ /^\+(\t+)$func\s*\(\s*$tested\s*\)\s*;\s*$/) {
4920						$new_leading_tabs = $1;
4921						if (length($leading_tabs) + 1 ne length($new_leading_tabs)) {
4922							$do_fix = 0;
4923						}
4924					} else {
4925						$do_fix = 0;
4926					}
4927					if ($do_fix) {
4928						fix_delete_line($fixlinenr - 1, $prevrawline);
4929						$fixed[$fixlinenr] =~ s/^\+$new_leading_tabs/\+$leading_tabs/;
4930					}
4931				}
4932			}
4933		}
4934
4935# check for unnecessary "Out of Memory" messages
4936		if ($line =~ /^\+.*\b$logFunctions\s*\(/ &&
4937		    $prevline =~ /^[ \+]\s*if\s*\(\s*(\!\s*|NULL\s*==\s*)?($Lval)(\s*==\s*NULL\s*)?\s*\)/ &&
4938		    (defined $1 || defined $3) &&
4939		    $linenr > 3) {
4940			my $testval = $2;
4941			my $testline = $lines[$linenr - 3];
4942
4943			my ($s, $c) = ctx_statement_block($linenr - 3, $realcnt, 0);
4944#			print("line: <$line>\nprevline: <$prevline>\ns: <$s>\nc: <$c>\n\n\n");
4945
4946			if ($c =~ /(?:^|\n)[ \+]\s*(?:$Type\s*)?\Q$testval\E\s*=\s*(?:\([^\)]*\)\s*)?\s*(?:devm_)?(?:[kv][czm]alloc(?:_node|_array)?\b|kstrdup|(?:dev_)?alloc_skb)/) {
4947				WARN("OOM_MESSAGE",
4948				     "Possible unnecessary 'out of memory' message\n" . $hereprev);
4949			}
4950		}
4951
4952# check for logging functions with KERN_<LEVEL>
4953		if ($line !~ /printk(?:_ratelimited|_once)?\s*\(/ &&
4954		    $line =~ /\b$logFunctions\s*\(.*\b(KERN_[A-Z]+)\b/) {
4955			my $level = $1;
4956			if (WARN("UNNECESSARY_KERN_LEVEL",
4957				 "Possible unnecessary $level\n" . $herecurr) &&
4958			    $fix) {
4959				$fixed[$fixlinenr] =~ s/\s*$level\s*//;
4960			}
4961		}
4962
4963# check for mask then right shift without a parentheses
4964		if ($^V && $^V ge 5.10.0 &&
4965		    $line =~ /$LvalOrFunc\s*\&\s*($LvalOrFunc)\s*>>/ &&
4966		    $4 !~ /^\&/) { # $LvalOrFunc may be &foo, ignore if so
4967			WARN("MASK_THEN_SHIFT",
4968			     "Possible precedence defect with mask then right shift - may need parentheses\n" . $herecurr);
4969		}
4970
4971# check for pointer comparisons to NULL
4972		if ($^V && $^V ge 5.10.0) {
4973			while ($line =~ /\b$LvalOrFunc\s*(==|\!=)\s*NULL\b/g) {
4974				my $val = $1;
4975				my $equal = "!";
4976				$equal = "" if ($4 eq "!=");
4977				if (CHK("COMPARISON_TO_NULL",
4978					"Comparison to NULL could be written \"${equal}${val}\"\n" . $herecurr) &&
4979					    $fix) {
4980					$fixed[$fixlinenr] =~ s/\b\Q$val\E\s*(?:==|\!=)\s*NULL\b/$equal$val/;
4981				}
4982			}
4983		}
4984
4985# check for bad placement of section $InitAttribute (e.g.: __initdata)
4986		if ($line =~ /(\b$InitAttribute\b)/) {
4987			my $attr = $1;
4988			if ($line =~ /^\+\s*static\s+(?:const\s+)?(?:$attr\s+)?($NonptrTypeWithAttr)\s+(?:$attr\s+)?($Ident(?:\[[^]]*\])?)\s*[=;]/) {
4989				my $ptr = $1;
4990				my $var = $2;
4991				if ((($ptr =~ /\b(union|struct)\s+$attr\b/ &&
4992				      ERROR("MISPLACED_INIT",
4993					    "$attr should be placed after $var\n" . $herecurr)) ||
4994				     ($ptr !~ /\b(union|struct)\s+$attr\b/ &&
4995				      WARN("MISPLACED_INIT",
4996					   "$attr should be placed after $var\n" . $herecurr))) &&
4997				    $fix) {
4998					$fixed[$fixlinenr] =~ s/(\bstatic\s+(?:const\s+)?)(?:$attr\s+)?($NonptrTypeWithAttr)\s+(?:$attr\s+)?($Ident(?:\[[^]]*\])?)\s*([=;])\s*/"$1" . trim(string_find_replace($2, "\\s*$attr\\s*", " ")) . " " . trim(string_find_replace($3, "\\s*$attr\\s*", "")) . " $attr" . ("$4" eq ";" ? ";" : " = ")/e;
4999				}
5000			}
5001		}
5002
5003# check for $InitAttributeData (ie: __initdata) with const
5004		if ($line =~ /\bconst\b/ && $line =~ /($InitAttributeData)/) {
5005			my $attr = $1;
5006			$attr =~ /($InitAttributePrefix)(.*)/;
5007			my $attr_prefix = $1;
5008			my $attr_type = $2;
5009			if (ERROR("INIT_ATTRIBUTE",
5010				  "Use of const init definition must use ${attr_prefix}initconst\n" . $herecurr) &&
5011			    $fix) {
5012				$fixed[$fixlinenr] =~
5013				    s/$InitAttributeData/${attr_prefix}initconst/;
5014			}
5015		}
5016
5017# check for $InitAttributeConst (ie: __initconst) without const
5018		if ($line !~ /\bconst\b/ && $line =~ /($InitAttributeConst)/) {
5019			my $attr = $1;
5020			if (ERROR("INIT_ATTRIBUTE",
5021				  "Use of $attr requires a separate use of const\n" . $herecurr) &&
5022			    $fix) {
5023				my $lead = $fixed[$fixlinenr] =~
5024				    /(^\+\s*(?:static\s+))/;
5025				$lead = rtrim($1);
5026				$lead = "$lead " if ($lead !~ /^\+$/);
5027				$lead = "${lead}const ";
5028				$fixed[$fixlinenr] =~ s/(^\+\s*(?:static\s+))/$lead/;
5029			}
5030		}
5031
5032# check for __read_mostly with const non-pointer (should just be const)
5033		if ($line =~ /\b__read_mostly\b/ &&
5034		    $line =~ /($Type)\s*$Ident/ && $1 !~ /\*\s*$/ && $1 =~ /\bconst\b/) {
5035			if (ERROR("CONST_READ_MOSTLY",
5036				  "Invalid use of __read_mostly with const type\n" . $herecurr) &&
5037			    $fix) {
5038				$fixed[$fixlinenr] =~ s/\s+__read_mostly\b//;
5039			}
5040		}
5041
5042# don't use __constant_<foo> functions outside of include/uapi/
5043		if ($realfile !~ m@^include/uapi/@ &&
5044		    $line =~ /(__constant_(?:htons|ntohs|[bl]e(?:16|32|64)_to_cpu|cpu_to_[bl]e(?:16|32|64)))\s*\(/) {
5045			my $constant_func = $1;
5046			my $func = $constant_func;
5047			$func =~ s/^__constant_//;
5048			if (WARN("CONSTANT_CONVERSION",
5049				 "$constant_func should be $func\n" . $herecurr) &&
5050			    $fix) {
5051				$fixed[$fixlinenr] =~ s/\b$constant_func\b/$func/g;
5052			}
5053		}
5054
5055# prefer usleep_range over udelay
5056		if ($line =~ /\budelay\s*\(\s*(\d+)\s*\)/) {
5057			my $delay = $1;
5058			# ignore udelay's < 10, however
5059			if (! ($delay < 10) ) {
5060				CHK("USLEEP_RANGE",
5061				    "usleep_range is preferred over udelay; see Documentation/timers/timers-howto.txt\n" . $herecurr);
5062			}
5063			if ($delay > 2000) {
5064				WARN("LONG_UDELAY",
5065				     "long udelay - prefer mdelay; see arch/arm/include/asm/delay.h\n" . $herecurr);
5066			}
5067		}
5068
5069# warn about unexpectedly long msleep's
5070		if ($line =~ /\bmsleep\s*\((\d+)\);/) {
5071			if ($1 < 20) {
5072				WARN("MSLEEP",
5073				     "msleep < 20ms can sleep for up to 20ms; see Documentation/timers/timers-howto.txt\n" . $herecurr);
5074			}
5075		}
5076
5077# check for comparisons of jiffies
5078		if ($line =~ /\bjiffies\s*$Compare|$Compare\s*jiffies\b/) {
5079			WARN("JIFFIES_COMPARISON",
5080			     "Comparing jiffies is almost always wrong; prefer time_after, time_before and friends\n" . $herecurr);
5081		}
5082
5083# check for comparisons of get_jiffies_64()
5084		if ($line =~ /\bget_jiffies_64\s*\(\s*\)\s*$Compare|$Compare\s*get_jiffies_64\s*\(\s*\)/) {
5085			WARN("JIFFIES_COMPARISON",
5086			     "Comparing get_jiffies_64() is almost always wrong; prefer time_after64, time_before64 and friends\n" . $herecurr);
5087		}
5088
5089# warn about #ifdefs in C files
5090#		if ($line =~ /^.\s*\#\s*if(|n)def/ && ($realfile =~ /\.c$/)) {
5091#			print "#ifdef in C files should be avoided\n";
5092#			print "$herecurr";
5093#			$clean = 0;
5094#		}
5095
5096# warn about spacing in #ifdefs
5097		if ($line =~ /^.\s*\#\s*(ifdef|ifndef|elif)\s\s+/) {
5098			if (ERROR("SPACING",
5099				  "exactly one space required after that #$1\n" . $herecurr) &&
5100			    $fix) {
5101				$fixed[$fixlinenr] =~
5102				    s/^(.\s*\#\s*(ifdef|ifndef|elif))\s{2,}/$1 /;
5103			}
5104
5105		}
5106
5107# check for spinlock_t definitions without a comment.
5108		if ($line =~ /^.\s*(struct\s+mutex|spinlock_t)\s+\S+;/ ||
5109		    $line =~ /^.\s*(DEFINE_MUTEX)\s*\(/) {
5110			my $which = $1;
5111			if (!ctx_has_comment($first_line, $linenr)) {
5112				CHK("UNCOMMENTED_DEFINITION",
5113				    "$1 definition without comment\n" . $herecurr);
5114			}
5115		}
5116# check for memory barriers without a comment.
5117		if ($line =~ /\b(mb|rmb|wmb|read_barrier_depends|smp_mb|smp_rmb|smp_wmb|smp_read_barrier_depends)\(/) {
5118			if (!ctx_has_comment($first_line, $linenr)) {
5119				WARN("MEMORY_BARRIER",
5120				     "memory barrier without comment\n" . $herecurr);
5121			}
5122		}
5123
5124# check for waitqueue_active without a comment.
5125		if ($line =~ /\bwaitqueue_active\s*\(/) {
5126			if (!ctx_has_comment($first_line, $linenr)) {
5127				WARN("WAITQUEUE_ACTIVE",
5128				     "waitqueue_active without comment\n" . $herecurr);
5129			}
5130		}
5131
5132# Check for expedited grace periods that interrupt non-idle non-nohz
5133# online CPUs.  These expedited can therefore degrade real-time response
5134# if used carelessly, and should be avoided where not absolutely
5135# needed.  It is always OK to use synchronize_rcu_expedited() and
5136# synchronize_sched_expedited() at boot time (before real-time applications
5137# start) and in error situations where real-time response is compromised in
5138# any case.  Note that synchronize_srcu_expedited() does -not- interrupt
5139# other CPUs, so don't warn on uses of synchronize_srcu_expedited().
5140# Of course, nothing comes for free, and srcu_read_lock() and
5141# srcu_read_unlock() do contain full memory barriers in payment for
5142# synchronize_srcu_expedited() non-interruption properties.
5143		if ($line =~ /\b(synchronize_rcu_expedited|synchronize_sched_expedited)\(/) {
5144			WARN("EXPEDITED_RCU_GRACE_PERIOD",
5145			     "expedited RCU grace periods should be avoided where they can degrade real-time response\n" . $herecurr);
5146
5147		}
5148
5149# check of hardware specific defines
5150		if ($line =~ m@^.\s*\#\s*if.*\b(__i386__|__powerpc64__|__sun__|__s390x__)\b@ && $realfile !~ m@include/asm-@) {
5151			CHK("ARCH_DEFINES",
5152			    "architecture specific defines should be avoided\n" .  $herecurr);
5153		}
5154
5155# Check that the storage class is at the beginning of a declaration
5156		if ($line =~ /\b$Storage\b/ && $line !~ /^.\s*$Storage\b/) {
5157			WARN("STORAGE_CLASS",
5158			     "storage class should be at the beginning of the declaration\n" . $herecurr)
5159		}
5160
5161# check the location of the inline attribute, that it is between
5162# storage class and type.
5163		if ($line =~ /\b$Type\s+$Inline\b/ ||
5164		    $line =~ /\b$Inline\s+$Storage\b/) {
5165			ERROR("INLINE_LOCATION",
5166			      "inline keyword should sit between storage class and type\n" . $herecurr);
5167		}
5168
5169# Check for __inline__ and __inline, prefer inline
5170		if ($realfile !~ m@\binclude/uapi/@ &&
5171		    $line =~ /\b(__inline__|__inline)\b/) {
5172			if (WARN("INLINE",
5173				 "plain inline is preferred over $1\n" . $herecurr) &&
5174			    $fix) {
5175				$fixed[$fixlinenr] =~ s/\b(__inline__|__inline)\b/inline/;
5176
5177			}
5178		}
5179
5180# Check for __attribute__ packed, prefer __packed
5181		if ($realfile !~ m@\binclude/uapi/@ &&
5182		    $line =~ /\b__attribute__\s*\(\s*\(.*\bpacked\b/) {
5183			WARN("PREFER_PACKED",
5184			     "__packed is preferred over __attribute__((packed))\n" . $herecurr);
5185		}
5186
5187# Check for __attribute__ aligned, prefer __aligned
5188		if ($realfile !~ m@\binclude/uapi/@ &&
5189		    $line =~ /\b__attribute__\s*\(\s*\(.*aligned/) {
5190			WARN("PREFER_ALIGNED",
5191			     "__aligned(size) is preferred over __attribute__((aligned(size)))\n" . $herecurr);
5192		}
5193
5194# Check for __attribute__ format(printf, prefer __printf
5195		if ($realfile !~ m@\binclude/uapi/@ &&
5196		    $line =~ /\b__attribute__\s*\(\s*\(\s*format\s*\(\s*printf/) {
5197			if (WARN("PREFER_PRINTF",
5198				 "__printf(string-index, first-to-check) is preferred over __attribute__((format(printf, string-index, first-to-check)))\n" . $herecurr) &&
5199			    $fix) {
5200				$fixed[$fixlinenr] =~ s/\b__attribute__\s*\(\s*\(\s*format\s*\(\s*printf\s*,\s*(.*)\)\s*\)\s*\)/"__printf(" . trim($1) . ")"/ex;
5201
5202			}
5203		}
5204
5205# Check for __attribute__ format(scanf, prefer __scanf
5206		if ($realfile !~ m@\binclude/uapi/@ &&
5207		    $line =~ /\b__attribute__\s*\(\s*\(\s*format\s*\(\s*scanf\b/) {
5208			if (WARN("PREFER_SCANF",
5209				 "__scanf(string-index, first-to-check) is preferred over __attribute__((format(scanf, string-index, first-to-check)))\n" . $herecurr) &&
5210			    $fix) {
5211				$fixed[$fixlinenr] =~ s/\b__attribute__\s*\(\s*\(\s*format\s*\(\s*scanf\s*,\s*(.*)\)\s*\)\s*\)/"__scanf(" . trim($1) . ")"/ex;
5212			}
5213		}
5214
5215# Check for __attribute__ weak, or __weak declarations (may have link issues)
5216		if ($^V && $^V ge 5.10.0 &&
5217		    $line =~ /(?:$Declare|$DeclareMisordered)\s*$Ident\s*$balanced_parens\s*(?:$Attribute)?\s*;/ &&
5218		    ($line =~ /\b__attribute__\s*\(\s*\(.*\bweak\b/ ||
5219		     $line =~ /\b__weak\b/)) {
5220			ERROR("WEAK_DECLARATION",
5221			      "Using weak declarations can have unintended link defects\n" . $herecurr);
5222		}
5223
5224# check for c99 types like uint8_t used outside of uapi/
5225		if ($realfile !~ m@\binclude/uapi/@ &&
5226		    $line =~ /\b($Declare)\s*$Ident\s*[=;,\[]/) {
5227			my $type = $1;
5228			if ($type =~ /\b($typeC99Typedefs)\b/) {
5229				$type = $1;
5230				my $kernel_type = 'u';
5231				$kernel_type = 's' if ($type =~ /^_*[si]/);
5232				$type =~ /(\d+)/;
5233				$kernel_type .= $1;
5234				if (CHK("PREFER_KERNEL_TYPES",
5235					"Prefer kernel type '$kernel_type' over '$type'\n" . $herecurr) &&
5236				    $fix) {
5237					$fixed[$fixlinenr] =~ s/\b$type\b/$kernel_type/;
5238				}
5239			}
5240		}
5241
5242# check for sizeof(&)
5243		if ($line =~ /\bsizeof\s*\(\s*\&/) {
5244			WARN("SIZEOF_ADDRESS",
5245			     "sizeof(& should be avoided\n" . $herecurr);
5246		}
5247
5248# check for sizeof without parenthesis
5249		if ($line =~ /\bsizeof\s+((?:\*\s*|)$Lval|$Type(?:\s+$Lval|))/) {
5250			if (WARN("SIZEOF_PARENTHESIS",
5251				 "sizeof $1 should be sizeof($1)\n" . $herecurr) &&
5252			    $fix) {
5253				$fixed[$fixlinenr] =~ s/\bsizeof\s+((?:\*\s*|)$Lval|$Type(?:\s+$Lval|))/"sizeof(" . trim($1) . ")"/ex;
5254			}
5255		}
5256
5257# check for struct spinlock declarations
5258		if ($line =~ /^.\s*\bstruct\s+spinlock\s+\w+\s*;/) {
5259			WARN("USE_SPINLOCK_T",
5260			     "struct spinlock should be spinlock_t\n" . $herecurr);
5261		}
5262
5263# check for seq_printf uses that could be seq_puts
5264		if ($sline =~ /\bseq_printf\s*\(.*"\s*\)\s*;\s*$/) {
5265			my $fmt = get_quoted_string($line, $rawline);
5266			$fmt =~ s/%%//g;
5267			if ($fmt !~ /%/) {
5268				if (WARN("PREFER_SEQ_PUTS",
5269					 "Prefer seq_puts to seq_printf\n" . $herecurr) &&
5270				    $fix) {
5271					$fixed[$fixlinenr] =~ s/\bseq_printf\b/seq_puts/;
5272				}
5273			}
5274		}
5275
5276# Check for misused memsets
5277		if ($^V && $^V ge 5.10.0 &&
5278		    defined $stat &&
5279		    $stat =~ /^\+(?:.*?)\bmemset\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*\,\s*$FuncArg\s*\)/) {
5280
5281			my $ms_addr = $2;
5282			my $ms_val = $7;
5283			my $ms_size = $12;
5284
5285			if ($ms_size =~ /^(0x|)0$/i) {
5286				ERROR("MEMSET",
5287				      "memset to 0's uses 0 as the 2nd argument, not the 3rd\n" . "$here\n$stat\n");
5288			} elsif ($ms_size =~ /^(0x|)1$/i) {
5289				WARN("MEMSET",
5290				     "single byte memset is suspicious. Swapped 2nd/3rd argument?\n" . "$here\n$stat\n");
5291			}
5292		}
5293
5294# Check for memcpy(foo, bar, ETH_ALEN) that could be ether_addr_copy(foo, bar)
5295		if ($^V && $^V ge 5.10.0 &&
5296		    defined $stat &&
5297		    $stat =~ /^\+(?:.*?)\bmemcpy\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*\,\s*ETH_ALEN\s*\)/) {
5298			if (WARN("PREFER_ETHER_ADDR_COPY",
5299				 "Prefer ether_addr_copy() over memcpy() if the Ethernet addresses are __aligned(2)\n" . "$here\n$stat\n") &&
5300			    $fix) {
5301				$fixed[$fixlinenr] =~ s/\bmemcpy\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*\,\s*ETH_ALEN\s*\)/ether_addr_copy($2, $7)/;
5302			}
5303		}
5304
5305# Check for memcmp(foo, bar, ETH_ALEN) that could be ether_addr_equal*(foo, bar)
5306		if ($^V && $^V ge 5.10.0 &&
5307		    defined $stat &&
5308		    $stat =~ /^\+(?:.*?)\bmemcmp\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*\,\s*ETH_ALEN\s*\)/) {
5309			WARN("PREFER_ETHER_ADDR_EQUAL",
5310			     "Prefer ether_addr_equal() or ether_addr_equal_unaligned() over memcmp()\n" . "$here\n$stat\n")
5311		}
5312
5313# check for memset(foo, 0x0, ETH_ALEN) that could be eth_zero_addr
5314# check for memset(foo, 0xFF, ETH_ALEN) that could be eth_broadcast_addr
5315		if ($^V && $^V ge 5.10.0 &&
5316		    defined $stat &&
5317		    $stat =~ /^\+(?:.*?)\bmemset\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*\,\s*ETH_ALEN\s*\)/) {
5318
5319			my $ms_val = $7;
5320
5321			if ($ms_val =~ /^(?:0x|)0+$/i) {
5322				if (WARN("PREFER_ETH_ZERO_ADDR",
5323					 "Prefer eth_zero_addr over memset()\n" . "$here\n$stat\n") &&
5324				    $fix) {
5325					$fixed[$fixlinenr] =~ s/\bmemset\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*,\s*ETH_ALEN\s*\)/eth_zero_addr($2)/;
5326				}
5327			} elsif ($ms_val =~ /^(?:0xff|255)$/i) {
5328				if (WARN("PREFER_ETH_BROADCAST_ADDR",
5329					 "Prefer eth_broadcast_addr() over memset()\n" . "$here\n$stat\n") &&
5330				    $fix) {
5331					$fixed[$fixlinenr] =~ s/\bmemset\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*,\s*ETH_ALEN\s*\)/eth_broadcast_addr($2)/;
5332				}
5333			}
5334		}
5335
5336# typecasts on min/max could be min_t/max_t
5337		if ($^V && $^V ge 5.10.0 &&
5338		    defined $stat &&
5339		    $stat =~ /^\+(?:.*?)\b(min|max)\s*\(\s*$FuncArg\s*,\s*$FuncArg\s*\)/) {
5340			if (defined $2 || defined $7) {
5341				my $call = $1;
5342				my $cast1 = deparenthesize($2);
5343				my $arg1 = $3;
5344				my $cast2 = deparenthesize($7);
5345				my $arg2 = $8;
5346				my $cast;
5347
5348				if ($cast1 ne "" && $cast2 ne "" && $cast1 ne $cast2) {
5349					$cast = "$cast1 or $cast2";
5350				} elsif ($cast1 ne "") {
5351					$cast = $cast1;
5352				} else {
5353					$cast = $cast2;
5354				}
5355				WARN("MINMAX",
5356				     "$call() should probably be ${call}_t($cast, $arg1, $arg2)\n" . "$here\n$stat\n");
5357			}
5358		}
5359
5360# check usleep_range arguments
5361		if ($^V && $^V ge 5.10.0 &&
5362		    defined $stat &&
5363		    $stat =~ /^\+(?:.*?)\busleep_range\s*\(\s*($FuncArg)\s*,\s*($FuncArg)\s*\)/) {
5364			my $min = $1;
5365			my $max = $7;
5366			if ($min eq $max) {
5367				WARN("USLEEP_RANGE",
5368				     "usleep_range should not use min == max args; see Documentation/timers/timers-howto.txt\n" . "$here\n$stat\n");
5369			} elsif ($min =~ /^\d+$/ && $max =~ /^\d+$/ &&
5370				 $min > $max) {
5371				WARN("USLEEP_RANGE",
5372				     "usleep_range args reversed, use min then max; see Documentation/timers/timers-howto.txt\n" . "$here\n$stat\n");
5373			}
5374		}
5375
5376# check for naked sscanf
5377		if ($^V && $^V ge 5.10.0 &&
5378		    defined $stat &&
5379		    $line =~ /\bsscanf\b/ &&
5380		    ($stat !~ /$Ident\s*=\s*sscanf\s*$balanced_parens/ &&
5381		     $stat !~ /\bsscanf\s*$balanced_parens\s*(?:$Compare)/ &&
5382		     $stat !~ /(?:$Compare)\s*\bsscanf\s*$balanced_parens/)) {
5383			my $lc = $stat =~ tr@\n@@;
5384			$lc = $lc + $linenr;
5385			my $stat_real = raw_line($linenr, 0);
5386		        for (my $count = $linenr + 1; $count <= $lc; $count++) {
5387				$stat_real = $stat_real . "\n" . raw_line($count, 0);
5388			}
5389			WARN("NAKED_SSCANF",
5390			     "unchecked sscanf return value\n" . "$here\n$stat_real\n");
5391		}
5392
5393# check for simple sscanf that should be kstrto<foo>
5394		if ($^V && $^V ge 5.10.0 &&
5395		    defined $stat &&
5396		    $line =~ /\bsscanf\b/) {
5397			my $lc = $stat =~ tr@\n@@;
5398			$lc = $lc + $linenr;
5399			my $stat_real = raw_line($linenr, 0);
5400		        for (my $count = $linenr + 1; $count <= $lc; $count++) {
5401				$stat_real = $stat_real . "\n" . raw_line($count, 0);
5402			}
5403			if ($stat_real =~ /\bsscanf\b\s*\(\s*$FuncArg\s*,\s*("[^"]+")/) {
5404				my $format = $6;
5405				my $count = $format =~ tr@%@%@;
5406				if ($count == 1 &&
5407				    $format =~ /^"\%(?i:ll[udxi]|[udxi]ll|ll|[hl]h?[udxi]|[udxi][hl]h?|[hl]h?|[udxi])"$/) {
5408					WARN("SSCANF_TO_KSTRTO",
5409					     "Prefer kstrto<type> to single variable sscanf\n" . "$here\n$stat_real\n");
5410				}
5411			}
5412		}
5413
5414# check for new externs in .h files.
5415		if ($realfile =~ /\.h$/ &&
5416		    $line =~ /^\+\s*(extern\s+)$Type\s*$Ident\s*\(/s) {
5417			if (CHK("AVOID_EXTERNS",
5418				"extern prototypes should be avoided in .h files\n" . $herecurr) &&
5419			    $fix) {
5420				$fixed[$fixlinenr] =~ s/(.*)\bextern\b\s*(.*)/$1$2/;
5421			}
5422		}
5423
5424# check for new externs in .c files.
5425		if ($realfile =~ /\.c$/ && defined $stat &&
5426		    $stat =~ /^.\s*(?:extern\s+)?$Type\s+($Ident)(\s*)\(/s)
5427		{
5428			my $function_name = $1;
5429			my $paren_space = $2;
5430
5431			my $s = $stat;
5432			if (defined $cond) {
5433				substr($s, 0, length($cond), '');
5434			}
5435			if ($s =~ /^\s*;/ &&
5436			    $function_name ne 'uninitialized_var')
5437			{
5438				WARN("AVOID_EXTERNS",
5439				     "externs should be avoided in .c files\n" .  $herecurr);
5440			}
5441
5442			if ($paren_space =~ /\n/) {
5443				WARN("FUNCTION_ARGUMENTS",
5444				     "arguments for function declarations should follow identifier\n" . $herecurr);
5445			}
5446
5447		} elsif ($realfile =~ /\.c$/ && defined $stat &&
5448		    $stat =~ /^.\s*extern\s+/)
5449		{
5450			WARN("AVOID_EXTERNS",
5451			     "externs should be avoided in .c files\n" .  $herecurr);
5452		}
5453
5454# checks for new __setup's
5455		if ($rawline =~ /\b__setup\("([^"]*)"/) {
5456			my $name = $1;
5457
5458			if (!grep(/$name/, @setup_docs)) {
5459				CHK("UNDOCUMENTED_SETUP",
5460				    "__setup appears un-documented -- check Documentation/kernel-parameters.txt\n" . $herecurr);
5461			}
5462		}
5463
5464# check for pointless casting of kmalloc return
5465		if ($line =~ /\*\s*\)\s*[kv][czm]alloc(_node){0,1}\b/) {
5466			WARN("UNNECESSARY_CASTS",
5467			     "unnecessary cast may hide bugs, see http://c-faq.com/malloc/mallocnocast.html\n" . $herecurr);
5468		}
5469
5470# alloc style
5471# p = alloc(sizeof(struct foo), ...) should be p = alloc(sizeof(*p), ...)
5472		if ($^V && $^V ge 5.10.0 &&
5473		    $line =~ /\b($Lval)\s*\=\s*(?:$balanced_parens)?\s*([kv][mz]alloc(?:_node)?)\s*\(\s*(sizeof\s*\(\s*struct\s+$Lval\s*\))/) {
5474			CHK("ALLOC_SIZEOF_STRUCT",
5475			    "Prefer $3(sizeof(*$1)...) over $3($4...)\n" . $herecurr);
5476		}
5477
5478# check for k[mz]alloc with multiplies that could be kmalloc_array/kcalloc
5479		if ($^V && $^V ge 5.10.0 &&
5480		    $line =~ /\b($Lval)\s*\=\s*(?:$balanced_parens)?\s*(k[mz]alloc)\s*\(\s*($FuncArg)\s*\*\s*($FuncArg)\s*,/) {
5481			my $oldfunc = $3;
5482			my $a1 = $4;
5483			my $a2 = $10;
5484			my $newfunc = "kmalloc_array";
5485			$newfunc = "kcalloc" if ($oldfunc eq "kzalloc");
5486			my $r1 = $a1;
5487			my $r2 = $a2;
5488			if ($a1 =~ /^sizeof\s*\S/) {
5489				$r1 = $a2;
5490				$r2 = $a1;
5491			}
5492			if ($r1 !~ /^sizeof\b/ && $r2 =~ /^sizeof\s*\S/ &&
5493			    !($r1 =~ /^$Constant$/ || $r1 =~ /^[A-Z_][A-Z0-9_]*$/)) {
5494				if (WARN("ALLOC_WITH_MULTIPLY",
5495					 "Prefer $newfunc over $oldfunc with multiply\n" . $herecurr) &&
5496				    $fix) {
5497					$fixed[$fixlinenr] =~ s/\b($Lval)\s*\=\s*(?:$balanced_parens)?\s*(k[mz]alloc)\s*\(\s*($FuncArg)\s*\*\s*($FuncArg)/$1 . ' = ' . "$newfunc(" . trim($r1) . ', ' . trim($r2)/e;
5498
5499				}
5500			}
5501		}
5502
5503# check for krealloc arg reuse
5504		if ($^V && $^V ge 5.10.0 &&
5505		    $line =~ /\b($Lval)\s*\=\s*(?:$balanced_parens)?\s*krealloc\s*\(\s*\1\s*,/) {
5506			WARN("KREALLOC_ARG_REUSE",
5507			     "Reusing the krealloc arg is almost always a bug\n" . $herecurr);
5508		}
5509
5510# check for alloc argument mismatch
5511		if ($line =~ /\b(kcalloc|kmalloc_array)\s*\(\s*sizeof\b/) {
5512			WARN("ALLOC_ARRAY_ARGS",
5513			     "$1 uses number as first arg, sizeof is generally wrong\n" . $herecurr);
5514		}
5515
5516# check for multiple semicolons
5517		if ($line =~ /;\s*;\s*$/) {
5518			if (WARN("ONE_SEMICOLON",
5519				 "Statements terminations use 1 semicolon\n" . $herecurr) &&
5520			    $fix) {
5521				$fixed[$fixlinenr] =~ s/(\s*;\s*){2,}$/;/g;
5522			}
5523		}
5524
5525# check for #defines like: 1 << <digit> that could be BIT(digit)
5526		if ($line =~ /#\s*define\s+\w+\s+\(?\s*1\s*([ulUL]*)\s*\<\<\s*(?:\d+|$Ident)\s*\)?/) {
5527			my $ull = "";
5528			$ull = "_ULL" if (defined($1) && $1 =~ /ll/i);
5529			if (CHK("BIT_MACRO",
5530				"Prefer using the BIT$ull macro\n" . $herecurr) &&
5531			    $fix) {
5532				$fixed[$fixlinenr] =~ s/\(?\s*1\s*[ulUL]*\s*<<\s*(\d+|$Ident)\s*\)?/BIT${ull}($1)/;
5533			}
5534		}
5535
5536# check for case / default statements not preceded by break/fallthrough/switch
5537		if ($line =~ /^.\s*(?:case\s+(?:$Ident|$Constant)\s*|default):/) {
5538			my $has_break = 0;
5539			my $has_statement = 0;
5540			my $count = 0;
5541			my $prevline = $linenr;
5542			while ($prevline > 1 && ($file || $count < 3) && !$has_break) {
5543				$prevline--;
5544				my $rline = $rawlines[$prevline - 1];
5545				my $fline = $lines[$prevline - 1];
5546				last if ($fline =~ /^\@\@/);
5547				next if ($fline =~ /^\-/);
5548				next if ($fline =~ /^.(?:\s*(?:case\s+(?:$Ident|$Constant)[\s$;]*|default):[\s$;]*)*$/);
5549				$has_break = 1 if ($rline =~ /fall[\s_-]*(through|thru)/i);
5550				next if ($fline =~ /^.[\s$;]*$/);
5551				$has_statement = 1;
5552				$count++;
5553				$has_break = 1 if ($fline =~ /\bswitch\b|\b(?:break\s*;[\s$;]*$|return\b|goto\b|continue\b)/);
5554			}
5555			if (!$has_break && $has_statement) {
5556				WARN("MISSING_BREAK",
5557				     "Possible switch case/default not preceeded by break or fallthrough comment\n" . $herecurr);
5558			}
5559		}
5560
5561# check for switch/default statements without a break;
5562		if ($^V && $^V ge 5.10.0 &&
5563		    defined $stat &&
5564		    $stat =~ /^\+[$;\s]*(?:case[$;\s]+\w+[$;\s]*:[$;\s]*|)*[$;\s]*\bdefault[$;\s]*:[$;\s]*;/g) {
5565			my $ctx = '';
5566			my $herectx = $here . "\n";
5567			my $cnt = statement_rawlines($stat);
5568			for (my $n = 0; $n < $cnt; $n++) {
5569				$herectx .= raw_line($linenr, $n) . "\n";
5570			}
5571			WARN("DEFAULT_NO_BREAK",
5572			     "switch default: should use break\n" . $herectx);
5573		}
5574
5575# check for gcc specific __FUNCTION__
5576		if ($line =~ /\b__FUNCTION__\b/) {
5577			if (WARN("USE_FUNC",
5578				 "__func__ should be used instead of gcc specific __FUNCTION__\n"  . $herecurr) &&
5579			    $fix) {
5580				$fixed[$fixlinenr] =~ s/\b__FUNCTION__\b/__func__/g;
5581			}
5582		}
5583
5584# check for uses of __DATE__, __TIME__, __TIMESTAMP__
5585		while ($line =~ /\b(__(?:DATE|TIME|TIMESTAMP)__)\b/g) {
5586			ERROR("DATE_TIME",
5587			      "Use of the '$1' macro makes the build non-deterministic\n" . $herecurr);
5588		}
5589
5590# check for use of yield()
5591		if ($line =~ /\byield\s*\(\s*\)/) {
5592			WARN("YIELD",
5593			     "Using yield() is generally wrong. See yield() kernel-doc (sched/core.c)\n"  . $herecurr);
5594		}
5595
5596# check for comparisons against true and false
5597		if ($line =~ /\+\s*(.*?)\b(true|false|$Lval)\s*(==|\!=)\s*(true|false|$Lval)\b(.*)$/i) {
5598			my $lead = $1;
5599			my $arg = $2;
5600			my $test = $3;
5601			my $otype = $4;
5602			my $trail = $5;
5603			my $op = "!";
5604
5605			($arg, $otype) = ($otype, $arg) if ($arg =~ /^(?:true|false)$/i);
5606
5607			my $type = lc($otype);
5608			if ($type =~ /^(?:true|false)$/) {
5609				if (("$test" eq "==" && "$type" eq "true") ||
5610				    ("$test" eq "!=" && "$type" eq "false")) {
5611					$op = "";
5612				}
5613
5614				CHK("BOOL_COMPARISON",
5615				    "Using comparison to $otype is error prone\n" . $herecurr);
5616
5617## maybe suggesting a correct construct would better
5618##				    "Using comparison to $otype is error prone.  Perhaps use '${lead}${op}${arg}${trail}'\n" . $herecurr);
5619
5620			}
5621		}
5622
5623# check for semaphores initialized locked
5624		if ($line =~ /^.\s*sema_init.+,\W?0\W?\)/) {
5625			WARN("CONSIDER_COMPLETION",
5626			     "consider using a completion\n" . $herecurr);
5627		}
5628
5629# recommend kstrto* over simple_strto* and strict_strto*
5630		if ($line =~ /\b((simple|strict)_(strto(l|ll|ul|ull)))\s*\(/) {
5631			WARN("CONSIDER_KSTRTO",
5632			     "$1 is obsolete, use k$3 instead\n" . $herecurr);
5633		}
5634
5635# check for __initcall(), use device_initcall() explicitly or more appropriate function please
5636		if ($line =~ /^.\s*__initcall\s*\(/) {
5637			WARN("USE_DEVICE_INITCALL",
5638			     "please use device_initcall() or more appropriate function instead of __initcall() (see include/linux/init.h)\n" . $herecurr);
5639		}
5640
5641# check for various structs that are normally const (ops, kgdb, device_tree)
5642		my $const_structs = qr{
5643				acpi_dock_ops|
5644				address_space_operations|
5645				backlight_ops|
5646				block_device_operations|
5647				dentry_operations|
5648				dev_pm_ops|
5649				dma_map_ops|
5650				extent_io_ops|
5651				file_lock_operations|
5652				file_operations|
5653				hv_ops|
5654				ide_dma_ops|
5655				intel_dvo_dev_ops|
5656				item_operations|
5657				iwl_ops|
5658				kgdb_arch|
5659				kgdb_io|
5660				kset_uevent_ops|
5661				lock_manager_operations|
5662				microcode_ops|
5663				mtrr_ops|
5664				neigh_ops|
5665				nlmsvc_binding|
5666				of_device_id|
5667				pci_raw_ops|
5668				pipe_buf_operations|
5669				platform_hibernation_ops|
5670				platform_suspend_ops|
5671				proto_ops|
5672				rpc_pipe_ops|
5673				seq_operations|
5674				snd_ac97_build_ops|
5675				soc_pcmcia_socket_ops|
5676				stacktrace_ops|
5677				sysfs_ops|
5678				tty_operations|
5679				uart_ops|
5680				usb_mon_operations|
5681				wd_ops}x;
5682		if ($line !~ /\bconst\b/ &&
5683		    $line =~ /\bstruct\s+($const_structs)\b/) {
5684			WARN("CONST_STRUCT",
5685			     "struct $1 should normally be const\n" .
5686				$herecurr);
5687		}
5688
5689# use of NR_CPUS is usually wrong
5690# ignore definitions of NR_CPUS and usage to define arrays as likely right
5691		if ($line =~ /\bNR_CPUS\b/ &&
5692		    $line !~ /^.\s*\s*#\s*if\b.*\bNR_CPUS\b/ &&
5693		    $line !~ /^.\s*\s*#\s*define\b.*\bNR_CPUS\b/ &&
5694		    $line !~ /^.\s*$Declare\s.*\[[^\]]*NR_CPUS[^\]]*\]/ &&
5695		    $line !~ /\[[^\]]*\.\.\.[^\]]*NR_CPUS[^\]]*\]/ &&
5696		    $line !~ /\[[^\]]*NR_CPUS[^\]]*\.\.\.[^\]]*\]/)
5697		{
5698			WARN("NR_CPUS",
5699			     "usage of NR_CPUS is often wrong - consider using cpu_possible(), num_possible_cpus(), for_each_possible_cpu(), etc\n" . $herecurr);
5700		}
5701
5702# Use of __ARCH_HAS_<FOO> or ARCH_HAVE_<BAR> is wrong.
5703		if ($line =~ /\+\s*#\s*define\s+((?:__)?ARCH_(?:HAS|HAVE)\w*)\b/) {
5704			ERROR("DEFINE_ARCH_HAS",
5705			      "#define of '$1' is wrong - use Kconfig variables or standard guards instead\n" . $herecurr);
5706		}
5707
5708# likely/unlikely comparisons similar to "(likely(foo) > 0)"
5709		if ($^V && $^V ge 5.10.0 &&
5710		    $line =~ /\b((?:un)?likely)\s*\(\s*$FuncArg\s*\)\s*$Compare/) {
5711			WARN("LIKELY_MISUSE",
5712			     "Using $1 should generally have parentheses around the comparison\n" . $herecurr);
5713		}
5714
5715# whine mightly about in_atomic
5716		if ($line =~ /\bin_atomic\s*\(/) {
5717			if ($realfile =~ m@^drivers/@) {
5718				ERROR("IN_ATOMIC",
5719				      "do not use in_atomic in drivers\n" . $herecurr);
5720			} elsif ($realfile !~ m@^kernel/@) {
5721				WARN("IN_ATOMIC",
5722				     "use of in_atomic() is incorrect outside core kernel code\n" . $herecurr);
5723			}
5724		}
5725
5726# check for lockdep_set_novalidate_class
5727		if ($line =~ /^.\s*lockdep_set_novalidate_class\s*\(/ ||
5728		    $line =~ /__lockdep_no_validate__\s*\)/ ) {
5729			if ($realfile !~ m@^kernel/lockdep@ &&
5730			    $realfile !~ m@^include/linux/lockdep@ &&
5731			    $realfile !~ m@^drivers/base/core@) {
5732				ERROR("LOCKDEP",
5733				      "lockdep_no_validate class is reserved for device->mutex.\n" . $herecurr);
5734			}
5735		}
5736
5737		if ($line =~ /debugfs_create_\w+.*\b$mode_perms_world_writable\b/ ||
5738		    $line =~ /DEVICE_ATTR.*\b$mode_perms_world_writable\b/) {
5739			WARN("EXPORTED_WORLD_WRITABLE",
5740			     "Exporting world writable files is usually an error. Consider more restrictive permissions.\n" . $herecurr);
5741		}
5742
5743# Mode permission misuses where it seems decimal should be octal
5744# This uses a shortcut match to avoid unnecessary uses of a slow foreach loop
5745		if ($^V && $^V ge 5.10.0 &&
5746		    $line =~ /$mode_perms_search/) {
5747			foreach my $entry (@mode_permission_funcs) {
5748				my $func = $entry->[0];
5749				my $arg_pos = $entry->[1];
5750
5751				my $skip_args = "";
5752				if ($arg_pos > 1) {
5753					$arg_pos--;
5754					$skip_args = "(?:\\s*$FuncArg\\s*,\\s*){$arg_pos,$arg_pos}";
5755				}
5756				my $test = "\\b$func\\s*\\(${skip_args}([\\d]+)\\s*[,\\)]";
5757				if ($line =~ /$test/) {
5758					my $val = $1;
5759					$val = $6 if ($skip_args ne "");
5760
5761					if ($val !~ /^0$/ &&
5762					    (($val =~ /^$Int$/ && $val !~ /^$Octal$/) ||
5763					     length($val) ne 4)) {
5764						ERROR("NON_OCTAL_PERMISSIONS",
5765						      "Use 4 digit octal (0777) not decimal permissions\n" . $herecurr);
5766					} elsif ($val =~ /^$Octal$/ && (oct($val) & 02)) {
5767						ERROR("EXPORTED_WORLD_WRITABLE",
5768						      "Exporting writable files is usually an error. Consider more restrictive permissions.\n" . $herecurr);
5769					}
5770				}
5771			}
5772		}
5773
5774# validate content of MODULE_LICENSE against list from include/linux/module.h
5775		if ($line =~ /\bMODULE_LICENSE\s*\(\s*($String)\s*\)/) {
5776			my $extracted_string = get_quoted_string($line, $rawline);
5777			my $valid_licenses = qr{
5778						GPL|
5779						GPL\ v2|
5780						GPL\ and\ additional\ rights|
5781						Dual\ BSD/GPL|
5782						Dual\ MIT/GPL|
5783						Dual\ MPL/GPL|
5784						Proprietary
5785					}x;
5786			if ($extracted_string !~ /^"(?:$valid_licenses)"$/x) {
5787				WARN("MODULE_LICENSE",
5788				     "unknown module license " . $extracted_string . "\n" . $herecurr);
5789			}
5790		}
5791	}
5792
5793	# If we have no input at all, then there is nothing to report on
5794	# so just keep quiet.
5795	if ($#rawlines == -1) {
5796		exit(0);
5797	}
5798
5799	# In mailback mode only produce a report in the negative, for
5800	# things that appear to be patches.
5801	if ($mailback && ($clean == 1 || !$is_patch)) {
5802		exit(0);
5803	}
5804
5805	# This is not a patch, and we are are in 'no-patch' mode so
5806	# just keep quiet.
5807	if (!$chk_patch && !$is_patch) {
5808		exit(0);
5809	}
5810
5811	if (!$is_patch && $file !~ /cover-letter\.patch$/) {
5812		ERROR("NOT_UNIFIED_DIFF",
5813		      "Does not appear to be a unified-diff format patch\n");
5814	}
5815	if ($is_patch && $filename ne '-' && $chk_signoff && $signoff == 0) {
5816		ERROR("MISSING_SIGN_OFF",
5817		      "Missing Signed-off-by: line(s)\n");
5818	}
5819
5820	print report_dump();
5821	if ($summary && !($clean == 1 && $quiet == 1)) {
5822		print "$filename " if ($summary_file);
5823		print "total: $cnt_error errors, $cnt_warn warnings, " .
5824			(($check)? "$cnt_chk checks, " : "") .
5825			"$cnt_lines lines checked\n";
5826	}
5827
5828	if ($quiet == 0) {
5829		# If there were whitespace errors which cleanpatch can fix
5830		# then suggest that.
5831		if ($rpt_cleaners) {
5832			$rpt_cleaners = 0;
5833			print << "EOM"
5834
5835NOTE: Whitespace errors detected.
5836      You may wish to use scripts/cleanpatch or scripts/cleanfile
5837EOM
5838		}
5839	}
5840
5841	if ($clean == 0 && $fix &&
5842	    ("@rawlines" ne "@fixed" ||
5843	     $#fixed_inserted >= 0 || $#fixed_deleted >= 0)) {
5844		my $newfile = $filename;
5845		$newfile .= ".EXPERIMENTAL-checkpatch-fixes" if (!$fix_inplace);
5846		my $linecount = 0;
5847		my $f;
5848
5849		@fixed = fix_inserted_deleted_lines(\@fixed, \@fixed_inserted, \@fixed_deleted);
5850
5851		open($f, '>', $newfile)
5852		    or die "$P: Can't open $newfile for write\n";
5853		foreach my $fixed_line (@fixed) {
5854			$linecount++;
5855			if ($file) {
5856				if ($linecount > 3) {
5857					$fixed_line =~ s/^\+//;
5858					print $f $fixed_line . "\n";
5859				}
5860			} else {
5861				print $f $fixed_line . "\n";
5862			}
5863		}
5864		close($f);
5865
5866		if (!$quiet) {
5867			print << "EOM";
5868
5869Wrote EXPERIMENTAL --fix correction(s) to '$newfile'
5870
5871Do _NOT_ trust the results written to this file.
5872Do _NOT_ submit these changes without inspecting them for correctness.
5873
5874This EXPERIMENTAL file is simply a convenience to help rewrite patches.
5875No warranties, expressed or implied...
5876EOM
5877		}
5878	}
5879
5880	if ($quiet == 0) {
5881		print "\n";
5882		if ($clean == 1) {
5883			print "$vname has no obvious style problems and is ready for submission.\n";
5884		} else {
5885			print "$vname has style problems, please review.\n";
5886		}
5887	}
5888	return $clean;
5889}
5890