Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp502720ybj; Tue, 5 May 2020 02:41:30 -0700 (PDT) X-Google-Smtp-Source: APiQypL8ZyqAGgTnb+Snd85lD9G9KC4+/1veHFAHAE8b+tXZiSbXWIz+LotzQTgLvVVKqpsxPNEy X-Received: by 2002:a17:906:809:: with SMTP id e9mr1741322ejd.81.1588671690619; Tue, 05 May 2020 02:41:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588671690; cv=none; d=google.com; s=arc-20160816; b=gIhXX3luig6qqL0T6IFIEZm68lyhZCLafq1TBcZRs/Dg9MqUGNqnosrHUjV4hO1zkf 6EgtdcFghyTHSckBhBSY9QDQXHwAT7+FYh4fME801Mh0XXpkeGijmU3j9rJ6jImTiR32 NKbC0hmKcBn7dQBrwLKcvonhBd4tuGy5YIHYhEM62pvL1emXfrYDcZO2GcQCJHaa1Yk6 pYMHYGfcK9VtO7If8h7VUC9gGeIdDW7CyvHxJVrXVM1hwnqx63JJpj/jPvrzeLpD2EuU Xr/cedGsVuxTy74yslnrtcXKnlYsY5wHKdBgyUkV1SohOGPR3ruzW7S5/mQJP/7vSN3C 2ELg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=ZM0VHNr+2PqNGH/2fYDW3FKPw90TSuCLdRgYmXwrR+8=; b=m6ZaFlAS/Vj5jY92oAKZp+KLP5ABq6V7VOXvgAfJCpZt4bia8IcoFaOUJdIHgmJ6YU Y0D0p9edniZs66zuLno3UXBr3lvt0wFTCaefgqaACLtpn42QHDlARvP4Gj1aTOpmee/z CdGhO79KbHbm9zUu6R0Brlo1itHdXfoOzZXG0fnA7vo3Fxx+3HZsNchf1RgAf7ekAgQD MSlKUviktUwITvXTeDdmqlbfSf9BmEEoCnRsS6DAC0ADYOa6vsjugoBZhtr0qPWEzEEk qn4OvX5LvuFrmOora0GnXtR04FFu8P+Y3BK2VbAPmb9xHW6SbXgU90IvVGwa901l/Co9 IU9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=BVqzgdyg; 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 p1si719753ejw.313.2020.05.05.02.40.44; Tue, 05 May 2020 02:41:30 -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; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=BVqzgdyg; 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 S1728631AbgEEJgt (ORCPT + 99 others); Tue, 5 May 2020 05:36:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33326 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1725766AbgEEJgs (ORCPT ); Tue, 5 May 2020 05:36:48 -0400 Received: from bombadil.infradead.org (bombadil.infradead.org [IPv6:2607:7c80:54:e::133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 977B4C061A0F for ; Tue, 5 May 2020 02:36:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=ZM0VHNr+2PqNGH/2fYDW3FKPw90TSuCLdRgYmXwrR+8=; b=BVqzgdygMhhzw0WM6XfsH145Le CKEc3vi0uXVFFVR17fAMuEnqJ02B2mP0U05hTLlNki25dEaAWRRCKE1QVJLkVn08/KazJLSMj6jEA cLDl0pT26xziJpnXv38unIW1QOqy5I6a5dOOeUxuqhALQn5FLXNKsRMPVWO+9/p1zDUTyMuGIvaNY N/5Q27P5NMzgmhR9kH7JhOwv0Gl60V6AFJ5X8s6cyyCzv1AIVhu2mM3EM5bQYcpf7mRL62GFNGGqe AojH28dWpSR6r+R6aABsNpz49JcvSmBH2PBWJESURB5lLujhuDYB/Hg7NA6Ko8gRcSmbV4aqP2ZZg dDGtTFpw==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=noisy.programming.kicks-ass.net) by bombadil.infradead.org with esmtpsa (Exim 4.92.3 #3 (Red Hat Linux)) id 1jVu04-0006jt-Ms; Tue, 05 May 2020 09:36:28 +0000 Received: from hirez.programming.kicks-ass.net (hirez.programming.kicks-ass.net [192.168.1.225]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by noisy.programming.kicks-ass.net (Postfix) with ESMTPS id 414C2300238; Tue, 5 May 2020 11:36:25 +0200 (CEST) Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id 268682B0C5BA7; Tue, 5 May 2020 11:36:25 +0200 (CEST) Date: Tue, 5 May 2020 11:36:25 +0200 From: Peter Zijlstra To: Rasmus Villemoes Cc: x86@kernel.org, linux-kernel@vger.kernel.org, rostedt@goodmis.org, mhiramat@kernel.org, bristot@redhat.com, jbaron@akamai.com, torvalds@linux-foundation.org, tglx@linutronix.de, mingo@kernel.org, namit@vmware.com, hpa@zytor.com, luto@kernel.org, ard.biesheuvel@linaro.org, jpoimboe@redhat.com, pbonzini@redhat.com, mathieu.desnoyers@efficios.com, hjl.tools@gmail.com, ndesaulniers@google.com Subject: Re: [PATCH v4 14/18] static_call: Add static_cond_call() Message-ID: <20200505093625.GE5298@hirez.programming.kicks-ass.net> References: <20200501202849.647891881@infradead.org> <20200501202944.593400184@infradead.org> <1238787e-d97d-f09b-d76d-2df2dc273f4b@rasmusvillemoes.dk> <20200503125813.GL3762@hirez.programming.kicks-ass.net> <20200504201445.GQ3762@hirez.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200504201445.GQ3762@hirez.programming.kicks-ass.net> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org HJ, Nick, Any chance any of you can see a way to make your respective compilers not emit utter junk for this? On Mon, May 04, 2020 at 10:14:45PM +0200, Peter Zijlstra wrote: > https://godbolt.org/z/SDRG2q > > --- > #include > > > #define READ_ONCE(var) (*((volatile typeof(var) *)&(var))) > #define WRITE_ONCE(var, val) (*((volatile typeof(var) *)&(var)) = (val)) > > struct static_call_key { > void *func; > }; > > #define DECLARE_STATIC_CALL(name, func) \ > extern struct static_call_key name; \ > extern typeof(func) __SCT__##name; > > #define DEFINE_STATIC_COND_CALL(name, _func) \ > DECLARE_STATIC_CALL(name, _func) \ > struct static_call_key name = { \ > .func = NULL, \ > } > > static void __static_call_nop(void) > { > } > > #define __static_cond_call(name) \ > ({ \ > void *func = READ_ONCE(name.func); \ > if (!func) \ > func = &__static_call_nop; \ > (typeof(__SCT__##name)*)func; \ > }) > > #define static_cond_call(name) (void)__static_cond_call(name) > > static void inline static_call_update(struct static_call_key *call, void *func) > { > WRITE_ONCE(call->func, func); > } > > volatile int _x; > > void bar(int x) > { > _x = x; > } > > DEFINE_STATIC_COND_CALL(foo, bar); > > void ponies(int x) > { > static_cond_call(foo)(x); > }