Re: [PATCH] checkpatch: allow an assignment in if condition for ACQUIRE_ERR()
From: Joe Perches
Date: Wed Aug 13 2025 - 03:19:45 EST
On Tue, 2025-08-12 at 17:38 -0700, alison.schofield@xxxxxxxxx wrote:
> From: Alison Schofield <alison.schofield@xxxxxxxxx>
>
> New helpers, ACQUIRE() and ACQUIRE_ERR(), were recently introduced to
> clean up conditional locking paths [1].
[]
> That compact format was a deliberate choice by the authors. By making
> this a checkpatch exception, existing ERRORs are quieted, and future
> users of the macro will not be dissuaded by checkpatch from using the
> preferred compact format.
not stylish IMO.
> diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
[]
> @@ -5696,7 +5696,14 @@ sub process {
> my ($s, $c) = ($stat, $cond);
> my $fixed_assign_in_if = 0;
>
> - if ($c =~ /\bif\s*\(.*[^<>!=]=[^=].*/s) {
> + if ($c =~ /\bif\s*\((.*[^<>!=]=[^=].*)\)/s) {
> + my $expr = $1;
> +
> + # Allow ACQUIRE_ERR() macro syntax
> + if ($expr =~ /\w+\s*=\s*ACQUIRE_ERR\s*\(/) {
> + next;
> + }
nak.
Using next would not do any additional checks on this line.
Likely use basic block or a constuct like
if ($c =~ /\bif\s*\((.*[^<>!=]=[^=].*)/s &&
$1 !~ /\bACQUIRE_ERR\b/) {
and perhaps the \w+ should be $Lval
> +
> if (ERROR("ASSIGN_IN_IF",
> "do not use assignment in if condition\n" . $herecurr) &&
> $fix && $perl_version_ok) {