[PATCH v3] checkpatch: warn on uppercase N/Y/M as Kconfig tristate literals

Andrew Jones posted 1 patch 2 days, 22 hours ago
scripts/checkpatch.pl | 14 ++++++++++++++
1 file changed, 14 insertions(+)
[PATCH v3] checkpatch: warn on uppercase N/Y/M as Kconfig tristate literals
Posted by Andrew Jones 2 days, 22 hours ago
Kconfig tristate literals are always lowercase ('n', 'y', 'm') and
uppercase N/Y/M are not Kconfig reserved words. Since undefined
symbols evaluate to 'n', writing 'default Y' or 'default M' silently
produces 'n' instead of 'y'/'m'. 'default N' happens to produce the
right value but is still invalid syntax.

Add a warning for N/Y/M in Kconfig expressions found by following
the same preprocessing logic used by the Kconfig parser itself.

This new warning was inspired by work done for [1].

Link: https://bugzilla.kernel.org/show_bug.cgi?id=216748 [1]
Assisted-by: Claude:claude-sonnet-4-6
Signed-off-by: Andrew Jones <andrew.jones@linux.dev>
Acked-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
---

v3:
  - More changes from another sashiko review which required the
    Perl to get even uglier.
v2:
  - Added Andy's tag
  - Changes thanks to sashiko's review
    - strip quoted strings before inline comments to avoid '#' inside a string
    - use [^)]* instead of .* in macro strip regex to avoid greedy match
      eating tokens between adjacent $(macro) expansions

 scripts/checkpatch.pl | 14 ++++++++++++++
 1 file changed, 14 insertions(+)

diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
index 0d18771f1b01..e3244c270d26 100755
--- a/scripts/checkpatch.pl
+++ b/scripts/checkpatch.pl
@@ -3732,6 +3732,20 @@ sub process {
 			}
 		}
 
+# check for uppercase N/Y/M used as Kconfig tristate literals
+		if ($realfile =~ /Kconfig/ &&
+		    $line =~ /^\+\s*(?:default|def_bool|def_tristate|select|imply|depends\s+on|visible\s+if|range|if|bool|tristate|int|hex|string|prompt)\s+(.+)$/) {
+			my $expr = $1;
+			$expr =~ s/"(?:[^"\\]|\\.)*"|'(?:[^'\\]|\\.)*'//g;	# strip quoted strings
+			$expr =~ s/#.*//;					# strip inline comments
+			$expr =~ s/\$\(.*\)//g;					# strip $(macro) expansions
+			for my $tok (split /[^A-Za-z0-9_]+/, $expr) {
+				next unless ($tok eq 'Y' || $tok eq 'M' || $tok eq 'N');
+				WARN("KCONFIG_TRISTATE_UPPERCASE",
+				     "'$tok' is probably not what you want here; Kconfig tristate literals are always lowercase ('n', 'y', 'm')\n" . $herecurr);
+			}
+		}
+
 # check MAINTAINERS entries
 		if ($realfile =~ /^MAINTAINERS$/) {
 # check MAINTAINERS entries for the right form
-- 
2.43.0
Re: [PATCH v3] checkpatch: warn on uppercase N/Y/M as Kconfig tristate literals
Posted by Andrew Jones 2 days, 20 hours ago
On Thu, May 21, 2026 at 03:46:05PM -0500, Andrew Jones wrote:
> Kconfig tristate literals are always lowercase ('n', 'y', 'm') and
> uppercase N/Y/M are not Kconfig reserved words. Since undefined
> symbols evaluate to 'n', writing 'default Y' or 'default M' silently
> produces 'n' instead of 'y'/'m'. 'default N' happens to produce the
> right value but is still invalid syntax.
> 
> Add a warning for N/Y/M in Kconfig expressions found by following
> the same preprocessing logic used by the Kconfig parser itself.
> 
> This new warning was inspired by work done for [1].
> 
> Link: https://bugzilla.kernel.org/show_bug.cgi?id=216748 [1]
> Assisted-by: Claude:claude-sonnet-4-6
> Signed-off-by: Andrew Jones <andrew.jones@linux.dev>
> Acked-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> ---
> 
> v3:
>   - More changes from another sashiko review which required the
>     Perl to get even uglier.
> v2:
>   - Added Andy's tag
>   - Changes thanks to sashiko's review
>     - strip quoted strings before inline comments to avoid '#' inside a string
>     - use [^)]* instead of .* in macro strip regex to avoid greedy match
>       eating tokens between adjacent $(macro) expansions
>

I need to send a v4 to also handle quoted N/M/Y as pointed out in the
review of the corresponding static checker patch[1]. I'll wait a bit
before sending in case other comments come in in the meantime.

[1] https://lore.kernel.org/all/numrmmjpnheiawifcjhc5zustrlk6bfv5wtr6ibdzbf7mq5o53@x6wf4zv7jhsg/

Thanks,
drew