reboot.c 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  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 <linux/oom.h>
  9. #include <kern_util.h>
  10. #include <os.h>
  11. #include <skas.h>
  12. void (*pm_power_off)(void);
  13. static void kill_off_processes(void)
  14. {
  15. if (proc_mm)
  16. /*
  17. * FIXME: need to loop over userspace_pids
  18. */
  19. os_kill_ptraced_process(userspace_pid[0], 1);
  20. else {
  21. struct task_struct *p;
  22. int pid;
  23. read_lock(&tasklist_lock);
  24. for_each_process(p) {
  25. struct task_struct *t;
  26. t = find_lock_task_mm(p);
  27. if (!t)
  28. continue;
  29. pid = t->mm->context.id.u.pid;
  30. task_unlock(t);
  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. }