Received: by 10.223.164.202 with SMTP id h10csp2799704wrb; Sun, 12 Nov 2017 19:03:47 -0800 (PST) X-Google-Smtp-Source: AGs4zMZkaAWkFPErYbLppHjHUG55N8JY7qr5yq8irtqvtc+D74lZM4wbbmVYVaKxNdWZ//RRbIUt X-Received: by 10.99.108.66 with SMTP id h63mr1257780pgc.362.1510542227848; Sun, 12 Nov 2017 19:03:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510542227; cv=none; d=google.com; s=arc-20160816; b=BGXAILzGk1n2h9WZUDG2Sg4M1PZnzU9nUBaVevqMdsQyGsNjesvCvyvZVpS1M7spoP VLcr6vWp9gDLypUVWjs5KUx6i5AAhFTrIFe2263eWm9zL0sy/SF04xSXIrCUYlVPeeyr GR/1dfgSySVnwP5F78sOAQOKbmJKwEiklEbEPlrBQIL620bGnYbg4EO5juea14dDnGI4 VcMUJa8N2jtamlu0aJhpUXu+tkK3rsn6zThGi+0dx9hk3u49+FISUfEwjTGhZJcDEErW F2qZPFVGmi3egl/eKn7Fd71saTHrGV5MMEwXzjQpTDUnqBGKKZ3LLG9E6nq2R50xJAHR 1Odg== 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:arc-authentication-results; bh=ibCTf8fUi/3iHUS8+ceNdW/GPRW59bsrmnAIN7yMzN0=; b=fNmItig/6EADyapaIpSys07CZjjEIwykeZ8Ts04YnIE+fcB5Skn56TQjYCOWVQvPcV xCaqx1u3a/27GYLEILfHjJyqW6ABEwrxNn+VlwOEzQ+7J5kN3ZYp/7HGmG0Q+UfTZSfX c6EWUsNzACOLpiM6kpoIYRDf73nRQhVnsZmzC8fU2vLzHJ6UcrOYepjuNtjOYOq20tCh Lw3XGO0I95bzqhbmGA9yBoCZtHsGJob6UT5FBWNvayfVx8mxGjoVpsSPcssN9hXzaVUq a77U+5dFDtR/Cze+pEkVQC2K2Ai1hh/YxoacF19kcW0wHQ74Cv+iMK1Ji6s8YukASanR CaWA== 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=ucloud.cn Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x1si11295861pfj.295.2017.11.12.19.03.35; Sun, 12 Nov 2017 19:03:47 -0800 (PST) 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=ucloud.cn Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751886AbdKMDBs (ORCPT + 87 others); Sun, 12 Nov 2017 22:01:48 -0500 Received: from m97139.mail.qiye.163.com ([220.181.97.139]:41744 "EHLO m97139.mail.qiye.163.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751602AbdKMDBq (ORCPT ); Sun, 12 Nov 2017 22:01:46 -0500 Received: from localhost (unknown [106.38.57.250]) by smtp10 (Coremail) with SMTP id vOCowAA39nLoCgla5iiKBA--.11S3; Mon, 13 Nov 2017 11:00:57 +0800 (CST) Date: Mon, 13 Nov 2017 11:00:56 +0800 From: WANG Chao To: "Rafael J. Wysocki" Cc: x86@kernel.org, Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Linus Torvalds , LKML , Linux PM , Len Brown Subject: Re: [PATCH] x86 / CPU: Avoid unnecessary IPIs in arch_freq_get_on_cpu() Message-ID: <20171113030056.GA43577@WANG-Chaos-MacBook-Pro.local> References: <1830825.NTYOMyctnU@aspire.rjw.lan> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1830825.NTYOMyctnU@aspire.rjw.lan> User-Agent: Mutt/1.9.1 (2017-09-22) X-CM-TRANSID: vOCowAA39nLoCgla5iiKBA--.11S3 X-Coremail-Antispam: 1Uf129KBjvJXoWxWFy5uFyktw4xGw1UuryrXrb_yoW5Jw1Upr sIkryIkr4rXr90y3y5Ar4kWr15u3s7Ja1UXF1rKF45Awn8XFsrXws7t343W3W7ur93Ca1S yFZ8CF4rtw18tFUanT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDUYxBIdaVFxhVjvjDU0xZFpf9x0JbMbyZUUUUU= X-Originating-IP: [106.38.57.250] X-CM-SenderInfo: pfkd0hpzdqwq5xfo03fgof0/1tbiag+PVFlZtnG6-wAAs8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/13/17 at 02:15P, Rafael J. Wysocki wrote: > From: Rafael J. Wysocki > > Even though aperfmperf_snapshot_khz() caches the samples.khz value > to return if called again in a sufficiently short time, its caller, > arch_freq_get_on_cpu(), still uses smp_call_function_single() to run > it which may allow user space to trigger an IPI storm by reading from > the scaling_cur_freq cpufreq sysfs file in a tight loop. > > To avoid that, move the decision on whether or not to return the > cached samples.khz value to arch_freq_get_on_cpu(). > > Fixes: 4815d3c56d1e (cpufreq: x86: Make scaling_cur_freq behave more as expected) > Signed-off-by: Rafael J. Wysocki Looks good to me. Reviewed-by: WANG Chao > --- > > This change was part of commit 941f5f0f6ef5 (x86: CPU: Fix up "cpu MHz" in > /proc/cpuinfo), but it was not the reason for the revert and it remains > applicable. > > Thanks, > Rafael > > --- > arch/x86/kernel/cpu/Makefile | 2 +- > arch/x86/kernel/cpu/aperfmperf.c | 11 +++++++---- > arch/x86/kernel/cpu/proc.c | 4 +++- > 3 files changed, 11 insertions(+), 6 deletions(-) > > Index: linux-pm/arch/x86/kernel/cpu/aperfmperf.c > =================================================================== > --- linux-pm.orig/arch/x86/kernel/cpu/aperfmperf.c > +++ linux-pm/arch/x86/kernel/cpu/aperfmperf.c > @@ -42,10 +42,6 @@ static void aperfmperf_snapshot_khz(void > s64 time_delta = ktime_ms_delta(now, s->time); > unsigned long flags; > > - /* Don't bother re-computing within the cache threshold time. */ > - if (time_delta < APERFMPERF_CACHE_THRESHOLD_MS) > - return; > - > local_irq_save(flags); > rdmsrl(MSR_IA32_APERF, aperf); > rdmsrl(MSR_IA32_MPERF, mperf); > @@ -74,6 +70,7 @@ static void aperfmperf_snapshot_khz(void > > unsigned int arch_freq_get_on_cpu(int cpu) > { > + s64 time_delta; > unsigned int khz; > > if (!cpu_khz) > @@ -82,6 +79,12 @@ unsigned int arch_freq_get_on_cpu(int cp > if (!static_cpu_has(X86_FEATURE_APERFMPERF)) > return 0; > > + /* Don't bother re-computing within the cache threshold time. */ > + time_delta = ktime_ms_delta(ktime_get(), per_cpu(samples.time, cpu)); > + khz = per_cpu(samples.khz, cpu); > + if (khz && time_delta < APERFMPERF_CACHE_THRESHOLD_MS) > + return khz; > + > smp_call_function_single(cpu, aperfmperf_snapshot_khz, NULL, 1); > khz = per_cpu(samples.khz, cpu); > if (khz) > From 1583911591706608714@xxx Mon Nov 13 01:16:44 +0000 2017 X-GM-THRID: 1583911591706608714 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread