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/ppc64 | |
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/ppc64')
-rw-r--r-- | arch/ppc64/kernel/Makefile | 2 | ||||
-rw-r--r-- | arch/ppc64/kernel/binfmt_elf32.c | 78 | ||||
-rw-r--r-- | arch/ppc64/kernel/sys_ppc32.c | 46 |
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 | |||
14 | obj-y += irq.o idle.o dma.o \ | 14 | obj-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 | ||
27 | struct 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 | ||
46 | struct 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 | ||
65 | static __inline__ void | ||
66 | cputime_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 | |||
73 | extern 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. */ | ||
613 | void 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) |