Commit 61d2d807 authored by Alexandre Julliard's avatar Alexandre Julliard

loader: Define asm functions instead of inlines for x86-64 syscalls to avoid…

loader: Define asm functions instead of inlines for x86-64 syscalls to avoid trouble with register constraints.
parent 17e66e06
...@@ -371,93 +371,58 @@ __ASM_GLOBAL_FUNC(_start, ...@@ -371,93 +371,58 @@ __ASM_GLOBAL_FUNC(_start,
"xorq %r11,%r11\n\t" "xorq %r11,%r11\n\t"
"ret") "ret")
#define SYSCALL_RET(ret) (((ret) < 0 && (ret) > -4096) ? -1 : (ret)) #define SYSCALL_FUNC( name, nr ) \
__ASM_GLOBAL_FUNC( name, \
static inline __attribute__((noreturn)) void wld_exit( int code ) "movq $" #nr ",%rax\n\t" \
{ "movq %rcx,%r10\n\t" \
for (;;) /* avoid warning */ "syscall\n\t" \
__asm__ __volatile__( "syscall" : : "a" (SYS_exit), "D" (code) ); "leaq 4096(%rax),%rcx\n\t" \
} "movq $-1,%rdx\n\t" \
"cmp $4096,%rcx\n\t" \
static inline int wld_open( const char *name, int flags ) "cmovb %rdx,%rax\n\t" \
{ "ret" )
int ret;
__asm__ __volatile__( "syscall" : "=a" (ret) : "0" (SYS_open), "D" (name), "S" (flags) ); #define SYSCALL_NOERR( name, nr ) \
return SYSCALL_RET(ret); __ASM_GLOBAL_FUNC( name, \
} "movq $" #nr ",%rax\n\t" \
"syscall\n\t" \
static inline int wld_close( int fd ) "ret" )
{
int ret; void wld_exit( int code ) __attribute__((noreturn));
__asm__ __volatile__( "syscall" : "=a" (ret) : "0" (SYS_close), "D" (fd) ); SYSCALL_NOERR( wld_exit, 60 /* SYS_exit */ );
return SYSCALL_RET(ret);
} ssize_t wld_read( int fd, void *buffer, size_t len );
SYSCALL_FUNC( wld_read, 0 /* SYS_read */ );
static inline ssize_t wld_read( int fd, void *buffer, size_t len )
{ ssize_t wld_write( int fd, const void *buffer, size_t len );
int ret; SYSCALL_FUNC( wld_write, 1 /* SYS_write */ );
__asm__ __volatile__( "syscall"
: "=a" (ret) int wld_open( const char *name, int flags );
: "0" (SYS_read), "D" (fd), "S" (buffer), "d" (len) SYSCALL_FUNC( wld_open, 2 /* SYS_open */ );
: "memory" );
return SYSCALL_RET(ret); int wld_close( int fd );
} SYSCALL_FUNC( wld_close, 3 /* SYS_close */ );
static inline ssize_t wld_write( int fd, const void *buffer, size_t len )
{
int ret;
__asm__ __volatile__( "syscall" : "=a" (ret) : "0" (SYS_write), "D" (fd), "S" (buffer), "d" (len) );
return SYSCALL_RET(ret);
}
static inline int wld_mprotect( const void *addr, size_t len, int prot )
{
int ret;
__asm__ __volatile__( "syscall" : "=a" (ret) : "0" (SYS_mprotect), "D" (addr), "S" (len), "d" (prot) );
return SYSCALL_RET(ret);
}
void *wld_mmap( void *start, size_t len, int prot, int flags, int fd, off_t offset ); void *wld_mmap( void *start, size_t len, int prot, int flags, int fd, off_t offset );
__ASM_GLOBAL_FUNC( wld_mmap, SYSCALL_FUNC( wld_mmap, 9 /* SYS_mmap */ );
"movq %rcx,%r10\n\t"
"movq $9,%rax\n\t" /* SYS_mmap */
"syscall\n\t"
"ret" );
static inline uid_t wld_getuid(void) int wld_mprotect( const void *addr, size_t len, int prot );
{ SYSCALL_FUNC( wld_mprotect, 10 /* SYS_mprotect */ );
uid_t ret;
__asm__( "syscall" : "=a" (ret) : "0" (SYS_getuid) );
return ret;
}
static inline uid_t wld_geteuid(void) int wld_prctl( int code, int arg );
{ SYSCALL_FUNC( wld_prctl, 157 /* SYS_prctl */ );
uid_t ret;
__asm__( "syscall" : "=a" (ret) : "0" (SYS_geteuid) );
return ret;
}
static inline gid_t wld_getgid(void) uid_t wld_getuid(void);
{ SYSCALL_NOERR( wld_getuid, 102 /* SYS_getuid */ );
gid_t ret;
__asm__( "syscall" : "=a" (ret) : "0" (SYS_getgid) );
return ret;
}
static inline gid_t wld_getegid(void) gid_t wld_getgid(void);
{ SYSCALL_NOERR( wld_getgid, 104 /* SYS_getgid */ );
gid_t ret;
__asm__( "syscall" : "=a" (ret) : "0" (SYS_getegid) );
return ret;
}
static inline int wld_prctl( int code, int arg ) uid_t wld_geteuid(void);
{ SYSCALL_NOERR( wld_geteuid, 107 /* SYS_geteuid */ );
int ret;
__asm__ __volatile__( "syscall" : "=a" (ret) : "D" (SYS_prctl), "S" (code), "d" (arg) ); gid_t wld_getegid(void);
return SYSCALL_RET(ret); SYSCALL_NOERR( wld_getegid, 108 /* SYS_getegid */ );
}
#else #else
#error preloader not implemented for this CPU #error preloader not implemented for this CPU
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment