Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp21604ybl; Tue, 7 Jan 2020 01:17:10 -0800 (PST) X-Google-Smtp-Source: APXvYqz9t/Y4JUR0dNETCY8pKIAaJA+W/jCrJ7i6aIH+HEjEhgW49z7O28DRYxlKGu0YApnrth+v X-Received: by 2002:a05:6830:1294:: with SMTP id z20mr116758803otp.60.1578388630767; Tue, 07 Jan 2020 01:17:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578388630; cv=none; d=google.com; s=arc-20160816; b=yuaaXsrUfxgvRYEvD0DMIWqGLcCSown/havwjGK9Wv5lCJumLzShW5LWha5l+Mkuuv NHJgZoNdtO8oUkHuLzTunwo6NQtD21PbzNpSqV5TZpNz96s91lP7vQx3boLFtWOPiecM Q+YmAidTtUI9+JwHnulpId+MH9IXghjbk29/Vr30BaRkjmOdHNU9MHnBEYkZfYBXAmsl bOff3UN6bcqcwZTdUqHKHNuVj7KPLSHXO5wjhqEEqdRYnasZAv0JG+zNw9LzbaznZpv5 YltFOcgPqVTRn8KSyJmsfG/DMlCFMXI0daWNfjSi9EqXF0eGd/bijiDl2anQkVfTDxRq W+qQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=RJt7Qc6z9slI6BnXIsygwrohKuJOmsZM+8Gb031kHZo=; b=lglohgzPx7i0NLzR1y6Tevtr9mEi7hZszPd4DAW1wRWlDJBLcmO7FK105m7zLngJwJ 1+TB2jjmkwzbrUcZ2B4U1TG2FsaCyTsJBLBdEyMnKN3welAv649x504fj7MaT8sGbrkd rNij8h6XvK78KiTr0dNn1jK2xQwUFOx0X4A6BfXowVPVbJb9A8Zgh/Fs7G4NKmiK+Roh CjnrsfGdR6BBrMi3zmEt3h0PlwagBIFWyv9MIaJ8JJqS4xvPkpflvOmluR5aI7hV9JVk zY5l3kEvuaaUiUPWuIaq9mvs4vr3d63AoIjC+cHFmG6NTeRsz7FraxhRG7qqumPlcPyy sCKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=w0RyRqrD; 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=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h9si15164548oie.74.2020.01.07.01.16.57; Tue, 07 Jan 2020 01:17:10 -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; dkim=pass header.i=@kernel.org header.s=default header.b=w0RyRqrD; 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=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727745AbgAGJQN (ORCPT + 99 others); Tue, 7 Jan 2020 04:16:13 -0500 Received: from mail.kernel.org ([198.145.29.99]:35356 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727680AbgAGJQL (ORCPT ); Tue, 7 Jan 2020 04:16:11 -0500 Received: from disco-boy.misterjones.org (disco-boy.misterjones.org [51.254.78.96]) (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 38B2920656; Tue, 7 Jan 2020 09:16:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1578388570; bh=hdFiCaeaNP79bTue6oK3n76q0rsZ9EjJ5bhLkJslDM8=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=w0RyRqrDUQlTP1euuzRbIXeNZRqGkpwEvpAwzpKbuY7InKXmxbL20omILRfsrnFEE dmpIx2rlolza0oax2ce89zyFWA/z/y+UOPTguSQ71+j07OjmMHTYj6FxIzEnx7PEMB 3ZN7lXAqfL6LFrKu9dIQLSmHfd7BX9aduw+3immQ= Received: from disco-boy.misterjones.org ([51.254.78.96] helo=www.loen.fr) by disco-boy.misterjones.org with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.92) (envelope-from ) id 1ioky8-0000iX-HV; Tue, 07 Jan 2020 09:16:08 +0000 MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Tue, 07 Jan 2020 09:16:08 +0000 From: Marc Zyngier To: Jianyong Wu Cc: netdev@vger.kernel.org, yangbo.lu@nxp.com, john.stultz@linaro.org, tglx@linutronix.de, pbonzini@redhat.com, sean.j.christopherson@intel.com, richardcochran@gmail.com, Mark.Rutland@arm.com, will@kernel.org, suzuki.poulose@arm.com, steven.price@arm.com, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, Steve.Capper@arm.com, Kaly.Xin@arm.com, justin.he@arm.com, nd@arm.com Subject: Re: [RFC PATCH v9 6/8] psci: Add hvc call service for ptp_kvm. In-Reply-To: <20191210034026.45229-7-jianyong.wu@arm.com> References: <20191210034026.45229-1-jianyong.wu@arm.com> <20191210034026.45229-7-jianyong.wu@arm.com> Message-ID: <7383dc06897bba253f174cd21a19b5c0@kernel.org> X-Sender: maz@kernel.org User-Agent: Roundcube Webmail/1.3.8 X-SA-Exim-Connect-IP: 51.254.78.96 X-SA-Exim-Rcpt-To: jianyong.wu@arm.com, netdev@vger.kernel.org, yangbo.lu@nxp.com, john.stultz@linaro.org, tglx@linutronix.de, pbonzini@redhat.com, sean.j.christopherson@intel.com, richardcochran@gmail.com, Mark.Rutland@arm.com, will@kernel.org, suzuki.poulose@arm.com, steven.price@arm.com, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, Steve.Capper@arm.com, Kaly.Xin@arm.com, justin.he@arm.com, nd@arm.com X-SA-Exim-Mail-From: maz@kernel.org X-SA-Exim-Scanned: No (on disco-boy.misterjones.org); SAEximRunCond expanded to false Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2019-12-10 03:40, Jianyong Wu wrote: > ptp_kvm modules will call hvc to get this service. > The service offers real time and counter cycle of host for guest. > > Signed-off-by: Jianyong Wu > --- > include/linux/arm-smccc.h | 12 ++++++++++++ > virt/kvm/arm/psci.c | 22 ++++++++++++++++++++++ > 2 files changed, 34 insertions(+) > > diff --git a/include/linux/arm-smccc.h b/include/linux/arm-smccc.h > index 6f82c87308ed..aafb6bac167d 100644 > --- a/include/linux/arm-smccc.h > +++ b/include/linux/arm-smccc.h > @@ -94,6 +94,7 @@ > > /* KVM "vendor specific" services */ > #define ARM_SMCCC_KVM_FUNC_FEATURES 0 > +#define ARM_SMCCC_KVM_PTP 1 > #define ARM_SMCCC_KVM_FUNC_FEATURES_2 127 > #define ARM_SMCCC_KVM_NUM_FUNCS 128 > > @@ -103,6 +104,17 @@ > ARM_SMCCC_OWNER_VENDOR_HYP, \ > ARM_SMCCC_KVM_FUNC_FEATURES) > > +/* > + * This ID used for virtual ptp kvm clock and it will pass second > value > + * and nanosecond value of host real time and system counter by vcpu > + * register to guest. > + */ > +#define ARM_SMCCC_VENDOR_HYP_KVM_PTP_FUNC_ID \ > + ARM_SMCCC_CALL_VAL(ARM_SMCCC_FAST_CALL, \ > + ARM_SMCCC_SMC_32, \ > + ARM_SMCCC_OWNER_VENDOR_HYP, \ > + ARM_SMCCC_KVM_PTP) > + All of this depends on patches that have never need posted to any ML, and just linger in Will's tree. You need to pick them up and post them as part of this series so that they can at least be reviewed. > #ifndef __ASSEMBLY__ > > #include > diff --git a/virt/kvm/arm/psci.c b/virt/kvm/arm/psci.c > index 0debf49bf259..682d892d6717 100644 > --- a/virt/kvm/arm/psci.c > +++ b/virt/kvm/arm/psci.c > @@ -9,6 +9,7 @@ > #include > #include > #include > +#include > > #include > #include > @@ -389,6 +390,8 @@ static int kvm_psci_call(struct kvm_vcpu *vcpu) > > int kvm_hvc_call_handler(struct kvm_vcpu *vcpu) > { > + struct system_time_snapshot systime_snapshot; > + u64 cycles; > u32 func_id = smccc_get_function(vcpu); > u32 val[4] = {}; > u32 option; > @@ -431,6 +434,25 @@ int kvm_hvc_call_handler(struct kvm_vcpu *vcpu) > case ARM_SMCCC_VENDOR_HYP_KVM_FEATURES_FUNC_ID: > val[0] = BIT(ARM_SMCCC_KVM_FUNC_FEATURES); > break; > + /* > + * This will used for virtual ptp kvm clock. three > + * values will be passed back. > + * reg0 stores high 32-bit host ktime; > + * reg1 stores low 32-bit host ktime; > + * reg2 stores high 32-bit difference of host cycles and cntvoff; > + * reg3 stores low 32-bit difference of host cycles and cntvoff. That's either two or four values, and not three as you claim above. Also, I fail to understand the meaning of the host cycle vs cntvoff comparison. This is something that guest can perform on its own (it has access to both physical and virtual timers, and can compute cntvoff without intervention of the hypervisor). Finally, how does it work with nested virt, where cntvoff is for the the vEL2 guest? > + */ > + case ARM_SMCCC_VENDOR_HYP_KVM_PTP_FUNC_ID: > + ktime_get_snapshot(&systime_snapshot); > + if (systime_snapshot.cs_id != CSID_ARM_ARCH_COUNTER) > + return kvm_psci_call(vcpu); What does this mean? Calling PSCI because you've failed to identify the clock source? What result do you expect from this? Hint: this isn't a PSCI call. Cosmetic comments below: > + val[0] = systime_snapshot.real >> 32; val[0] = upper_32_bits(systime_snapshot.real); > + val[1] = systime_snapshot.real << 32 >> 32; val[1] = lower_32_bits(systime_snapshot.real); > + cycles = systime_snapshot.cycles - > + vcpu_vtimer(vcpu)->cntvoff; On a single line please. > + val[2] = cycles >> 32; > + val[3] = cycles << 32 >> 32; Same as above. > + break; > default: > return kvm_psci_call(vcpu); > } Thanks, M. -- Jazz is not dead. It just smells funny...