Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp7199201ybi; Mon, 8 Jul 2019 16:45:30 -0700 (PDT) X-Google-Smtp-Source: APXvYqxZM1O9S1amo3c97SkWCWfS0HAgjcMChaA336403etkU86It7QjYCQr0DajPo1yzevbmZGa X-Received: by 2002:a17:902:830c:: with SMTP id bd12mr28641848plb.237.1562629530825; Mon, 08 Jul 2019 16:45:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562629530; cv=none; d=google.com; s=arc-20160816; b=Osu6qDJkMDx6OREIArpzF8/xJZoaT37Gj1/dDyd7usFDrsN5wUjelfZqy9nLD6dM/5 7TOFKDx99KT4P1cSXB/mdvXpeJ7SsAOOd6oy+KuBSjkOc1Cvwvy/EzGBcUaPo4wSqwDK XwiMkN+bfDad6VTD9lTLMtE9XkGaARCsESa7HY0p0rJ4ssP2OXq9A5cP2ulPYp2UxPSV 8TqOqMsJaJMeOKaS5wMX5KMAklfkx7zPLp0kFiy86Eflf+HIP4FbEhQHc3IU93NjwOsl VybqWhX1MAysiLofQ+7i+N3bvzmluWgjI6QE3Z/51aukNBsq1em+Jxt6vgx+XgQtbOFS HdMA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=m+PxXv2jPq44mGx/kVYeGqpT15k+gzUGcQ8sW4etsTw=; b=dwaX7ZInkjAPmgHwUZZpXeXfwDj9n+QNiR6Z837bJ0WZ9yOfG5PTXWV27lTY1ZYdC9 YQm5vSVSoIMbmh8I4sjlsrAufTV0DLVUEf+Cbd2MA7Qn0UEpvf3ur7KrG+YHltoMe9CN liVpxTIb5/ISnQbE+6mcdPB0/aTLafNw6b+Qmv+zyIT0fXPb6EeIiTsTytz8oauwqaBl TpzeObeQT05o+Hothzovu9luxXFyehfwCfbX90zHitcc+WiuBKmd37CYuJluIIoyrJXA SDRLRVeIr7w/mWlpxI+CeCoSwaKztNygip8AMi9agxsttUvLO/Bh1WaEtnssKrZ0Y8MQ R/FA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h2si19859970plh.380.2019.07.08.16.45.13; Mon, 08 Jul 2019 16:45:30 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727456AbfGHXCQ (ORCPT + 99 others); Mon, 8 Jul 2019 19:02:16 -0400 Received: from mx1.redhat.com ([209.132.183.28]:38916 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726820AbfGHXCP (ORCPT ); Mon, 8 Jul 2019 19:02:15 -0400 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id B05CE8552A; Mon, 8 Jul 2019 23:02:07 +0000 (UTC) Received: from treble (ovpn-112-43.rdu2.redhat.com [10.10.112.43]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 1E53F2B592; Mon, 8 Jul 2019 23:02:03 +0000 (UTC) Date: Mon, 8 Jul 2019 18:02:01 -0500 From: Josh Poimboeuf To: Alexei Starovoitov Cc: Ingo Molnar , Borislav Petkov , "H. Peter Anvin" , Song Liu , Thomas Gleixner , Steven Rostedt , Kairui Song , Daniel Borkmann , Alexei Starovoitov , Peter Zijlstra , LKML , linux-tip-commits@vger.kernel.org Subject: Re: [tip:x86/urgent] bpf: Fix ORC unwinding in non-JIT BPF code Message-ID: <20190708230201.mol27wzansuy3n2v@treble> References: <881939122b88f32be4c374d248c09d7527a87e35.1561685471.git.jpoimboe@redhat.com> <20190706202942.GA123403@gmail.com> <20190707013206.don22x3tfldec4zm@treble> <20190707055209.xqyopsnxfurhrkxw@treble> <20190708223834.zx7u45a4uuu2yyol@treble> <20190708225359.ewk44pvrv6a4oao7@treble> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20190708225359.ewk44pvrv6a4oao7@treble> User-Agent: NeoMutt/20180716 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.28]); Mon, 08 Jul 2019 23:02:15 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jul 08, 2019 at 05:53:59PM -0500, Josh Poimboeuf wrote: > On Mon, Jul 08, 2019 at 03:49:33PM -0700, Alexei Starovoitov wrote: > > > > Sorry for delay. I'm mostly offgrid until next week. > > > > As far as -fno-gcse.. I don't mind as long as it doesn't hurt performance. > > > > Which I suspect it will :( > > > > All these indirect gotos are there for performance. > > > > Single indirect goto and a bunch of jmp select_insn > > > > are way slower, since there is only one instruction > > > > for cpu branch predictor to work with. > > > > When every insn is followed by "jmp *jumptable" > > > > there is more room for cpu to speculate. > > > > It's been long time, but when I wrote it the difference > > > > between all indirect goto vs single indirect goto was almost 2x. > > > > > > Just to clarify, -fno-gcse doesn't get rid of any of the indirect jumps. > > > It still has 166 indirect jumps. It just gets rid of the second > > > optimization, where the jumptable address is placed in a register. > > > > what about other functions in core.c ? > > May be it's easier to teach objtool to recognize that pattern? > > The GCC man page actually recommends using -fno-gcse for computed goto > code, for better performance. So if that's actually true, then it would > be win-win because objtool wouldn't need a change for it. > > Otherwise I can teach objtool to recognize the new pattern. > > > > If you have a benchmark which is relatively easy to use, I could try to > > > run some tests. > > > > modprobe test_bpf > > selftests/bpf/test_progs > > both print runtime. > > Some of test_progs have high run-to-run variations though. > > Thanks, I'll give it a shot. I modprobed test_bpf with JIT disabled. Before: 2.493018s After: 2.523572s So it looks like it's either no change, or slightly slower. I'll just teach objtool to recognize the optimization. -- Josh