Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1264961pxf; Fri, 9 Apr 2021 04:22:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxEixBk/G5V+lkp1gAhRoVbsi+5hbrVegxoj/1Of7FjF9pId1VEhAwN8T7LOFzo+ApP+5BT X-Received: by 2002:a17:907:75cc:: with SMTP id jl12mr5909747ejc.52.1617967375243; Fri, 09 Apr 2021 04:22:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617967375; cv=none; d=google.com; s=arc-20160816; b=cIcCc5p8rFHrhfIEFvLo8V32k2++NzgqPzG2hu3BqVR+NfvKkjieKyFCh5gdDl4eLl Q63XtLtpryyoJ3FIuZvoCDrpC5OhcerXPCQdu8eFK6x6dXngAoUJkCDO7ugFK4Oe8K9w pzGMAwwaS2E4VJ2ILoARGeq1HoZIuVPN4Th+CeMFBGQSuOG5ftWaRBGJDmDUAxEebumK WhLqwr/Xwyb0x6wC/P6sRtdJG0L4LBb/8n6ZXGzvfk9o4F6XkKC7Dp497FjyIlFiKQG8 S3tms7PjLVZ4GH1J+dHCyde6qTVmvVgI/fZeJb1DE305ittfKbK4J3n6bpjV9gpAzQWT 4KHA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=cvKqJAsDp0hVwDeBdNNZxr3x2/ARRj4tE0SxrkqqX3k=; b=qS/n1OM0+htjJmaOhafwupkSd7+gUZbWQsIW+V6UqbUEd3beEiX7mb1S10cUf7Qtz0 YIbAc4I5ZMdLG85hmkhRlvI3eo/QvMJVx0xNcmmLC1vlbdjxsku4BDw9/kiE2dUeH/fe x/Zks04uRcBZyCxzcR1KDuY2YG0zJn4zRrOS4Z9JGn3/xXrxMcxOPNn/y4jJC7qmsreL atII0TV9+Z64VV84ly9ksQTkgpAp+HQavkeYJ82PUNQFrHaPdlhe62i8iFHAHr5EJBJq IMlkr6WKqsmKftfrcbFJZIJ6FT4fPaqMm/Lu8epoQEk699FLWAapVI+WVQ0M9rVyyeuZ Su1g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n21si1748581ejg.609.2021.04.09.04.22.31; Fri, 09 Apr 2021 04:22:55 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234087AbhDILTs (ORCPT + 99 others); Fri, 9 Apr 2021 07:19:48 -0400 Received: from mail-qk1-f178.google.com ([209.85.222.178]:45715 "EHLO mail-qk1-f178.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234257AbhDILTW (ORCPT ); Fri, 9 Apr 2021 07:19:22 -0400 Received: by mail-qk1-f178.google.com with SMTP id q3so5342579qkq.12 for ; Fri, 09 Apr 2021 04:19:09 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=cvKqJAsDp0hVwDeBdNNZxr3x2/ARRj4tE0SxrkqqX3k=; b=GpD5DgH14pvDjUu+E+sYNVNvwPKIEw7c0yh6sV/GslzIRJSn3THcUjWYOdUbw+APRS gh8dqEtVzPf5a0lat3VeTaGhAOEhIQl7LMj1ewHtYK0tmn4UjshJ5AnlWkmUxXycDkTK 74ZLxHdPwMgWrY1r5T8LnjXciDWTcyovfNF3azlEJEw63U9Wt9rH8E0LuG7yEnsTc7sN vE9jQKZBU8Tq76fWMNIFBRJyZKVfSiyww3d/FD048b8y1TAWE9W7q7D/gUWB6l0ICir8 opsxQqOijUyShEGMAkqF/2ysKgF0JbxN11ihXrIJME0OUlv+eCUr3JFl7x5otWti+SRu a0WQ== X-Gm-Message-State: AOAM530w150Y3hn2YyD0liA6EKxA5dI7WKx0XfsyvMEB5sAOmr3wAiup S+Ri6knmjBN/SA0L07WzkYesJm07qo0= X-Received: by 2002:a37:5a46:: with SMTP id o67mr7305417qkb.240.1617967148999; Fri, 09 Apr 2021 04:19:08 -0700 (PDT) Received: from black.ru.oracle.com (winnie.ispras.ru. [83.149.199.91]) by smtp.googlemail.com with ESMTPSA id a8sm1578477qtx.9.2021.04.09.04.19.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 09 Apr 2021 04:19:08 -0700 (PDT) From: Denis Efremov To: julia.lawall@inria.fr Cc: Denis Efremov , cocci@systeme.lip6.fr, linux-kernel@vger.kernel.org Subject: [PATCH] coccinelle: misc: minmax: suppress patch generation for err returns Date: Fri, 9 Apr 2021 14:19:02 +0300 Message-Id: <20210409111902.7561-1-efremov@linux.com> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There is a standard idiom for "if 'ret' holds an error, return it": return ret < 0 ? ret : 0; Developers prefer to keep the things as they are because stylistic change to "return min(ret, 0);" breaks readability. Let's suppress automatic generation for this type of patches. Signed-off-by: Denis Efremov --- scripts/coccinelle/misc/minmax.cocci | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/scripts/coccinelle/misc/minmax.cocci b/scripts/coccinelle/misc/minmax.cocci index eccdd3eb3452..fcf908b34f27 100644 --- a/scripts/coccinelle/misc/minmax.cocci +++ b/scripts/coccinelle/misc/minmax.cocci @@ -116,16 +116,32 @@ func(...) ...> } +// Don't generate patches for errcode returns. +@errcode depends on patch@ +position p; +identifier func; +expression x; +binary operator cmp = {<, <=}; +@@ + +func(...) +{ + <... + return ((x) cmp@p 0 ? (x) : 0); + ...> +} + @pmin depends on patch@ identifier func; expression x, y; binary operator cmp = {<=, <}; +position p != errcode.p; @@ func(...) { <... -- ((x) cmp (y) ? (x) : (y)) +- ((x) cmp@p (y) ? (x) : (y)) + min(x, y) ...> } -- 2.30.2