Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp865950yba; Mon, 1 Apr 2019 19:30:57 -0700 (PDT) X-Google-Smtp-Source: APXvYqxQTEaDsR3OLBl+razNd/8qwgtlvZydv37IZffzMs2SaCbCHFlO8bW8+77W7modVtnuSdpI X-Received: by 2002:a63:4a5f:: with SMTP id j31mr5195280pgl.369.1554172257786; Mon, 01 Apr 2019 19:30:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554172257; cv=none; d=google.com; s=arc-20160816; b=giD5EgLVSKhmaqbmkni5ZyRTQnU3xGYuvfWb9dyWNTlzlMfHvGClRQ9giP8T59H3IU W16e6+Xj49NyYz/iXv46ne1diTOPwN1pxCcMqm9JjSiBwSGUuPFiwlHtxkXnRgBGu0pQ mJgE568Pz2n73wp75JJ8l1UBbVIMKpc7ftzzEvHhroIA1gFUeFALCb25vq9eF+ITwmBl OqCGCXlUxan1EDeC/AQQqIl8CnKO+UZ/uFPsRs3GYxS9nnbHexz08dPUZtyU9Xc8/uBn LH4J09aXjtpkOIRE9jpRDPMDPnIv8PURP2y6erhd9xPslu+5nBIfa8xw4aj9e37gzX0G 4H4A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=/pjOfyGeK78h/RxJoXbFWHE7VeJ8u+6EVywN+W+mNAw=; b=qVBC+dTBv7vX+pdYCM9VTao49M4ZWRp/m6F2PUCktnGuMhkd8Mh6XjnuSOAS3AvSzE Pr0OXZPfRKLUYiH08RSvr4f0VW8iXRto4dfJh4ngxBWMEwhLncQfLRskU9QCOgaCXPNG il661s/oGT0TqSSy+8/kzkYbwRZMTaAU9ybXgmabGOJmWX0rD605VUeKKqWj5jYNtA8r 1p9emtr8528uMlFOnh31FmpCpiYuZRF0LLcVsvgHvnOmbu/szVd3epTV3Ozfq6XS16qM /IZsLMZvHXdswv4dkmD+wPN5S4TSHBS2TTe+I9B8Yw9W3wx3cnuQxTKJaXGsP/XRFa53 vutw== ARC-Authentication-Results: i=1; mx.google.com; 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 f12si10353951pgj.535.2019.04.01.19.30.42; Mon, 01 Apr 2019 19:30: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; 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 S1728952AbfDBC2R (ORCPT + 99 others); Mon, 1 Apr 2019 22:28:17 -0400 Received: from foss.arm.com ([217.140.101.70]:43624 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726269AbfDBC2R (ORCPT ); Mon, 1 Apr 2019 22:28:17 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 9B261EBD; Mon, 1 Apr 2019 19:28:16 -0700 (PDT) Received: from a075553-lin.blr.arm.com (a075553-lin.blr.arm.com [10.162.0.144]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id DEDD13F59C; Mon, 1 Apr 2019 19:28:11 -0700 (PDT) From: Amit Daniel Kachhap To: linux-arm-kernel@lists.infradead.org Cc: Christoffer Dall , Marc Zyngier , Catalin Marinas , Will Deacon , Andrew Jones , Dave Martin , Ramana Radhakrishnan , kvmarm@lists.cs.columbia.edu, Kristina Martsenko , linux-kernel@vger.kernel.org, Amit Daniel Kachhap , Mark Rutland , James Morse , Julien Thierry Subject: [PATCH v8 8/9] KVM: arm64: Add capability to advertise ptrauth for guest Date: Tue, 2 Apr 2019 07:57:16 +0530 Message-Id: <1554172037-4516-9-git-send-email-amit.kachhap@arm.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1554172037-4516-1-git-send-email-amit.kachhap@arm.com> References: <1554172037-4516-1-git-send-email-amit.kachhap@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch advertises the capability of two cpu feature called address pointer authentication and generic pointer authentication. These capabilities depend upon system support for pointer authentication and VHE mode. The current arm64 KVM partially implements pointer authentication and support of address/generic authentication are tied together. However, separate ABI requirements for both of them is added so that the future isolated implementation will not require any ABI changes. Signed-off-by: Amit Daniel Kachhap Cc: Mark Rutland Cc: Marc Zyngier Cc: Christoffer Dall Cc: kvmarm@lists.cs.columbia.edu --- Changes since v7: * Created 2 capabilities KVM_CAP_ARM_PTRAUTH_ADDRESS and KVM_CAP_ARM_PTRAUTH_GENERIC instead of one KVM_CAP_ARM_PTRAUTH [Kristina Martsenko]. * Added documentation here itself instead of in a new patch. Documentation/virtual/kvm/api.txt | 3 +++ arch/arm64/kvm/reset.c | 6 ++++++ include/uapi/linux/kvm.h | 2 ++ 3 files changed, 11 insertions(+) diff --git a/Documentation/virtual/kvm/api.txt b/Documentation/virtual/kvm/api.txt index aaa048d..9b56892 100644 --- a/Documentation/virtual/kvm/api.txt +++ b/Documentation/virtual/kvm/api.txt @@ -2661,8 +2661,11 @@ Possible features: Depends on KVM_CAP_ARM_PMU_V3. - KVM_ARM_VCPU_PTRAUTH_ADDRESS: Enables Address Pointer authentication for the CPU and supported only on arm64 architecture. + Depends on KVM_CAP_ARM_PTRAUTH_ADDRESS. - KVM_ARM_VCPU_PTRAUTH_GENERIC: Enables Generic Pointer authentication for the CPU and supported only on arm64 architecture. + Depends on KVM_CAP_ARM_PTRAUTH_GENERIC. + More details on Documentation/arm64/pointer-authentication.txt. 4.83 KVM_ARM_PREFERRED_TARGET diff --git a/arch/arm64/kvm/reset.c b/arch/arm64/kvm/reset.c index 717afed..8aa8982 100644 --- a/arch/arm64/kvm/reset.c +++ b/arch/arm64/kvm/reset.c @@ -92,6 +92,12 @@ int kvm_arch_vm_ioctl_check_extension(struct kvm *kvm, long ext) case KVM_CAP_ARM_VM_IPA_SIZE: r = kvm_ipa_limit; break; + case KVM_CAP_ARM_PTRAUTH_ADDRESS: + r = has_vhe() && system_supports_address_auth(); + break; + case KVM_CAP_ARM_PTRAUTH_GENERIC: + r = has_vhe() && system_supports_generic_auth(); + break; default: r = 0; } diff --git a/include/uapi/linux/kvm.h b/include/uapi/linux/kvm.h index 6d4ea4b..500ac2b 100644 --- a/include/uapi/linux/kvm.h +++ b/include/uapi/linux/kvm.h @@ -988,6 +988,8 @@ struct kvm_ppc_resize_hpt { #define KVM_CAP_ARM_VM_IPA_SIZE 165 #define KVM_CAP_MANUAL_DIRTY_LOG_PROTECT 166 #define KVM_CAP_HYPERV_CPUID 167 +#define KVM_CAP_ARM_PTRAUTH_ADDRESS 168 +#define KVM_CAP_ARM_PTRAUTH_GENERIC 169 #ifdef KVM_CAP_IRQ_ROUTING -- 2.7.4