init_task.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * linux/arch/arm26/kernel/init_task.c
  3. *
  4. * Copyright (C) 2003 Ian Molton
  5. *
  6. */
  7. #include <linux/mm.h>
  8. #include <linux/module.h>
  9. #include <linux/fs.h>
  10. #include <linux/sched.h>
  11. #include <linux/init.h>
  12. #include <linux/init_task.h>
  13. #include <linux/mqueue.h>
  14. #include <linux/nsproxy.h>
  15. #include <asm/uaccess.h>
  16. #include <asm/pgtable.h>
  17. static struct fs_struct init_fs = INIT_FS;
  18. static struct files_struct init_files = INIT_FILES;
  19. static struct signal_struct init_signals = INIT_SIGNALS(init_signals);
  20. static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand);
  21. struct mm_struct init_mm = INIT_MM(init_mm);
  22. struct nsproxy init_nsproxy = INIT_NSPROXY(init_nsproxy);
  23. EXPORT_SYMBOL(init_mm);
  24. /*
  25. * Initial thread structure.
  26. *
  27. * We need to make sure that this is 8192-byte aligned due to the
  28. * way process stacks are handled. This is done by making sure
  29. * the linker maps this in the .text segment right after head.S,
  30. * and making the linker scripts ensure the proper alignment.
  31. *
  32. * FIXME - should this be 32K alignment on arm26?
  33. *
  34. * The things we do for performance...
  35. */
  36. union thread_union init_thread_union
  37. __attribute__((__section__(".init.task"))) =
  38. { INIT_THREAD_INFO(init_task) };
  39. /*
  40. * Initial task structure.
  41. *
  42. * All other task structs will be allocated on slabs in fork.c
  43. */
  44. struct task_struct init_task = INIT_TASK(init_task);
  45. EXPORT_SYMBOL(init_task);