diff options
author | Stephen Rothwell <sfr@canb.auug.org.au> | 2005-10-12 23:40:54 -0400 |
---|---|---|
committer | Stephen Rothwell <sfr@canb.auug.org.au> | 2005-10-12 23:40:54 -0400 |
commit | d4bf9a7858a0766cafb21dcb66ff9a5d92c1cd09 (patch) | |
tree | 7179d40fa2b016414fb2b7fcc9e9da960459bc8d /arch/powerpc/kernel/process.c | |
parent | 0f17d0742f27b7a69b0e2dfb21190f06ea3a9087 (diff) |
ppc64: merge binfmt_elf32.c
and use start_thread for both 32 and 64 bit bineries.
Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au>
Diffstat (limited to 'arch/powerpc/kernel/process.c')
-rw-r--r-- | arch/powerpc/kernel/process.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/arch/powerpc/kernel/process.c b/arch/powerpc/kernel/process.c index 92bc75f61ca6..193c8c1bf132 100644 --- a/arch/powerpc/kernel/process.c +++ b/arch/powerpc/kernel/process.c | |||
@@ -620,7 +620,7 @@ void start_thread(struct pt_regs *regs, unsigned long start, unsigned long sp) | |||
620 | regs->nip = start; | 620 | regs->nip = start; |
621 | regs->msr = MSR_USER; | 621 | regs->msr = MSR_USER; |
622 | #else | 622 | #else |
623 | { | 623 | if (!test_thread_flag(TIF_32BIT)) { |
624 | unsigned long entry, toc, load_addr = regs->gpr[2]; | 624 | unsigned long entry, toc, load_addr = regs->gpr[2]; |
625 | 625 | ||
626 | /* start is a relocated pointer to the function descriptor for | 626 | /* start is a relocated pointer to the function descriptor for |
@@ -641,6 +641,10 @@ void start_thread(struct pt_regs *regs, unsigned long start, unsigned long sp) | |||
641 | regs->nip = entry; | 641 | regs->nip = entry; |
642 | regs->gpr[2] = toc; | 642 | regs->gpr[2] = toc; |
643 | regs->msr = MSR_USER64; | 643 | regs->msr = MSR_USER64; |
644 | } else { | ||
645 | regs->nip = start; | ||
646 | regs->gpr[2] = 0; | ||
647 | regs->msr = MSR_USER32; | ||
644 | } | 648 | } |
645 | #endif | 649 | #endif |
646 | 650 | ||