init_task.c 1.4 KB

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