Patchwork [5/5] s390x: implement SIGP restart and shutdown

login
register
mail settings
Submitter Alexander Graf
Date July 13, 2011, 2:44 a.m.
Message ID <1310525052-22530-6-git-send-email-agraf@suse.de>
Download mbox | patch
Permalink /patch/104659/
State New
Headers show

Comments

Alexander Graf - July 13, 2011, 2:44 a.m.
An s390x OS does reboot and shutdown triggers through hypercalls that
we didn't implement on the TCG backend yet. That means that so far we
couldn't shut down virtual machines for example, having them hang on
shutdown when not using KVM.

With this patch, this restriction is gone. We can now shut down and
reboot s390x virtual machines even when using the TCG backend.

Signed-off-by: Alexander Graf <agraf@suse.de>
---
 target-s390x/op_helper.c |   14 ++++++++++++++
 1 files changed, 14 insertions(+), 0 deletions(-)

Patch

diff --git a/target-s390x/op_helper.c b/target-s390x/op_helper.c
index 356eac8..bbc2002 100644
--- a/target-s390x/op_helper.c
+++ b/target-s390x/op_helper.c
@@ -28,6 +28,10 @@ 
 #include <linux/kvm.h>
 #endif
 
+#if !defined (CONFIG_USER_ONLY)
+#include "sysemu.h"
+#endif
+
 /*****************************************************************************/
 /* Softmmu support */
 #if !defined (CONFIG_USER_ONLY)
@@ -2900,6 +2904,16 @@  uint32_t HELPER(sigp)(uint64_t order_code, uint32_t r1, uint64_t cpu_addr)
         env->regs[r1] &= 0xffffffff00000000ULL;
         cc = 1;
         break;
+#if !defined (CONFIG_USER_ONLY)
+    case SIGP_RESTART:
+        qemu_system_reset_request();
+        cpu_loop_exit(env);
+        break;
+    case SIGP_STOP:
+        qemu_system_shutdown_request();
+        cpu_loop_exit(env);
+        break;
+#endif
     default:
         /* unknown sigp */
         fprintf(stderr, "XXX unknown sigp: 0x%" PRIx64 "\n", order_code);