$(addsuffix .vgtest,$(INSN_TESTS)) \
int3-x86.vgtest int3-x86.stderr.exp int3-x86.stdout.exp \
pushfpopf.stderr.exp pushfpopf.stdout.exp pushfpopf.vgtest \
+ pushfw_x86.vgtest pushfw_x86.stdout.exp pushfw_x86.stderr.exp \
pushpopmem.stderr.exp pushpopmem.stdout.exp pushpopmem.vgtest \
scalar.stderr.exp scalar.stderr.exp2 scalar.vgtest \
scalar_fork.stderr.exp scalar_fork.vgtest \
espindola2 \
int3-x86 \
scalar_exit_group scalar_fork scalar_supp scalar_vfork \
- fpeflags pushfpopf pushpopmem scalar sse_memory tronical \
+ fpeflags pushfpopf \
+ pushfw_x86 \
+ pushpopmem scalar sse_memory tronical \
more_x86_fp fprem xor-undef-x86
AM_CPPFLAGS = -I$(top_srcdir)/include
--- /dev/null
+
+/* Test case for http://bugs.kde.org/show_bug.cgi?id=157748 */
+
+#include <stdio.h>
+
+int arr[3];
+
+int main ( void )
+{
+ /* eax points at arr[0] */
+ __asm__ __volatile__(
+ "movl %%esp,0(%%eax)\n\t"
+ "pushfw\n\t"
+ "movl %%esp,4(%%eax)\n\t"
+ "popfw\n\t"
+ "movl %%esp,8(%%eax)\n"
+ : /*out*/ : /*in*/ "a"(&arr) : /*trash*/ "memory","cc"
+ );
+
+ printf("%x %x %x\n", arr[0]-arr[0], arr[0]-arr[1], arr[0]-arr[2]);
+ return 0;
+}