diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2012-05-03 05:02:48 -0400 |
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2012-05-05 07:00:21 -0400 |
| commit | a4a2eb490e38aaff61eafcb8cde6725ad1be22ab (patch) | |
| tree | cc626df26302e96f3fc7247f3fe895d2eddb69f6 /init | |
| parent | c6ae063aaf3786b9db7f19a90bf4ed8aaebb7f90 (diff) | |
init_task: Create generic init_task instance
All archs define init_task in the same way (except ia64, but there is
no particular reason why ia64 cannot use the common version). Create a
generic instance so all archs can be converted over.
The config switch is temporary and will be removed when all archs are
converted over.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Chen Liqin <liqin.chen@sunplusct.com>
Cc: Chris Metcalf <cmetcalf@tilera.com>
Cc: Chris Zankel <chris@zankel.net>
Cc: David Howells <dhowells@redhat.com>
Cc: David S. Miller <davem@davemloft.net>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Guan Xuetao <gxt@mprc.pku.edu.cn>
Cc: Haavard Skinnemoen <hskinnemoen@gmail.com>
Cc: Hirokazu Takata <takata@linux-m32r.org>
Cc: James E.J. Bottomley <jejb@parisc-linux.org>
Cc: Jesper Nilsson <jesper.nilsson@axis.com>
Cc: Jonas Bonn <jonas@southpole.se>
Cc: Mark Salter <msalter@redhat.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: Matt Turner <mattst88@gmail.com>
Cc: Michal Simek <monstr@monstr.eu>
Cc: Mike Frysinger <vapier@gentoo.org>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Richard Kuo <rkuo@codeaurora.org>
Cc: Richard Weinberger <richard@nod.at>
Cc: Russell King <linux@arm.linux.org.uk>
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Link: http://lkml.kernel.org/r/20120503085034.092585287@linutronix.de
Diffstat (limited to 'init')
| -rw-r--r-- | init/Makefile | 1 | ||||
| -rw-r--r-- | init/init_task.c | 24 |
2 files changed, 25 insertions, 0 deletions
diff --git a/init/Makefile b/init/Makefile index 0bf677aa087..c55eac955cd 100644 --- a/init/Makefile +++ b/init/Makefile | |||
| @@ -9,6 +9,7 @@ else | |||
| 9 | obj-$(CONFIG_BLK_DEV_INITRD) += initramfs.o | 9 | obj-$(CONFIG_BLK_DEV_INITRD) += initramfs.o |
| 10 | endif | 10 | endif |
| 11 | obj-$(CONFIG_GENERIC_CALIBRATE_DELAY) += calibrate.o | 11 | obj-$(CONFIG_GENERIC_CALIBRATE_DELAY) += calibrate.o |
| 12 | obj-$(CONFIG_HAVE_GENERIC_INIT_TASK) += init_task.o | ||
| 12 | 13 | ||
| 13 | mounts-y := do_mounts.o | 14 | mounts-y := do_mounts.o |
| 14 | mounts-$(CONFIG_BLK_DEV_RAM) += do_mounts_rd.o | 15 | mounts-$(CONFIG_BLK_DEV_RAM) += do_mounts_rd.o |
diff --git a/init/init_task.c b/init/init_task.c new file mode 100644 index 00000000000..8b2f3996b03 --- /dev/null +++ b/init/init_task.c | |||
| @@ -0,0 +1,24 @@ | |||
| 1 | #include <linux/init_task.h> | ||
| 2 | #include <linux/export.h> | ||
| 3 | #include <linux/mqueue.h> | ||
| 4 | #include <linux/sched.h> | ||
| 5 | #include <linux/init.h> | ||
| 6 | #include <linux/fs.h> | ||
| 7 | #include <linux/mm.h> | ||
| 8 | |||
| 9 | #include <asm/pgtable.h> | ||
| 10 | #include <asm/uaccess.h> | ||
| 11 | |||
| 12 | static struct signal_struct init_signals = INIT_SIGNALS(init_signals); | ||
| 13 | static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand); | ||
| 14 | |||
| 15 | /* Initial task structure */ | ||
| 16 | struct task_struct init_task = INIT_TASK(init_task); | ||
| 17 | EXPORT_SYMBOL(init_task); | ||
| 18 | |||
| 19 | /* | ||
| 20 | * Initial thread structure. Alignment of this is handled by a special | ||
| 21 | * linker map entry. | ||
| 22 | */ | ||
| 23 | union thread_union init_thread_union __init_task_data = | ||
| 24 | { INIT_THREAD_INFO(init_task) }; | ||
