[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20181126205723.14478-1-mark.tomlinson@alliedtelesis.co.nz>
Date: Tue, 27 Nov 2018 09:57:23 +1300
From: Mark Tomlinson <mark.tomlinson@...iedtelesis.co.nz>
To: gregkh@...uxfoundation.org, linux-kernel@...r.kernel.org
Cc: Mark Tomlinson <mark.tomlinson@...iedtelesis.co.nz>
Subject: [PATCH RESEND] tty/sysrq: Do not call sync directly from sysrq_do_reset()
sysrq_do_reset() is called in softirq context, so it cannot call
sync() directly. Instead, call orderly_reboot(), which creates a work
item to run /sbin/reboot, or do emergency_sync and restart if the
command fails.
Signed-off-by: Mark Tomlinson <mark.tomlinson@...iedtelesis.co.nz>
---
drivers/tty/sysrq.c | 3 +--
1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/drivers/tty/sysrq.c b/drivers/tty/sysrq.c
index ad1ee5d01b53..f2ca32c1ad7c 100644
--- a/drivers/tty/sysrq.c
+++ b/drivers/tty/sysrq.c
@@ -660,8 +660,7 @@ static void sysrq_do_reset(struct timer_list *t)
state->reset_requested = true;
- ksys_sync();
- kernel_restart(NULL);
+ orderly_reboot();
}
static void sysrq_handle_reset_request(struct sysrq_state *state)
--
2.19.2
Powered by blists - more mailing lists