Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp172392ybh; Fri, 17 Jul 2020 23:39:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy83qHRx0X/r47t82ZLYbjOJNednsEXYd0rX4oIiGjmoPBmRv+7PoHz/aOhja6Uho8fe6LT X-Received: by 2002:a50:fe18:: with SMTP id f24mr12566906edt.14.1595054373886; Fri, 17 Jul 2020 23:39:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595054373; cv=none; d=google.com; s=arc-20160816; b=0dKnbUvy2+TDCmhHHKo7fjfcJoLP4PWmeZ297+l3sVfzmDoNd30U2c7C4RBEhKQTdm T60RJiXSilOHBvgn5KyUFsYn2CJfIcdqUOm5A1KmXeGA37UkdRAaDEGzBQKK72fVkXVT 9m/YK25g8uQPaotCjR+vsiDK4Y5pyxxKIctk6CKoYoHxs76LmEGgGv100FUlpjBs2/uV B8FL+eXo1yPgczjmyOgwysIQ3pABDVwKv3+AEnkBLLNFjr3mHTjJQuhsR9CfVIDuqzbE VpJ4yp3hwc85A2i1QswfcUAhkyw621VNuokr4hoI4JWd3SswsoCC/HMMIY0BxcwHLYCT 8FJg== 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 :ironport-sdr:ironport-sdr; bh=X30HcA+yLMkeNGXd6UzAXe6TDOiWKnyCWrCi67eB7is=; b=0/fgje5RzE5m1YEH/ApYNu3KvhoirCyDwZsKv4ys9ibOup92NmhUB90Tmd6OUxTvdS ffAJelHdJndObU2ZSwyTRT/cwYKwQ51qy/AtYrcA8JFw4L/7o+hYmmOZtQ6l8q/etYGv 0wGfKU+eVvw0oFBFmoYCm7eYAu9YoT6C3jAEv7DJMY6aOJ5b73VvKJ3RAjAOS2vhYo2k fjaTjxZe20Rk5y5fEPw/Pr0zrS/Rdt8smXGksnOLc5/l9InMkRN4VX+6YClUQjn7APbz LPIiHqAu72JplDOXmiXxGClZGxB+2TEGdSXB9E121jFKtQFJVm536eIcNZ4Btd6q4CEI 94Lw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l21si7178256ejg.690.2020.07.17.23.39.10; Fri, 17 Jul 2020 23:39:33 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728936AbgGRGjD (ORCPT + 99 others); Sat, 18 Jul 2020 02:39:03 -0400 Received: from mga09.intel.com ([134.134.136.24]:30319 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728506AbgGRGjB (ORCPT ); Sat, 18 Jul 2020 02:39:01 -0400 IronPort-SDR: IKeC2cswCgh59Aowcvu5Rk5czzELqeIa0DZCqmogZ5c3i5g+RWbFGM0HBNS02/+fIdrYdHBCKQ ECS4PAFSzyYw== X-IronPort-AV: E=McAfee;i="6000,8403,9685"; a="151079555" X-IronPort-AV: E=Sophos;i="5.75,366,1589266800"; d="scan'208";a="151079555" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by orsmga102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Jul 2020 23:39:00 -0700 IronPort-SDR: UzIsVVoq+ZrMut9wraWzRDxZelCQpt67gwPVdF1Rn1KSWmBr/u91AGRHNGnVwK5BPhVlz8Yh7Q EC26xKINAlRg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,366,1589266800"; d="scan'208";a="486690959" Received: from sjchrist-coffee.jf.intel.com ([10.54.74.152]) by fmsmga006.fm.intel.com with ESMTP; 17 Jul 2020 23:39:00 -0700 From: Sean Christopherson To: Paolo Bonzini Cc: Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , kvm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 3/7] KVM: VMX: Add a helper to test for a valid error code given an intr info Date: Fri, 17 Jul 2020 23:38:50 -0700 Message-Id: <20200718063854.16017-4-sean.j.christopherson@intel.com> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200718063854.16017-1-sean.j.christopherson@intel.com> References: <20200718063854.16017-1-sean.j.christopherson@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add a helper, is_exception_with_error_code(), to provide the simple but difficult to read code of checking for a valid exception with an error code given a vmcs.VM_EXIT_INTR_INFO value. The helper will gain another user, vmx_get_exit_info(), in a future patch. Signed-off-by: Sean Christopherson --- arch/x86/kvm/vmx/nested.c | 4 +--- arch/x86/kvm/vmx/vmcs.h | 7 +++++++ 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/arch/x86/kvm/vmx/nested.c b/arch/x86/kvm/vmx/nested.c index 6f81097cbc794..fc70644b916ca 100644 --- a/arch/x86/kvm/vmx/nested.c +++ b/arch/x86/kvm/vmx/nested.c @@ -5931,9 +5931,7 @@ bool nested_vmx_reflect_vmexit(struct kvm_vcpu *vcpu) * need to be synthesized by querying the in-kernel LAPIC, but external * interrupts are never reflected to L1 so it's a non-issue. */ - if ((exit_intr_info & - (INTR_INFO_VALID_MASK | INTR_INFO_DELIVER_CODE_MASK)) == - (INTR_INFO_VALID_MASK | INTR_INFO_DELIVER_CODE_MASK)) { + if (is_exception_with_error_code(exit_intr_info)) { struct vmcs12 *vmcs12 = get_vmcs12(vcpu); vmcs12->vm_exit_intr_error_code = diff --git a/arch/x86/kvm/vmx/vmcs.h b/arch/x86/kvm/vmx/vmcs.h index 7a3675fddec20..1472c6c376f74 100644 --- a/arch/x86/kvm/vmx/vmcs.h +++ b/arch/x86/kvm/vmx/vmcs.h @@ -138,6 +138,13 @@ static inline bool is_external_intr(u32 intr_info) return is_intr_type(intr_info, INTR_TYPE_EXT_INTR); } +static inline bool is_exception_with_error_code(u32 intr_info) +{ + const u32 mask = INTR_INFO_VALID_MASK | INTR_INFO_DELIVER_CODE_MASK; + + return (intr_info & mask) == mask; +} + enum vmcs_field_width { VMCS_FIELD_WIDTH_U16 = 0, VMCS_FIELD_WIDTH_U64 = 1, -- 2.26.0