Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2364883imu; Thu, 24 Jan 2019 11:27:40 -0800 (PST) X-Google-Smtp-Source: ALg8bN61UgkeyNqO2qb5bldJh/bsBHBMAEf9z47itN55tOIrFH4QZ5+6MNW4E9zWweIDuhmXJyuR X-Received: by 2002:a62:f54f:: with SMTP id n76mr7820589pfh.59.1548358060716; Thu, 24 Jan 2019 11:27:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548358060; cv=none; d=google.com; s=arc-20160816; b=s6OXuiLW8hmTICiC0XyJ7wQnQYN5St8g/DKLxkzOM4kAYRVZQGeMkrhPjo6TzWei6x JbOLqxbWuJb4oP9q8pD5op/nl5bOEZwR5Z5fo+QMTmPFgYqwpGeb1b8KWWyNFS3YKZyQ Qy5GOpaQf9oculKZHpenvwvcqif/bWUIZ2S2Siup2Pg5LMyv6i0wac48m4fSjt952o/C kIhw1DswZOPUqUaejeuazL4+iBdt1o0SCebYNxxX1N7+S/GOcOlLK5OAKeT6f3mHLf1v +dPCqFqdHACwM3uUNnGTyVI1EeYfv5PXlYd+Mn8HNxre+fq85idm/VRV40QdCIQCjfL4 N4Ww== 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=E3OSb8NB/2ei9D2i2++qiugKxCdM+sryOHv14GI/Qwc=; b=d+RuPE5IgA4OrkyGuj07jqEYar2nCeTpx18SBnYCDDLup4WjSQttKxBApu4pcNVzOq OiKXnEJ8kVZ2Mq6m7ZgyYR/5THcOzMLmDHFFjZw4dsCW6XNctncSpwf4e05e4d9Og4lt Q/2rNdB3Ey2BQwRt77RnR4eWGConsd09s7rFl0Kp09DZudTvW7EWRArKIddOw23pDVOP kIUTg6UZZD7kOGqTCfHWdL186hUJUc8Ad0hUefxcg/fDT1SMykrsKUNc8+r/PF9wRZs5 p1mN5/EfeLVOf5iKt4+eI5y/emqnU5uuit196C3rHJC2ddLahI2wEFxLhS70pJtrNmx5 rzfw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=i3s9Juv5; 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 v189si21947363pgb.398.2019.01.24.11.27.24; Thu, 24 Jan 2019 11:27:40 -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=i3s9Juv5; 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 S1730559AbfAXT00 (ORCPT + 99 others); Thu, 24 Jan 2019 14:26:26 -0500 Received: from mail.kernel.org ([198.145.29.99]:52440 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729813AbfAXT0Z (ORCPT ); Thu, 24 Jan 2019 14:26:25 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.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 54525217D7; Thu, 24 Jan 2019 19:26:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1548357985; bh=+7ErUhRccliF/yaFujFEtz3ZTe0c32H6mE0t7nlyD2Y=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=i3s9Juv5hzPWUlTeMA1GTi5+fKFi3hGx5VVBbRLFLOcNKcICXdEKX72R78ZU8IOMP uQv3C2uYxvK8b5qYE61bB2YtklNQt9hdq1wKP6kqAYUk0LAyHzs1cE+hfFa6ES5SZK tUr7c0LRvT/ZfnnWIpkBwySbzPSDYTOO0Wp+iJg8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Marc Zyngier , Richard Henderson , Mark Rutland , Christoffer Dall , Catalin Marinas , Will Deacon , kvmarm@lists.cs.columbia.edu, Kristina Martsenko , Sasha Levin Subject: [PATCH 4.4 040/104] arm64/kvm: consistently handle host HCR_EL2 flags Date: Thu, 24 Jan 2019 20:19:29 +0100 Message-Id: <20190124190159.774535855@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190124190154.968308875@linuxfoundation.org> References: <20190124190154.968308875@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 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ [ Backport of upstream commit 4eaed6aa2c628101246bcabc91b203bfac1193f8 ] In KVM we define the configuration of HCR_EL2 for a VHE HOST in HCR_HOST_VHE_FLAGS, but we don't have a similar definition for the non-VHE host flags, and open-code HCR_RW. Further, in head.S we open-code the flags for VHE and non-VHE configurations. In future, we're going to want to configure more flags for the host, so lets add a HCR_HOST_NVHE_FLAGS defintion, and consistently use both HCR_HOST_VHE_FLAGS and HCR_HOST_NVHE_FLAGS in the kvm code and head.S. We now use mov_q to generate the HCR_EL2 value, as we use when configuring other registers in head.S. Reviewed-by: Marc Zyngier Reviewed-by: Richard Henderson Signed-off-by: Mark Rutland Reviewed-by: Christoffer Dall Cc: Catalin Marinas Cc: Marc Zyngier Cc: Will Deacon Cc: kvmarm@lists.cs.columbia.edu Signed-off-by: Will Deacon [kristina: backport to 4.4.y: non-VHE only; __deactivate_traps_nvhe in assembly; add #include] Signed-off-by: Kristina Martsenko Signed-off-by: Sasha Levin --- arch/arm64/include/asm/kvm_arm.h | 1 + arch/arm64/kernel/head.S | 3 ++- arch/arm64/kvm/hyp.S | 2 +- 3 files changed, 4 insertions(+), 2 deletions(-) diff --git a/arch/arm64/include/asm/kvm_arm.h b/arch/arm64/include/asm/kvm_arm.h index ef8e13d379cb..013b7de45ee7 100644 --- a/arch/arm64/include/asm/kvm_arm.h +++ b/arch/arm64/include/asm/kvm_arm.h @@ -81,6 +81,7 @@ HCR_AMO | HCR_SWIO | HCR_TIDCP | HCR_RW) #define HCR_VIRT_EXCP_MASK (HCR_VA | HCR_VI | HCR_VF) #define HCR_INT_OVERRIDE (HCR_FMO | HCR_IMO) +#define HCR_HOST_NVHE_FLAGS (HCR_RW) /* Hyp System Control Register (SCTLR_EL2) bits */ diff --git a/arch/arm64/kernel/head.S b/arch/arm64/kernel/head.S index d019c3a58cc2..0382eba4bf7b 100644 --- a/arch/arm64/kernel/head.S +++ b/arch/arm64/kernel/head.S @@ -30,6 +30,7 @@ #include #include #include +#include #include #include #include @@ -464,7 +465,7 @@ CPU_LE( bic x0, x0, #(3 << 24) ) // Clear the EE and E0E bits for EL1 ret /* Hyp configuration. */ -2: mov x0, #(1 << 31) // 64-bit EL1 +2: mov_q x0, HCR_HOST_NVHE_FLAGS msr hcr_el2, x0 /* Generic timers. */ diff --git a/arch/arm64/kvm/hyp.S b/arch/arm64/kvm/hyp.S index 86c289832272..8d3da858c257 100644 --- a/arch/arm64/kvm/hyp.S +++ b/arch/arm64/kvm/hyp.S @@ -494,7 +494,7 @@ .endm .macro deactivate_traps - mov x2, #HCR_RW + mov_q x2, HCR_HOST_NVHE_FLAGS msr hcr_el2, x2 msr hstr_el2, xzr -- 2.19.1