]> www.infradead.org Git - users/willy/linux.git/commitdiff
x86/paravirt: Drop {read,write}_cr8() hooks
authorAndrew Cooper <andrew.cooper3@citrix.com>
Mon, 15 Jul 2019 15:16:41 +0000 (16:16 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Mon, 22 Jul 2019 08:12:33 +0000 (10:12 +0200)
There is a lot of infrastructure for functionality which is used
exclusively in __{save,restore}_processor_state() on the suspend/resume
path.

cr8 is an alias of APIC_TASKPRI, and APIC_TASKPRI is saved/restored by
lapic_{suspend,resume}().  Saving and restoring cr8 independently of the
rest of the Local APIC state isn't a clever thing to be doing.

Delete the suspend/resume cr8 handling, which shrinks the size of struct
saved_context, and allows for the removal of both PVOPS.

Signed-off-by: Andrew Cooper <andrew.cooper3@citrix.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Juergen Gross <jgross@suse.com>
Link: https://lkml.kernel.org/r/20190715151641.29210-1-andrew.cooper3@citrix.com
arch/x86/include/asm/paravirt.h
arch/x86/include/asm/paravirt_types.h
arch/x86/include/asm/special_insns.h
arch/x86/include/asm/suspend_64.h
arch/x86/kernel/asm-offsets_64.c
arch/x86/kernel/paravirt.c
arch/x86/power/cpu.c
arch/x86/xen/enlighten_pv.c

index dce26f1d13e1a5e5a63d5feb2e2f30edecef97e3..69089d46f1285565c9ff5b32dbf934b5d80e15d5 100644 (file)
@@ -139,18 +139,6 @@ static inline void __write_cr4(unsigned long x)
        PVOP_VCALL1(cpu.write_cr4, x);
 }
 
-#ifdef CONFIG_X86_64
-static inline unsigned long read_cr8(void)
-{
-       return PVOP_CALL0(unsigned long, cpu.read_cr8);
-}
-
-static inline void write_cr8(unsigned long x)
-{
-       PVOP_VCALL1(cpu.write_cr8, x);
-}
-#endif
-
 static inline void arch_safe_halt(void)
 {
        PVOP_VCALL0(irq.safe_halt);
index 639b2df445ee6caff6b980cac0e106306e3f0329..70b654f3ffe575e628820c0ec8efb49b86efaeae 100644 (file)
@@ -119,11 +119,6 @@ struct pv_cpu_ops {
 
        void (*write_cr4)(unsigned long);
 
-#ifdef CONFIG_X86_64
-       unsigned long (*read_cr8)(void);
-       void (*write_cr8)(unsigned long);
-#endif
-
        /* Segment descriptor handling */
        void (*load_tr_desc)(void);
        void (*load_gdt)(const struct desc_ptr *);
index 219be88a59d207c683e3be85ebcabcd9e8174393..6d37b8fcfc778cb52663c7a924aa4f5153b67bb3 100644 (file)
@@ -73,20 +73,6 @@ static inline unsigned long native_read_cr4(void)
 
 void native_write_cr4(unsigned long val);
 
-#ifdef CONFIG_X86_64
-static inline unsigned long native_read_cr8(void)
-{
-       unsigned long cr8;
-       asm volatile("movq %%cr8,%0" : "=r" (cr8));
-       return cr8;
-}
-
-static inline void native_write_cr8(unsigned long val)
-{
-       asm volatile("movq %0,%%cr8" :: "r" (val) : "memory");
-}
-#endif
-
 #ifdef CONFIG_X86_INTEL_MEMORY_PROTECTION_KEYS
 static inline u32 rdpkru(void)
 {
@@ -200,16 +186,6 @@ static inline void wbinvd(void)
 
 #ifdef CONFIG_X86_64
 
-static inline unsigned long read_cr8(void)
-{
-       return native_read_cr8();
-}
-
-static inline void write_cr8(unsigned long x)
-{
-       native_write_cr8(x);
-}
-
 static inline void load_gs_index(unsigned selector)
 {
        native_load_gs_index(selector);
index a7af9f53c0cb773d05fd84ebe94525a1971e3ebb..35bb35d28733e52b7fe61886558bde878fbf01d3 100644 (file)
@@ -34,7 +34,7 @@ struct saved_context {
         */
        unsigned long kernelmode_gs_base, usermode_gs_base, fs_base;
 
-       unsigned long cr0, cr2, cr3, cr4, cr8;
+       unsigned long cr0, cr2, cr3, cr4;
        u64 misc_enable;
        bool misc_enable_saved;
        struct saved_msrs saved_msrs;
index d3d075226c0aa39761e9f4a33ae05cec321d36d7..8b54d8e3a561c1e37f0a4f0d2364e22e5a1d01ee 100644 (file)
@@ -62,7 +62,6 @@ int main(void)
        ENTRY(cr2);
        ENTRY(cr3);
        ENTRY(cr4);
-       ENTRY(cr8);
        ENTRY(gdt_desc);
        BLANK();
 #undef ENTRY
index 0aa6256eedd83e15b57090e33d6b501481757efd..59d3d2763a9e6e9d0d992e8d2f70d06e6c7124ac 100644 (file)
@@ -311,10 +311,6 @@ struct paravirt_patch_template pv_ops = {
        .cpu.read_cr0           = native_read_cr0,
        .cpu.write_cr0          = native_write_cr0,
        .cpu.write_cr4          = native_write_cr4,
-#ifdef CONFIG_X86_64
-       .cpu.read_cr8           = native_read_cr8,
-       .cpu.write_cr8          = native_write_cr8,
-#endif
        .cpu.wbinvd             = native_wbinvd,
        .cpu.read_msr           = native_read_msr,
        .cpu.write_msr          = native_write_msr,
index 24b079e94bc261b6b7b27c4aadf0ff7ec5f7ccda..1c58d8982728a7ac57e9bcb6a8799edc0ccda853 100644 (file)
@@ -122,9 +122,6 @@ static void __save_processor_state(struct saved_context *ctxt)
        ctxt->cr2 = read_cr2();
        ctxt->cr3 = __read_cr3();
        ctxt->cr4 = __read_cr4();
-#ifdef CONFIG_X86_64
-       ctxt->cr8 = read_cr8();
-#endif
        ctxt->misc_enable_saved = !rdmsrl_safe(MSR_IA32_MISC_ENABLE,
                                               &ctxt->misc_enable);
        msr_save_context(ctxt);
@@ -207,7 +204,6 @@ static void notrace __restore_processor_state(struct saved_context *ctxt)
 #else
 /* CONFIG X86_64 */
        wrmsrl(MSR_EFER, ctxt->efer);
-       write_cr8(ctxt->cr8);
        __write_cr4(ctxt->cr4);
 #endif
        write_cr3(ctxt->cr3);
index 7ceb32821093a226995a86e9832c59b9b9d586ae..58f79ab32358429ea4f948ccccbdfe86e9e294e3 100644 (file)
@@ -877,16 +877,6 @@ static void xen_write_cr4(unsigned long cr4)
 
        native_write_cr4(cr4);
 }
-#ifdef CONFIG_X86_64
-static inline unsigned long xen_read_cr8(void)
-{
-       return 0;
-}
-static inline void xen_write_cr8(unsigned long val)
-{
-       BUG_ON(val);
-}
-#endif
 
 static u64 xen_read_msr_safe(unsigned int msr, int *err)
 {
@@ -1023,11 +1013,6 @@ static const struct pv_cpu_ops xen_cpu_ops __initconst = {
 
        .write_cr4 = xen_write_cr4,
 
-#ifdef CONFIG_X86_64
-       .read_cr8 = xen_read_cr8,
-       .write_cr8 = xen_write_cr8,
-#endif
-
        .wbinvd = native_wbinvd,
 
        .read_msr = xen_read_msr,