blob: d29d37a2abb610c844deda222046a885d260b58c [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#ifndef _LINUX_REBOOT_H
3#define _LINUX_REBOOT_H
4
Linus Torvalds1da177e2005-04-16 15:20:36 -07005
6#include <linux/notifier.h>
David Howells607ca462012-10-13 10:46:48 +01007#include <uapi/linux/reboot.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07008
Andrey Smirnov2d8364b2017-11-17 15:30:57 -08009struct device;
Dmitry Osipenko232edc22022-05-10 02:32:11 +030010struct sys_off_handler;
Andrey Smirnov2d8364b2017-11-17 15:30:57 -080011
Amerigo Wangc5f41752011-07-25 17:13:10 -070012#define SYS_DOWN 0x0001 /* Notify of system down */
13#define SYS_RESTART SYS_DOWN
14#define SYS_HALT 0x0002 /* Notify of system halt */
15#define SYS_POWER_OFF 0x0003 /* Notify of system power off */
16
Robin Holtedf2b132013-07-08 16:01:35 -070017enum reboot_mode {
Aaro Koskinenb287a252019-05-14 15:45:37 -070018 REBOOT_UNDEFINED = -1,
Robin Holtedf2b132013-07-08 16:01:35 -070019 REBOOT_COLD = 0,
20 REBOOT_WARM,
Robin Holtc97a7002013-07-08 16:01:36 -070021 REBOOT_HARD,
22 REBOOT_SOFT,
Robin Holt7b6d8642013-07-08 16:01:40 -070023 REBOOT_GPIO,
Robin Holtedf2b132013-07-08 16:01:35 -070024};
Robin Holt1b3a5d02013-07-08 16:01:42 -070025extern enum reboot_mode reboot_mode;
Aaro Koskinenb287a252019-05-14 15:45:37 -070026extern enum reboot_mode panic_reboot_mode;
Robin Holt1b3a5d02013-07-08 16:01:42 -070027
28enum reboot_type {
Ingo Molnar5be44a62014-04-04 08:41:26 +020029 BOOT_TRIPLE = 't',
30 BOOT_KBD = 'k',
31 BOOT_BIOS = 'b',
32 BOOT_ACPI = 'a',
33 BOOT_EFI = 'e',
34 BOOT_CF9_FORCE = 'p',
35 BOOT_CF9_SAFE = 'q',
Robin Holt1b3a5d02013-07-08 16:01:42 -070036};
37extern enum reboot_type reboot_type;
38
39extern int reboot_default;
40extern int reboot_cpu;
41extern int reboot_force;
42
Robin Holtedf2b132013-07-08 16:01:35 -070043
Linus Torvalds1da177e2005-04-16 15:20:36 -070044extern int register_reboot_notifier(struct notifier_block *);
45extern int unregister_reboot_notifier(struct notifier_block *);
46
Andrey Smirnov2d8364b2017-11-17 15:30:57 -080047extern int devm_register_reboot_notifier(struct device *, struct notifier_block *);
48
Guenter Roeckb63adb972014-09-26 00:03:16 +000049extern int register_restart_handler(struct notifier_block *);
50extern int unregister_restart_handler(struct notifier_block *);
51extern void do_kernel_restart(char *cmd);
Linus Torvalds1da177e2005-04-16 15:20:36 -070052
53/*
54 * Architecture-specific implementations of sys_reboot commands.
55 */
56
Vivek Goyalc97102b2013-12-18 17:08:31 -080057extern void migrate_to_reboot_cpu(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -070058extern void machine_restart(char *cmd);
59extern void machine_halt(void);
60extern void machine_power_off(void);
61
Eric W. Biedermandc009d92005-06-25 14:57:52 -070062extern void machine_shutdown(void);
Alexander Nyberg6e274d12005-06-25 14:58:26 -070063struct pt_regs;
64extern void machine_crash_shutdown(struct pt_regs *);
Eric W. Biedermandc009d92005-06-25 14:57:52 -070065
Dmitry Osipenko2b6aa732022-05-10 02:32:13 +030066void do_kernel_power_off(void);
67
Robin Holt972ee832013-07-08 16:01:34 -070068/*
Dmitry Osipenko232edc22022-05-10 02:32:11 +030069 * sys-off handler API.
70 */
71
72/*
73 * Standard sys-off priority levels. Users are expected to set priorities
74 * relative to the standard levels.
75 *
76 * SYS_OFF_PRIO_PLATFORM: Use this for platform-level handlers.
77 *
78 * SYS_OFF_PRIO_LOW: Use this for handler of last resort.
79 *
80 * SYS_OFF_PRIO_DEFAULT: Use this for normal handlers.
81 *
82 * SYS_OFF_PRIO_HIGH: Use this for higher priority handlers.
83 *
84 * SYS_OFF_PRIO_FIRMWARE: Use this if handler uses firmware call.
85 */
86#define SYS_OFF_PRIO_PLATFORM -256
87#define SYS_OFF_PRIO_LOW -128
88#define SYS_OFF_PRIO_DEFAULT 0
89#define SYS_OFF_PRIO_HIGH 192
90#define SYS_OFF_PRIO_FIRMWARE 224
91
92enum sys_off_mode {
93 /**
94 * @SYS_OFF_MODE_POWER_OFF_PREPARE:
95 *
96 * Handlers prepare system to be powered off. Handlers are
97 * allowed to sleep.
98 */
99 SYS_OFF_MODE_POWER_OFF_PREPARE,
100
101 /**
102 * @SYS_OFF_MODE_POWER_OFF:
103 *
104 * Handlers power-off system. Handlers are disallowed to sleep.
105 */
106 SYS_OFF_MODE_POWER_OFF,
107
108 /**
109 * @SYS_OFF_MODE_RESTART:
110 *
111 * Handlers restart system. Handlers are disallowed to sleep.
112 */
113 SYS_OFF_MODE_RESTART,
114};
115
116/**
117 * struct sys_off_data - sys-off callback argument
118 *
119 * @mode: Mode ID. Currently used only by the sys-off restart mode,
120 * see enum reboot_mode for the available modes.
121 * @cb_data: User's callback data.
122 * @cmd: Command string. Currently used only by the sys-off restart mode,
123 * NULL otherwise.
124 */
125struct sys_off_data {
126 int mode;
127 void *cb_data;
128 const char *cmd;
129};
130
131struct sys_off_handler *
132register_sys_off_handler(enum sys_off_mode mode,
133 int priority,
134 int (*callback)(struct sys_off_data *data),
135 void *cb_data);
136void unregister_sys_off_handler(struct sys_off_handler *handler);
137
138int devm_register_sys_off_handler(struct device *dev,
139 enum sys_off_mode mode,
140 int priority,
141 int (*callback)(struct sys_off_data *data),
142 void *cb_data);
143
Dmitry Osipenkod2c54152022-05-10 02:32:34 +0300144int devm_register_power_off_handler(struct device *dev,
145 int (*callback)(struct sys_off_data *data),
146 void *cb_data);
147
Dmitry Osipenko6779db972022-05-10 02:32:35 +0300148int devm_register_restart_handler(struct device *dev,
149 int (*callback)(struct sys_off_data *data),
150 void *cb_data);
151
Dmitry Osipenkofb613752022-05-10 02:32:16 +0300152int register_platform_power_off(void (*power_off)(void));
153void unregister_platform_power_off(void (*power_off)(void));
154
Dmitry Osipenko232edc22022-05-10 02:32:11 +0300155/*
Eric W. Biederman4a00ea12005-07-26 11:24:14 -0600156 * Architecture independent implemenations of sys_reboot commands.
157 */
158
Huang Yingca195b72008-08-15 00:40:24 -0700159extern void kernel_restart_prepare(char *cmd);
Eric W. Biederman4a00ea12005-07-26 11:24:14 -0600160extern void kernel_restart(char *cmd);
161extern void kernel_halt(void);
162extern void kernel_power_off(void);
Dmitry Osipenko0e2110d2022-05-10 02:32:15 +0300163extern bool kernel_can_power_off(void);
Adrian Bunk83cc5ed2006-06-25 05:47:41 -0700164
Dave Youngeb5572f2010-03-10 15:23:59 -0800165extern int C_A_D; /* for sysctl */
Adrian Bunk83cc5ed2006-06-25 05:47:41 -0700166void ctrl_alt_del(void);
Eric W. Biederman4a00ea12005-07-26 11:24:14 -0600167
Jeremy Fitzhardinge10a0a8d2007-07-17 18:37:02 -0700168#define POWEROFF_CMD_PATH_LEN 256
169extern char poweroff_cmd[POWEROFF_CMD_PATH_LEN];
170
Joel Stanley7a54f462015-04-15 16:16:53 -0700171extern void orderly_poweroff(bool force);
172extern void orderly_reboot(void);
Matti Vaittinendfa19b12021-06-03 08:40:45 +0300173void hw_protection_shutdown(const char *reason, int ms_until_forced);
Jeremy Fitzhardinge10a0a8d2007-07-17 18:37:02 -0700174
Eric W. Biederman7c903472005-07-26 11:29:55 -0600175/*
176 * Emergency restart, callable from an interrupt handler.
177 */
178
179extern void emergency_restart(void);
180#include <asm/emergency-restart.h>
181
Linus Torvalds1da177e2005-04-16 15:20:36 -0700182#endif /* _LINUX_REBOOT_H */