/* #DF */
 DECLARE_IDTENTRY_DF(X86_TRAP_DF,       exc_double_fault);
+#ifdef CONFIG_XEN_PV
+DECLARE_IDTENTRY_RAW_ERRORCODE(X86_TRAP_DF,    xenpv_exc_double_fault);
+#endif
 
 /* #VC */
 #ifdef CONFIG_AMD_MEM_ENCRYPT
 
 
 DEFINE_IDTENTRY_RAW(xenpv_exc_nmi)
 {
-       /* On Xen PV, NMI doesn't use IST.  The C part is the sane as native. */
+       /* On Xen PV, NMI doesn't use IST.  The C part is the same as native. */
        exc_nmi(regs);
 }
 
+DEFINE_IDTENTRY_RAW_ERRORCODE(xenpv_exc_double_fault)
+{
+       /* On Xen PV, DF doesn't use IST.  The C part is the same as native. */
+       exc_double_fault(regs, error_code);
+}
+
 DEFINE_IDTENTRY_RAW(xenpv_exc_debug)
 {
        /*
 
 static struct trap_array_entry trap_array[] = {
        TRAP_ENTRY_REDIR(exc_debug,                     true  ),
-       TRAP_ENTRY(exc_double_fault,                    true  ),
+       TRAP_ENTRY_REDIR(exc_double_fault,              true  ),
 #ifdef CONFIG_X86_MCE
        TRAP_ENTRY_REDIR(exc_machine_check,             true  ),
 #endif
 
 xen_pv_trap asm_exc_bounds
 xen_pv_trap asm_exc_invalid_op
 xen_pv_trap asm_exc_device_not_available
-xen_pv_trap asm_exc_double_fault
+xen_pv_trap asm_xenpv_exc_double_fault
 xen_pv_trap asm_exc_coproc_segment_overrun
 xen_pv_trap asm_exc_invalid_tss
 xen_pv_trap asm_exc_segment_not_present