blob: dcfceca950523ce7b1e7ebba36994d2816d071ca [file] [log] [blame]
Jeff Dikec14b8492007-05-10 22:22:34 -07001/*
2 * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,intel.linux}.com)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 * Licensed under the GPL
4 */
5
Linus Torvalds1da177e2005-04-16 15:20:36 -07006#include "linux/sched.h"
7#include "linux/init_task.h"
Jeff Dike4c9e1382007-10-16 01:26:54 -07008#include "linux/fs.h"
9#include "linux/module.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070010#include "linux/mqueue.h"
11#include "asm/uaccess.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070012
13static struct fs_struct init_fs = INIT_FS;
14struct mm_struct init_mm = INIT_MM(init_mm);
15static struct files_struct init_files = INIT_FILES;
16static struct signal_struct init_signals = INIT_SIGNALS(init_signals);
17static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand);
18EXPORT_SYMBOL(init_mm);
19
20/*
21 * Initial task structure.
22 *
23 * All other task structs will be allocated on slabs in fork.c
24 */
25
26struct task_struct init_task = INIT_TASK(init_task);
27
28EXPORT_SYMBOL(init_task);
29
30/*
31 * Initial thread structure.
32 *
Jeff Dikec14b8492007-05-10 22:22:34 -070033 * We need to make sure that this is aligned due to the
Linus Torvalds1da177e2005-04-16 15:20:36 -070034 * way process stacks are handled. This is done by having a special
35 * "init_task" linker map entry..
36 */
37
Jeff Dikec14b8492007-05-10 22:22:34 -070038union thread_union init_thread_union
39 __attribute__((__section__(".data.init_task"))) =
40 { INIT_THREAD_INFO(init_task) };
41
42union thread_union cpu0_irqstack
43 __attribute__((__section__(".data.init_irqstack"))) =
44 { INIT_THREAD_INFO(init_task) };