* [Qemu-devel] [PATCH V2] char: restore stdio echo on resume from suspend.
@ 2015-01-07 8:38 Gal Hammer
2015-01-07 9:43 ` Paolo Bonzini
0 siblings, 1 reply; 2+ messages in thread
From: Gal Hammer @ 2015-01-07 8:38 UTC (permalink / raw)
To: qemu-devel; +Cc: Gal Hammer, peter.maydell, marcel.apfelbaum, pbonzini
The monitor's auto-completion feature stopped working when stdio is used
as an input and qemu was resumed after it was suspended (using ctrl-z).
Signed-off-by: Gal Hammer <ghammer@redhat.com>
---
V2 - restore old echo state rather than alway disable it.
- don't check signal identifier in the handler function.
- use sigaction() and not signal().
---
qemu-char.c | 15 +++++++++++++++
1 file changed, 15 insertions(+)
diff --git a/qemu-char.c b/qemu-char.c
index ef84b53..5430b87 100644
--- a/qemu-char.c
+++ b/qemu-char.c
@@ -1112,6 +1112,9 @@ static struct termios oldtty;
static int old_fd0_flags;
static bool stdio_in_use;
static bool stdio_allow_signal;
+static bool stdio_echo_state;
+
+static void qemu_chr_set_echo_stdio(CharDriverState *chr, bool echo);
static void term_exit(void)
{
@@ -1119,10 +1122,17 @@ static void term_exit(void)
fcntl(0, F_SETFL, old_fd0_flags);
}
+static void term_stdio_handler(int sig)
+{
+ /* restore echo after resume from suspend. */
+ qemu_chr_set_echo_stdio(NULL, stdio_echo_state);
+}
+
static void qemu_chr_set_echo_stdio(CharDriverState *chr, bool echo)
{
struct termios tty;
+ stdio_echo_state = echo;
tty = oldtty;
if (!echo) {
tty.c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP
@@ -1149,6 +1159,7 @@ static void qemu_chr_close_stdio(struct CharDriverState *chr)
static CharDriverState *qemu_chr_open_stdio(ChardevStdio *opts)
{
CharDriverState *chr;
+ struct sigaction act;
if (is_daemonized()) {
error_report("cannot use stdio with -daemonize");
@@ -1166,6 +1177,10 @@ static CharDriverState *qemu_chr_open_stdio(ChardevStdio *opts)
qemu_set_nonblock(0);
atexit(term_exit);
+ memset(&act, 0, sizeof(act));
+ act.sa_handler = term_stdio_handler;
+ sigaction(SIGCONT, &act, NULL);
+
chr = qemu_chr_open_fd(0, 1);
chr->chr_close = qemu_chr_close_stdio;
chr->chr_set_echo = qemu_chr_set_echo_stdio;
--
2.1.0
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [Qemu-devel] [PATCH V2] char: restore stdio echo on resume from suspend.
2015-01-07 8:38 [Qemu-devel] [PATCH V2] char: restore stdio echo on resume from suspend Gal Hammer
@ 2015-01-07 9:43 ` Paolo Bonzini
0 siblings, 0 replies; 2+ messages in thread
From: Paolo Bonzini @ 2015-01-07 9:43 UTC (permalink / raw)
To: Gal Hammer, qemu-devel; +Cc: peter.maydell, marcel.apfelbaum
On 07/01/2015 09:38, Gal Hammer wrote:
> The monitor's auto-completion feature stopped working when stdio is used
> as an input and qemu was resumed after it was suspended (using ctrl-z).
>
> Signed-off-by: Gal Hammer <ghammer@redhat.com>
Looks good, thanks Peter for reviewing v1.
Paolo
> ---
> V2 - restore old echo state rather than alway disable it.
> - don't check signal identifier in the handler function.
> - use sigaction() and not signal().
> ---
> qemu-char.c | 15 +++++++++++++++
> 1 file changed, 15 insertions(+)
>
> diff --git a/qemu-char.c b/qemu-char.c
> index ef84b53..5430b87 100644
> --- a/qemu-char.c
> +++ b/qemu-char.c
> @@ -1112,6 +1112,9 @@ static struct termios oldtty;
> static int old_fd0_flags;
> static bool stdio_in_use;
> static bool stdio_allow_signal;
> +static bool stdio_echo_state;
> +
> +static void qemu_chr_set_echo_stdio(CharDriverState *chr, bool echo);
>
> static void term_exit(void)
> {
> @@ -1119,10 +1122,17 @@ static void term_exit(void)
> fcntl(0, F_SETFL, old_fd0_flags);
> }
>
> +static void term_stdio_handler(int sig)
> +{
> + /* restore echo after resume from suspend. */
> + qemu_chr_set_echo_stdio(NULL, stdio_echo_state);
> +}
> +
> static void qemu_chr_set_echo_stdio(CharDriverState *chr, bool echo)
> {
> struct termios tty;
>
> + stdio_echo_state = echo;
> tty = oldtty;
> if (!echo) {
> tty.c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP
> @@ -1149,6 +1159,7 @@ static void qemu_chr_close_stdio(struct CharDriverState *chr)
> static CharDriverState *qemu_chr_open_stdio(ChardevStdio *opts)
> {
> CharDriverState *chr;
> + struct sigaction act;
>
> if (is_daemonized()) {
> error_report("cannot use stdio with -daemonize");
> @@ -1166,6 +1177,10 @@ static CharDriverState *qemu_chr_open_stdio(ChardevStdio *opts)
> qemu_set_nonblock(0);
> atexit(term_exit);
>
> + memset(&act, 0, sizeof(act));
> + act.sa_handler = term_stdio_handler;
> + sigaction(SIGCONT, &act, NULL);
> +
> chr = qemu_chr_open_fd(0, 1);
> chr->chr_close = qemu_chr_close_stdio;
> chr->chr_set_echo = qemu_chr_set_echo_stdio;
>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2015-01-07 14:16 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-01-07 8:38 [Qemu-devel] [PATCH V2] char: restore stdio echo on resume from suspend Gal Hammer
2015-01-07 9:43 ` Paolo Bonzini
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).