| /* |
| * Copyright (C) 2000, 2002 Jeff Dike (jdike@karaya.com) |
| * Licensed under the GPL |
| */ |
| |
| #include "linux/module.h" |
| #include "linux/sched.h" |
| #include "asm/smp.h" |
| #include "user_util.h" |
| #include "kern_util.h" |
| #include "kern.h" |
| #include "os.h" |
| #include "mode.h" |
| #include "choose-mode.h" |
| |
| void (*pm_power_off)(void); |
| |
| #ifdef CONFIG_SMP |
| static void kill_idlers(int me) |
| { |
| #ifdef CONFIG_MODE_TT |
| struct task_struct *p; |
| int i; |
| |
| for(i = 0; i < ARRAY_SIZE(idle_threads); i++){ |
| p = idle_threads[i]; |
| if((p != NULL) && (p->thread.mode.tt.extern_pid != me)) |
| os_kill_process(p->thread.mode.tt.extern_pid, 0); |
| } |
| #endif |
| } |
| #endif |
| |
| static void kill_off_processes(void) |
| { |
| CHOOSE_MODE(kill_off_processes_tt(), kill_off_processes_skas()); |
| #ifdef CONFIG_SMP |
| kill_idlers(os_getpid()); |
| #endif |
| } |
| |
| void uml_cleanup(void) |
| { |
| kmalloc_ok = 0; |
| do_uml_exitcalls(); |
| kill_off_processes(); |
| } |
| |
| void machine_restart(char * __unused) |
| { |
| uml_cleanup(); |
| CHOOSE_MODE(reboot_tt(), reboot_skas()); |
| } |
| |
| void machine_power_off(void) |
| { |
| uml_cleanup(); |
| CHOOSE_MODE(halt_tt(), halt_skas()); |
| } |
| |
| void machine_halt(void) |
| { |
| machine_power_off(); |
| } |