mm: fix exec activate_mm vs TLB shootdown and lazy tlb switching race
[linux/fpc-iii.git] / arch / x86 / xen / suspend_pv.c
bloba2e0f110af56ddac120b382691dcf61e70e3db14
1 // SPDX-License-Identifier: GPL-2.0
2 #include <linux/types.h>
4 #include <asm/fixmap.h>
6 #include <asm/xen/hypercall.h>
7 #include <asm/xen/page.h>
9 #include "xen-ops.h"
11 void xen_pv_pre_suspend(void)
13 xen_mm_pin_all();
15 xen_start_info->store_mfn = mfn_to_pfn(xen_start_info->store_mfn);
16 xen_start_info->console.domU.mfn =
17 mfn_to_pfn(xen_start_info->console.domU.mfn);
19 BUG_ON(!irqs_disabled());
21 HYPERVISOR_shared_info = &xen_dummy_shared_info;
22 if (HYPERVISOR_update_va_mapping(fix_to_virt(FIX_PARAVIRT_BOOTMAP),
23 __pte_ma(0), 0))
24 BUG();
27 void xen_pv_post_suspend(int suspend_cancelled)
29 xen_build_mfn_list_list();
31 xen_setup_shared_info();
33 if (suspend_cancelled) {
34 xen_start_info->store_mfn =
35 pfn_to_mfn(xen_start_info->store_mfn);
36 xen_start_info->console.domU.mfn =
37 pfn_to_mfn(xen_start_info->console.domU.mfn);
38 } else {
39 #ifdef CONFIG_SMP
40 BUG_ON(xen_cpu_initialized_map == NULL);
41 cpumask_copy(xen_cpu_initialized_map, cpu_online_mask);
42 #endif
43 xen_vcpu_restore();
46 xen_mm_unpin_all();