Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp2281874ybi; Thu, 20 Jun 2019 12:12:42 -0700 (PDT) X-Google-Smtp-Source: APXvYqzpZ1muYbt0w8Agd8D09dCtQh+nU514LRtxbvZHcgTXfjQ/Sj7gdaKtqet+Qoml+mFgrfEj X-Received: by 2002:a17:90a:d151:: with SMTP id t17mr1253669pjw.60.1561057962755; Thu, 20 Jun 2019 12:12:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561057962; cv=none; d=google.com; s=arc-20160816; b=zSDMVM7KWOD9GV2Se3Q3wolykvY4PJKITmNBYV3TVhniFTIDNkcKxVTCxPm0TurtOT yesBSCETa+vAWDm09yk4rDn9DDNncEYAw110T8TZaxL2KFVDEQ5mq/BcwLLgmBFPZ2dU SXrjXSCCDvCm/aR6GWXriIbGJ9EkCR4IKrbD1gtHf/0dhkL38L89CZuzaQxilP0Elnv1 /kJsvO1R/vb3e9ttWs2bqyDapW76mkc9GlhB6SxYui0AxN+BGNcpDM8+ux8YmvHQ0mui SN+NrYy+Il0e62ALv4Cr4+m34FI/JKjBGCB1WSexHIFwEoq2PU14PtYauAjmMAn6c0J+ TK/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date; bh=15jXtWU41ylOZ27smOVXhvfcBDeq21pp5TPLiDQ5h40=; b=Ybah5Oum6cbZAP66cxrVgOqG44SfUq0Q9FE9wIcxQJ55FN4O6xLiUui8kePbhdS0iQ yZLZOKggkysrLKjtuCNABK+6pIE9PDcfrHCFbtcmQm9VAnYWtVITVnGzbadsiC0mTYOs LbMYl4BrdyjSvxQIFJ4Wod35BhWn8qR90qkE3N7vVl5E8rVTKnF4FLuTzsLq5oAgHP46 k0ZkAoWCdXaY1YF1nneX22Lc7+2eCqGGxqEc1nqfp5GxVAD/WlTZKWaXR4P3+1Y09TeS QCilLmnHaybCmOX3LqBgKNDdUHUJpDxnC8nC1Z1inG7XXC06jQCv8c69LONiRKX2AwKh OTvw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 13si298532pfh.169.2019.06.20.12.12.27; Thu, 20 Jun 2019 12:12:42 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726304AbfFTTMW (ORCPT + 99 others); Thu, 20 Jun 2019 15:12:22 -0400 Received: from mail2-relais-roc.national.inria.fr ([192.134.164.83]:16227 "EHLO mail2-relais-roc.national.inria.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725897AbfFTTMW (ORCPT ); Thu, 20 Jun 2019 15:12:22 -0400 X-IronPort-AV: E=Sophos;i="5.63,397,1557180000"; d="scan'208";a="388396700" Received: from abo-12-105-68.mrs.modulonet.fr (HELO hadrien) ([85.68.105.12]) by mail2-relais-roc.national.inria.fr with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 20 Jun 2019 21:12:20 +0200 Date: Thu, 20 Jun 2019 21:12:20 +0200 (CEST) From: Julia Lawall X-X-Sender: jll@hadrien To: Markus Elfring cc: Julia Lawall , kernel-janitors@vger.kernel.org, Gilles Muller , Masahiro Yamada , Michal Marek , Nicolas Palix , Coccinelle , LKML , Ding Xiang Subject: Re: Coccinelle: Add a SmPL script for the reconsideration of redundant dev_err() calls In-Reply-To: <34d528db-5582-5fe2-caeb-89bcb07a1d30@web.de> Message-ID: References: <05d85182-7ec3-8fc1-4bcd-fd2528de3a40@web.de> <34d528db-5582-5fe2-caeb-89bcb07a1d30@web.de> User-Agent: Alpine 2.21 (DEB 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 20 Jun 2019, Markus Elfring wrote: > >> +@display depends on context@ > >> +expression e; > >> +@@ > >> + e = devm_ioremap_resource(...); > >> + if (IS_ERR(e)) > >> + { > >> +* dev_err(...); > >> + return (...); > >> + } > > > > Why do you assume that there is exactly one dev_err and one return after > > the test? > > I propose to start with the addition of a simple source code search pattern. > Would you prefer to clarify a more advanced approach? I think that something like if (IS_ERR(e)) { <+... *dev_err(...) ...+> } would be more appropriate. Whether there is a return or not doesn't really matter. > > > >> +@script:python to_do depends on org@ > >> +p << or.p; > >> +@@ > >> +coccilib.org.print_todo(p[0], > >> + "WARNING: An error message is probably not needed here because the previously called function contains appropriate error reporting.") > > > > "the previously called function" would be better as "devm_ioremap_resource". > > Would you like to get the relevant function name dynamically determined? I have no idea what you consider "the relevant function name" to be. If it is always devm_ioremap_resource then it would seem that it does not need to be dynamically determined. julia