Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp19368610ybl; Fri, 3 Jan 2020 23:20:30 -0800 (PST) X-Google-Smtp-Source: APXvYqy7xAaojhsCNx+CnA//1zXDb1opYSsO5SI6JxdnOk8GA1hLzPyqLczU4xRvnkFsQ9ha24q2 X-Received: by 2002:a05:6830:22e6:: with SMTP id t6mr107866566otc.244.1578122430021; Fri, 03 Jan 2020 23:20:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578122430; cv=none; d=google.com; s=arc-20160816; b=cJkIuaaMMy5IkPMb/JQjeReHlWyc+ausyphyhmgo3z1gu5poIj0OYz6mYNEsK7r3Uf kc+vFERDNxAQ4Q5xxOQ/Y3dpuPfvxCrWcsafhVeapTQ4FZg/4niHmtWgH4k8Qx2fUc0T 9GEq/BY+GKkTBIprJXCoMFMpUDlsM3UAF+ekfLeMwoM4vlmI8YK105hUVeZizAMGiPmX iAhd3ND67t1NsxF7tMQT67FwFLCQH0lHwKdyRWvOHmu71rMSlPqt61MmFoO3Tx1tI4/D Rr6ts9jrJRQ5J4wGZrGq/agqeneANfq/537BljHYkKkP3BTlgvyOGLn/FhWBgaGTPnff WqIg== 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=277rVnu9zaMyUQm65sc0NGIrwel2m0Z5doFe+52S3oc=; b=FErQMCuguWvH1Jrwn88b8nxNdpPsFzBy72pi1he6imLEpr3XmKlowVqqZi8NBhG4z1 Qmzmt5UUDal3ekL0rWLStSVPxYmyO5+bdOmV+W5lELTf5P0diIX9iHnmgMvR/U7RBPRy PEK9zmK4lpPiUce/EjwWlL6LANZMmIi0M4W6p1qP2O9AbB3sv8Ty914JVa3Nh55gzdiY KPC3c3NI/r1M45ywrLVz+tP2pW+rlo8fuKNwWsjGnFr6OgQPPJr8L94tJupqUnPfpPJo uMS9aX6mE0h5Nh8uXDUNnpZlYbTO+45VK9ESirFngdx1nQA/g24/GNQRTM3q+fAPSlBk kiQg== 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 n9si31255769ota.103.2020.01.03.23.20.05; Fri, 03 Jan 2020 23:20:30 -0800 (PST) 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 S1725995AbgADHRB (ORCPT + 99 others); Sat, 4 Jan 2020 02:17:01 -0500 Received: from mail3-relais-sop.national.inria.fr ([192.134.164.104]:47665 "EHLO mail3-relais-sop.national.inria.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725870AbgADHRB (ORCPT ); Sat, 4 Jan 2020 02:17:01 -0500 X-IronPort-AV: E=Sophos;i="5.69,393,1571695200"; d="scan'208";a="334728961" Received: from abo-154-110-68.mrs.modulonet.fr (HELO hadrien) ([85.68.110.154]) by mail3-relais-sop.national.inria.fr with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 04 Jan 2020 08:16:58 +0100 Date: Sat, 4 Jan 2020 08:16:58 +0100 (CET) From: Julia Lawall X-X-Sender: jll@hadrien To: Wen Yang cc: Gilles Muller , Nicolas Palix , Michal Marek , Matthias Maennich , Greg Kroah-Hartman , Masahiro Yamada , Thomas Gleixner , cocci@systeme.lip6.fr, linux-kernel@vger.kernel.org Subject: Re: [PATCH] coccinelle: semantic patch to check for inappropriate do_div() calls In-Reply-To: <20200104064448.24314-1-wenyang@linux.alibaba.com> Message-ID: References: <20200104064448.24314-1-wenyang@linux.alibaba.com> 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 --- Please note the new email address --- On Sat, 4 Jan 2020, Wen Yang wrote: > do_div() does a 64-by-32 division. > When the divisor is unsigned long, u64, or s64, > do_div() truncates it to 32 bits, this means it > can test non-zero and be truncated to zero for division. Would it be worth having a specific warning message for the long/unsigned long case? If the target architecture has 32 bit longs then the warning can be immediately ignored. julia > This semantic patch is inspired by Mateusz Guzik's patch: > commit b0ab99e7736a ("sched: Fix possible divide by zero in avg_atom() calculation") > > Signed-off-by: Wen Yang > Cc: Julia Lawall > Cc: Gilles Muller > Cc: Nicolas Palix > Cc: Michal Marek > Cc: Matthias Maennich > Cc: Greg Kroah-Hartman > Cc: Masahiro Yamada > Cc: Thomas Gleixner > Cc: cocci@systeme.lip6.fr > Cc: linux-kernel@vger.kernel.org > --- > scripts/coccinelle/misc/do_div.cocci | 66 ++++++++++++++++++++++++++++++++++++ > 1 file changed, 66 insertions(+) > create mode 100644 scripts/coccinelle/misc/do_div.cocci > > diff --git a/scripts/coccinelle/misc/do_div.cocci b/scripts/coccinelle/misc/do_div.cocci > new file mode 100644 > index 0000000..f1b72d1 > --- /dev/null > +++ b/scripts/coccinelle/misc/do_div.cocci > @@ -0,0 +1,66 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/// do_div() does a 64-by-32 division. > +/// When the divisor is unsigned long, u64, or s64, > +/// do_div() truncates it to 32 bits, this means it > +/// can test non-zero and be truncated to zero for division. > +/// > +//# This makes an effort to find those inappropriate do_div () calls. > +// > +// Confidence: Moderate > +// Copyright: (C) 2020 Wen Yang, Alibaba. > +// Comments: > +// Options: --no-includes --include-headers > + > +virtual context > +virtual org > +virtual report > + > +@depends on context@ > +expression f; > +long l; > +unsigned long ul; > +u64 ul64; > +s64 sl64; > + > +@@ > +( > +* do_div(f, l); > +| > +* do_div(f, ul); > +| > +* do_div(f, ul64); > +| > +* do_div(f, sl64); > +) > + > +@r depends on (org || report)@ > +expression f; > +long l; > +unsigned long ul; > +position p; > +u64 ul64; > +s64 sl64; > +@@ > +( > +do_div@p(f, l); > +| > +do_div@p(f, ul); > +| > +do_div@p(f, ul64); > +| > +do_div@p(f, sl64); > +) > + > +@script:python depends on org@ > +p << r.p; > +@@ > + > +msg="WARNING: WARNING: do_div() does a 64-by-32 division, which may truncation the divisor to 32-bit" > +coccilib.org.print_todo(p[0], msg) > + > +@script:python depends on report@ > +p << r.p; > +@@ > + > +msg="WARNING: WARNING: do_div() does a 64-by-32 division, which may truncation the divisor to 32-bit" > +coccilib.report.print_report(p[0], msg) > -- > 1.8.3.1 > >