From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751552Ab3LKRrR (ORCPT ); Wed, 11 Dec 2013 12:47:17 -0500 Received: from mail-ea0-f179.google.com ([209.85.215.179]:47912 "EHLO mail-ea0-f179.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751387Ab3LKRrP (ORCPT ); Wed, 11 Dec 2013 12:47:15 -0500 Date: Wed, 11 Dec 2013 18:47:10 +0100 From: Ingo Molnar To: Peter Zijlstra Cc: Mike Galbraith , Borislav Petkov , Thomas Gleixner , Len Brown , Linux PM list , "linux-kernel@vger.kernel.org" , Jeremy Eder , x86@kernel.org Subject: Re: 50 Watt idle power regression bisected to Linux-3.10 Message-ID: <20131211174710.GA12431@gmail.com> References: <1386732093.5964.6.camel@marge.simpson.net> <20131211113839.GF21683@pd.tnic> <20131211115239.GA21999@twins.programming.kicks-ass.net> <1386764955.12005.60.camel@marge.simpson.net> <20131211124352.GB21999@twins.programming.kicks-ass.net> <20131211144238.GA4510@gmail.com> <20131211164403.GB2480@laptop.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20131211164403.GB2480@laptop.programming.kicks-ass.net> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Peter Zijlstra wrote: > On Wed, Dec 11, 2013 at 03:42:38PM +0100, Ingo Molnar wrote: > > Another thing that is required I think is to issue a write barrier > > before CLFLUSH instruction. By my (possibly incorrect ...) reading of > > the documentation CLFLUSH does not appear to be ordered (at all), so > > it might execute before the modification to the affected memory? > > > > > > So something like: > > > > if (this_cpu_has(X86_FEATURE_CLFLUSH_MONITOR)) { > > smp_wmb(); /* order CLFLUSH */ > > clflush(¤t_thread_info()->flags); > > } > > smp_wmb() is a NO-OP on x86 remember :-) Well, it's a compiler barrier but yes - I suspect a smp_mb() might be needed - at least according to the CLFLUSH documentation it has no implicit guaranteed ordering wrt. preceding writes. Thanks, Ingo