reboot.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /*
  2. * Copyright (C) 2000, 2002 Jeff Dike (jdike@karaya.com)
  3. * Licensed under the GPL
  4. */
  5. #include "linux/module.h"
  6. #include "linux/sched.h"
  7. #include "asm/smp.h"
  8. #include "user_util.h"
  9. #include "kern_util.h"
  10. #include "kern.h"
  11. #include "os.h"
  12. #include "mode.h"
  13. #include "choose-mode.h"
  14. void (*pm_power_off)(void);
  15. #ifdef CONFIG_SMP
  16. static void kill_idlers(int me)
  17. {
  18. #ifdef CONFIG_MODE_TT
  19. struct task_struct *p;
  20. int i;
  21. for(i = 0; i < ARRAY_SIZE(idle_threads); i++){
  22. p = idle_threads[i];
  23. if((p != NULL) && (p->thread.mode.tt.extern_pid != me))
  24. os_kill_process(p->thread.mode.tt.extern_pid, 0);
  25. }
  26. #endif
  27. }
  28. #endif
  29. static void kill_off_processes(void)
  30. {
  31. CHOOSE_MODE(kill_off_processes_tt(), kill_off_processes_skas());
  32. #ifdef CONFIG_SMP
  33. kill_idlers(os_getpid());
  34. #endif
  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. CHOOSE_MODE(reboot_tt(), reboot_skas());
  46. }
  47. void machine_power_off(void)
  48. {
  49. uml_cleanup();
  50. CHOOSE_MODE(halt_tt(), halt_skas());
  51. }
  52. void machine_halt(void)
  53. {
  54. machine_power_off();
  55. }