aboutsummaryrefslogtreecommitdiffstats
path: root/arch/ppc64
diff options
context:
space:
mode:
authorStephen Rothwell <sfr@canb.auug.org.au>2005-10-12 23:40:54 -0400
committerStephen Rothwell <sfr@canb.auug.org.au>2005-10-12 23:40:54 -0400
commitd4bf9a7858a0766cafb21dcb66ff9a5d92c1cd09 (patch)
tree7179d40fa2b016414fb2b7fcc9e9da960459bc8d /arch/ppc64
parent0f17d0742f27b7a69b0e2dfb21190f06ea3a9087 (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/ppc64')
-rw-r--r--arch/ppc64/kernel/Makefile2
-rw-r--r--arch/ppc64/kernel/binfmt_elf32.c78
-rw-r--r--arch/ppc64/kernel/sys_ppc32.c46
3 files changed, 1 insertions, 125 deletions
diff --git a/arch/ppc64/kernel/Makefile b/arch/ppc64/kernel/Makefile
index 834aef034b77..a724f6fc04da 100644
--- a/arch/ppc64/kernel/Makefile
+++ b/arch/ppc64/kernel/Makefile
@@ -14,7 +14,7 @@ endif
14obj-y += irq.o idle.o dma.o \ 14obj-y += irq.o idle.o dma.o \
15 time.o signal.o syscalls.o ptrace.o \ 15 time.o signal.o syscalls.o ptrace.o \
16 align.o bitops.o pacaData.o \ 16 align.o bitops.o pacaData.o \
17 udbg.o binfmt_elf32.o sys_ppc32.o ioctl32.o \ 17 udbg.o sys_ppc32.o ioctl32.o \
18 ptrace32.o signal32.o rtc.o \ 18 ptrace32.o signal32.o rtc.o \
19 cpu_setup_power4.o \ 19 cpu_setup_power4.o \
20 iommu.o sysfs.o vdso.o pmc.o firmware.o 20 iommu.o sysfs.o vdso.o pmc.o firmware.o
diff --git a/arch/ppc64/kernel/binfmt_elf32.c b/arch/ppc64/kernel/binfmt_elf32.c
deleted file mode 100644
index fadc699a0497..000000000000
--- a/arch/ppc64/kernel/binfmt_elf32.c
+++ /dev/null
@@ -1,78 +0,0 @@
1/*
2 * binfmt_elf32.c: Support 32-bit PPC ELF binaries on Power3 and followons.
3 * based on the SPARC64 version.
4 * Copyright (C) 1995, 1996, 1997, 1998 David S. Miller (davem@redhat.com)
5 * Copyright (C) 1995, 1996, 1997, 1998 Jakub Jelinek (jj@ultra.linux.cz)
6 *
7 * Copyright (C) 2000,2001 Ken Aaker (kdaaker@rchland.vnet.ibm.com), IBM Corp
8 * Copyright (C) 2001 Anton Blanchard (anton@au.ibm.com), IBM
9 *
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License
12 * as published by the Free Software Foundation; either version
13 * 2 of the License, or (at your option) any later version.
14 */
15
16#define ELF_ARCH EM_PPC
17#define ELF_CLASS ELFCLASS32
18#define ELF_DATA ELFDATA2MSB;
19
20#include <asm/processor.h>
21#include <linux/module.h>
22#include <linux/config.h>
23#include <linux/elfcore.h>
24#include <linux/compat.h>
25
26#define elf_prstatus elf_prstatus32
27struct elf_prstatus32
28{
29 struct elf_siginfo pr_info; /* Info associated with signal */
30 short pr_cursig; /* Current signal */
31 unsigned int pr_sigpend; /* Set of pending signals */
32 unsigned int pr_sighold; /* Set of held signals */
33 pid_t pr_pid;
34 pid_t pr_ppid;
35 pid_t pr_pgrp;
36 pid_t pr_sid;
37 struct compat_timeval pr_utime; /* User time */
38 struct compat_timeval pr_stime; /* System time */
39 struct compat_timeval pr_cutime; /* Cumulative user time */
40 struct compat_timeval pr_cstime; /* Cumulative system time */
41 elf_gregset_t pr_reg; /* General purpose registers. */
42 int pr_fpvalid; /* True if math co-processor being used. */
43};
44
45#define elf_prpsinfo elf_prpsinfo32
46struct elf_prpsinfo32
47{
48 char pr_state; /* numeric process state */
49 char pr_sname; /* char for pr_state */
50 char pr_zomb; /* zombie */
51 char pr_nice; /* nice val */
52 unsigned int pr_flag; /* flags */
53 u32 pr_uid;
54 u32 pr_gid;
55 pid_t pr_pid, pr_ppid, pr_pgrp, pr_sid;
56 /* Lots missing */
57 char pr_fname[16]; /* filename of executable */
58 char pr_psargs[ELF_PRARGSZ]; /* initial part of arg list */
59};
60
61#include <linux/time.h>
62
63#undef cputime_to_timeval
64#define cputime_to_timeval cputime_to_compat_timeval
65static __inline__ void
66cputime_to_compat_timeval(const cputime_t cputime, struct compat_timeval *value)
67{
68 unsigned long jiffies = cputime_to_jiffies(cputime);
69 value->tv_usec = (jiffies % HZ) * (1000000L / HZ);
70 value->tv_sec = jiffies / HZ;
71}
72
73extern void start_thread32(struct pt_regs *, unsigned long, unsigned long);
74#undef start_thread
75#define start_thread start_thread32
76#define init_elf_binfmt init_elf32_binfmt
77
78#include "../../../fs/binfmt_elf.c"
diff --git a/arch/ppc64/kernel/sys_ppc32.c b/arch/ppc64/kernel/sys_ppc32.c
index 1cacf61f9c91..b53f565ee443 100644
--- a/arch/ppc64/kernel/sys_ppc32.c
+++ b/arch/ppc64/kernel/sys_ppc32.c
@@ -609,52 +609,6 @@ out:
609 return error; 609 return error;
610} 610}
611 611
612/* Set up a thread for executing a new program. */
613void start_thread32(struct pt_regs* regs, unsigned long nip, unsigned long sp)
614{
615 set_fs(USER_DS);
616
617 /*
618 * If we exec out of a kernel thread then thread.regs will not be
619 * set. Do it now.
620 */
621 if (!current->thread.regs) {
622 unsigned long childregs = (unsigned long)current->thread_info +
623 THREAD_SIZE;
624 childregs -= sizeof(struct pt_regs);
625 current->thread.regs = (struct pt_regs *)childregs;
626 }
627
628 /*
629 * ELF_PLAT_INIT already clears all registers but it also sets r2.
630 * So just clear r2 here.
631 */
632 regs->gpr[2] = 0;
633
634 regs->nip = nip;
635 regs->gpr[1] = sp;
636 regs->msr = MSR_USER32;
637#ifndef CONFIG_SMP
638 if (last_task_used_math == current)
639 last_task_used_math = 0;
640#endif /* CONFIG_SMP */
641 current->thread.fpscr = 0;
642 memset(current->thread.fpr, 0, sizeof(current->thread.fpr));
643#ifdef CONFIG_ALTIVEC
644#ifndef CONFIG_SMP
645 if (last_task_used_altivec == current)
646 last_task_used_altivec = 0;
647#endif /* CONFIG_SMP */
648 memset(current->thread.vr, 0, sizeof(current->thread.vr));
649 current->thread.vscr.u[0] = 0;
650 current->thread.vscr.u[1] = 0;
651 current->thread.vscr.u[2] = 0;
652 current->thread.vscr.u[3] = 0x00010000; /* Java mode disabled */
653 current->thread.vrsave = 0;
654 current->thread.used_vr = 0;
655#endif /* CONFIG_ALTIVEC */
656}
657
658/* Note: it is necessary to treat option as an unsigned int, 612/* Note: it is necessary to treat option as an unsigned int,
659 * with the corresponding cast to a signed int to insure that the 613 * with the corresponding cast to a signed int to insure that the
660 * proper conversion (sign extension) between the register representation of a signed int (msr in 32-bit mode) 614 * proper conversion (sign extension) between the register representation of a signed int (msr in 32-bit mode)