Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp746775ybz; Wed, 15 Apr 2020 18:04:29 -0700 (PDT) X-Google-Smtp-Source: APiQypLzdACfu5dZXVviUhZgzEPZVFYdR5eG/qy2Jt3i7L764t1WUsTFWq2tsvQjuLp/oeF/wZgp X-Received: by 2002:a50:a0c7:: with SMTP id 65mr28267904edo.7.1586999069577; Wed, 15 Apr 2020 18:04:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586999069; cv=none; d=google.com; s=arc-20160816; b=crHf3G9u6ND2uP0AqmNgbbKmGBtppdE8PlDB3woi+xw71qm9icO9co7vWg2NucnXvD nwShTkVV8jZpubyyCmdGomPyGCAMgCZUBwFPsVxbSsDtA2V+sz5Ly/UsLDX0nKpmGSzm uoiifkd2suH615OjtxrnVztf8MpY5CIDgqzyh4Ocahf4cWqJMs/8pwC/E8ue0E+0mNLh 6jCVbdCqWaW1BzV/1KvBmq5M8IIb+48JnRJ266hY6dn5JSy2E7NEooiyBIcY9tjLkv1s kKBhskji55olwu8JUsyZHFfXFGFnrjuHkjcq9vXqmTzwz5dQ3TkpHdPYAzzd2uwfbYSc gFFA== 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:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id :ironport-sdr:ironport-sdr; bh=HmUnp1AAM2LUv0W9Jg03lF5pYP3JRjF1kFgHYnnx39s=; b=IcoMkj8sUkWRCNM5K6IoMAcHq01mLYG0UbgJOhCEXd6aEcP7nxOz0JQR5nE6WYtPX4 utgAUMA/rftXWlw1jxgHwPCDBPJEufi1IT7bILJw8cfQ7pkX28gLBLR3duHBg8Rbq/7Y ljVwmN2R4/qivTuLH+/m+1MbQHTYMs1zT/4N7Sdo5L8hWr5rST3n85w1iHmPMFs4Febx MClPtCcUFZa5Mjeev+SxbK36Fr8TP6qO98G7fH/TIRyJItF3s02gslnqt2HVHwleHOlq lZ8NrXbDm1XrlndvzQt94YX+p9OddpIq8ORWVGaQ5HJXfJB3a961+Kislz8KIHKiSmAy /dTA== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i6si13131697edg.339.2020.04.15.18.04.06; Wed, 15 Apr 2020 18:04:29 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2436804AbgDOUIL (ORCPT + 99 others); Wed, 15 Apr 2020 16:08:11 -0400 Received: from mga03.intel.com ([134.134.136.65]:61120 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2406385AbgDOUII (ORCPT ); Wed, 15 Apr 2020 16:08:08 -0400 IronPort-SDR: a9i+qvlKS2MUcti8hBTD6QfEBVEOkn5e6uRprad2Vfo2HJdEKrZ2844mak7tBTNGAjytcKux2z N0LlRmQJAhNQ== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Apr 2020 13:08:04 -0700 IronPort-SDR: bVXKlqUIpUAJd05C0gQ+TdCfPVcVuwnGhkAQOqeNR7sWe5U3Sa6vbVfPRqNjjF4dxX0JOc08Fa V85kyjbEHc2g== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.72,388,1580803200"; d="scan'208";a="253630268" Received: from km-skylake-client-platform.sc.intel.com ([10.3.52.160]) by orsmga003.jf.intel.com with ESMTP; 15 Apr 2020 13:08:01 -0700 Message-ID: Subject: Re: [PATCH v3 3/3] x86/delay: Introduce TPAUSE delay From: km To: Peter Zijlstra , "Luck, Tony" Cc: "x86@kernel.org" , "linux-kernel@vger.kernel.org" , "tglx@linutronix.de" , "mingo@redhat.com" , "hpa@zytor.com" , "gregkh@linuxfoundation.org" , "ak@linux.intel.com" , "Raj, Ashok" , "Shankar, Ravi V" , "Yu, Fenghua" Date: Wed, 15 Apr 2020 12:57:16 -0700 In-Reply-To: <20200414180545.GE2483@worktop.programming.kicks-ass.net> References: <1586561395-50914-1-git-send-email-kyung.min.park@intel.com> <1586561395-50914-4-git-send-email-kyung.min.park@intel.com> <20200414103106.GK20713@hirez.programming.kicks-ass.net> <3908561D78D1C84285E8C5FCA982C28F7F5E3E80@ORSMSX115.amr.corp.intel.com> <20200414180545.GE2483@worktop.programming.kicks-ass.net> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.28.5-0ubuntu0.18.04.1 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Peter, On Tue, 2020-04-14 at 20:05 +0200, Peter Zijlstra wrote: > On Tue, Apr 14, 2020 at 06:00:21PM +0000, Luck, Tony wrote: > > > > +static inline void __tpause(u32 ecx, u32 edx, u32 eax) > > > > +{ > > > > + /* "tpause %ecx, %edx, %eax;" */ > > > > + asm volatile(".byte 0x66, 0x0f, 0xae, 0xf1\t\n" > > > > + : > > > > + : "c"(ecx), "d"(edx), "a"(eax)); > > > > +} > > > > > > Can we please get a comment stating from what binutils version > > > this > > > opcode has a mnemonic? That way, when we raise the minimum > > > binutils > > > version we can easily grep and find such things. > > > > Or maybe use arch/x86/Kconfig.assembler to set up a > > CONFIG_AS_TPAUSE? > > > > Then the code can read something like (syntax may need fixing) > > > > #ifdef CONFIG_AS_TPAUSE > > asm volatile("tpause %ecx\n", : : "c"(ecx), "d"(edx), > > "a"(eax)); > > #else > > asm volatile(".byte hex gibberish ... > > #endif > > Then we still need a comment to know when we can kill that... Thanks. I'll update in next patch.