Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1139033ybz; Wed, 22 Apr 2020 14:22:36 -0700 (PDT) X-Google-Smtp-Source: APiQypJefDUfiMIp/C+5urP1u4rJFzgAZOrDq/lhE0MKrycQ+XC7tPON4ggQkDJl++m4UuKb56gU X-Received: by 2002:a17:906:38c:: with SMTP id b12mr269043eja.332.1587590555844; Wed, 22 Apr 2020 14:22:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587590555; cv=none; d=google.com; s=arc-20160816; b=ccKDUuxGZac7jp5S3mMeREW0Yzd+E5Ync4LgKt1bI7p5tFxkNP9Tg0IiePaAaJ2USW 8cvw6b4DCnAHCiZqQsS6mdlDUxpyQ5kGnXd7+X6I3c/ng58ElJIy4v/kM+vfZB7JTdAd A6ga+7cDKiBesvRsGMpo/IXKTVKFTYUMvloxvLrvWRaWHxiRtQ7gHfe6rg3oC1TPJBoZ BaBeBH8BbuCYxDRvb+EKWiy1rhEfaeGmfW0aSADMbDy9mqiaLsw/Re8ghQCn/qd9HOG6 uS2w7sN8bEAh6kmqjKo0BoieuTHWhsVeWcGFrYYnPz+260A4nm9PrSc8vwdY4L7LRbH8 Db6g== 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 :robot-unsubscribe:robot-id:message-id:mime-version:references :in-reply-to:cc:subject:to:reply-to:from:date; bh=1wORY/xoctBVXtXfEO38rRQijAtIGXdvgdnbCc5ax7Y=; b=D1U0RAC2x6iuxnQYvDQvjv53Lqy+KI5rZUX2AsCGCkbimaFBmB4qmUar0BGCFjQhmP uY1NSSF67ZMjvaos77sW1Pow9Ok/IqOnvTCHwvMq3F0VACAoSAN5hEq/KlluKObl0pu7 R0QWv4zBVBHK4tpwgeZMolKgsqArVaVnZad6jegigAhQTUyGNGUWhuh4V8Fzq6yip9ng k1z6fF1ns3Mr232YXtje5ESfVQ10YXz0z3b4WcMBkdGATSRv6N6Dy+n7k+iLHg8/tWfK p3G5BNPY0AfoCNIlzeP02mS4EVJT9BpXYzGZbimgyVelWfy01lH0fTehr6T2vsUhFAHn AP0A== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u10si236317ejt.145.2020.04.22.14.22.10; Wed, 22 Apr 2020 14:22:35 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726489AbgDVVU4 (ORCPT + 99 others); Wed, 22 Apr 2020 17:20:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53214 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726066AbgDVVUz (ORCPT ); Wed, 22 Apr 2020 17:20:55 -0400 Received: from Galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8128DC03C1A9; Wed, 22 Apr 2020 14:20:55 -0700 (PDT) Received: from [5.158.153.53] (helo=tip-bot2.lab.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1jRMnZ-0000Ol-VY; Wed, 22 Apr 2020 23:20:50 +0200 Received: from [127.0.1.1] (localhost [IPv6:::1]) by tip-bot2.lab.linutronix.de (Postfix) with ESMTP id 7A1641C0450; Wed, 22 Apr 2020 23:20:49 +0200 (CEST) Date: Wed, 22 Apr 2020 21:20:49 -0000 From: "tip-bot2 for Giovanni Gherdovich" Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: sched/urgent] x86, sched: Bail out of frequency invariance if base frequency is unknown Cc: Giovanni Gherdovich , "Peter Zijlstra (Intel)" , "Rafael J. Wysocki" , x86 , LKML In-Reply-To: <20200416054745.740-2-ggherdovich@suse.cz> References: <20200416054745.740-2-ggherdovich@suse.cz> MIME-Version: 1.0 Message-ID: <158759044911.28353.2414263048020355766.tip-bot2@tip-bot2> X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The following commit has been merged into the sched/urgent branch of tip: Commit-ID: 9a6c2c3c7a73ce315c57c1b002caad6fcc858d0f Gitweb: https://git.kernel.org/tip/9a6c2c3c7a73ce315c57c1b002caad6fcc858d0f Author: Giovanni Gherdovich AuthorDate: Thu, 16 Apr 2020 07:47:42 +02:00 Committer: Peter Zijlstra CommitterDate: Wed, 22 Apr 2020 23:10:13 +02:00 x86, sched: Bail out of frequency invariance if base frequency is unknown Some hypervisors such as VMWare ESXi 5.5 advertise support for X86_FEATURE_APERFMPERF but then fill all MSR's with zeroes. In particular, MSR_PLATFORM_INFO set to zero tricks the code that wants to know the base clock frequency of the CPU (highest non-turbo frequency), producing a division by zero when computing the ratio turbo_freq/base_freq necessary for frequency invariant accounting. It is to be noted that even if MSR_PLATFORM_INFO contained the appropriate data, APERF and MPERF are constantly zero on ESXi 5.5, thus freq-invariance couldn't be done in principle (not that it would make a lot of sense in a VM anyway). The real problem is advertising X86_FEATURE_APERFMPERF. This appears to be fixed in more recent versions: ESXi 6.7 doesn't advertise that feature. Fixes: 1567c3e3467c ("x86, sched: Add support for frequency invariance") Signed-off-by: Giovanni Gherdovich Signed-off-by: Peter Zijlstra (Intel) Acked-by: Rafael J. Wysocki Link: https://lkml.kernel.org/r/20200416054745.740-2-ggherdovich@suse.cz --- arch/x86/kernel/smpboot.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/arch/x86/kernel/smpboot.c b/arch/x86/kernel/smpboot.c index fe3ab96..3a318ec 100644 --- a/arch/x86/kernel/smpboot.c +++ b/arch/x86/kernel/smpboot.c @@ -1985,6 +1985,15 @@ static bool intel_set_max_freq_ratio(void) return false; out: + /* + * Some hypervisors advertise X86_FEATURE_APERFMPERF + * but then fill all MSR's with zeroes. + */ + if (!base_freq) { + pr_debug("Couldn't determine cpu base frequency, necessary for scale-invariant accounting.\n"); + return false; + } + arch_turbo_freq_ratio = div_u64(turbo_freq * SCHED_CAPACITY_SCALE, base_freq); arch_set_max_freq_ratio(turbo_disabled());