blob: 66d754c46e7b048492f7587fdcbe08fed2b4630d [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"
Anton Vorontsov9bd0a072012-05-31 16:26:25 -07007#include "linux/spinlock.h"
Tejun Heo5a0e3ad2010-03-24 17:04:11 +09008#include "linux/slab.h"
Jeff Dikeedea1382008-02-04 22:30:46 -08009#include "kern_util.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070010#include "os.h"
Jeff Dike77bf4402007-10-16 01:26:58 -070011#include "skas.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070012
Eric W. Biederman5e382912006-01-08 01:03:46 -080013void (*pm_power_off)(void);
14
Linus Torvalds1da177e2005-04-16 15:20:36 -070015static void kill_off_processes(void)
16{
Jeff Dikec5d4bb12008-02-04 22:31:14 -080017 if (proc_mm)
Jeff Dike77bf4402007-10-16 01:26:58 -070018 /*
19 * FIXME: need to loop over userspace_pids
20 */
21 os_kill_ptraced_process(userspace_pid[0], 1);
22 else {
23 struct task_struct *p;
Richard Weinbergerf1c93e42011-07-25 17:12:55 -070024 int pid;
Jeff Dike77bf4402007-10-16 01:26:58 -070025
Anton Vorontsov9bd0a072012-05-31 16:26:25 -070026 read_lock(&tasklist_lock);
Jeff Dikec5d4bb12008-02-04 22:31:14 -080027 for_each_process(p) {
28 if (p->mm == NULL)
Jeff Dike77bf4402007-10-16 01:26:58 -070029 continue;
30
Jeff Dike6c738ff2007-10-16 01:27:06 -070031 pid = p->mm->context.id.u.pid;
Jeff Dike77bf4402007-10-16 01:26:58 -070032 os_kill_ptraced_process(pid, 1);
33 }
Anton Vorontsov9bd0a072012-05-31 16:26:25 -070034 read_unlock(&tasklist_lock);
Jeff Dike77bf4402007-10-16 01:26:58 -070035 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070036}
37
38void uml_cleanup(void)
39{
Jeff Dikeba180fd2007-10-16 01:27:00 -070040 kmalloc_ok = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070041 do_uml_exitcalls();
Jeff Dike026549d2005-06-25 14:55:23 -070042 kill_off_processes();
Linus Torvalds1da177e2005-04-16 15:20:36 -070043}
44
45void machine_restart(char * __unused)
46{
Jeff Dikeba180fd2007-10-16 01:27:00 -070047 uml_cleanup();
Jeff Dike6aa802c2007-10-16 01:26:56 -070048 reboot_skas();
Linus Torvalds1da177e2005-04-16 15:20:36 -070049}
50
Linus Torvalds1da177e2005-04-16 15:20:36 -070051void machine_power_off(void)
52{
Jeff Dikeba180fd2007-10-16 01:27:00 -070053 uml_cleanup();
Jeff Dike6aa802c2007-10-16 01:26:56 -070054 halt_skas();
Linus Torvalds1da177e2005-04-16 15:20:36 -070055}
56
Linus Torvalds1da177e2005-04-16 15:20:36 -070057void machine_halt(void)
58{
59 machine_power_off();
60}