* [Qemu-devel] [PATCH] chardev: don't splatter terminal settings on exit if not previously set
@ 2018-06-04 12:30 Daniel P. Berrangé
2018-06-04 12:52 ` Marc-André Lureau
0 siblings, 1 reply; 2+ messages in thread
From: Daniel P. Berrangé @ 2018-06-04 12:30 UTC (permalink / raw)
To: qemu-devel; +Cc: Paolo Bonzini, Marc-André Lureau, Daniel P. Berrangé
The stdio chardev finalize method calls term_exit() to restore the
original terminal settings that were saved in the "oldtty" global. If
the qemu_chr_open_stdio() method exited with an error, we might not have
any original terminal settings saved in "oldtty" yet.
eg
$ qemu-system-x86_64 -monitor stdio -daemonize
qemu-system-x86_64: -monitor stdio: cannot use stdio with -daemonize
will cause QEMU to splatter the terminal settings with an all-zeros
"struct termios", with predictably unpleasant results. Fortunately the
existing "stdio_in_use" flag is suitable witness for whether "oldtty"
contains settings that need restoring.
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
---
chardev/char-stdio.c | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/chardev/char-stdio.c b/chardev/char-stdio.c
index d83e60e787..8039e85f64 100644
--- a/chardev/char-stdio.c
+++ b/chardev/char-stdio.c
@@ -46,8 +46,10 @@ static bool stdio_echo_state;
static void term_exit(void)
{
- tcsetattr(0, TCSANOW, &oldtty);
- fcntl(0, F_SETFL, old_fd0_flags);
+ if (stdio_in_use) {
+ tcsetattr(0, TCSANOW, &oldtty);
+ fcntl(0, F_SETFL, old_fd0_flags);
+ }
}
static void qemu_chr_set_echo_stdio(Chardev *chr, bool echo)
--
2.17.0
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [Qemu-devel] [PATCH] chardev: don't splatter terminal settings on exit if not previously set
2018-06-04 12:30 [Qemu-devel] [PATCH] chardev: don't splatter terminal settings on exit if not previously set Daniel P. Berrangé
@ 2018-06-04 12:52 ` Marc-André Lureau
0 siblings, 0 replies; 2+ messages in thread
From: Marc-André Lureau @ 2018-06-04 12:52 UTC (permalink / raw)
To: Daniel P. Berrangé; +Cc: qemu-devel, Paolo Bonzini
On Mon, Jun 4, 2018 at 2:30 PM, Daniel P. Berrangé <berrange@redhat.com> wrote:
> The stdio chardev finalize method calls term_exit() to restore the
> original terminal settings that were saved in the "oldtty" global. If
> the qemu_chr_open_stdio() method exited with an error, we might not have
> any original terminal settings saved in "oldtty" yet.
>
> eg
>
> $ qemu-system-x86_64 -monitor stdio -daemonize
> qemu-system-x86_64: -monitor stdio: cannot use stdio with -daemonize
>
> will cause QEMU to splatter the terminal settings with an all-zeros
> "struct termios", with predictably unpleasant results. Fortunately the
> existing "stdio_in_use" flag is suitable witness for whether "oldtty"
> contains settings that need restoring.
>
> Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
> ---
> chardev/char-stdio.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/chardev/char-stdio.c b/chardev/char-stdio.c
> index d83e60e787..8039e85f64 100644
> --- a/chardev/char-stdio.c
> +++ b/chardev/char-stdio.c
> @@ -46,8 +46,10 @@ static bool stdio_echo_state;
>
> static void term_exit(void)
> {
> - tcsetattr(0, TCSANOW, &oldtty);
> - fcntl(0, F_SETFL, old_fd0_flags);
> + if (stdio_in_use) {
> + tcsetattr(0, TCSANOW, &oldtty);
> + fcntl(0, F_SETFL, old_fd0_flags);
> + }
> }
>
> static void qemu_chr_set_echo_stdio(Chardev *chr, bool echo)
> --
> 2.17.0
>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2018-06-04 12:52 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-06-04 12:30 [Qemu-devel] [PATCH] chardev: don't splatter terminal settings on exit if not previously set Daniel P. Berrangé
2018-06-04 12:52 ` Marc-André Lureau
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).