qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [PATCH risu] A script to run concurrently the master and th


From: Laurent Vivier
Subject: [Qemu-devel] [PATCH risu] A script to run concurrently the master and the apprentice
Date: Fri, 9 Dec 2016 00:21:00 +0100

This expect script will generate the .out file and then
start the apprentice in a chroot and the master on the reference
hardware. The list of patterns is given on the command line.

As my reference system is very slow, ssh can take more than 2 minutes,
this script starts a ssh and a chroot once, and interacts with
them to run the list of instruction patterns given on the command line.

Some environment variables define the test environment:
- RISU_ARCH: the pattern file used will be $RISU_ARCH.risu
- RISU_MASTER: the IP address or name of the reference hardware (for ssh)
- RISU_CHROOT: the path of the QEMU chroot to start the apprentice
- RISU_PATH: the path, common to master and apprentice (you can use NFS),
             where the risu files are stored (binaries and data).

Example:

$ RISU_ARCH=m68k RISU_MASTER=q800 \
  RISU_CHROOT=/var/lib/lxc/virtm68k-etch-m68k/rootfs \
  RISU_PATH=/nfs/home/laurent/q800/risu \
  ./automatic-run ASx ADD AND OR EOR

Signed-off-by: Laurent Vivier <address@hidden>
---
 automatic-run | 84 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 84 insertions(+)
 create mode 100755 automatic-run

diff --git a/automatic-run b/automatic-run
new file mode 100755
index 0000000..3517f37
--- /dev/null
+++ b/automatic-run
@@ -0,0 +1,84 @@
+#!/usr/bin/expect -f
+#
+# This script generates the risugen output for a given
+# list of instructions
+# Then it runs concurrently the master and the apprentice:
+# - the master is started on remote host provided by the
+#   environment variable RISU_MASTER
+# - the apprentice is started in a chroot provided by the
+#   environment variable RISU_CHROOT
+# Master and apprentice must share a directory, the path
+# of this directory is given by RISU_PATH. The risu files
+# will be searched in this directory.
+# The RISU_ARCH gives the name of the risu patterns file
+# to use.
+#
+# Example:
+#
+#    RISU_ARCH=m68k RISU_MASTER=192.168.100.3 \
+#    RISU_CHROOT=/chroot/m68k \
+#    RISU_PATH=/nfs/risu ./automatic-run ASx ADD AND
+#
+set arch $env(RISU_ARCH)
+set master $env(RISU_MASTER)
+set chroot $env(RISU_CHROOT)
+set risupath $env(RISU_PATH)
+set numinsns 10000
+
+set prompt "(%|#|\\$) $"
+
+set timeout 1
+spawn sudo -S chroot $chroot
+expect {
+    -re ":" {
+        set timeout 300
+        stty -echo
+        expect_user -re "(.*)\n"
+        send "$expect_out(1,string)\r"
+        stty echo
+        expect -r $prompt
+    }
+}
+send "ls $risupath > /dev/null; echo RESULT:$?\n"
+expect {
+   "RESULT:2" { exit 1 }
+   -re $prompt
+}
+
+set timeout 1
+set retry 0
+expect {
+    timeout { if { $retry == 5 } { exit 2}
+              incr retry 1
+              send "\r"
+              exp_continue;
+            }
+    -re $prompt
+}
+
+set chroot_id $spawn_id
+spawn ssh $master
+
+set timeout 600
+expect {
+    timeout { send "\r"; exp_continue; }
+    -re $prompt
+}
+
+for { set arg 0 } { $arg < $argc } { incr arg 1 } {
+    set insn  [lindex $argv $arg]
+
+    system $risupath/risugen --numinsns $numinsns --pattern $insn 
$risupath/$arch.risu $risupath/$insn.out
+
+    send "$risupath/risu --master $risupath/$insn.out\n"
+
+    expect "master: waiting for connection on port 9191..."
+
+    send -i $chroot_id "$risupath/risu --host $master $risupath/$insn.out\n"
+
+    expect {
+        "mismatch!" { exit 3 }
+        "match!";
+    }
+    expect -re $prompt
+}
-- 
2.7.4




reply via email to

[Prev in Thread] Current Thread [Next in Thread]