blob: 04cebcf0679ff90e590b9374ed5c8a8b041acc1e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Jeff Dikeba180fd2007-10-16 01:27:00 -07002 * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 * Licensed under the GPL
4 */
5
Linus Torvalds1da177e2005-04-16 15:20:36 -07006#include "linux/sched.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -07007#include "os.h"
Jeff Dike77bf4402007-10-16 01:26:58 -07008#include "skas.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -07009
Eric W. Biederman5e382912006-01-08 01:03:46 -080010void (*pm_power_off)(void);
11
Linus Torvalds1da177e2005-04-16 15:20:36 -070012static void kill_off_processes(void)
13{
Jeff Dike77bf4402007-10-16 01:26:58 -070014 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, me;
22
23 me = os_getpid();
24 for_each_process(p){
25 if(p->mm == NULL)
26 continue;
27
Jeff Dike6c738ff2007-10-16 01:27:06 -070028 pid = p->mm->context.id.u.pid;
Jeff Dike77bf4402007-10-16 01:26:58 -070029 os_kill_ptraced_process(pid, 1);
30 }
31 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070032}
33
34void uml_cleanup(void)
35{
Jeff Dikeba180fd2007-10-16 01:27:00 -070036 kmalloc_ok = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070037 do_uml_exitcalls();
Jeff Dike026549d2005-06-25 14:55:23 -070038 kill_off_processes();
Linus Torvalds1da177e2005-04-16 15:20:36 -070039}
40
41void machine_restart(char * __unused)
42{
Jeff Dikeba180fd2007-10-16 01:27:00 -070043 uml_cleanup();
Jeff Dike6aa802c2007-10-16 01:26:56 -070044 reboot_skas();
Linus Torvalds1da177e2005-04-16 15:20:36 -070045}
46
Linus Torvalds1da177e2005-04-16 15:20:36 -070047void machine_power_off(void)
48{
Jeff Dikeba180fd2007-10-16 01:27:00 -070049 uml_cleanup();
Jeff Dike6aa802c2007-10-16 01:26:56 -070050 halt_skas();
Linus Torvalds1da177e2005-04-16 15:20:36 -070051}
52
Linus Torvalds1da177e2005-04-16 15:20:36 -070053void machine_halt(void)
54{
55 machine_power_off();
56}