qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Anthony Liguori <anthony@codemonkey.ws>
To: qemu-devel@nongnu.org
Subject: [Qemu-devel] [5055] Handle terminating signals (Gerd Hoffmann)
Date: Thu, 21 Aug 2008 20:08:03 +0000	[thread overview]
Message-ID: <E1KWGRv-0004PS-DQ@cvs.savannah.gnu.org> (raw)

Revision: 5055
          http://svn.sv.gnu.org/viewvc/?view=rev&root=qemu&revision=5055
Author:   aliguori
Date:     2008-08-21 20:08:03 +0000 (Thu, 21 Aug 2008)

Log Message:
-----------
Handle terminating signals (Gerd Hoffmann)

This patch makes qemu handle signals better.  It sets the request_shutdown
flag, making the main_loop exit and qemu taking the usual exit route, with
atexit handlers being called and so on, instead of qemu just being killed
by the signal.

To avoid calling vm_start() from the signal handler main_loop() got an
additional check so qemu_system_shutdown_request() works even when the
vm is in stopped state.

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>

Modified Paths:
--------------
    trunk/curses.c
    trunk/sdl.c
    trunk/vl.c

Modified: trunk/curses.c
===================================================================
--- trunk/curses.c	2008-08-21 19:33:09 UTC (rev 5054)
+++ trunk/curses.c	2008-08-21 20:08:03 UTC (rev 5055)
@@ -350,8 +350,6 @@
     atexit(curses_atexit);
 
 #ifndef _WIN32
-    signal(SIGINT, SIG_DFL);
-    signal(SIGQUIT, SIG_DFL);
 #if defined(SIGWINCH) && defined(KEY_RESIZE)
     /* some curses implementations provide a handler, but we
      * want to be sure this is handled regardless of the library */

Modified: trunk/sdl.c
===================================================================
--- trunk/sdl.c	2008-08-21 19:33:09 UTC (rev 5054)
+++ trunk/sdl.c	2008-08-21 20:08:03 UTC (rev 5055)
@@ -476,10 +476,8 @@
                 sdl_process_key(&ev->key);
             break;
         case SDL_QUIT:
-            if (!no_quit) {
+            if (!no_quit)
                 qemu_system_shutdown_request();
-                vm_start();	/* In case we're paused */
-            }
             break;
         case SDL_MOUSEMOTION:
             if (gui_grab || kbd_mouse_is_absolute() ||
@@ -636,11 +634,6 @@
         fprintf(stderr, "Could not initialize SDL - exiting\n");
         exit(1);
     }
-#ifndef _WIN32
-    /* NOTE: we still want Ctrl-C to work, so we undo the SDL redirections */
-    signal(SIGINT, SIG_DFL);
-    signal(SIGQUIT, SIG_DFL);
-#endif
 
     ds->dpy_update = sdl_update;
     ds->dpy_resize = sdl_resize;

Modified: trunk/vl.c
===================================================================
--- trunk/vl.c	2008-08-21 19:33:09 UTC (rev 5054)
+++ trunk/vl.c	2008-08-21 20:08:03 UTC (rev 5055)
@@ -7621,6 +7621,8 @@
                 timeout = 0;
             }
         } else {
+            if (shutdown_requested)
+                break;
             timeout = 10;
         }
 #ifdef CONFIG_PROFILER
@@ -8185,6 +8187,26 @@
 
 #define MAX_NET_CLIENTS 32
 
+#ifndef _WIN32
+
+static void termsig_handler(int signal)
+{
+    qemu_system_shutdown_request();
+}
+
+void termsig_setup(void)
+{
+    struct sigaction act;
+
+    memset(&act, 0, sizeof(act));
+    act.sa_handler = termsig_handler;
+    sigaction(SIGINT,  &act, NULL);
+    sigaction(SIGHUP,  &act, NULL);
+    sigaction(SIGTERM, &act, NULL);
+}
+
+#endif
+
 int main(int argc, char **argv)
 {
 #ifdef CONFIG_GDBSTUB
@@ -9073,6 +9095,11 @@
 #endif
     }
 
+#ifndef _WIN32
+    /* must be after terminal init, SDL library changes signal handlers */
+    termsig_setup();
+#endif
+
     /* Maintain compatibility with multiple stdio monitors */
     if (!strcmp(monitor_device,"stdio")) {
         for (i = 0; i < MAX_SERIAL_PORTS; i++) {

             reply	other threads:[~2008-08-21 20:08 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-08-21 20:08 Anthony Liguori [this message]
2008-08-22 10:48 ` [Qemu-devel] Re: [5055] Handle terminating signals (Gerd Hoffmann) Jan Kiszka
2008-08-22 11:32   ` Gerd Hoffmann
2008-08-22 11:55     ` Jan Kiszka
2008-08-22 12:06       ` Gerd Hoffmann
2008-08-22 13:21         ` Jan Kiszka
2008-08-22 12:52   ` Anthony Liguori
2008-08-22 13:20     ` Jan Kiszka
2008-08-22 13:50       ` Anthony Liguori
2008-09-02 11:21   ` Jan Kiszka

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=E1KWGRv-0004PS-DQ@cvs.savannah.gnu.org \
    --to=anthony@codemonkey.ws \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).