From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754829AbcCBKeR (ORCPT ); Wed, 2 Mar 2016 05:34:17 -0500 Received: from casper.infradead.org ([85.118.1.10]:59312 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753441AbcCBKeN (ORCPT ); Wed, 2 Mar 2016 05:34:13 -0500 Date: Wed, 2 Mar 2016 11:34:01 +0100 From: Peter Zijlstra To: "H. Peter Anvin" Cc: Mathieu Desnoyers , Linus Torvalds , Ben Maurer , Thomas Gleixner , Ingo Molnar , Russell King , linux-api , Andrew Morton , Michael Kerrisk , Dave Watson , rostedt , Andy Lutomirski , Will Deacon , "Paul E. McKenney" , Chris Lameter , Andi Kleen , Josh Triplett , Paul Turner , Linux Kernel Mailing List , Catalin Marinas , Andrew Hunter Subject: Re: [PATCH v4 1/5] getcpu_cache system call: cache CPU number of running thread Message-ID: <20160302103401.GC6357@twins.programming.kicks-ass.net> References: <1401667361.10273.1456617236327.JavaMail.zimbra@efficios.com> <1082926946.10326.1456619994590.JavaMail.zimbra@efficios.com> <1538518747.10504.1456669948568.JavaMail.zimbra@efficios.com> <20160229103506.GJ6356@twins.programming.kicks-ass.net> <676569856.13488.1456863792603.JavaMail.zimbra@efficios.com> <20160301213202.GY6357@twins.programming.kicks-ass.net> <56D60DFA.4040809@zytor.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <56D60DFA.4040809@zytor.com> User-Agent: Mutt/1.5.21 (2012-12-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 01, 2016 at 01:47:38PM -0800, H. Peter Anvin wrote: > On 03/01/16 13:32, Peter Zijlstra wrote: > > On Tue, Mar 01, 2016 at 08:23:12PM +0000, Mathieu Desnoyers wrote: > >> I think it's important that user-space fast-paths can quickly > >> detect whether the feature is enabled without having to rely on > >> always reading a separate cache-line. I've put together an ABI > >> proposal that take into account the feedback received so far. > > > > Nah, adding detectoring code to fast paths is silly, makes them less > > fast. Doesn't userspace have self modifying code? I know that at least > > glibc does linker trickery to call different functions depending on > > runtime context. > > > > No, userspace does not have self-modifying code. The glibc indirect > function is done at dynamic link time; it is also worth noting that > resolving global symbols through dynamic linking often requires an > indirect call. Boy that blows. And here I was thinking you could edit the code at dynamic link time because nobody was running it yet :/ And I suppose JITs need an (effective) munmap()+mmap() cycle to ensure the 'old' code is flushed from all caches etc..?