Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 28 Jan 2013 17:25:54 +0000 (UTC)
From:      "Cherry G. Mathew" <cherry@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-projects@freebsd.org
Subject:   svn commit: r246036 - projects/amd64_xen_pv/sys/amd64/xen
Message-ID:  <201301281725.r0SHPsje053110@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: cherry
Date: Mon Jan 28 17:25:53 2013
New Revision: 246036
URL: http://svnweb.freebsd.org/changeset/base/246036

Log:
  Exception handling stack bugs:
   i) Stop overwriting the previous stackframe
   ii) Restore stack frame *after* restoring registers after alignment check
  
  Approved by: gibbs (implicit)

Modified:
  projects/amd64_xen_pv/sys/amd64/xen/exception.S

Modified: projects/amd64_xen_pv/sys/amd64/xen/exception.S
==============================================================================
--- projects/amd64_xen_pv/sys/amd64/xen/exception.S	Mon Jan 28 15:48:31 2013	(r246035)
+++ projects/amd64_xen_pv/sys/amd64/xen/exception.S	Mon Jan 28 17:25:53 2013	(r246036)
@@ -131,10 +131,10 @@
 	subq 	$TF_ERR, %rsp
 
 #define TRAP_FRAME_EXIT_NOERR \
-	addq	$TF_RIP + 8, %rsp
+	addq	$TF_RIP, %rsp
 
 #define TRAP_FRAME_EXIT_ERR \
-	addq 	$TF_ERR + 8, %rsp
+	addq 	$TF_ERR, %rsp
 
 #define TRAP_PROLOGUE(a) \
 	movl	$(a), TF_TRAPNO(%rsp) 	; \
@@ -434,9 +434,9 @@ IDTVEC(ac)			/* Alignment-Check */
 	DO_STI_MAYBE		;
 	CALLTRAP		;
 	DO_AST_MAYBE		;
-	TRAP_FRAME_EXIT_ERR   	;
 	RESTORE_GENERAL_REGS	;
 	RESTORE_SEGMENT_REGS	;
+	TRAP_FRAME_EXIT_ERR   	;
 	INTR_EXIT		;
 
 IDTVEC(mc)			/* Machine-Check */



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201301281725.r0SHPsje053110>