blob: 7e4305a1fd3c648d91d397a240dde7e8ac659458 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * Copyright (C) 2000, 2002 Jeff Dike (jdike@karaya.com)
3 * Licensed under the GPL
4 */
5
6#include "linux/module.h"
7#include "linux/sched.h"
Paolo 'Blaisorblade' Giarrusso72e55252006-02-01 03:06:29 -08008#include "asm/smp.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -07009#include "kern_util.h"
10#include "kern.h"
11#include "os.h"
12#include "mode.h"
13#include "choose-mode.h"
14
Eric W. Biederman5e382912006-01-08 01:03:46 -080015void (*pm_power_off)(void);
16
Linus Torvalds1da177e2005-04-16 15:20:36 -070017#ifdef CONFIG_SMP
18static void kill_idlers(int me)
19{
20#ifdef CONFIG_MODE_TT
21 struct task_struct *p;
22 int i;
23
Jeff Dike91b165c2006-09-25 23:33:00 -070024 for(i = 0; i < ARRAY_SIZE(idle_threads); i++){
Linus Torvalds1da177e2005-04-16 15:20:36 -070025 p = idle_threads[i];
26 if((p != NULL) && (p->thread.mode.tt.extern_pid != me))
27 os_kill_process(p->thread.mode.tt.extern_pid, 0);
28 }
29#endif
30}
31#endif
32
33static void kill_off_processes(void)
34{
35 CHOOSE_MODE(kill_off_processes_tt(), kill_off_processes_skas());
36#ifdef CONFIG_SMP
37 kill_idlers(os_getpid());
38#endif
39}
40
41void uml_cleanup(void)
42{
Jeff Dike026549d2005-06-25 14:55:23 -070043 kmalloc_ok = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070044 do_uml_exitcalls();
Jeff Dike026549d2005-06-25 14:55:23 -070045 kill_off_processes();
Linus Torvalds1da177e2005-04-16 15:20:36 -070046}
47
48void machine_restart(char * __unused)
49{
Jeff Dike026549d2005-06-25 14:55:23 -070050 uml_cleanup();
Linus Torvalds1da177e2005-04-16 15:20:36 -070051 CHOOSE_MODE(reboot_tt(), reboot_skas());
52}
53
Linus Torvalds1da177e2005-04-16 15:20:36 -070054void machine_power_off(void)
55{
Jeff Dike026549d2005-06-25 14:55:23 -070056 uml_cleanup();
Linus Torvalds1da177e2005-04-16 15:20:36 -070057 CHOOSE_MODE(halt_tt(), halt_skas());
58}
59
Linus Torvalds1da177e2005-04-16 15:20:36 -070060void machine_halt(void)
61{
62 machine_power_off();
63}