aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/xen/enlighten.c
diff options
context:
space:
mode:
authorLuis R. Rodriguez <mcgrof@kernel.org>2016-04-13 20:04:34 -0400
committerIngo Molnar <mingo@kernel.org>2016-04-22 04:29:01 -0400
commit8d152e7a5c7537b18b4e9e0eb96f549b016636dc (patch)
treede956f52ec790f8ff066dc78c192e3dd8da70a3b /arch/x86/xen/enlighten.c
parent907bb655797427cc6498045d6977e77f8363fff7 (diff)
x86/rtc: Replace paravirt rtc check with platform legacy quirk
We have 4 types of x86 platforms that disable RTC: * Intel MID * Lguest - uses paravirt * Xen dom-U - uses paravirt * x86 on legacy systems annotated with an ACPI legacy flag We can consolidate all of these into a platform specific legacy quirk set early in boot through i386_start_kernel() and through x86_64_start_reservations(). This deals with the RTC quirks which we can rely on through the hardware subarch, the ACPI check can be dealt with separately. For Xen things are bit more complex given that the @X86_SUBARCH_XEN x86_hardware_subarch is shared on for Xen which uses the PV path for both domU and dom0. Since the semantics for differentiating between the two are Xen specific we provide a platform helper to help override default legacy features -- x86_platform.set_legacy_features(). Use of this helper is highly discouraged, its only purpose should be to account for the lack of semantics available within your given x86_hardware_subarch. As per 0-day, this bumps the vmlinux size using i386-tinyconfig as follows: TOTAL TEXT init.text x86_early_init_platform_quirks() +70 +62 +62 +43 Only 8 bytes overhead total, as the main increase in size is all removed via __init. Suggested-by: Ingo Molnar <mingo@kernel.org> Signed-off-by: Luis R. Rodriguez <mcgrof@kernel.org> Reviewed-by: Juergen Gross <jgross@suse.com> Cc: Andy Lutomirski <luto@amacapital.net> Cc: Borislav Petkov <bp@alien8.de> Cc: Brian Gerst <brgerst@gmail.com> Cc: Denys Vlasenko <dvlasenk@redhat.com> Cc: H. Peter Anvin <hpa@zytor.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: andrew.cooper3@citrix.com Cc: andriy.shevchenko@linux.intel.com Cc: bigeasy@linutronix.de Cc: boris.ostrovsky@oracle.com Cc: david.vrabel@citrix.com Cc: ffainelli@freebox.fr Cc: george.dunlap@citrix.com Cc: glin@suse.com Cc: jlee@suse.com Cc: josh@joshtriplett.org Cc: julien.grall@linaro.org Cc: konrad.wilk@oracle.com Cc: kozerkov@parallels.com Cc: lenb@kernel.org Cc: lguest@lists.ozlabs.org Cc: linux-acpi@vger.kernel.org Cc: lv.zheng@intel.com Cc: matt@codeblueprint.co.uk Cc: mbizon@freebox.fr Cc: rjw@rjwysocki.net Cc: robert.moore@intel.com Cc: rusty@rustcorp.com.au Cc: tiwai@suse.de Cc: toshi.kani@hp.com Cc: xen-devel@lists.xensource.com Link: http://lkml.kernel.org/r/1460592286-300-5-git-send-email-mcgrof@kernel.org Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'arch/x86/xen/enlighten.c')
-rw-r--r--arch/x86/xen/enlighten.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c
index 61f4d9f67f60..752029d571bf 100644
--- a/arch/x86/xen/enlighten.c
+++ b/arch/x86/xen/enlighten.c
@@ -1193,7 +1193,6 @@ static const struct pv_info xen_info __initconst = {
1193#ifdef CONFIG_X86_64 1193#ifdef CONFIG_X86_64
1194 .extra_user_64bit_cs = FLAT_USER_CS64, 1194 .extra_user_64bit_cs = FLAT_USER_CS64,
1195#endif 1195#endif
1196 .features = 0,
1197 .name = "Xen", 1196 .name = "Xen",
1198}; 1197};
1199 1198
@@ -1506,6 +1505,11 @@ static void __init xen_pvh_early_guest_init(void)
1506} 1505}
1507#endif /* CONFIG_XEN_PVH */ 1506#endif /* CONFIG_XEN_PVH */
1508 1507
1508static void __init xen_dom0_set_legacy_features(void)
1509{
1510 x86_platform.legacy.rtc = 1;
1511}
1512
1509/* First C function to be called on Xen boot */ 1513/* First C function to be called on Xen boot */
1510asmlinkage __visible void __init xen_start_kernel(void) 1514asmlinkage __visible void __init xen_start_kernel(void)
1511{ 1515{
@@ -1527,8 +1531,6 @@ asmlinkage __visible void __init xen_start_kernel(void)
1527 1531
1528 /* Install Xen paravirt ops */ 1532 /* Install Xen paravirt ops */
1529 pv_info = xen_info; 1533 pv_info = xen_info;
1530 if (xen_initial_domain())
1531 pv_info.features |= PV_SUPPORTED_RTC;
1532 pv_init_ops = xen_init_ops; 1534 pv_init_ops = xen_init_ops;
1533 if (!xen_pvh_domain()) { 1535 if (!xen_pvh_domain()) {
1534 pv_cpu_ops = xen_cpu_ops; 1536 pv_cpu_ops = xen_cpu_ops;
@@ -1688,6 +1690,8 @@ asmlinkage __visible void __init xen_start_kernel(void)
1688 .u.firmware_info.type = XEN_FW_KBD_SHIFT_FLAGS, 1690 .u.firmware_info.type = XEN_FW_KBD_SHIFT_FLAGS,
1689 }; 1691 };
1690 1692
1693 x86_platform.set_legacy_features =
1694 xen_dom0_set_legacy_features;
1691 xen_init_vga(info, xen_start_info->console.dom0.info_size); 1695 xen_init_vga(info, xen_start_info->console.dom0.info_size);
1692 xen_start_info->console.domU.mfn = 0; 1696 xen_start_info->console.domU.mfn = 0;
1693 xen_start_info->console.domU.evtchn = 0; 1697 xen_start_info->console.domU.evtchn = 0;