void hv_ghcb_msr_write(u64 msr, u64 value);
  void hv_ghcb_msr_read(u64 msr, u64 *value);
  bool hv_ghcb_negotiate_protocol(void);
- void hv_ghcb_terminate(unsigned int set, unsigned int reason);
+ void __noreturn hv_ghcb_terminate(unsigned int set, unsigned int reason);
 +void hv_vtom_init(void);
  #else
  static inline void hv_ghcb_msr_write(u64 msr, u64 value) {}
  static inline void hv_ghcb_msr_read(u64 msr, u64 *value) {}
 
        ANNOTATE_RETPOLINE_SAFE
        jmp     *%rax
  1:
-       UNWIND_HINT_EMPTY
+       UNWIND_HINT_END_OF_STACK
        ANNOTATE_NOENDBR // above
  
 +#ifdef CONFIG_SMP
 +      movl    smpboot_control(%rip), %ecx
 +
 +      /* Get the per cpu offset for the given CPU# which is in ECX */
 +      movq    __per_cpu_offset(,%rcx,8), %rdx
 +#else
 +      xorl    %edx, %edx /* zero-extended to clear all of RDX */
 +#endif /* CONFIG_SMP */
 +
 +      /*
 +       * Setup a boot time stack - Any secondary CPU will have lost its stack
 +       * by now because the cr3-switch above unmaps the real-mode stack.
 +       *
 +       * RDX contains the per-cpu offset
 +       */
 +      movq    pcpu_hot + X86_current_task(%rdx), %rax
 +      movq    TASK_threadsp(%rax), %rsp
 +
        /*
         * We must switch to a new descriptor in kernel space for the GDT
         * because soon the kernel won't have access anymore to the userspace
   */
  SYM_CODE_START(start_cpu0)
        ANNOTATE_NOENDBR
-       UNWIND_HINT_EMPTY
+       UNWIND_HINT_END_OF_STACK
 -      movq    initial_stack(%rip), %rsp
 +
 +      /* Find the idle task stack */
 +      movq    PER_CPU_VAR(pcpu_hot) + X86_current_task, %rcx
 +      movq    TASK_threadsp(%rcx), %rsp
 +
        jmp     .Ljump_to_C_code
  SYM_CODE_END(start_cpu0)
  #endif
 
  static inline int exception_enter(void) { return 0; }
  static inline void exception_exit(enum ctx_state prev_ctx) { }
  static inline int ct_state(void) { return -1; }
 +static inline int __ct_state(void) { return -1; }
  static __always_inline bool context_tracking_guest_enter(void) { return false; }
- static inline void context_tracking_guest_exit(void) { }
+ static __always_inline void context_tracking_guest_exit(void) { }
  #define CT_WARN_ON(cond) do { } while (0)
  #endif /* !CONFIG_CONTEXT_TRACKING_USER */