diff options
author | Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> | 2005-11-07 00:58:46 -0800 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-11-07 07:53:30 -0800 |
commit | 4f0272415ad1867cea2a7ef5659769243ae50fbe (patch) | |
tree | 5daba11ac90defc604399aa7ff41fa11b8cd088a /arch/um/drivers/net_kern.c | |
parent | 953206858070e5921b9d5931c293ec983a6790cb (diff) | |
download | kernel_samsung_tuna-4f0272415ad1867cea2a7ef5659769243ae50fbe.zip kernel_samsung_tuna-4f0272415ad1867cea2a7ef5659769243ae50fbe.tar.gz kernel_samsung_tuna-4f0272415ad1867cea2a7ef5659769243ae50fbe.tar.bz2 |
[PATCH] uml: fix syscall stubs
Jeff Dike noted that the assembly code for syscall stubs is misassembled with
GCC 3.2.3: the values copied in registers weren't preserved between one asm()
and the following one.
So I fixed the thing by rewriting the __asm__ constraints more like unistd.h
ones.
Note: in syscall6 case I had to add one more instruction (i.e. moving arg6 in
eax and shuffling things around) - it's needed for the function to be valid in
general (we can't load the value from the stack, relative to ebp, because we
change it), but could be avoided since we actually use a constant as param 6.
The only fix would be to turn stub_syscall6 to a macro and use a "i"
constraint for arg6 (i.e., specify it's a constant value).
Signed-off-by: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
Signed-off-by: Jeff Dike <jdike@addtoit.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/um/drivers/net_kern.c')
0 files changed, 0 insertions, 0 deletions