diff options
Diffstat (limited to 'arch/um')
-rw-r--r-- | arch/um/Kconfig.common | 1 | ||||
-rw-r--r-- | arch/um/kernel/Makefile | 2 | ||||
-rw-r--r-- | arch/um/kernel/init_task.c | 38 | ||||
-rw-r--r-- | arch/um/kernel/um_arch.c | 5 |
4 files changed, 7 insertions, 39 deletions
diff --git a/arch/um/Kconfig.common b/arch/um/Kconfig.common index 20a49ba93cb9..f03473cf86df 100644 --- a/arch/um/Kconfig.common +++ b/arch/um/Kconfig.common | |||
@@ -10,6 +10,7 @@ config UML | |||
10 | select GENERIC_IRQ_SHOW | 10 | select GENERIC_IRQ_SHOW |
11 | select GENERIC_CPU_DEVICES | 11 | select GENERIC_CPU_DEVICES |
12 | select GENERIC_IO | 12 | select GENERIC_IO |
13 | select HAVE_GENERIC_INIT_TASK | ||
13 | 14 | ||
14 | config MMU | 15 | config MMU |
15 | bool | 16 | bool |
diff --git a/arch/um/kernel/Makefile b/arch/um/kernel/Makefile index 65a1c3d690ea..babe21826e3e 100644 --- a/arch/um/kernel/Makefile +++ b/arch/um/kernel/Makefile | |||
@@ -10,7 +10,7 @@ CPPFLAGS_vmlinux.lds := -DSTART=$(LDS_START) \ | |||
10 | extra-y := vmlinux.lds | 10 | extra-y := vmlinux.lds |
11 | clean-files := | 11 | clean-files := |
12 | 12 | ||
13 | obj-y = config.o exec.o exitcode.o init_task.o irq.o ksyms.o mem.o \ | 13 | obj-y = config.o exec.o exitcode.o irq.o ksyms.o mem.o \ |
14 | physmem.o process.o ptrace.o reboot.o sigio.o \ | 14 | physmem.o process.o ptrace.o reboot.o sigio.o \ |
15 | signal.o smp.o syscall.o sysrq.o time.o tlb.o trap.o \ | 15 | signal.o smp.o syscall.o sysrq.o time.o tlb.o trap.o \ |
16 | um_arch.o umid.o skas/ | 16 | um_arch.o umid.o skas/ |
diff --git a/arch/um/kernel/init_task.c b/arch/um/kernel/init_task.c deleted file mode 100644 index ddc9698b66ed..000000000000 --- a/arch/um/kernel/init_task.c +++ /dev/null | |||
@@ -1,38 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,intel.linux}.com) | ||
3 | * Licensed under the GPL | ||
4 | */ | ||
5 | |||
6 | #include "linux/sched.h" | ||
7 | #include "linux/init_task.h" | ||
8 | #include "linux/fs.h" | ||
9 | #include "linux/module.h" | ||
10 | #include "linux/mqueue.h" | ||
11 | #include "asm/uaccess.h" | ||
12 | |||
13 | static struct signal_struct init_signals = INIT_SIGNALS(init_signals); | ||
14 | static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand); | ||
15 | /* | ||
16 | * Initial task structure. | ||
17 | * | ||
18 | * All other task structs will be allocated on slabs in fork.c | ||
19 | */ | ||
20 | |||
21 | struct task_struct init_task = INIT_TASK(init_task); | ||
22 | |||
23 | EXPORT_SYMBOL(init_task); | ||
24 | |||
25 | /* | ||
26 | * Initial thread structure. | ||
27 | * | ||
28 | * We need to make sure that this is aligned due to the | ||
29 | * way process stacks are handled. This is done by having a special | ||
30 | * "init_task" linker map entry.. | ||
31 | */ | ||
32 | |||
33 | union thread_union init_thread_union __init_task_data = | ||
34 | { INIT_THREAD_INFO(init_task) }; | ||
35 | |||
36 | union thread_union cpu0_irqstack | ||
37 | __attribute__((__section__(".data..init_irqstack"))) = | ||
38 | { INIT_THREAD_INFO(init_task) }; | ||
diff --git a/arch/um/kernel/um_arch.c b/arch/um/kernel/um_arch.c index ba00eae45aad..4db8770906ca 100644 --- a/arch/um/kernel/um_arch.c +++ b/arch/um/kernel/um_arch.c | |||
@@ -10,6 +10,7 @@ | |||
10 | #include <linux/seq_file.h> | 10 | #include <linux/seq_file.h> |
11 | #include <linux/string.h> | 11 | #include <linux/string.h> |
12 | #include <linux/utsname.h> | 12 | #include <linux/utsname.h> |
13 | #include <linux/sched.h> | ||
13 | #include <asm/pgtable.h> | 14 | #include <asm/pgtable.h> |
14 | #include <asm/processor.h> | 15 | #include <asm/processor.h> |
15 | #include <asm/setup.h> | 16 | #include <asm/setup.h> |
@@ -47,6 +48,10 @@ struct cpuinfo_um boot_cpu_data = { | |||
47 | .ipi_pipe = { -1, -1 } | 48 | .ipi_pipe = { -1, -1 } |
48 | }; | 49 | }; |
49 | 50 | ||
51 | union thread_union cpu0_irqstack | ||
52 | __attribute__((__section__(".data..init_irqstack"))) = | ||
53 | { INIT_THREAD_INFO(init_task) }; | ||
54 | |||
50 | unsigned long thread_saved_pc(struct task_struct *task) | 55 | unsigned long thread_saved_pc(struct task_struct *task) |
51 | { | 56 | { |
52 | /* FIXME: Need to look up userspace_pid by cpu */ | 57 | /* FIXME: Need to look up userspace_pid by cpu */ |