How and when is the command string arg to reboot() with LINUX_REBOOT_CMD_RESTART2 executed?
The manpage of reboot() says
LINUX_REBOOT_CMD_RESTART2
(0xa1b2c3d4; since Linux 2.1.30). The message "Restarting
system with command '%s'" is printed, and a restart (using the
command string given in arg) is performed immediately. If not
preceded by a sync(2), data will be lost.
How and when exactly is the command string given in arg is executed during shutdown process?
https://unix.stackexchange.com/a/489651/674 says about LINUX_REBOOT_CMD_RESTART2
An added confusion here is caused by the fact that the
reboot()
system call appears to be capable of running a process to do the
restart (however that works)
Is the command string given in arg run before the kernel is shutdown, so can the command do some cleanup before kernel shutdown?
Thanks.
linux reboot
add a comment |
The manpage of reboot() says
LINUX_REBOOT_CMD_RESTART2
(0xa1b2c3d4; since Linux 2.1.30). The message "Restarting
system with command '%s'" is printed, and a restart (using the
command string given in arg) is performed immediately. If not
preceded by a sync(2), data will be lost.
How and when exactly is the command string given in arg is executed during shutdown process?
https://unix.stackexchange.com/a/489651/674 says about LINUX_REBOOT_CMD_RESTART2
An added confusion here is caused by the fact that the
reboot()
system call appears to be capable of running a process to do the
restart (however that works)
Is the command string given in arg run before the kernel is shutdown, so can the command do some cleanup before kernel shutdown?
Thanks.
linux reboot
add a comment |
The manpage of reboot() says
LINUX_REBOOT_CMD_RESTART2
(0xa1b2c3d4; since Linux 2.1.30). The message "Restarting
system with command '%s'" is printed, and a restart (using the
command string given in arg) is performed immediately. If not
preceded by a sync(2), data will be lost.
How and when exactly is the command string given in arg is executed during shutdown process?
https://unix.stackexchange.com/a/489651/674 says about LINUX_REBOOT_CMD_RESTART2
An added confusion here is caused by the fact that the
reboot()
system call appears to be capable of running a process to do the
restart (however that works)
Is the command string given in arg run before the kernel is shutdown, so can the command do some cleanup before kernel shutdown?
Thanks.
linux reboot
The manpage of reboot() says
LINUX_REBOOT_CMD_RESTART2
(0xa1b2c3d4; since Linux 2.1.30). The message "Restarting
system with command '%s'" is printed, and a restart (using the
command string given in arg) is performed immediately. If not
preceded by a sync(2), data will be lost.
How and when exactly is the command string given in arg is executed during shutdown process?
https://unix.stackexchange.com/a/489651/674 says about LINUX_REBOOT_CMD_RESTART2
An added confusion here is caused by the fact that the
reboot()
system call appears to be capable of running a process to do the
restart (however that works)
Is the command string given in arg run before the kernel is shutdown, so can the command do some cleanup before kernel shutdown?
Thanks.
linux reboot
linux reboot
asked Dec 19 '18 at 19:48
Tim
26k74246455
26k74246455
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
That command is not executed during the shutdown process. It's not a shell command or such; it's a string that's supposed to be passed as callback data (via machine_restart()
=> do_kernel_restart()
) to the restart handler registered via register_restart_handler()
by some driver (watchdog, etc).
But that mechanism is not used on x86; there that "command" is completely ignored. From arch/x86/kernel/reboot.c
:
void machine_restart(char *cmd)
{
machine_ops.restart(cmd);
struct machine_ops machine_ops __ro_after_init = {
...
.restart = native_machine_restart,
static void native_machine_restart(char *__unused)
{
That string will be also passed to the handlers registered with register_reboot_notifier()
. The only driver which is (ab)using that seems to be EFI Bootloader Control which is setting the non-volative LoaderEntryOneShot
EFI variable from it, causing some bootloaders to determine which OS should be booted in next. I don't think that driver was ever used outside Android -- but in any case it looks quite clunky, as it's also detailed in an old lkml discussion concerning a previous version of that same thing.
Thanks. I am using X86-64.
– Tim
Dec 20 '18 at 4:56
Yeah, seems like I misinterpreted the meaning of that "with command" phrase in the man page. Not that the man page is too clear on what the commands could be, or what architectures even use it. Sigh.
– ilkkachu
Dec 20 '18 at 14:45
add a comment |
Your Answer
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "106"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f489995%2fhow-and-when-is-the-command-string-arg-to-reboot-with-linux-reboot-cmd-restart%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
That command is not executed during the shutdown process. It's not a shell command or such; it's a string that's supposed to be passed as callback data (via machine_restart()
=> do_kernel_restart()
) to the restart handler registered via register_restart_handler()
by some driver (watchdog, etc).
But that mechanism is not used on x86; there that "command" is completely ignored. From arch/x86/kernel/reboot.c
:
void machine_restart(char *cmd)
{
machine_ops.restart(cmd);
struct machine_ops machine_ops __ro_after_init = {
...
.restart = native_machine_restart,
static void native_machine_restart(char *__unused)
{
That string will be also passed to the handlers registered with register_reboot_notifier()
. The only driver which is (ab)using that seems to be EFI Bootloader Control which is setting the non-volative LoaderEntryOneShot
EFI variable from it, causing some bootloaders to determine which OS should be booted in next. I don't think that driver was ever used outside Android -- but in any case it looks quite clunky, as it's also detailed in an old lkml discussion concerning a previous version of that same thing.
Thanks. I am using X86-64.
– Tim
Dec 20 '18 at 4:56
Yeah, seems like I misinterpreted the meaning of that "with command" phrase in the man page. Not that the man page is too clear on what the commands could be, or what architectures even use it. Sigh.
– ilkkachu
Dec 20 '18 at 14:45
add a comment |
That command is not executed during the shutdown process. It's not a shell command or such; it's a string that's supposed to be passed as callback data (via machine_restart()
=> do_kernel_restart()
) to the restart handler registered via register_restart_handler()
by some driver (watchdog, etc).
But that mechanism is not used on x86; there that "command" is completely ignored. From arch/x86/kernel/reboot.c
:
void machine_restart(char *cmd)
{
machine_ops.restart(cmd);
struct machine_ops machine_ops __ro_after_init = {
...
.restart = native_machine_restart,
static void native_machine_restart(char *__unused)
{
That string will be also passed to the handlers registered with register_reboot_notifier()
. The only driver which is (ab)using that seems to be EFI Bootloader Control which is setting the non-volative LoaderEntryOneShot
EFI variable from it, causing some bootloaders to determine which OS should be booted in next. I don't think that driver was ever used outside Android -- but in any case it looks quite clunky, as it's also detailed in an old lkml discussion concerning a previous version of that same thing.
Thanks. I am using X86-64.
– Tim
Dec 20 '18 at 4:56
Yeah, seems like I misinterpreted the meaning of that "with command" phrase in the man page. Not that the man page is too clear on what the commands could be, or what architectures even use it. Sigh.
– ilkkachu
Dec 20 '18 at 14:45
add a comment |
That command is not executed during the shutdown process. It's not a shell command or such; it's a string that's supposed to be passed as callback data (via machine_restart()
=> do_kernel_restart()
) to the restart handler registered via register_restart_handler()
by some driver (watchdog, etc).
But that mechanism is not used on x86; there that "command" is completely ignored. From arch/x86/kernel/reboot.c
:
void machine_restart(char *cmd)
{
machine_ops.restart(cmd);
struct machine_ops machine_ops __ro_after_init = {
...
.restart = native_machine_restart,
static void native_machine_restart(char *__unused)
{
That string will be also passed to the handlers registered with register_reboot_notifier()
. The only driver which is (ab)using that seems to be EFI Bootloader Control which is setting the non-volative LoaderEntryOneShot
EFI variable from it, causing some bootloaders to determine which OS should be booted in next. I don't think that driver was ever used outside Android -- but in any case it looks quite clunky, as it's also detailed in an old lkml discussion concerning a previous version of that same thing.
That command is not executed during the shutdown process. It's not a shell command or such; it's a string that's supposed to be passed as callback data (via machine_restart()
=> do_kernel_restart()
) to the restart handler registered via register_restart_handler()
by some driver (watchdog, etc).
But that mechanism is not used on x86; there that "command" is completely ignored. From arch/x86/kernel/reboot.c
:
void machine_restart(char *cmd)
{
machine_ops.restart(cmd);
struct machine_ops machine_ops __ro_after_init = {
...
.restart = native_machine_restart,
static void native_machine_restart(char *__unused)
{
That string will be also passed to the handlers registered with register_reboot_notifier()
. The only driver which is (ab)using that seems to be EFI Bootloader Control which is setting the non-volative LoaderEntryOneShot
EFI variable from it, causing some bootloaders to determine which OS should be booted in next. I don't think that driver was ever used outside Android -- but in any case it looks quite clunky, as it's also detailed in an old lkml discussion concerning a previous version of that same thing.
edited Dec 20 '18 at 6:21
answered Dec 20 '18 at 4:51
mosvy
6,0311425
6,0311425
Thanks. I am using X86-64.
– Tim
Dec 20 '18 at 4:56
Yeah, seems like I misinterpreted the meaning of that "with command" phrase in the man page. Not that the man page is too clear on what the commands could be, or what architectures even use it. Sigh.
– ilkkachu
Dec 20 '18 at 14:45
add a comment |
Thanks. I am using X86-64.
– Tim
Dec 20 '18 at 4:56
Yeah, seems like I misinterpreted the meaning of that "with command" phrase in the man page. Not that the man page is too clear on what the commands could be, or what architectures even use it. Sigh.
– ilkkachu
Dec 20 '18 at 14:45
Thanks. I am using X86-64.
– Tim
Dec 20 '18 at 4:56
Thanks. I am using X86-64.
– Tim
Dec 20 '18 at 4:56
Yeah, seems like I misinterpreted the meaning of that "with command" phrase in the man page. Not that the man page is too clear on what the commands could be, or what architectures even use it. Sigh.
– ilkkachu
Dec 20 '18 at 14:45
Yeah, seems like I misinterpreted the meaning of that "with command" phrase in the man page. Not that the man page is too clear on what the commands could be, or what architectures even use it. Sigh.
– ilkkachu
Dec 20 '18 at 14:45
add a comment |
Thanks for contributing an answer to Unix & Linux Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f489995%2fhow-and-when-is-the-command-string-arg-to-reboot-with-linux-reboot-cmd-restart%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown