blob: 806d381947bf1c704dc584e5b29360abb7b40a88 [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
Linus Torvalds1da177e2005-04-16 15:20:36 -070013struct mm_struct init_mm = INIT_MM(init_mm);
Linus Torvalds1da177e2005-04-16 15:20:36 -070014static struct signal_struct init_signals = INIT_SIGNALS(init_signals);
15static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand);
16EXPORT_SYMBOL(init_mm);
17
18/*
19 * Initial task structure.
20 *
21 * All other task structs will be allocated on slabs in fork.c
22 */
23
24struct task_struct init_task = INIT_TASK(init_task);
25
26EXPORT_SYMBOL(init_task);
27
28/*
29 * Initial thread structure.
30 *
Jeff Dikec14b8492007-05-10 22:22:34 -070031 * We need to make sure that this is aligned due to the
Linus Torvalds1da177e2005-04-16 15:20:36 -070032 * way process stacks are handled. This is done by having a special
33 * "init_task" linker map entry..
34 */
35
Jeff Dikec14b8492007-05-10 22:22:34 -070036union thread_union init_thread_union
37 __attribute__((__section__(".data.init_task"))) =
38 { INIT_THREAD_INFO(init_task) };
39
40union thread_union cpu0_irqstack
41 __attribute__((__section__(".data.init_irqstack"))) =
42 { INIT_THREAD_INFO(init_task) };