From mboxrd@z Thu Jan 1 00:00:00 1970 From: Boris Ostrovsky Subject: [PATCH v2 03/11] xen/hvmlite: Initialize HVMlite kernel Date: Mon, 1 Feb 2016 10:38:49 -0500 Message-ID: <1454341137-14110-4-git-send-email-boris.ostrovsky@oracle.com> References: <1454341137-14110-1-git-send-email-boris.ostrovsky@oracle.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: Received: from mail6.bemta14.messagelabs.com ([193.109.254.103]) by lists.xen.org with esmtp (Exim 4.72) (envelope-from ) id 1aQGa9-0003B9-Pn for xen-devel@lists.xenproject.org; Mon, 01 Feb 2016 15:40:01 +0000 In-Reply-To: <1454341137-14110-1-git-send-email-boris.ostrovsky@oracle.com> List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Sender: xen-devel-bounces@lists.xen.org Errors-To: xen-devel-bounces@lists.xen.org To: david.vrabel@citrix.com, konrad.wilk@oracle.com Cc: Boris Ostrovsky , xen-devel@lists.xenproject.org, mcgrof@suse.com, linux-kernel@vger.kernel.org, roger.pau@citrix.com List-Id: xen-devel@lists.xenproject.org HVMlite guests need to make a few additional initialization calls compared to regular HVM guests. Signed-off-by: Boris Ostrovsky --- arch/x86/xen/enlighten.c | 18 ++++++++++++------ 1 files changed, 12 insertions(+), 6 deletions(-) diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index 5f05fa2..1409de6 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c @@ -1863,15 +1863,21 @@ static void __init init_hvm_pv_info(void) minor = eax & 0xffff; printk(KERN_INFO "Xen version %d.%d.\n", major, minor); - cpuid(base + 2, &pages, &msr, &ecx, &edx); - - pfn = __pa(hypercall_page); - wrmsr_safe(msr, (u32)pfn, (u32)(pfn >> 32)); + /* HVMlite set up hypercall page earlier in xen_prepare_hvmlite() */ + if (xen_hvmlite) { + pv_info.name = "Xen HVMlite"; + pv_info.paravirt_enabled = 1; + xen_init_apic(); + machine_ops = xen_machine_ops; + } else { + pv_info.name = "Xen HVM"; + cpuid(base + 2, &pages, &msr, &ecx, &edx); + pfn = __pa(hypercall_page); + wrmsr_safe(msr, (u32)pfn, (u32)(pfn >> 32)); + } xen_setup_features(); - pv_info.name = "Xen HVM"; - xen_domain_type = XEN_HVM_DOMAIN; } -- 1.7.1