reboot.c 1008 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
  3. * Licensed under the GPL
  4. */
  5. #include "linux/sched.h"
  6. #include "linux/spinlock.h"
  7. #include "linux/slab.h"
  8. #include "kern_util.h"
  9. #include "os.h"
  10. #include "skas.h"
  11. void (*pm_power_off)(void);
  12. static void kill_off_processes(void)
  13. {
  14. if (proc_mm)
  15. /*
  16. * FIXME: need to loop over userspace_pids
  17. */
  18. os_kill_ptraced_process(userspace_pid[0], 1);
  19. else {
  20. struct task_struct *p;
  21. int pid;
  22. read_lock(&tasklist_lock);
  23. for_each_process(p) {
  24. task_lock(p);
  25. if (!p->mm) {
  26. task_unlock(p);
  27. continue;
  28. }
  29. pid = p->mm->context.id.u.pid;
  30. task_unlock(p);
  31. os_kill_ptraced_process(pid, 1);
  32. }
  33. read_unlock(&tasklist_lock);
  34. }
  35. }
  36. void uml_cleanup(void)
  37. {
  38. kmalloc_ok = 0;
  39. do_uml_exitcalls();
  40. kill_off_processes();
  41. }
  42. void machine_restart(char * __unused)
  43. {
  44. uml_cleanup();
  45. reboot_skas();
  46. }
  47. void machine_power_off(void)
  48. {
  49. uml_cleanup();
  50. halt_skas();
  51. }
  52. void machine_halt(void)
  53. {
  54. machine_power_off();
  55. }