diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-01-10 11:48:29 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-01-10 11:48:29 -0500 |
commit | 8c8ae4e8cd5a67467192f3361eeec463694f8ed8 (patch) | |
tree | c4216f3f8cb89dd6a12e727d886abc0f6ab74c83 /arch/x86/xen/enlighten.c | |
parent | a1e8fad5900fa94adb500c6e0dfd60a307f7a3c9 (diff) | |
parent | d9b8ca8474fd4fdd43ba6d97a4fee8b49b978067 (diff) |
Merge branch 'stable/generic' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen
* 'stable/generic' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen:
xen: HVM X2APIC support
apic: Move hypervisor detection of x2apic to hypervisor.h
Diffstat (limited to 'arch/x86/xen/enlighten.c')
-rw-r--r-- | arch/x86/xen/enlighten.c | 31 |
1 files changed, 12 insertions, 19 deletions
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index aa8c89ae54cf..6aba2a23e2c3 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c | |||
@@ -1256,25 +1256,6 @@ asmlinkage void __init xen_start_kernel(void) | |||
1256 | #endif | 1256 | #endif |
1257 | } | 1257 | } |
1258 | 1258 | ||
1259 | static uint32_t xen_cpuid_base(void) | ||
1260 | { | ||
1261 | uint32_t base, eax, ebx, ecx, edx; | ||
1262 | char signature[13]; | ||
1263 | |||
1264 | for (base = 0x40000000; base < 0x40010000; base += 0x100) { | ||
1265 | cpuid(base, &eax, &ebx, &ecx, &edx); | ||
1266 | *(uint32_t *)(signature + 0) = ebx; | ||
1267 | *(uint32_t *)(signature + 4) = ecx; | ||
1268 | *(uint32_t *)(signature + 8) = edx; | ||
1269 | signature[12] = 0; | ||
1270 | |||
1271 | if (!strcmp("XenVMMXenVMM", signature) && ((eax - base) >= 2)) | ||
1272 | return base; | ||
1273 | } | ||
1274 | |||
1275 | return 0; | ||
1276 | } | ||
1277 | |||
1278 | static int init_hvm_pv_info(int *major, int *minor) | 1259 | static int init_hvm_pv_info(int *major, int *minor) |
1279 | { | 1260 | { |
1280 | uint32_t eax, ebx, ecx, edx, pages, msr, base; | 1261 | uint32_t eax, ebx, ecx, edx, pages, msr, base; |
@@ -1384,6 +1365,18 @@ static bool __init xen_hvm_platform(void) | |||
1384 | return true; | 1365 | return true; |
1385 | } | 1366 | } |
1386 | 1367 | ||
1368 | bool xen_hvm_need_lapic(void) | ||
1369 | { | ||
1370 | if (xen_pv_domain()) | ||
1371 | return false; | ||
1372 | if (!xen_hvm_domain()) | ||
1373 | return false; | ||
1374 | if (xen_feature(XENFEAT_hvm_pirqs) && xen_have_vector_callback) | ||
1375 | return false; | ||
1376 | return true; | ||
1377 | } | ||
1378 | EXPORT_SYMBOL_GPL(xen_hvm_need_lapic); | ||
1379 | |||
1387 | const __refconst struct hypervisor_x86 x86_hyper_xen_hvm = { | 1380 | const __refconst struct hypervisor_x86 x86_hyper_xen_hvm = { |
1388 | .name = "Xen HVM", | 1381 | .name = "Xen HVM", |
1389 | .detect = xen_hvm_platform, | 1382 | .detect = xen_hvm_platform, |