[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH 02/12] early PV on HVM
On Fri, 4 Jun 2010, Konrad Rzeszutek Wilk wrote: > On Thu, Jun 03, 2010 at 02:10:35PM +0100, stefano.stabellini@xxxxxxxxxxxxx > wrote: > > From: Sheng Yang <sheng@xxxxxxxxxxxxxxx> > > > > Initialize basic pv on hvm features in xen_guest_init. > > > > The hook in arch/x86/kernel/setup.c can easily be removed using the new > > generic hypervisor independent initialization infrastructure present in > > the linux-2.6-tip tree. > > > > Signed-off-by: Stefano Stabellini <stefano.stabellini@xxxxxxxxxxxxx> > > Signed-off-by: Sheng Yang <sheng@xxxxxxxxxxxxxxx> > > Signed-off-by: Yaozu (Eddie) Dong <eddie.dong@xxxxxxxxx> > > --- > > arch/x86/kernel/setup.c | 2 + > > arch/x86/xen/enlighten.c | 86 > > +++++++++++++++++++++++++++++++++++++ > > drivers/input/xen-kbdfront.c | 2 +- > > drivers/video/xen-fbfront.c | 2 +- > > drivers/xen/xenbus/xenbus_probe.c | 21 ++++++++- > > include/xen/xen.h | 2 + > > 6 files changed, 110 insertions(+), 5 deletions(-) > > > > diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c > > index c4851ef..ae9b6cb 100644 > > --- a/arch/x86/kernel/setup.c > > +++ b/arch/x86/kernel/setup.c > > @@ -69,6 +69,7 @@ > > #include <linux/tboot.h> > > > > #include <video/edid.h> > > +#include <xen/xen.h> > > > > #include <asm/mtrr.h> > > #include <asm/apic.h> > > @@ -1032,6 +1033,7 @@ void __init setup_arch(char **cmdline_p) > > probe_nr_irqs_gsi(); > > > > kvm_guest_init(); > > + xen_guest_init(); > > > > e820_reserve_resources(); > > e820_mark_nosave_regions(max_low_pfn); > > diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c > > index 65d8d79..c1f6545 100644 > > --- a/arch/x86/xen/enlighten.c > > +++ b/arch/x86/xen/enlighten.c > > @@ -35,6 +35,7 @@ > > #include <xen/interface/version.h> > > #include <xen/interface/physdev.h> > > #include <xen/interface/vcpu.h> > > +#include <xen/interface/memory.h> > > #include <xen/features.h> > > #include <xen/page.h> > > #include <xen/hvc-console.h> > > @@ -56,6 +57,7 @@ > > #include <asm/tlbflush.h> > > #include <asm/reboot.h> > > #include <asm/stackprotector.h> > > +#include <asm/hypervisor.h> > > > > #include "xen-ops.h" > > #include "mmu.h" > > @@ -1206,3 +1208,87 @@ asmlinkage void __init xen_start_kernel(void) > > x86_64_start_reservations((char *)__pa_symbol(&boot_params)); > > #endif > > } > > + > > +static uint32_t xen_cpuid_base(void) > > +{ > > + uint32_t base, eax, ebx, ecx, edx; > > + char signature[13]; > > + > > + for (base = 0x40000000; base < 0x40010000; base += 0x100) { > > + cpuid(base, &eax, &ebx, &ecx, &edx); > > + *(uint32_t*)(signature + 0) = ebx; > > + *(uint32_t*)(signature + 4) = ecx; > > + *(uint32_t*)(signature + 8) = edx; > > + signature[12] = 0; > > + > > + if (!strcmp("XenVMMXenVMM", signature) && ((eax - base) >= 2)) > > + return base; > > + } > > + > > + return 0; > > +} > > + > > +static int init_hvm_pv_info(int *major, int *minor) > > +{ > > + uint32_t eax, ebx, ecx, edx, pages, msr, base; > > + u64 pfn; > > + > > + base = xen_cpuid_base(); > > + if (!base) > > + return -EINVAL; > > + > > + cpuid(base + 1, &eax, &ebx, &ecx, &edx); > > + > > + *major = eax >> 16; > > + *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)); > > + > > + xen_setup_features(); > > + > > + pv_info = xen_info; > > + pv_info.kernel_rpl = 0; > > + > > + xen_domain_type = XEN_HVM_DOMAIN; > > + > > + return 0; > > +} > > + > > +static void __init init_shared_info(void) > > +{ > > + struct xen_add_to_physmap xatp; > > + struct shared_info *shared_info_page; > > + > > + shared_info_page = (struct shared_info *) > > alloc_bootmem_pages(PAGE_SIZE); > > + xatp.domid = DOMID_SELF; > > + xatp.idx = 0; > > + xatp.space = XENMAPSPACE_shared_info; > > + xatp.gpfn = __pa(shared_info_page) >> PAGE_SHIFT; > > + if (HYPERVISOR_memory_op(XENMEM_add_to_physmap, &xatp)) > > + BUG(); > > + > > + HYPERVISOR_shared_info = (struct shared_info *)shared_info_page; > > + > > + /* Don't do the full vcpu_info placement stuff until we have a > > + possible map and a non-dummy shared_info. */ > > Might want to mention where the full vpcu placement is done. The comment is not accurate, we actually don't do any vcpu_info placement on hvm because it is not very useful there. Better just to remove the comment (I have done so in my tree). > > + per_cpu(xen_vcpu, 0) = &HYPERVISOR_shared_info->vcpu_info[0]; > > Otherwise looks good to me. In other words, Reviewed-by: Konrad > Rzeszutek Wilk <konrad.wilk@xxxxxxxxxx> > thanks! _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |