]> bbs.cooldavid.org Git - net-next-2.6.git/blobdiff - arch/x86/include/asm/elf.h
x86-64: make compat_start_thread() match start_thread()
[net-next-2.6.git] / arch / x86 / include / asm / elf.h
index 456a304b817266320ad59d6f6b49419ea4e1aa15..8a024babe5e646a3b1f8282deeae9edcf70088ba 100644 (file)
@@ -157,19 +157,6 @@ do {                                               \
 
 #define compat_elf_check_arch(x)       elf_check_arch_ia32(x)
 
-static inline void start_ia32_thread(struct pt_regs *regs, u32 ip, u32 sp)
-{
-       loadsegment(fs, 0);
-       loadsegment(ds, __USER32_DS);
-       loadsegment(es, __USER32_DS);
-       load_gs_index(0);
-       regs->ip = ip;
-       regs->sp = sp;
-       regs->flags = X86_EFLAGS_IF;
-       regs->cs = __USER32_CS;
-       regs->ss = __USER32_DS;
-}
-
 static inline void elf_common_init(struct thread_struct *t,
                                   struct pt_regs *regs, const u16 ds)
 {
@@ -191,11 +178,8 @@ do {                                                       \
 #define        COMPAT_ELF_PLAT_INIT(regs, load_addr)           \
        elf_common_init(&current->thread, regs, __USER_DS)
 
-#define        compat_start_thread(regs, ip, sp)               \
-do {                                                   \
-       start_ia32_thread(regs, ip, sp);                \
-       set_fs(USER_DS);                                \
-} while (0)
+void start_thread_ia32(struct pt_regs *regs, u32 new_ip, u32 new_sp);
+#define compat_start_thread start_thread_ia32
 
 #define COMPAT_SET_PERSONALITY(ex)                     \
 do {                                                   \