Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp625468img; Fri, 22 Mar 2019 05:24:46 -0700 (PDT) X-Google-Smtp-Source: APXvYqxpARb9HnICJKPDhIsgCm5Bd0xVjXoOaqxSHl2+1iLnY6K+U8BZ0P6BTdiWTJMhCXF1Da/F X-Received: by 2002:a62:6f06:: with SMTP id k6mr8810246pfc.257.1553257486883; Fri, 22 Mar 2019 05:24:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553257486; cv=none; d=google.com; s=arc-20160816; b=HrxT2JIleEWArgaNyo52AnjGHxbDWNVgIKmTWRj1yveh7Ke3CwrSb6S4Wa5dcrk/iW jBfF/czsxhj0jwSZi4Ur3jebAU+nW1prxf3SMwRFmreKMb9UdZ8y8RDUZXUTmnwpbdK6 9KxAQQpeqzxPRQOh2ASBhTAWBG5CoraOI/fgE06UlFMvTEJ0+DbLAa053KGHMmqdxZox dOwT0hkr9T3U8cft2ciJgHOQWR3bsknDgqV0YUswKv6BR/mFEGpE34y0XnIZxt6GiWS0 vxN8Z/3WMt7UbgHc8QRUk03n5mZ51xRKa818Ctyn7fcGZDN0VZG23m//D5dWN/1Txy8t uigg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=8AN002wN4fLicA+FYNxNuNMqHAe1YPHdXzZsFPzMT8U=; b=BVex6jkrdjoUC9poPO/6Hxa72T+EqQl2m9nfWvJWanX+VM+CfYjc9Jt21aR8LU4mjy sGT1PuovglT0YrwZ7RfRWLq/ZyrEv0f9ujfjuThfzUX/1qDPDjt9pm6IfEbUFxaH0bD3 lZ9e2zer0xeKaEv92VxLol5BXqfX3012c2SbZTWYSf+B7m/Tqxai7h56js4lZH6qbKaN Ks8YEu6V02nFo9kI7dZ+INTdw+VqmegsnqUMZins9QRGEwojTMXtSusT2iD9DSMUfHlI TckAIbZRO1X9wuCOTE9PZGePxPfVTsbguNDlZeC6yTOJnBscjMyJjvOIScJCU7LaondT FceQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pwShzJtc; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d36si7288900pla.425.2019.03.22.05.24.32; Fri, 22 Mar 2019 05:24:46 -0700 (PDT) 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; dkim=pass header.i=@kernel.org header.s=default header.b=pwShzJtc; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391019AbfCVMWh (ORCPT + 99 others); Fri, 22 Mar 2019 08:22:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:33700 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390662AbfCVMWd (ORCPT ); Fri, 22 Mar 2019 08:22:33 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0252A218A1; Fri, 22 Mar 2019 12:22:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553257352; bh=DPznJgemzeVkxeeFLwwBKz7+zIos2vbJFKx9ohJjI4A=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pwShzJtcvJFwzAE2lAiUASFEG08vbydYfvOorNMAtAao1wtiaIOk8tiEGQsZot9qk HfcLlHQNRUWky7CW/BV65QRchQxx9HtD6am0VS/VRAoVtfaghunGPFlIa3Hgh6nR9J T8n7Y3JdQMhDAW0sk5mKqkzbROIMNm3YVWDN4WtA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Dominique Martinet , Pavel Tatashin , Paolo Bonzini Subject: [PATCH 5.0 207/238] x86/kvmclock: set offset for kvm unstable clock Date: Fri, 22 Mar 2019 12:17:06 +0100 Message-Id: <20190322111310.446706040@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190322111258.383569278@linuxfoundation.org> References: <20190322111258.383569278@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 5.0-stable review patch. If anyone has any objections, please let me know. ------------------ From: Pavel Tatashin commit b5179ec4187251a751832193693d6e474d3445ac upstream. VMs may show incorrect uptime and dmesg printk offsets on hypervisors with unstable clock. The problem is produced when VM is rebooted without exiting from qemu. The fix is to calculate clock offset not only for stable clock but for unstable clock as well, and use kvm_sched_clock_read() which substracts the offset for both clocks. This is safe, because pvclock_clocksource_read() does the right thing and makes sure that clock always goes forward, so once offset is calculated with unstable clock, we won't get new reads that are smaller than offset, and thus won't get negative results. Thank you Jon DeVree for helping to reproduce this issue. Fixes: 857baa87b642 ("sched/clock: Enable sched clock early") Cc: stable@vger.kernel.org Reported-by: Dominique Martinet Signed-off-by: Pavel Tatashin Signed-off-by: Paolo Bonzini Signed-off-by: Greg Kroah-Hartman --- arch/x86/kernel/kvmclock.c | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) --- a/arch/x86/kernel/kvmclock.c +++ b/arch/x86/kernel/kvmclock.c @@ -104,12 +104,8 @@ static u64 kvm_sched_clock_read(void) static inline void kvm_sched_clock_init(bool stable) { - if (!stable) { - pv_ops.time.sched_clock = kvm_clock_read; + if (!stable) clear_sched_clock_stable(); - return; - } - kvm_sched_clock_offset = kvm_clock_read(); pv_ops.time.sched_clock = kvm_sched_clock_read;