blob: 344c01aede08b3e85b1b3f7b0b454ca8ae78d879 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/arch/m68knommu/kernel/init_task.c
3 */
4#include <linux/mm.h>
5#include <linux/module.h>
6#include <linux/sched.h>
7#include <linux/init.h>
8#include <linux/init_task.h>
9#include <linux/fs.h>
10#include <linux/mqueue.h>
11
12#include <asm/uaccess.h>
13#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 task structure.
24 *
25 * All other task structs will be allocated on slabs in fork.c
26 */
27__asm__(".align 4");
28struct task_struct init_task = INIT_TASK(init_task);
29
30EXPORT_SYMBOL(init_task);
31
32/*
33 * Initial thread structure.
34 *
35 * We need to make sure that this is 8192-byte aligned due to the
36 * way process stacks are handled. This is done by having a special
37 * "init_task" linker map entry..
38 */
39union thread_union init_thread_union
40 __attribute__((__section__(".data.init_task"))) =
41 { INIT_THREAD_INFO(init_task) };
42