blob: 0bbf806253954c1ac42c9f8fd634f1b7e5cfe63c [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/arch/arm/kernel/init_task.c
3 */
4#include <linux/mm.h>
5#include <linux/module.h>
6#include <linux/fs.h>
7#include <linux/sched.h>
8#include <linux/init.h>
9#include <linux/init_task.h>
10#include <linux/mqueue.h>
Russell King33fa9b12008-09-06 11:35:55 +010011#include <linux/uaccess.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070012
Linus Torvalds1da177e2005-04-16 15:20:36 -070013#include <asm/pgtable.h>
14
15static struct fs_struct init_fs = INIT_FS;
Linus Torvalds1da177e2005-04-16 15:20:36 -070016static struct signal_struct init_signals = INIT_SIGNALS(init_signals);
17static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand);
18struct mm_struct init_mm = INIT_MM(init_mm);
Linus Torvalds1da177e2005-04-16 15:20:36 -070019
20EXPORT_SYMBOL(init_mm);
21
22/*
23 * Initial thread structure.
24 *
25 * We need to make sure that this is 8192-byte aligned due to the
26 * way process stacks are handled. This is done by making sure
27 * the linker maps this in the .text segment right after head.S,
28 * and making head.S ensure the proper alignment.
29 *
30 * The things we do for performance..
31 */
32union thread_union init_thread_union
Russell King4efb4482007-05-08 12:39:37 +010033 __attribute__((__section__(".data.init_task"))) =
Linus Torvalds1da177e2005-04-16 15:20:36 -070034 { INIT_THREAD_INFO(init_task) };
35
36/*
37 * Initial task structure.
38 *
39 * All other task structs will be allocated on slabs in fork.c
40 */
41struct task_struct init_task = INIT_TASK(init_task);
42
43EXPORT_SYMBOL(init_task);