* [uml-devel] [PATCH] Early x86_64 crash
@ 2005-09-29 16:16 Jeff Dike
2005-09-30 14:41 ` Blaisorblade
0 siblings, 1 reply; 4+ messages in thread
From: Jeff Dike @ 2005-09-29 16:16 UTC (permalink / raw)
To: user-mode-linux-devel
If you are running UML/x86_64 and are seeing it crash before starting init,
I'd like you to do the following:
- make sure that you have CONFIG_FRAME_POINTER disabled
- enable it and see that UML boots
- apply the patch below, disable CONFIG_FRAME_POINTER again, and
see if UML still boots
- report results back to me
Jeff
Index: test/arch/um/sys-x86_64/stub_segv.c
===================================================================
--- test.orig/arch/um/sys-x86_64/stub_segv.c 2005-09-29 12:19:07.000000000 -0400
+++ test/arch/um/sys-x86_64/stub_segv.c 2005-09-29 12:21:03.000000000 -0400
@@ -11,6 +11,16 @@
#include "sysdep/sigcontext.h"
#include "sysdep/faultinfo.h"
+/* Copied from sys-x86_64/signal.c - Can't find an equivalent definition
+ * in the libc headers anywhere.
+ */
+struct rt_sigframe
+{
+ char *pretcode;
+ struct ucontext uc;
+ struct siginfo info;
+};
+
void __attribute__ ((__section__ (".__syscall_stub")))
stub_segv_handler(int sig)
{
@@ -22,11 +32,14 @@
__asm__("movq %0, %%rax ; syscall": : "g" (__NR_getpid));
__asm__("movq %%rax, %%rdi ; movq %0, %%rax ; movq %1, %%rsi ;"
- "syscall": : "g" (__NR_kill), "g" (SIGUSR1));
- /* Two popqs to restore the stack to the state just before entering
- * the handler, one pops the return address, the other pops the frame
- * pointer.
+ "syscall": : "g" (__NR_kill), "g" (SIGUSR1) :
+ "%rdi", "%rax", "%rsi");
+ /* sys_sigreturn expects that the stack pointer will be 8 bytes into
+ * the signal frame. So, we use the ucontext pointer, which we know
+ * already, to get the signal frame pointer, and add 8 to that.
*/
- __asm__("popq %%rax ; popq %%rax ; movq %0, %%rax ; syscall" : : "g"
- (__NR_rt_sigreturn));
+ __asm__("movq %0, %%rsp": :
+ "g" ((unsigned long) container_of(uc, struct rt_sigframe,
+ uc) + 8));
+ __asm__("movq %0, %%rax ; syscall" : : "g" (__NR_rt_sigreturn));
}
-------------------------------------------------------
This SF.Net email is sponsored by:
Power Architecture Resource Center: Free content, downloads, discussions,
and more. http://solutions.newsforge.com/ibmarch.tmpl
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [uml-devel] [PATCH] Early x86_64 crash
2005-09-29 16:16 [uml-devel] [PATCH] Early x86_64 crash Jeff Dike
@ 2005-09-30 14:41 ` Blaisorblade
2005-10-02 2:35 ` Jeff Dike
0 siblings, 1 reply; 4+ messages in thread
From: Blaisorblade @ 2005-09-30 14:41 UTC (permalink / raw)
To: user-mode-linux-devel; +Cc: Jeff Dike
[-- Attachment #1: Type: text/plain, Size: 2076 bytes --]
On Thursday 29 September 2005 18:16, Jeff Dike wrote:
> If you are running UML/x86_64 and are seeing it crash before starting init,
> I'd like you to do the following:
I assume you've been able to reproduce this crash and see this patch fix it,
right?
I'm going to take it for -bs3, meanwhile, as soon as you answer on the
attachment (I'd like it at least to compile).
> - make sure that you have CONFIG_FRAME_POINTER disabled
> - enable it and see that UML boots
> - apply the patch below, disable CONFIG_FRAME_POINTER again, and
> see if UML still boots
> - report results back to me
> Jeff
> @@ -22,11 +32,14 @@
>
> __asm__("movq %0, %%rax ; syscall": : "g" (__NR_getpid));
Why there's no "%rax" in the register clobber list, here and at the end?
> __asm__("movq %%rax, %%rdi ; movq %0, %%rax ; movq %1, %%rsi ;"
> - "syscall": : "g" (__NR_kill), "g" (SIGUSR1));
> - /* Two popqs to restore the stack to the state just before entering
> - * the handler, one pops the return address, the other pops the frame
> - * pointer.
> + "syscall": : "g" (__NR_kill), "g" (SIGUSR1) :
> + "%rdi", "%rax", "%rsi");
Here you're correctly informing GCC that your asm uses these regs.
> + /* sys_sigreturn expects that the stack pointer will be 8 bytes into
> + * the signal frame. So, we use the ucontext pointer, which we know
> + * already, to get the signal frame pointer, and add 8 to that.
> */
> - __asm__("popq %%rax ; popq %%rax ; movq %0, %%rax ; syscall" : : "g"
> - (__NR_rt_sigreturn));
> + __asm__("movq %0, %%rsp": :
> + "g" ((unsigned long) container_of(uc, struct rt_sigframe,
> + uc) + 8));
> + __asm__("movq %0, %%rax ; syscall" : : "g" (__NR_rt_sigreturn));
> }
I've attached the addon with additional clobber, and with fixed tabs (i.e.
hardtabs). Not compiled it (no time to reboot right now).
--
Inform me of my mistakes, so I can keep imitating Homer Simpson's "Doh!".
Paolo Giarrusso, aka Blaisorblade (Skype ID "PaoloGiarrusso", ICQ 215621894)
http://www.user-mode-linux.org/~blaisorblade
[-- Attachment #2: uml-early-x86-64-crash-fix --]
[-- Type: text/x-diff, Size: 1408 bytes --]
Index: linux-2.6.13/arch/um/sys-x86_64/stub_segv.c
===================================================================
--- linux-2.6.13.orig/arch/um/sys-x86_64/stub_segv.c
+++ linux-2.6.13/arch/um/sys-x86_64/stub_segv.c
@@ -25,20 +25,20 @@ stub_segv_handler(int sig)
{
struct ucontext *uc;
- __asm__("movq %%rdx, %0" : "=g" (uc) :);
+ __asm__("movq %%rdx, %0" : "=g" (uc) : );
GET_FAULTINFO_FROM_SC(*((struct faultinfo *) UML_CONFIG_STUB_DATA),
&uc->uc_mcontext);
- __asm__("movq %0, %%rax ; syscall": : "g" (__NR_getpid));
+ __asm__("movq %0, %%rax ; syscall": : "g" (__NR_getpid) : "%rax");
__asm__("movq %%rax, %%rdi ; movq %0, %%rax ; movq %1, %%rsi ;"
"syscall": : "g" (__NR_kill), "g" (SIGUSR1) :
- "%rdi", "%rax", "%rsi");
+ "%rdi", "%rax", "%rsi");
/* sys_sigreturn expects that the stack pointer will be 8 bytes into
* the signal frame. So, we use the ucontext pointer, which we know
* already, to get the signal frame pointer, and add 8 to that.
*/
- __asm__("movq %0, %%rsp": :
- "g" ((unsigned long) container_of(uc, struct rt_sigframe,
+ __asm__("movq %0, %%rsp": :
+ "g" ((unsigned long) container_of(uc, struct rt_sigframe,
uc) + 8));
- __asm__("movq %0, %%rax ; syscall" : : "g" (__NR_rt_sigreturn));
+ __asm__("movq %0, %%rax ; syscall" : : "g" (__NR_rt_sigreturn) : "%rax");
}
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [uml-devel] [PATCH] Early x86_64 crash
2005-09-30 14:41 ` Blaisorblade
@ 2005-10-02 2:35 ` Jeff Dike
2005-10-02 15:23 ` Blaisorblade
0 siblings, 1 reply; 4+ messages in thread
From: Jeff Dike @ 2005-10-02 2:35 UTC (permalink / raw)
To: Blaisorblade; +Cc: user-mode-linux-devel
On Fri, Sep 30, 2005 at 04:41:58PM +0200, Blaisorblade wrote:
> I assume you've been able to reproduce this crash and see this patch fix it,
> right?
Yup.
> I've attached the addon with additional clobber, and with fixed tabs (i.e.
> hardtabs). Not compiled it (no time to reboot right now).
Yeah, I'll fix the spacing in my copy.
Jeff
-------------------------------------------------------
This SF.Net email is sponsored by:
Power Architecture Resource Center: Free content, downloads, discussions,
and more. http://solutions.newsforge.com/ibmarch.tmpl
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [uml-devel] [PATCH] Early x86_64 crash
2005-10-02 2:35 ` Jeff Dike
@ 2005-10-02 15:23 ` Blaisorblade
0 siblings, 0 replies; 4+ messages in thread
From: Blaisorblade @ 2005-10-02 15:23 UTC (permalink / raw)
To: Jeff Dike; +Cc: user-mode-linux-devel
On Sunday 02 October 2005 04:35, Jeff Dike wrote:
> On Fri, Sep 30, 2005 at 04:41:58PM +0200, Blaisorblade wrote:
> > I assume you've been able to reproduce this crash and see this patch fix
> > it, right?
> Yup.
> > I've attached the addon with additional clobber, and with fixed tabs
> > (i.e. hardtabs). Not compiled it (no time to reboot right now).
> Yeah, I'll fix the spacing in my copy.
I'm assuming the additional clobbers are ok, and queuing the whole in -bs3.
--
Inform me of my mistakes, so I can keep imitating Homer Simpson's "Doh!".
Paolo Giarrusso, aka Blaisorblade (Skype ID "PaoloGiarrusso", ICQ 215621894)
http://www.user-mode-linux.org/~blaisorblade
___________________________________
Yahoo! Messenger: chiamate gratuite in tutto il mondo
http://it.messenger.yahoo.com
-------------------------------------------------------
This SF.Net email is sponsored by:
Power Architecture Resource Center: Free content, downloads, discussions,
and more. http://solutions.newsforge.com/ibmarch.tmpl
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2005-10-02 17:30 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-09-29 16:16 [uml-devel] [PATCH] Early x86_64 crash Jeff Dike
2005-09-30 14:41 ` Blaisorblade
2005-10-02 2:35 ` Jeff Dike
2005-10-02 15:23 ` Blaisorblade
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.