blob: 00197d3d21ec96daba38fe57b74db08183fc1310 [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"
Jeff Dikeedea1382008-02-04 22:30:46 -08007#include "kern_util.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -07008#include "os.h"
Jeff Dike77bf4402007-10-16 01:26:58 -07009#include "skas.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070010
Eric W. Biederman5e382912006-01-08 01:03:46 -080011void (*pm_power_off)(void);
12
Linus Torvalds1da177e2005-04-16 15:20:36 -070013static void kill_off_processes(void)
14{
Jeff Dikec5d4bb12008-02-04 22:31:14 -080015 if (proc_mm)
Jeff Dike77bf4402007-10-16 01:26:58 -070016 /*
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, me;
23
24 me = os_getpid();
Jeff Dikec5d4bb12008-02-04 22:31:14 -080025 for_each_process(p) {
26 if (p->mm == NULL)
Jeff Dike77bf4402007-10-16 01:26:58 -070027 continue;
28
Jeff Dike6c738ff2007-10-16 01:27:06 -070029 pid = p->mm->context.id.u.pid;
Jeff Dike77bf4402007-10-16 01:26:58 -070030 os_kill_ptraced_process(pid, 1);
31 }
32 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070033}
34
35void uml_cleanup(void)
36{
Jeff Dikeba180fd2007-10-16 01:27:00 -070037 kmalloc_ok = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070038 do_uml_exitcalls();
Jeff Dike026549d2005-06-25 14:55:23 -070039 kill_off_processes();
Linus Torvalds1da177e2005-04-16 15:20:36 -070040}
41
42void machine_restart(char * __unused)
43{
Jeff Dikeba180fd2007-10-16 01:27:00 -070044 uml_cleanup();
Jeff Dike6aa802c2007-10-16 01:26:56 -070045 reboot_skas();
Linus Torvalds1da177e2005-04-16 15:20:36 -070046}
47
Linus Torvalds1da177e2005-04-16 15:20:36 -070048void machine_power_off(void)
49{
Jeff Dikeba180fd2007-10-16 01:27:00 -070050 uml_cleanup();
Jeff Dike6aa802c2007-10-16 01:26:56 -070051 halt_skas();
Linus Torvalds1da177e2005-04-16 15:20:36 -070052}
53
Linus Torvalds1da177e2005-04-16 15:20:36 -070054void machine_halt(void)
55{
56 machine_power_off();
57}