Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp4424875ybi; Tue, 30 Jul 2019 01:48:57 -0700 (PDT) X-Google-Smtp-Source: APXvYqzW1fOTEpexdQAZVcGUNqLLKQ4wgYpnqXZAzREPNY2ozuBTjSRx76YgAnC0d9qofe44ldZh X-Received: by 2002:a63:6c4:: with SMTP id 187mr101359112pgg.401.1564476537637; Tue, 30 Jul 2019 01:48:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564476537; cv=none; d=google.com; s=arc-20160816; b=CCCPMukMqU5iTQXlhTjo9zIYN1LukUtP/+XOLD39/rU7X29rD+bLmzzbEWr1F74Mjc 6V+P/JpTk21bK9OhhPsJ1MgGVAcWXrcNJa+1eXOUeP3Ac58lvUQWL+8f6VHzN1rFvagJ BJtd5c6/dclmPy7s6nk1EoqDuA2unaVVVsvaN6qONMKiAvkrjIPPz/zMfr3ddbaky4IP IF+yq83lgL3xqR+hn2gq46tBjdNrie1aElm+dex8//UYHDWvvAzjiVINxWVtHaXiMDI7 +7VkuyKu4uZ0Ol2k13isGFmilIEEmcijGakEOmGoqXBb/8m6w06J9TDaaSas1uM7HOoG 2Vrg== 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:message-id:date:subject:cc:to:from :dkim-signature; bh=ZLZDNq5pm2mTDaqv2dwp/abuaruOxAFX4DFrbxtsS3U=; b=NuukHZKRcKYeK83UW1+T7iSYr43YRRF6jWRiaYQsDdZ7wssaET38RkocFCjuJccQqu DYempzbGPLiHyzkkUivwthjUCk9R7l9IewPHMR9O//v+grRTZzpcmrdx5fXxNaSFSjox ORLyxNGdJ9TLJ7XaFMNdnFFsuJTlhFuCxIuR/AhfRDB85Y3LWvEGToxK+sbtOJkKpi9l PhKn68b/wGjDEAxKI87ZhJ857izMh92UCqwASwOLnwtA6kupPA59TOfbhWCJZJRrMR5I WbyMkYhT4MAJmCj8s0bopWKEuH6iCUyW+MGmTFUsoL6R3p/fQDtkwpwp2gPbFnexk8Vz LmjA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@arista.com header.s=googlenew header.b="M/VNVvPS"; 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=pass (p=QUARANTINE sp=REJECT dis=NONE) header.from=arista.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 85si32878636pgb.583.2019.07.30.01.48.43; Tue, 30 Jul 2019 01:48:57 -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=@arista.com header.s=googlenew header.b="M/VNVvPS"; 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=pass (p=QUARANTINE sp=REJECT dis=NONE) header.from=arista.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729669AbfG2WBz (ORCPT + 99 others); Mon, 29 Jul 2019 18:01:55 -0400 Received: from mail-wr1-f66.google.com ([209.85.221.66]:40178 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389230AbfG2V6P (ORCPT ); Mon, 29 Jul 2019 17:58:15 -0400 Received: by mail-wr1-f66.google.com with SMTP id r1so63462365wrl.7 for ; Mon, 29 Jul 2019 14:58:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arista.com; s=googlenew; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=ZLZDNq5pm2mTDaqv2dwp/abuaruOxAFX4DFrbxtsS3U=; b=M/VNVvPSR7BlmAhDH2lovmGmgLk97R+1GL43do5srTu1wANXq39v9P6m+cEXz6okk+ ebIpEjYor2Vgti9kLgnwgLx/ptriGbWEG3u7mmaOUbUAZGu6wAPETV5ckspfAq8Pt9cT YrmxQriwMO1Y5HbF6Pfx6DpXuoR43Yz/LAFlpTrTZPp/VwKR97aDlDnvQPsrYTeJMH3g EaQJrsi5e+PNo19HgAzQVm/HQQwCJNUIZEjm0TiQttw25eUOj+cIlTgVMHwbVV2iPtpk xkWcZW5n1DtKPXOA0J6iuRhwuWL0t4MDyZtjA+qnc7yJHIBVHnCZxSmUGZ3ZWZuFNHhR BSag== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=ZLZDNq5pm2mTDaqv2dwp/abuaruOxAFX4DFrbxtsS3U=; b=mKLB8Dkv4p8h99bjWqz7nvIt9NAnPCYmgox2JIdOMqMVkTSmxMHkyl/uh4TdPbxOCP 3Vz2jtFb1+B1ipORDBwf4ddPQKDTul7sCJpFGgg2QDV5Rb31LKi8xtDBoZgCV/IRvC1z 1PgJGFg5Ff4Lf0g02rUB8ozwQacHdzNpfoqQ6tmAvVFU0pyh2xc/We8wX0aNcuZmwdwH gvxjpmVyBZvb2QqDKuH++CUU1gcQ1lpTJwVBfjdXUM3BFuoJx88Gcv8mwfQ7mrggKIOh fwXd0F0M5ewmx0tQOcYgoUCP/fwkUXDL1w573fRXxU0r6l1ph+QN+nSSD7ruQw3oVA2r YTyw== X-Gm-Message-State: APjAAAVrmE0Uzrc+HMC87KFuJTQq3g8Mzlr8yNYH6j9WBlJ/Ym+xlPoF UVrtPr2xKlui6+xNWNmSHqZuEahlpwJ0BEmW35xTLlp/aKgpYt9Wo5RO2JtANH7HXgMSnWXX6Dq NDk9XeeOCvxmlnLoL5Rngr7jRYU5PJ4gsAycoa+fGKvwuOEm6dqMvn90FUjP0ThA0OFqapcNNs3 rzRvcR8DxnrvJAQSYcG+jsLSRjOh1K8G0vdWRnVv4= X-Received: by 2002:adf:f206:: with SMTP id p6mr50649643wro.216.1564437492712; Mon, 29 Jul 2019 14:58:12 -0700 (PDT) Received: from Mindolluin.ire.aristanetworks.com ([217.173.96.166]) by smtp.gmail.com with ESMTPSA id x20sm49230728wmc.1.2019.07.29.14.58.11 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Mon, 29 Jul 2019 14:58:12 -0700 (PDT) From: Dmitry Safonov To: linux-kernel@vger.kernel.org Cc: Dmitry Safonov <0x7f454c46@gmail.com>, Andrei Vagin , Dmitry Safonov , Adrian Reber , Andy Lutomirski , Arnd Bergmann , Christian Brauner , Cyrill Gorcunov , "Eric W. Biederman" , "H. Peter Anvin" , Ingo Molnar , Jann Horn , Jeff Dike , Oleg Nesterov , Pavel Emelyanov , Shuah Khan , Thomas Gleixner , Vincenzo Frascino , containers@lists.linux-foundation.org, criu@openvz.org, linux-api@vger.kernel.org, x86@kernel.org Subject: [PATCHv5 09/37] posix-clocks: Introduce CLOCK_MONOTONIC time namespace offsets Date: Mon, 29 Jul 2019 22:56:51 +0100 Message-Id: <20190729215758.28405-10-dima@arista.com> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190729215758.28405-1-dima@arista.com> References: <20190729215758.28405-1-dima@arista.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-CLOUD-SEC-AV-Info: arista,google_mail,monitor X-CLOUD-SEC-AV-Sent: true X-Gm-Spam: 0 X-Gm-Phishy: 0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andrei Vagin Add monotonic time virtualisation for time namespace. Introduce timespec for monotionic clock into timens offsets and wire clock_gettime() syscall. Signed-off-by: Andrei Vagin Co-developed-by: Dmitry Safonov Signed-off-by: Dmitry Safonov --- include/linux/time_namespace.h | 8 ++++++++ include/linux/timens_offsets.h | 1 + kernel/time/posix-stubs.c | 2 ++ kernel/time/posix-timers.c | 4 ++++ 4 files changed, 15 insertions(+) diff --git a/include/linux/time_namespace.h b/include/linux/time_namespace.h index b6985aa87479..186c134fe222 100644 --- a/include/linux/time_namespace.h +++ b/include/linux/time_namespace.h @@ -40,6 +40,13 @@ static inline void put_time_ns(struct time_namespace *ns) kref_put(&ns->kref, free_time_ns); } +static inline void timens_add_monotonic(struct timespec64 *ts) +{ + struct timens_offsets *ns_offsets = current->nsproxy->time_ns->offsets; + + if (ns_offsets) + *ts = timespec64_add(*ts, ns_offsets->monotonic); +} #else static inline struct time_namespace *get_time_ns(struct time_namespace *ns) @@ -65,6 +72,7 @@ static inline int timens_on_fork(struct nsproxy *nsproxy, struct task_struct *ts return 0; } +static inline void timens_add_monotonic(struct timespec64 *ts) {} #endif #endif /* _LINUX_TIMENS_H */ diff --git a/include/linux/timens_offsets.h b/include/linux/timens_offsets.h index 7d7cb68ea778..eaac2c82be5c 100644 --- a/include/linux/timens_offsets.h +++ b/include/linux/timens_offsets.h @@ -3,6 +3,7 @@ #define _LINUX_TIME_OFFSETS_H struct timens_offsets { + struct timespec64 monotonic; }; #endif diff --git a/kernel/time/posix-stubs.c b/kernel/time/posix-stubs.c index 67df65f887ac..17c67e0aecd8 100644 --- a/kernel/time/posix-stubs.c +++ b/kernel/time/posix-stubs.c @@ -14,6 +14,7 @@ #include #include #include +#include #include #ifdef CONFIG_ARCH_HAS_SYSCALL_WRAPPER @@ -77,6 +78,7 @@ int do_clock_gettime(clockid_t which_clock, struct timespec64 *tp) break; case CLOCK_MONOTONIC: ktime_get_ts64(tp); + timens_add_monotonic(tp); break; case CLOCK_BOOTTIME: ktime_get_boottime_ts64(tp); diff --git a/kernel/time/posix-timers.c b/kernel/time/posix-timers.c index aae7ab53790d..cfeb0477d1f9 100644 --- a/kernel/time/posix-timers.c +++ b/kernel/time/posix-timers.c @@ -30,6 +30,7 @@ #include #include #include +#include #include "timekeeping.h" #include "posix-timers.h" @@ -196,6 +197,7 @@ static int posix_clock_realtime_adj(const clockid_t which_clock, int posix_get_timespec(clockid_t which_clock, struct timespec64 *tp) { ktime_get_ts64(tp); + timens_add_monotonic(tp); return 0; } @@ -210,6 +212,7 @@ static ktime_t posix_get_ktime(clockid_t which_clock) static int posix_get_monotonic_raw(clockid_t which_clock, struct timespec64 *tp) { ktime_get_raw_ts64(tp); + timens_add_monotonic(tp); return 0; } @@ -224,6 +227,7 @@ static int posix_get_monotonic_coarse(clockid_t which_clock, struct timespec64 *tp) { ktime_get_coarse_ts64(tp); + timens_add_monotonic(tp); return 0; } -- 2.22.0