init_task.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,intel.linux}.com)
  3. * Licensed under the GPL
  4. */
  5. #include "linux/mm.h"
  6. #include "linux/module.h"
  7. #include "linux/sched.h"
  8. #include "linux/init_task.h"
  9. #include "linux/mqueue.h"
  10. #include "asm/uaccess.h"
  11. #include "asm/pgtable.h"
  12. #include "mem_user.h"
  13. #include "os.h"
  14. static struct fs_struct init_fs = INIT_FS;
  15. struct mm_struct init_mm = INIT_MM(init_mm);
  16. static struct files_struct init_files = INIT_FILES;
  17. static struct signal_struct init_signals = INIT_SIGNALS(init_signals);
  18. static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand);
  19. EXPORT_SYMBOL(init_mm);
  20. /*
  21. * Initial task structure.
  22. *
  23. * All other task structs will be allocated on slabs in fork.c
  24. */
  25. struct task_struct init_task = INIT_TASK(init_task);
  26. EXPORT_SYMBOL(init_task);
  27. /*
  28. * Initial thread structure.
  29. *
  30. * We need to make sure that this is aligned due to the
  31. * way process stacks are handled. This is done by having a special
  32. * "init_task" linker map entry..
  33. */
  34. union thread_union init_thread_union
  35. __attribute__((__section__(".data.init_task"))) =
  36. { INIT_THREAD_INFO(init_task) };
  37. union thread_union cpu0_irqstack
  38. __attribute__((__section__(".data.init_irqstack"))) =
  39. { INIT_THREAD_INFO(init_task) };
  40. void unprotect_stack(unsigned long stack)
  41. {
  42. os_protect_memory((void *) stack, THREAD_SIZE, 1, 1, 0);
  43. }