Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751870AbdH3PZQ (ORCPT ); Wed, 30 Aug 2017 11:25:16 -0400 Received: from mailhub.sw.ru ([195.214.232.25]:1209 "EHLO relay.sw.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751416AbdH3PZN (ORCPT ); Wed, 30 Aug 2017 11:25:13 -0400 From: Denis Plotnikov To: pbonzini@redhat.com, rkrcmar@redhat.com, kvm@vger.kernel.org, john.stultz@linaro.org, tglx@linutronix.de Cc: mingo@redhat.com, hpa@zytor.com, linux-kernel@vger.kernel.org, x86@kernel.org, rkagan@virtuozzo.com, den@virtuozzo.com Subject: [PATCH v5 1/6] timekeeper: introduce extended clocksource reading callback Date: Wed, 30 Aug 2017 18:23:43 +0300 Message-Id: <1504106628-172372-2-git-send-email-dplotnikov@virtuozzo.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1504106628-172372-1-git-send-email-dplotnikov@virtuozzo.com> References: <1504106628-172372-1-git-send-email-dplotnikov@virtuozzo.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1585 Lines: 43 The callback provides extended information about just read clocksource value. It's going to be used in cases when detailed system information needed for further time related values calculation, e.g in KVM masterclock settings calculation. Signed-off-by: Denis Plotnikov --- include/linux/clocksource.h | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/include/linux/clocksource.h b/include/linux/clocksource.h index a78cb18..786a522 100644 --- a/include/linux/clocksource.h +++ b/include/linux/clocksource.h @@ -48,7 +48,14 @@ struct module; * 400-499: Perfect * The ideal clocksource. A must-use where * available. - * @read: returns a cycle value, passes clocksource as argument + * @read: returns a cycle value (might be not quite cycles: + * see pvclock) passes clocksource as argument + * @read_with_stamp: saves cycles value (got from timekeeper) and cycles + * stamp (got from hardware counter value and used by + * timekeeper to calculate the cycles value) to + * corresponding input pointers return true if cycles + * stamp holds real cycles and false if it holds some + * time derivative value * @enable: optional function to enable the clocksource * @disable: optional function to disable the clocksource * @mask: bitmask for two's complement @@ -78,6 +85,8 @@ struct module; */ struct clocksource { u64 (*read)(struct clocksource *cs); + bool (*read_with_stamp)(struct clocksource *cs, + u64 *cycles, u64 *cycles_stamp); u64 mask; u32 mult; u32 shift; -- 2.7.4