Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp3309319ybl; Sun, 25 Aug 2019 12:57:15 -0700 (PDT) X-Google-Smtp-Source: APXvYqyIfU1RgsiOswbE/TN5eIkwP78VYZqF/BNOiYnRsWTCmM1i4EAu2DLxicCok0/JPMY3B9XA X-Received: by 2002:a62:1858:: with SMTP id 85mr16841742pfy.120.1566763035867; Sun, 25 Aug 2019 12:57:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566763035; cv=none; d=google.com; s=arc-20160816; b=ytSNoBpobYT+RMhGQCVbXerDLX8p+/pqCG8COrc3anKUOfejJXSfIz3pVaW7RjvlJb m5CTbl61BJNpKZYxjfw4MJBEKinlNeBPu5Ttu2v1a0rI8ixWKXhohWTW/lNXMPbkMSRF RLebRAhiq99KlAgAy87rKRBvMYIpU8GaYvvgaCcofh1603sjcXyXTyV0vh5Ywkfot9af ZMrcEYWcjdOZY+nxpbyKC3ovFFQSRsCqPlNoHYOc8AVBYms7zaZZwah+cgww43OX8kx/ zQPWSyxTqYCZLI1Abah+qL0FGGDgtUyWW4nFlkg52BGN/+JlxBZroGvxGX+sUSGqKerN LRKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=HC8F/9/UXZritXuADo9xVPlkrJhuLUNcByy7bFV18Rw=; b=zbPGYWitX4To+Ttik98vhzhoV9d2nLzeCfo/Lcam16yXKP8jqyRn+VITPE0EP+E+9l vqo+V9Lo4vs6xqzHPZgXLxmBP3YaiTSC8wZFMWSzkeCHql2AbYXh2jyvlrUMdCj73xv4 AYpO3/yB15XGyqJW/XQU3P8i/9f7BJVcOD3ZnU9HL94H4dBfUUwIIwAO4UHT0RSC4L0t 7zvHmCP2S6Eox5+ph0rSC+XpbbhS5K/bNCghuRliJCo4DbbjakkktZvtnOpnDQgHHcFe qbisshxS4dNNpNSkkqea53E1L0SmspdlopnI0KCUVPzbmNuCUcVJU9R7aobO/S0eYYcb lLSQ== 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 y15si7719694plr.199.2019.08.25.12.57.00; Sun, 25 Aug 2019 12:57:15 -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 S1728811AbfHYS7P (ORCPT + 99 others); Sun, 25 Aug 2019 14:59:15 -0400 Received: from mail-lf1-f68.google.com ([209.85.167.68]:35866 "EHLO mail-lf1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726345AbfHYS7P (ORCPT ); Sun, 25 Aug 2019 14:59:15 -0400 Received: by mail-lf1-f68.google.com with SMTP id r5so5135257lfc.3 for ; Sun, 25 Aug 2019 11:59:13 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=HC8F/9/UXZritXuADo9xVPlkrJhuLUNcByy7bFV18Rw=; b=FfVyXOt/7xRglE+7brwG6/FNTJ9mK2F2vfTHWXALja+GEc8kvr2il4U6QiYbvkLYNK s7gVRV7J29uYNTvQ9UJKpj/w4+n8n4lynMWvRZMjGDLg7vGneNrHMhhJHbUl/WzsrT4F jJKPkNmrK0klQ1sqCGGES8zMNEib3K5DyUrzsRb0oXUZxftKhAdqsfMQ7t+kNEUBr2Ck jKO+YY9WaJyJTamfFh4U9BCjP1AJem45EjORTqljfXKE5RbIYXouZclSwWlgDwQs126d Kkx1TdZc3VSHuAS+ir8bNnO1kXH/YaKwBn2PNYKFfTQLTQP5YzelQsUnMCc4VIn8TmhB gZXw== X-Gm-Message-State: APjAAAWkVDKQRmEq5jPyWHRvnWsBiOj7BMQFlkAIY4wvw+OiO7dnPfnY H60tnllpa/hO4QtfM3BqpQI= X-Received: by 2002:a19:7515:: with SMTP id y21mr161268lfe.129.1566759552735; Sun, 25 Aug 2019 11:59:12 -0700 (PDT) Received: from [10.68.32.192] (broadband-188-32-48-208.ip.moscow.rt.ru. [188.32.48.208]) by smtp.gmail.com with ESMTPSA id a20sm1666375ljk.34.2019.08.25.11.59.11 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sun, 25 Aug 2019 11:59:12 -0700 (PDT) Subject: Re: [PATCH] scripts: coccinelle: check for !(un)?likely usage To: Joe Perches , cocci@systeme.lip6.fr Cc: linux-kernel@vger.kernel.org, Julia Lawall , Gilles Muller , Nicolas Palix , Michal Marek References: <20190825130536.14683-1-efremov@linux.com> From: Denis Efremov Message-ID: <88f6e48e-1230-9488-a973-397f4e6dfbb5@linux.com> Date: Sun, 25 Aug 2019 21:59:10 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 25.08.2019 19:37, Joe Perches wrote: > On Sun, 2019-08-25 at 16:05 +0300, Denis Efremov wrote: >> This patch adds coccinelle script for detecting !likely and !unlikely >> usage. It's better to use unlikely instead of !likely and vice versa. > > Please explain _why_ is it better in the changelog. > In my naive understanding the negation (!) before the likely/unlikely could confuse the compiler and the initial branch-prediction intent could be "falsified". I would say that either you need to move the negation under the bracket "!unlikely(cond) -> unlikely(!cond)" or you need to use likely instead "!unlikely(cond) -> likely(cond)". However, I'm not a compiler expert to state that this is a general rule. But, we've got 2 special macro for branch predicting, not one. There is also ftrace in-between. I will try to do some simple benchmarking. > btw: there are relatively few uses like this in the kernel. > > $ git grep -P '!\s*(?:un)?likely\s*\(' | wc -l > 40 > > afaict: It may save 2 bytes of x86/64 object code. > > For instance: > > $ diff -urN kernel/tsacct.lst.old kernel/tsacct.lst.new|less > --- kernel/tsacct.lst.old 2019-08-25 09:21:39.936570183 -0700 > +++ kernel/tsacct.lst.new 2019-08-25 09:22:20.774324886 -0700 > @@ -24,158 +24,153 @@ > 15: 48 89 fb mov %rdi,%rbx > u64 time, delta; > > - if (!likely(tsk->mm)) > + if (unlikely(tsk->mm)) > 18: 4c 8d ab 28 02 00 00 lea 0x228(%rbx),%r13 > 1f: e8 00 00 00 00 callq 24 <__acct_update_integrals+0x24> > 20: R_X86_64_PLT32 __sanitizer_cov_trace_pc-0x4 > 24: 4c 89 ef mov %r13,%rdi > 27: e8 00 00 00 00 callq 2c <__acct_update_integrals+0x2c> > 28: R_X86_64_PLT32 __asan_load8_noabort-0x4 > - 2c: 4c 8b bb 28 02 00 00 mov 0x228(%rbx),%r15 > - 33: 4d 85 ff test %r15,%r15 > - 36: 74 34 je 6c <__acct_update_integrals+0x6c> > + 2c: 48 83 bb 28 02 00 00 cmpq $0x0,0x228(%rbx) > + 33: 00 > + 34: 75 34 jne 6a <__acct_update_integrals+0x6a> > return; I think it's incorrect to say so in general. For example, on x86/64: $ make mrproper $ make allyesconfig $ make && mv vmlinux vmlinux-000 $ make coccicheck MODE=patch COCCI=scripts/coccinelle/misc/unlikely.cocci | patch -p1 $ make $ ./scripts/bloat-o-meter ./vmlinux-000 ./vmlinux add/remove: 0/0 grow/shrink: 3/4 up/down: 41/-35 (6) Function old new delta dpaa2_io_service_rearm 357 382 +25 intel_pmu_hw_config 1277 1285 +8 get_sigframe.isra.constprop 1657 1665 +8 csum_partial_copy_from_user 605 603 -2 wait_consider_task 3807 3797 -10 __acct_update_integrals 384 373 -11 pipe_to_sendpage 459 447 -12 Total: Before=312759461, After=312759467, chg +0.00% It definitely influence the way the compiler optimizes the code. > > And here's a possible equivalent checkpatch test. > --- > scripts/checkpatch.pl | 18 ++++++++++++++++++ > 1 file changed, 18 insertions(+) > > diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl > index 287fe73688f0..364603ad1a47 100755 > --- a/scripts/checkpatch.pl > +++ b/scripts/checkpatch.pl > @@ -6529,6 +6529,24 @@ sub process { > "Using $1 should generally have parentheses around the comparison\n" . $herecurr); > } > > +# !(likely|unlikely)(condition) use should be (unlikely|likely)(condition) > + if ($perl_version_ok && > + $line =~ /(\!\s*((?:un)?likely))\s*$balanced_parens/) { > + my $match = $1; > + my $type = $2; > + my $reverse; > + if ($type eq "likely") { > + $reverse = "unlikely"; > + } else { > + $reverse = "likely"; > + } > + if (WARN("LIKELY_MISUSE", > + "Prefer $reverse over $match\n" . $herecurr) && > + $fix) { > + $fixed[$fixlinenr] =~ s/\Q$match\E\s*\(/$reverse(/; > + } > + } > + > # whine mightly about in_atomic > if ($line =~ /\bin_atomic\s*\(/) { > if ($realfile =~ m@^drivers/@) { > >