Hello community,

here is the log from the commit of package qemu for openSUSE:Factory checked in 
at 2015-05-15 07:43:57
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/qemu (Old)
 and      /work/SRC/openSUSE:Factory/.qemu.new (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "qemu"

Changes:
--------
--- /work/SRC/openSUSE:Factory/qemu/libcacard.changes   2015-05-02 
17:31:33.000000000 +0200
+++ /work/SRC/openSUSE:Factory/.qemu.new/libcacard.changes      2015-05-15 
07:44:23.000000000 +0200
@@ -1,0 +2,7 @@
+Tue May 12 22:43:56 UTC 2015 - ag...@suse.com
+
+- Patch queue updated from git://github.com/openSUSE/qemu.git opensuse-2.3
+* Patches added:
+  0040-s390x-Add-interlocked-access-facili.patch
+
+-------------------------------------------------------------------
--- /work/SRC/openSUSE:Factory/qemu/qemu-linux-user.changes     2015-05-10 
10:54:27.000000000 +0200
+++ /work/SRC/openSUSE:Factory/.qemu.new/qemu-linux-user.changes        
2015-05-15 07:44:23.000000000 +0200
@@ -1,0 +2,13 @@
+Tue May 12 22:43:53 UTC 2015 - ag...@suse.com
+
+- Patch queue updated from git://github.com/openSUSE/qemu.git opensuse-2.3
+- Fix illegal instruction for s390x SLE12 guest binaries
+* Patches added:
+  0040-s390x-Add-interlocked-access-facili.patch
+
+-------------------------------------------------------------------
+Sun May 10 14:55:31 UTC 2015 - afaer...@suse.de
+
+- Add %check executing /usr/bin/ls via qemu-HOSTARCH
+
+-------------------------------------------------------------------
--- /work/SRC/openSUSE:Factory/qemu/qemu-testsuite.changes      2015-05-02 
17:31:33.000000000 +0200
+++ /work/SRC/openSUSE:Factory/.qemu.new/qemu-testsuite.changes 2015-05-15 
07:44:23.000000000 +0200
@@ -1,0 +2,8 @@
+Tue May 12 22:43:49 UTC 2015 - ag...@suse.com
+
+- Patch queue updated from git://github.com/openSUSE/qemu.git opensuse-2.3
+* Patches added:
+  0040-s390x-Add-interlocked-access-facili.patch
+- Disable dependency on libnuma for s390x (not available in SLE12)
+
+-------------------------------------------------------------------
qemu.changes: same change

New:
----
  0040-s390x-Add-interlocked-access-facili.patch

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ libcacard.spec ++++++
--- /var/tmp/diff_new_pack.HYkqgw/_old  2015-05-15 07:44:25.000000000 +0200
+++ /var/tmp/diff_new_pack.HYkqgw/_new  2015-05-15 07:44:25.000000000 +0200
@@ -64,6 +64,7 @@
 Patch0037:      0037-linux-user-Allocate-thunk-size-dyna.patch
 Patch0038:      0038-Revert-Revert-seccomp-tests-that-al.patch
 Patch0039:      0039-s390x-Fix-stoc-direction.patch
+Patch0040:      0040-s390x-Add-interlocked-access-facili.patch
 # Please do not add patches manually here, run update_git.sh.
 # this is to make lint happy
 Source300:      qemu-rpmlintrc
@@ -162,6 +163,7 @@
 %patch0037 -p1
 %patch0038 -p1
 %patch0039 -p1
+%patch0040 -p1
 
 %build
 ./configure --prefix=%_prefix --sysconfdir=%_sysconfdir \

++++++ qemu-linux-user.spec ++++++
--- /var/tmp/diff_new_pack.HYkqgw/_old  2015-05-15 07:44:26.000000000 +0200
+++ /var/tmp/diff_new_pack.HYkqgw/_new  2015-05-15 07:44:26.000000000 +0200
@@ -64,6 +64,7 @@
 Patch0037:      0037-linux-user-Allocate-thunk-size-dyna.patch
 Patch0038:      0038-Revert-Revert-seccomp-tests-that-al.patch
 Patch0039:      0039-s390x-Fix-stoc-direction.patch
+Patch0040:      0040-s390x-Add-interlocked-access-facili.patch
 # Please do not add patches manually here, run update_git.sh.
 # this is to make lint happy
 Source300:      qemu-rpmlintrc
@@ -156,6 +157,7 @@
 %patch0037 -p1
 %patch0038 -p1
 %patch0039 -p1
+%patch0040 -p1
 
 %build
 ./configure --prefix=%_prefix --sysconfdir=%_sysconfdir \
@@ -176,6 +178,36 @@
 %endif
 make %{?_smp_mflags} V=1
 
+%ifarch %ix86
+%define qemu_arch i386
+%endif
+%ifarch x86_64
+%define qemu_arch x86_64
+%endif
+%ifarch %arm
+%define qemu_arch arm
+%endif
+%ifarch aarch64
+%define qemu_arch aarch64
+%endif
+%ifarch ppc
+%define qemu_arch ppc
+%endif
+%ifarch ppc64
+%define qemu_arch ppc64
+%endif
+%ifarch ppc64le
+%define qemu_arch ppc64le
+%endif
+%ifarch s390x
+%define qemu_arch s390x
+%endif
+
+%if 0%{?suse_version} >= 1310
+%check
+%{qemu_arch}-linux-user/qemu-%{qemu_arch} %_bindir/ls > /dev/null
+%endif
+
 %install
 make install DESTDIR=$RPM_BUILD_ROOT
 rm -fr $RPM_BUILD_ROOT/%_datadir/doc

++++++ qemu-testsuite.spec ++++++
--- /var/tmp/diff_new_pack.HYkqgw/_old  2015-05-15 07:44:26.000000000 +0200
+++ /var/tmp/diff_new_pack.HYkqgw/_new  2015-05-15 07:44:26.000000000 +0200
@@ -95,6 +95,7 @@
 Patch0037:      0037-linux-user-Allocate-thunk-size-dyna.patch
 Patch0038:      0038-Revert-Revert-seccomp-tests-that-al.patch
 Patch0039:      0039-s390x-Fix-stoc-direction.patch
+Patch0040:      0040-s390x-Add-interlocked-access-facili.patch
 # Please do not add QEMU patches manually here.
 # Run update_git.sh to regenerate this queue.
 
@@ -155,7 +156,7 @@
 BuildRequires:  libnuma-devel
 %endif
 %else
-%ifnarch %arm
+%ifnarch %arm s390x
 BuildRequires:  libnuma-devel
 %endif
 %endif
@@ -594,6 +595,7 @@
 %patch0037 -p1
 %patch0038 -p1
 %patch0039 -p1
+%patch0040 -p1
 
 %if %{build_x86_fw_from_source}
 pushd roms/seabios
@@ -673,7 +675,7 @@
        --disable-numa \
 %endif
 %else
-%ifarch %arm
+%ifarch %arm s390x
        --disable-numa \
 %else
        --enable-numa \

qemu.spec: same change
++++++ 0040-s390x-Add-interlocked-access-facili.patch ++++++
>From 9c5c8b0716f6c5526a5bd5abe13937321d95de26 Mon Sep 17 00:00:00 2001
From: Alexander Graf <ag...@suse.de>
Date: Fri, 8 May 2015 03:07:53 +0200
Subject: [PATCH] s390x: Add interlocked access facility 1 instructions

We're currently missing all instructions defined by the "interlocked-access
facility 1" which is part of zEC12. This patch implements all of them except
for LPD and LPDG.

Signed-off-by: Alexander Graf <ag...@suse.de>
---
 target-s390x/insn-data.def | 16 ++++++++++++++++
 target-s390x/translate.c   | 35 +++++++++++++++++++++++++++++++++++
 2 files changed, 51 insertions(+)

diff --git a/target-s390x/insn-data.def b/target-s390x/insn-data.def
index 8d8e47e..a36c366 100644
--- a/target-s390x/insn-data.def
+++ b/target-s390x/insn-data.def
@@ -338,6 +338,21 @@
     C(0xe371, LAY,     RXY_a, LD,  0, a2, 0, r1, mov2, 0)
 /* LOAD ADDRESS RELATIVE LONG */
     C(0xc000, LARL,    RIL_b, Z,   0, ri2, 0, r1, mov2, 0)
+/* LOAD AND ADD */
+    C(0xebf8, LAA,     RSY_a, ILA, r3_32s, m2_32s_atomic, new, 
m2_32_r1_atomic, add, adds32)
+    C(0xebe8, LAAG,    RSY_a, ILA, r3, m2_64_atomic, new, m2_64_r1_atomic, 
add, adds64)
+/* LOAD AND ADD LOGICAL */
+    C(0xebfa, LAAL,    RSY_a, ILA, r3_32s, m2_32s_atomic, new, 
m2_32_r1_atomic, add, addu32)
+    C(0xebea, LAALG,   RSY_a, ILA, r3, m2_64_atomic, new, m2_64_r1_atomic, 
add, addu64)
+/* LOAD AND AND */
+    C(0xebf4, LAN,     RSY_a, ILA, r3_32s, m2_32s_atomic, new, 
m2_32_r1_atomic, and, nz32)
+    C(0xebe4, LANG,    RSY_a, ILA, r3, m2_64_atomic, new, m2_64_r1_atomic, 
and, nz64)
+/* LOAD AND EXCLUSIVE OR */
+    C(0xebf7, LAX,     RSY_a, ILA, r3_32s, m2_32s_atomic, new, 
m2_32_r1_atomic, xor, nz32)
+    C(0xebe7, LAXG,    RSY_a, ILA, r3, m2_64_atomic, new, m2_64_r1_atomic, 
xor, nz64)
+/* LOAD AND OR */
+    C(0xebf6, LAO,     RSY_a, ILA, r3_32s, m2_32s_atomic, new, 
m2_32_r1_atomic, or, nz32)
+    C(0xebe6, LAOG,    RSY_a, ILA, r3, m2_64_atomic, new, m2_64_r1_atomic, or, 
nz64)
 /* LOAD AND TEST */
     C(0x1200, LTR,     RR_a,  Z,   0, r2_o, 0, cond_r1r2_32, mov2, s32)
     C(0xb902, LTGR,    RRE,   Z,   0, r2_o, 0, r1, mov2, s64)
@@ -417,6 +432,7 @@
     C(0xb9e2, LOCGR,   RRF_c, LOC, r1, r2, r1, 0, loc, 0)
     C(0xebf2, LOC,     RSY_b, LOC, r1, m2_32u, new, r1_32, loc, 0)
     C(0xebe2, LOCG,    RSY_b, LOC, r1, m2_64, r1, 0, loc, 0)
+/* LOAD PAIR DISJOINT TODO */
 /* LOAD POSITIVE */
     C(0x1000, LPR,     RR_a,  Z,   0, r2_32s, new, r1_32, abs, abs32)
     C(0xb900, LPGR,    RRE,   Z,   0, r2, r1, 0, abs, abs64)
diff --git a/target-s390x/translate.c b/target-s390x/translate.c
index 8ae4912..07794fb 100644
--- a/target-s390x/translate.c
+++ b/target-s390x/translate.c
@@ -1118,6 +1118,7 @@ typedef enum DisasFacility {
     FAC_PC,                 /* population count */
     FAC_SCF,                /* store clock fast */
     FAC_SFLE,               /* store facility list extended */
+    FAC_ILA,                /* interlocked access facility 1 */
 } DisasFacility;
 
 struct DisasInsn {
@@ -4065,6 +4066,22 @@ static void wout_m2_32(DisasContext *s, DisasFields *f, 
DisasOps *o)
 }
 #define SPEC_wout_m2_32 0
 
+static void wout_m2_32_r1_atomic(DisasContext *s, DisasFields *f, DisasOps *o)
+{
+    /* XXX release reservation */
+    tcg_gen_qemu_st32(o->out, o->addr1, get_mem_index(s));
+    store_reg32_i64(get_field(f, r1), o->in2);
+}
+#define SPEC_wout_m2_32_r1_atomic 0
+
+static void wout_m2_64_r1_atomic(DisasContext *s, DisasFields *f, DisasOps *o)
+{
+    /* XXX release reservation */
+    tcg_gen_qemu_st64(o->out, o->addr1, get_mem_index(s));
+    store_reg(get_field(f, r1), o->in2);
+}
+#define SPEC_wout_m2_64_r1_atomic 0
+
 /* ====================================================================== */
 /* The "INput 1" generators.  These load the first operand to an insn.  */
 
@@ -4486,6 +4503,24 @@ static void in2_mri2_64(DisasContext *s, DisasFields *f, 
DisasOps *o)
 }
 #define SPEC_in2_mri2_64 0
 
+static void in2_m2_32s_atomic(DisasContext *s, DisasFields *f, DisasOps *o)
+{
+    /* XXX should reserve the address */
+    in1_la2(s, f, o);
+    o->in2 = tcg_temp_new_i64();
+    tcg_gen_qemu_ld32s(o->in2, o->addr1, get_mem_index(s));
+}
+#define SPEC_in2_m2_32s_atomic 0
+
+static void in2_m2_64_atomic(DisasContext *s, DisasFields *f, DisasOps *o)
+{
+    /* XXX should reserve the address */
+    in1_la2(s, f, o);
+    o->in2 = tcg_temp_new_i64();
+    tcg_gen_qemu_ld64(o->in2, o->addr1, get_mem_index(s));
+}
+#define SPEC_in2_m2_64_atomic 0
+
 static void in2_i2(DisasContext *s, DisasFields *f, DisasOps *o)
 {
     o->in2 = tcg_const_i64(get_field(f, i2));


++++++ qemu-linux-user.spec.in ++++++
--- /var/tmp/diff_new_pack.HYkqgw/_old  2015-05-15 07:44:26.000000000 +0200
+++ /var/tmp/diff_new_pack.HYkqgw/_new  2015-05-15 07:44:26.000000000 +0200
@@ -100,6 +100,36 @@
 %endif
 make %{?_smp_mflags} V=1
 
+%ifarch %ix86
+%define qemu_arch i386
+%endif
+%ifarch x86_64
+%define qemu_arch x86_64
+%endif
+%ifarch %arm
+%define qemu_arch arm
+%endif
+%ifarch aarch64
+%define qemu_arch aarch64
+%endif
+%ifarch ppc
+%define qemu_arch ppc
+%endif
+%ifarch ppc64
+%define qemu_arch ppc64
+%endif
+%ifarch ppc64le
+%define qemu_arch ppc64le
+%endif
+%ifarch s390x
+%define qemu_arch s390x
+%endif
+
+%if 0%{?suse_version} >= 1310
+%check
+%{qemu_arch}-linux-user/qemu-%{qemu_arch} %_bindir/ls > /dev/null
+%endif
+
 %install
 make install DESTDIR=$RPM_BUILD_ROOT
 rm -fr $RPM_BUILD_ROOT/%_datadir/doc

++++++ qemu.spec.in ++++++
--- /var/tmp/diff_new_pack.HYkqgw/_old  2015-05-15 07:44:26.000000000 +0200
+++ /var/tmp/diff_new_pack.HYkqgw/_new  2015-05-15 07:44:26.000000000 +0200
@@ -117,7 +117,7 @@
 BuildRequires:  libnuma-devel
 %endif
 %else
-%ifnarch %arm
+%ifnarch %arm s390x
 BuildRequires:  libnuma-devel
 %endif
 %endif
@@ -597,7 +597,7 @@
        --disable-numa \
 %endif
 %else
-%ifarch %arm
+%ifarch %arm s390x
        --disable-numa \
 %else
        --enable-numa \


Reply via email to