All of lore.kernel.org
 help / color / mirror / Atom feed
* [Qemu-devel] [PATCH v3 00/45] Windbg supporting
@ 2017-11-21 14:07 Mihail Abakumov
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 01/45] windbg: added empty windbgstub files Mihail Abakumov
                   ` (47 more replies)
  0 siblings, 48 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

An update of:

	v1: https://lists.nongnu.org/archive/html/qemu-devel/2017-09/msg07092.html

We made the debugger module WinDbg (like GDB) for QEMU. This is the replacement of the remote stub in Windows kernel. Used for remote Windows kernel debugging without debugging mode.

WinDbg is a multipurpose debugger for the Microsoft Windows computer operating system, distributed by Microsoft. Recent versions of WinDbg have been and are being distributed as part of the free Debugging Tools for Windows suite.

How to start debugging QEMU using WinDbg:
  Run QEMU with next option:
    -windbg pipe:<name>
  QEMU will start and pause for waiting WinDbg connection.
  Run WinDbg with next options:
    -b -k com:pipe,baud=115200,port=\\.\pipe\<name>,resets=0
  Wait for debugger connect to kernel.

Note: You can add Symbol Search Path in WinDbg such as srv*c:\tmp*http://msdl.microsoft.com/download/symbols.

How it works:
The WinDbg debugger has the possibility of connecting to a remote debug service (Kdsrv.exe) in the Windows kernel. Therefore, it is possible to connect to the guest system running in the QEMU emulator. Kernel debugging is possible only with the enabled debugging mode, may change at the same time. Our module of WinDbg debugger for QEMU is an alternative of the remote debugging service in the kernel. Thus, the debugger connects to the debugging module, not to the kernel of the operating system. The module obtains all the necessary information answering debugger requests from the QEMU emulator. At the same time for debugging there is no need to enable debugging mode in the kernel. This leads to hidden debugging. Our module supports all features of WinDbg regarding remote debugging, besides interception of events and exceptions. Only i386 is supported now.

Changed in v3:

 - Add a support of the new api functions from the WinDbg v10.

Changed in v2:

 - Move target specific code in the 'target/' directory. (Alistair Francis)
 - Change 'kd_api_fill_memory'. Made a fill of memory by line segments. Before that, a full array was immediately collected and written in RAM. (Ladi Prosek)
 - Change 'kd_api_search_memory'. Made a search for memory by line segments. (Ladi Prosek)
 - Change ld* to st* where it needs. (Ladi Prosek)
 - Add a additional check of input arguments in 'windbg_read_context' and 'windbg_read_ks_regs'. (Ladi Prosek)
 - Fix typos. (Ladi Prosek)
 - Add a fliping back 'windbg_state->is_loaded' after reset VM.
 - Add a check to disabled kvm. It is supported yet. (Ladi Prosek)
 - Add a check to device in windbg option. Only pipe is supporting now. (Alistair Francis)
 - Add a check to 'ifdef' WINDBG_DEBUG_ON before define it. (Alistair Francis)
 - Replace printf to qemu_log. (Alistair Francis)
 - Fix build on s390x host. (patchew)
 - Fix code style error. (patchew)

---

Mihail Abakumov (45):
      windbg: added empty windbgstub files
      windbg: added windbg's KD header file
      windbg: modified windbgkd.h
      windbg: added '-windbg' option
      windbg: added helper features
      windbg: added WindbgState
      windbg: added chardev
      windbg: hook to wrmsr operation
      windbg: handler of fs/gs register
      windbg: structures for parsing data stream
      windbg: parsing data stream
      windbg: send data and control packets
      windbg: handler of parsing context
      windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
      windbg: sized data buffer
      windbg: generate ExceptionStateChange
      windbg: generate LoadSymbolsStateChange
      windbg: windbg_vm_stop
      windbg: implemented windbg_process_control_packet
      windbg: implemented windbg_process_data_packet
      windbg: implemented windbg_process_manipulate_packet
      windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
      windbg: kernel's structures
      windbg: implemented kd_api_get_context and kd_api_set_context
      windbg: implemented kd_api_read_control_space and kd_api_write_control_space
      windbg: implemented windbg_read_context
      windbg: implemented windbg_write_context
      windbg: implemented windbg_read_ks_regs
      windbg: implemented windbg_write_ks_regs
      windbg: implemented windbg_set_sr
      windbg: implemented windbg_set_dr
      windbg: implemented windbg_set_dr7
      windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
      windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
      windbg: debug exception subscribing
      windbg: implemented kd_api_continue
      windbg: implemented kd_api_read_io_space and kd_api_write_io_space
      windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
      windbg: implemented kd_api_get_version
      windbg: implemented kd_api_read_msr and kd_api_write_msr
      windbg: implemented kd_api_search_memory
      windbg: implemented kd_api_fill_memory
      windbg: implemented kd_api_query_memory
      windbg: added new api functions
      windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex


 Makefile.target                 |    7 
 cpus.c                          |   18 
 gdbstub.c                       |    4 
 include/exec/windbgkd.h         |  967 +++++++++++++++++++++++++
 include/exec/windbgstub-utils.h |  117 +++
 include/exec/windbgstub.h       |   24 +
 include/sysemu/sysemu.h         |    2 
 qemu-options.hx                 |    8 
 stubs/Makefile.objs             |    1 
 stubs/windbgstub.c              |   21 +
 target/i386/Makefile.objs       |    2 
 target/i386/misc_helper.c       |    3 
 target/i386/windbgstub.c        | 1502 +++++++++++++++++++++++++++++++++++++++
 vl.c                            |    8 
 windbgstub-utils.c              |  354 +++++++++
 windbgstub.c                    |  498 +++++++++++++
 16 files changed, 3534 insertions(+), 2 deletions(-)
 create mode 100755 include/exec/windbgkd.h
 create mode 100755 include/exec/windbgstub-utils.h
 create mode 100755 include/exec/windbgstub.h
 create mode 100755 stubs/windbgstub.c
 create mode 100755 target/i386/windbgstub.c
 create mode 100755 windbgstub-utils.c
 create mode 100755 windbgstub.c

--
Thanks,
Mihail Abakumov

^ permalink raw reply	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 01/45] windbg: added empty windbgstub files
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
@ 2017-11-21 14:07 ` Mihail Abakumov
  2017-11-28 12:10   ` Ladi Prosek
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 02/45] windbg: added windbg's KD header file Mihail Abakumov
                   ` (46 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 Makefile.target                 |    7 +++++++
 include/exec/windbgstub-utils.h |   18 ++++++++++++++++++
 include/exec/windbgstub.h       |   17 +++++++++++++++++
 stubs/Makefile.objs             |    1 +
 stubs/windbgstub.c              |   18 ++++++++++++++++++
 target/i386/Makefile.objs       |    2 +-
 target/i386/windbgstub.c        |   12 ++++++++++++
 windbgstub-utils.c              |   12 ++++++++++++
 windbgstub.c                    |   19 +++++++++++++++++++
 9 files changed, 105 insertions(+), 1 deletion(-)
 create mode 100755 include/exec/windbgstub-utils.h
 create mode 100755 include/exec/windbgstub.h
 create mode 100755 stubs/windbgstub.c
 create mode 100755 target/i386/windbgstub.c
 create mode 100755 windbgstub-utils.c
 create mode 100755 windbgstub.c

diff --git a/Makefile.target b/Makefile.target
index 7f42c45db8..6df0836509 100644
--- a/Makefile.target
+++ b/Makefile.target
@@ -148,6 +148,13 @@ obj-y += dump.o
 obj-y += migration/ram.o
 LIBS := $(libs_softmmu) $(LIBS)
 
+# WinDbg support
+ifeq ($(TARGET_NAME), i386)
+ifneq ($(TARGET_NAME), x86_64)
+obj-y += windbgstub.o windbgstub-utils.o
+endif
+endif
+
 # Hardware support
 ifeq ($(TARGET_NAME), sparc64)
 obj-y += hw/sparc64/
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
new file mode 100755
index 0000000000..67d190bf6c
--- /dev/null
+++ b/include/exec/windbgstub-utils.h
@@ -0,0 +1,18 @@
+/*
+ * windbgstub-utils.h
+ *
+ * Copyright (c) 2010-2017 Institute for System Programming
+ *                         of the Russian Academy of Sciences.
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ *
+ */
+
+#ifndef WINDBGSTUB_UTILS_H
+#define WINDBGSTUB_UTILS_H
+
+#include "qemu/osdep.h"
+#include "exec/windbgstub.h"
+
+#endif
diff --git a/include/exec/windbgstub.h b/include/exec/windbgstub.h
new file mode 100755
index 0000000000..1a6e1cc6e5
--- /dev/null
+++ b/include/exec/windbgstub.h
@@ -0,0 +1,17 @@
+/*
+ * windbgstub.h
+ *
+ * Copyright (c) 2010-2017 Institute for System Programming
+ *                         of the Russian Academy of Sciences.
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ *
+ */
+
+#ifndef WINDBGSTUB_H
+#define WINDBGSTUB_H
+
+int windbg_server_start(const char *device);
+
+#endif
diff --git a/stubs/Makefile.objs b/stubs/Makefile.objs
index e69c217aff..5c25a53c15 100644
--- a/stubs/Makefile.objs
+++ b/stubs/Makefile.objs
@@ -12,6 +12,7 @@ stub-obj-y += dump.o
 stub-obj-y += error-printf.o
 stub-obj-y += fdset.o
 stub-obj-y += gdbstub.o
+stub-obj-y += windbgstub.o
 stub-obj-y += get-vm-name.o
 stub-obj-y += iothread.o
 stub-obj-y += iothread-lock.o
diff --git a/stubs/windbgstub.c b/stubs/windbgstub.c
new file mode 100755
index 0000000000..4951f59203
--- /dev/null
+++ b/stubs/windbgstub.c
@@ -0,0 +1,18 @@
+/*
+ * windbgstub.c
+ *
+ * Copyright (c) 2010-2017 Institute for System Programming
+ *                         of the Russian Academy of Sciences.
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ *
+ */
+
+#include "qemu/osdep.h"
+#include "exec/windbgstub.h"
+
+int windbg_server_start(const char *device)
+{
+    return 0;
+}
diff --git a/target/i386/Makefile.objs b/target/i386/Makefile.objs
index 6a26e9d9f0..730ee04e27 100644
--- a/target/i386/Makefile.objs
+++ b/target/i386/Makefile.objs
@@ -1,4 +1,4 @@
-obj-y += helper.o cpu.o gdbstub.o xsave_helper.o
+obj-y += helper.o cpu.o gdbstub.o windbgstub.o xsave_helper.o
 obj-$(CONFIG_TCG) += translate.o
 obj-$(CONFIG_TCG) += bpt_helper.o cc_helper.o excp_helper.o fpu_helper.o
 obj-$(CONFIG_TCG) += int_helper.o mem_helper.o misc_helper.o mpx_helper.o
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
new file mode 100755
index 0000000000..df89e1edd8
--- /dev/null
+++ b/target/i386/windbgstub.c
@@ -0,0 +1,12 @@
+/*
+ * windbgstub.c
+ *
+ * Copyright (c) 2010-2017 Institute for System Programming
+ *                         of the Russian Academy of Sciences.
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ *
+ */
+
+#include "qemu/osdep.h"
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
new file mode 100755
index 0000000000..dc5e505c63
--- /dev/null
+++ b/windbgstub-utils.c
@@ -0,0 +1,12 @@
+/*
+ * windbgstub-utils.c
+ *
+ * Copyright (c) 2010-2017 Institute for System Programming
+ *                         of the Russian Academy of Sciences.
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ *
+ */
+
+#include "exec/windbgstub-utils.h"
diff --git a/windbgstub.c b/windbgstub.c
new file mode 100755
index 0000000000..3830446988
--- /dev/null
+++ b/windbgstub.c
@@ -0,0 +1,19 @@
+/*
+ * windbgstub.c
+ *
+ * Copyright (c) 2010-2017 Institute for System Programming
+ *                         of the Russian Academy of Sciences.
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ *
+ */
+
+#include "qemu/osdep.h"
+#include "exec/windbgstub.h"
+#include "exec/windbgstub-utils.h"
+
+int windbg_server_start(const char *device)
+{
+    return 0;
+}

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 02/45] windbg: added windbg's KD header file
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 01/45] windbg: added empty windbgstub files Mihail Abakumov
@ 2017-11-21 14:07 ` Mihail Abakumov
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 03/45] windbg: modified windbgkd.h Mihail Abakumov
                   ` (45 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Header file from windbg's source code describing the main structures.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgkd.h         |  873 +++++++++++++++++++++++++++++++++++++++
 include/exec/windbgstub-utils.h |    1 
 2 files changed, 874 insertions(+)
 create mode 100755 include/exec/windbgkd.h

diff --git a/include/exec/windbgkd.h b/include/exec/windbgkd.h
new file mode 100755
index 0000000000..b8f98925e7
--- /dev/null
+++ b/include/exec/windbgkd.h
@@ -0,0 +1,873 @@
+/*
+ * windbgkd.h
+ *
+ * Copyright (c) 2010-2017 Institute for System Programming
+ *                         of the Russian Academy of Sciences.
+ *
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
+ * See the COPYING file in the top-level directory.
+ *
+ */
+
+#ifndef WINDBGKD_H
+#define WINDBGKD_H
+
+/*
+ * Packet Size and Control Stream Size
+ */
+#define PACKET_MAX_SIZE                     4096
+#define DBGKD_MAXSTREAM                     16
+
+/*
+ * Magic Packet IDs
+ */
+#define INITIAL_PACKET_ID                   0x80800000
+#define SYNC_PACKET_ID                      0x00000800
+#define RESET_PACKET_ID                     0x0018359b
+
+/*
+ * Magic Packet bytes
+ */
+#define BREAKIN_PACKET                      0x62626262
+#define BREAKIN_PACKET_BYTE                 0x62
+#define PACKET_LEADER                       0x30303030
+#define PACKET_LEADER_BYTE                  0x30
+#define CONTROL_PACKET_LEADER               0x69696969
+#define CONTROL_PACKET_LEADER_BYTE          0x69
+#define PACKET_TRAILING_BYTE                0xaa
+
+/*
+ * Packet Types
+ */
+#define PACKET_TYPE_UNUSED                  0
+#define PACKET_TYPE_KD_STATE_CHANGE32       1
+#define PACKET_TYPE_KD_STATE_MANIPULATE     2
+#define PACKET_TYPE_KD_DEBUG_IO             3
+#define PACKET_TYPE_KD_ACKNOWLEDGE          4
+#define PACKET_TYPE_KD_RESEND               5
+#define PACKET_TYPE_KD_RESET                6
+#define PACKET_TYPE_KD_STATE_CHANGE64       7
+#define PACKET_TYPE_KD_POLL_BREAKIN         8
+#define PACKET_TYPE_KD_TRACE_IO             9
+#define PACKET_TYPE_KD_CONTROL_REQUEST      10
+#define PACKET_TYPE_KD_FILE_IO              11
+#define PACKET_TYPE_MAX                     12
+
+/*
+ * Wait State Change Types
+ */
+#define DbgKdMinimumStateChange             0x00003030
+#define DbgKdExceptionStateChange           0x00003030
+#define DbgKdLoadSymbolsStateChange         0x00003031
+#define DbgKdCommandStringStateChange       0x00003032
+#define DbgKdMaximumStateChange             0x00003033
+
+/*
+ * This is combined with the basic state change code
+ * if the state is from an alternate source
+ */
+#define DbgKdAlternateStateChange           0x00010000
+
+/*
+ * Manipulate Types
+ */
+#define DbgKdMinimumManipulate              0x00003130
+#define DbgKdReadVirtualMemoryApi           0x00003130
+#define DbgKdWriteVirtualMemoryApi          0x00003131
+#define DbgKdGetContextApi                  0x00003132
+#define DbgKdSetContextApi                  0x00003133
+#define DbgKdWriteBreakPointApi             0x00003134
+#define DbgKdRestoreBreakPointApi           0x00003135
+#define DbgKdContinueApi                    0x00003136
+#define DbgKdReadControlSpaceApi            0x00003137
+#define DbgKdWriteControlSpaceApi           0x00003138
+#define DbgKdReadIoSpaceApi                 0x00003139
+#define DbgKdWriteIoSpaceApi                0x0000313a
+#define DbgKdRebootApi                      0x0000313b
+#define DbgKdContinueApi2                   0x0000313c
+#define DbgKdReadPhysicalMemoryApi          0x0000313d
+#define DbgKdWritePhysicalMemoryApi         0x0000313e
+#define DbgKdQuerySpecialCallsApi           0x0000313f
+#define DbgKdSetSpecialCallApi              0x00003140
+#define DbgKdClearSpecialCallsApi           0x00003141
+#define DbgKdSetInternalBreakPointApi       0x00003142
+#define DbgKdGetInternalBreakPointApi       0x00003143
+#define DbgKdReadIoSpaceExtendedApi         0x00003144
+#define DbgKdWriteIoSpaceExtendedApi        0x00003145
+#define DbgKdGetVersionApi                  0x00003146
+#define DbgKdWriteBreakPointExApi           0x00003147
+#define DbgKdRestoreBreakPointExApi         0x00003148
+#define DbgKdCauseBugCheckApi               0x00003149
+#define DbgKdSwitchProcessor                0x00003150
+#define DbgKdPageInApi                      0x00003151
+#define DbgKdReadMachineSpecificRegister    0x00003152
+#define DbgKdWriteMachineSpecificRegister   0x00003153
+#define OldVlm1                             0x00003154
+#define OldVlm2                             0x00003155
+#define DbgKdSearchMemoryApi                0x00003156
+#define DbgKdGetBusDataApi                  0x00003157
+#define DbgKdSetBusDataApi                  0x00003158
+#define DbgKdCheckLowMemoryApi              0x00003159
+#define DbgKdClearAllInternalBreakpointsApi 0x0000315a
+#define DbgKdFillMemoryApi                  0x0000315b
+#define DbgKdQueryMemoryApi                 0x0000315c
+#define DbgKdSwitchPartition                0x0000315d
+#define DbgKdMaximumManipulate              0x0000315e
+
+/*
+ * Debug I/O Types
+ */
+#define DbgKdPrintStringApi                 0x00003230
+#define DbgKdGetStringApi                   0x00003231
+
+/*
+ * Trace I/O Types
+ */
+#define DbgKdPrintTraceApi                  0x00003330
+
+/*
+ * Control Request Types
+ */
+#define DbgKdRequestHardwareBp              0x00004300
+#define DbgKdReleaseHardwareBp              0x00004301
+
+/*
+ * File I/O Types
+ */
+#define DbgKdCreateFileApi                 0x00003430
+#define DbgKdReadFileApi                   0x00003431
+#define DbgKdWriteFileApi                  0x00003432
+#define DbgKdCloseFileApi                  0x00003433
+
+/*
+ * Control Report Flags
+ */
+#define REPORT_INCLUDES_SEGS                0x0001
+#define REPORT_STANDARD_CS                  0x0002
+
+/*
+ * Protocol Versions
+ */
+#define DBGKD_64BIT_PROTOCOL_VERSION1       5
+#define DBGKD_64BIT_PROTOCOL_VERSION2       6
+
+/*
+ * Query Memory Address Spaces
+ */
+#define DBGKD_QUERY_MEMORY_VIRTUAL          0
+#define DBGKD_QUERY_MEMORY_PROCESS          0
+#define DBGKD_QUERY_MEMORY_SESSION          1
+#define DBGKD_QUERY_MEMORY_KERNEL           2
+
+/*
+ * Query Memory Flags
+ */
+#define DBGKD_QUERY_MEMORY_READ             0x01
+#define DBGKD_QUERY_MEMORY_WRITE            0x02
+#define DBGKD_QUERY_MEMORY_EXECUTE          0x04
+#define DBGKD_QUERY_MEMORY_FIXED            0x08
+
+/*
+ * Internal Breakpoint Flags
+ */
+#define DBGKD_INTERNAL_BP_FLAG_COUNTONLY    0x01
+#define DBGKD_INTERNAL_BP_FLAG_INVALID      0x02
+#define DBGKD_INTERNAL_BP_FLAG_SUSPENDED    0x04
+#define DBGKD_INTERNAL_BP_FLAG_DYING        0x08
+
+/*
+ * Fill Memory Flags
+ */
+#define DBGKD_FILL_MEMORY_VIRTUAL           0x01
+#define DBGKD_FILL_MEMORY_PHYSICAL          0x02
+
+/*
+ * Physical Memory Caching Flags
+ */
+#define DBGKD_CACHING_DEFAULT               0
+#define DBGKD_CACHING_CACHED                1
+#define DBGKD_CACHING_UNCACHED              2
+#define DBGKD_CACHING_WRITE_COMBINED        3
+
+/*
+ * Partition Switch Flags
+ */
+#define DBGKD_PARTITION_DEFAULT             0x00
+#define DBGKD_PARTITION_ALTERNATE           0x01
+
+/*
+ * AMD64 Control Space types
+ */
+#define AMD64_DEBUG_CONTROL_SPACE_KPCR      0
+#define AMD64_DEBUG_CONTROL_SPACE_KPRCB     1
+#define AMD64_DEBUG_CONTROL_SPACE_KSPECIAL  2
+#define AMD64_DEBUG_CONTROL_SPACE_KTHREAD   3
+
+/*
+ * Maximum supported number of breakpoints
+ */
+#define KD_BREAKPOINT_MAX 32
+
+typedef uint8_t boolean_t;
+typedef int32_t ntstatus_t;
+
+/*
+ * NTSTATUS
+ */
+#define NT_SUCCESS(status)       ((ntstatus_t) (status) >= 0)
+#ifndef STATUS_SUCCESS
+#define STATUS_SUCCESS           ((ntstatus_t) 0x00000000)
+#endif
+#ifndef DBG_CONTINUE
+#define DBG_CONTINUE             ((ntstatus_t) 0x00010002)
+#endif
+#ifndef STATUS_NO_MORE_ENTRIES
+#define STATUS_NO_MORE_ENTRIES   ((ntstatus_t) 0x8000001A)
+#endif
+#ifndef STATUS_UNSUCCESSFUL
+#define STATUS_UNSUCCESSFUL      ((ntstatus_t) 0xC0000001)
+#endif
+#ifndef STATUS_INVALID_PARAMETER
+#define STATUS_INVALID_PARAMETER ((ntstatus_t) 0xC000000D)
+#endif
+
+/*
+ * KD Packet Structure
+ */
+typedef struct _KD_PACKET {
+    uint32_t PacketLeader;
+    uint16_t PacketType;
+    uint16_t ByteCount;
+    uint32_t PacketId;
+    uint32_t Checksum;
+} KD_PACKET, *PKD_PACKET;
+
+/*
+ * KD Context
+ */
+typedef struct _KD_CONTEXT {
+    uint32_t KdpDefaultRetries;
+    boolean_t KdpControlCPending;
+} KD_CONTEXT, *PKD_CONTEXT;
+
+/*
+ * Control Sets for Supported Architectures
+ */
+typedef struct _X86_DBGKD_CONTROL_SET {
+    uint32_t TraceFlag;
+    uint32_t Dr7;
+    uint32_t CurrentSymbolStart;
+    uint32_t CurrentSymbolEnd;
+} X86_DBGKD_CONTROL_SET, *PX86_DBGKD_CONTROL_SET;
+
+typedef struct _ALPHA_DBGKD_CONTROL_SET {
+    uint32_t __padding;
+} ALPHA_DBGKD_CONTROL_SET, *PALPHA_DBGKD_CONTROL_SET;
+
+typedef struct _IA64_DBGKD_CONTROL_SET {
+    uint32_t Continue;
+    uint64_t CurrentSymbolStart;
+    uint64_t CurrentSymbolEnd;
+} IA64_DBGKD_CONTROL_SET, *PIA64_DBGKD_CONTROL_SET;
+
+typedef struct _AMD64_DBGKD_CONTROL_SET {
+    uint32_t TraceFlag;
+    uint64_t Dr7;
+    uint64_t CurrentSymbolStart;
+    uint64_t CurrentSymbolEnd;
+} AMD64_DBGKD_CONTROL_SET, *PAMD64_DBGKD_CONTROL_SET;
+
+typedef struct _ARM_DBGKD_CONTROL_SET {
+    uint32_t Continue;
+    uint32_t CurrentSymbolStart;
+    uint32_t CurrentSymbolEnd;
+} ARM_DBGKD_CONTROL_SET, *PARM_DBGKD_CONTROL_SET;
+
+typedef struct _DBGKD_ANY_CONTROL_SET {
+    union {
+        X86_DBGKD_CONTROL_SET X86ControlSet;
+        ALPHA_DBGKD_CONTROL_SET AlphaControlSet;
+        IA64_DBGKD_CONTROL_SET IA64ControlSet;
+        AMD64_DBGKD_CONTROL_SET Amd64ControlSet;
+        ARM_DBGKD_CONTROL_SET ARMControlSet;
+    };
+} DBGKD_ANY_CONTROL_SET, *PDBGKD_ANY_CONTROL_SET;
+
+#if defined(TARGET_I386)
+typedef X86_DBGKD_CONTROL_SET DBGKD_CONTROL_SET, *PDBGKD_CONTROL_SET;
+#elif defined(TARGET_X86_64)
+typedef AMD64_DBGKD_CONTROL_SET DBGKD_CONTROL_SET, *PDBGKD_CONTROL_SET;
+#elif defined(TARGET_ARM)
+typedef ARM_DBGKD_CONTROL_SET DBGKD_CONTROL_SET, *PDBGKD_CONTROL_SET;
+#else
+#error Unsupported Architecture
+#endif
+
+/*
+ * EXCEPTION_RECORD Structures
+ */
+typedef struct _DBGKM_EXCEPTION_RECORD32 {
+    int32_t ExceptionCode;
+    uint32_t ExceptionFlags;
+    uint32_t ExceptionRecord;
+    uint32_t ExceptionAddress;
+    uint32_t NumberParameters;
+    uint32_t ExceptionInformation[15];
+} DBGKM_EXCEPTION_RECORD32, *PDBGKM_EXCEPTION_RECORD32;
+
+typedef struct _DBGKM_EXCEPTION_RECORD64 {
+    int32_t ExceptionCode;
+    uint32_t ExceptionFlags;
+    uint64_t ExceptionRecord;
+    uint64_t ExceptionAddress;
+    uint32_t NumberParameters;
+    uint32_t __unusedAligment;
+    uint64_t ExceptionInformation[15];
+} DBGKM_EXCEPTION_RECORD64, *PDBGKM_EXCEPTION_RECORD64;
+
+/*
+ * DBGKM Structure for Exceptions
+ */
+typedef struct _DBGKM_EXCEPTION32 {
+    DBGKM_EXCEPTION_RECORD32 ExceptionRecord;
+    uint32_t FirstChance;
+} DBGKM_EXCEPTION32, *PDBGKM_EXCEPTION32;
+
+typedef struct _DBGKM_EXCEPTION64 {
+    DBGKM_EXCEPTION_RECORD64 ExceptionRecord;
+    uint32_t FirstChance;
+} DBGKM_EXCEPTION64, *PDBGKM_EXCEPTION64;
+
+/*
+ * DBGKD Structure for State Change
+ */
+typedef struct _X86_DBGKD_CONTROL_REPORT {
+    uint32_t   Dr6;
+    uint32_t   Dr7;
+    uint16_t  InstructionCount;
+    uint16_t  ReportFlags;
+    uint8_t   InstructionStream[DBGKD_MAXSTREAM];
+    uint16_t  SegCs;
+    uint16_t  SegDs;
+    uint16_t  SegEs;
+    uint16_t  SegFs;
+    uint32_t   EFlags;
+} X86_DBGKD_CONTROL_REPORT, *PX86_DBGKD_CONTROL_REPORT;
+
+typedef struct _ALPHA_DBGKD_CONTROL_REPORT {
+    uint32_t InstructionCount;
+    uint8_t InstructionStream[DBGKD_MAXSTREAM];
+} ALPHA_DBGKD_CONTROL_REPORT, *PALPHA_DBGKD_CONTROL_REPORT;
+
+typedef struct _IA64_DBGKD_CONTROL_REPORT {
+    uint32_t InstructionCount;
+    uint8_t InstructionStream[DBGKD_MAXSTREAM];
+} IA64_DBGKD_CONTROL_REPORT, *PIA64_DBGKD_CONTROL_REPORT;
+
+typedef struct _AMD64_DBGKD_CONTROL_REPORT {
+    uint64_t Dr6;
+    uint64_t Dr7;
+    uint32_t EFlags;
+    uint16_t InstructionCount;
+    uint16_t ReportFlags;
+    uint8_t InstructionStream[DBGKD_MAXSTREAM];
+    uint16_t SegCs;
+    uint16_t SegDs;
+    uint16_t SegEs;
+    uint16_t SegFs;
+} AMD64_DBGKD_CONTROL_REPORT, *PAMD64_DBGKD_CONTROL_REPORT;
+
+typedef struct _ARM_DBGKD_CONTROL_REPORT {
+    uint32_t Cpsr;
+    uint32_t InstructionCount;
+    uint8_t InstructionStream[DBGKD_MAXSTREAM];
+} ARM_DBGKD_CONTROL_REPORT, *PARM_DBGKD_CONTROL_REPORT;
+
+typedef struct _DBGKD_ANY_CONTROL_REPORT {
+    union {
+        X86_DBGKD_CONTROL_REPORT X86ControlReport;
+        ALPHA_DBGKD_CONTROL_REPORT AlphaControlReport;
+        IA64_DBGKD_CONTROL_REPORT IA64ControlReport;
+        AMD64_DBGKD_CONTROL_REPORT Amd64ControlReport;
+        ARM_DBGKD_CONTROL_REPORT ARMControlReport;
+    };
+} DBGKD_ANY_CONTROL_REPORT, *PDBGKD_ANY_CONTROL_REPORT;
+
+#if defined(TARGET_I386)
+typedef X86_DBGKD_CONTROL_REPORT DBGKD_CONTROL_REPORT, *PDBGKD_CONTROL_REPORT;
+#elif defined(TARGET_X86_64)
+typedef AMD64_DBGKD_CONTROL_REPORT DBGKD_CONTROL_REPORT, *PDBGKD_CONTROL_REPORT;
+#elif defined(TARGET_ARM)
+typedef ARM_DBGKD_CONTROL_REPORT DBGKD_CONTROL_REPORT, *PDBGKD_CONTROL_REPORT;
+#else
+#error Unsupported Architecture
+#endif
+
+/*
+ * DBGKD Structure for Debug I/O Type Print String
+ */
+typedef struct _DBGKD_PRINT_STRING {
+    uint32_t LengthOfString;
+} DBGKD_PRINT_STRING, *PDBGKD_PRINT_STRING;
+
+/*
+ * DBGKD Structure for Debug I/O Type Get String
+ */
+typedef struct _DBGKD_GET_STRING {
+    uint32_t LengthOfPromptString;
+    uint32_t LengthOfStringRead;
+} DBGKD_GET_STRING, *PDBGKD_GET_STRING;
+
+/*
+ * DBGKD Structure for Debug I/O
+ */
+typedef struct _DBGKD_DEBUG_IO {
+    uint32_t ApiNumber;
+    uint16_t ProcessorLevel;
+    uint16_t Processor;
+    union {
+        DBGKD_PRINT_STRING PrintString;
+        DBGKD_GET_STRING GetString;
+    } u;
+} DBGKD_DEBUG_IO, *PDBGKD_DEBUG_IO;
+
+/*
+ * DBGkD Structure for Command String
+ */
+typedef struct _DBGKD_COMMAND_STRING {
+    uint32_t Flags;
+    uint32_t Reserved1;
+    uint64_t Reserved2[7];
+} DBGKD_COMMAND_STRING, *PDBGKD_COMMAND_STRING;
+
+/*
+ * DBGKD Structure for Load Symbols
+ */
+typedef struct _DBGKD_LOAD_SYMBOLS32 {
+    uint32_t PathNameLength;
+    uint32_t BaseOfDll;
+    uint32_t ProcessId;
+    uint32_t CheckSum;
+    uint32_t SizeOfImage;
+    boolean_t UnloadSymbols;
+} DBGKD_LOAD_SYMBOLS32, *PDBGKD_LOAD_SYMBOLS32;
+
+typedef struct _DBGKD_LOAD_SYMBOLS64 {
+    uint32_t PathNameLength;
+    uint64_t BaseOfDll;
+    uint64_t ProcessId;
+    uint32_t CheckSum;
+    uint32_t SizeOfImage;
+    boolean_t UnloadSymbols;
+} DBGKD_LOAD_SYMBOLS64, *PDBGKD_LOAD_SYMBOLS64;
+
+/*
+ * DBGKD Structure for Wait State Change
+ */
+typedef struct _DBGKD_WAIT_STATE_CHANGE32 {
+    uint32_t NewState;
+    uint16_t ProcessorLevel;
+    uint16_t Processor;
+    uint32_t NumberProcessors;
+    uint32_t Thread;
+    uint32_t ProgramCounter;
+    union {
+        DBGKM_EXCEPTION32 Exception;
+        DBGKD_LOAD_SYMBOLS32 LoadSymbols;
+    } u;
+} DBGKD_WAIT_STATE_CHANGE32, *PDBGKD_WAIT_STATE_CHANGE32;
+
+typedef struct _DBGKD_WAIT_STATE_CHANGE64 {
+    uint32_t NewState;
+    uint16_t ProcessorLevel;
+    uint16_t Processor;
+    uint32_t NumberProcessors;
+    uint64_t Thread;
+    uint64_t ProgramCounter;
+    union {
+        DBGKM_EXCEPTION64 Exception;
+        DBGKD_LOAD_SYMBOLS64 LoadSymbols;
+    } u;
+} DBGKD_WAIT_STATE_CHANGE64, *PDBGKD_WAIT_STATE_CHANGE64;
+
+typedef struct _DBGKD_ANY_WAIT_STATE_CHANGE {
+    uint32_t NewState;
+    uint16_t ProcessorLevel;
+    uint16_t Processor;
+    uint32_t NumberProcessors;
+    uint64_t Thread;
+    uint64_t ProgramCounter;
+    union {
+        DBGKM_EXCEPTION64 Exception;
+        DBGKD_LOAD_SYMBOLS64 LoadSymbols;
+        DBGKD_COMMAND_STRING CommandString;
+    } u;
+    union {
+        DBGKD_CONTROL_REPORT ControlReport;
+        DBGKD_ANY_CONTROL_REPORT AnyControlReport;
+    };
+} DBGKD_ANY_WAIT_STATE_CHANGE, *PDBGKD_ANY_WAIT_STATE_CHANGE;
+
+/*
+ * DBGKD Manipulate Structures
+ */
+typedef struct _DBGKD_READ_MEMORY32 {
+    uint32_t TargetBaseAddress;
+    uint32_t TransferCount;
+    uint32_t ActualBytesRead;
+} DBGKD_READ_MEMORY32, *PDBGKD_READ_MEMORY32;
+
+typedef struct _DBGKD_READ_MEMORY64 {
+    uint64_t TargetBaseAddress;
+    uint32_t TransferCount;
+    uint32_t ActualBytesRead;
+} DBGKD_READ_MEMORY64, *PDBGKD_READ_MEMORY64;
+
+typedef struct _DBGKD_WRITE_MEMORY32 {
+    uint32_t TargetBaseAddress;
+    uint32_t TransferCount;
+    uint32_t ActualBytesWritten;
+} DBGKD_WRITE_MEMORY32, *PDBGKD_WRITE_MEMORY32;
+
+typedef struct _DBGKD_WRITE_MEMORY64 {
+    uint64_t TargetBaseAddress;
+    uint32_t TransferCount;
+    uint32_t ActualBytesWritten;
+} DBGKD_WRITE_MEMORY64, *PDBGKD_WRITE_MEMORY64;
+
+typedef struct _DBGKD_GET_CONTEXT {
+    uint32_t Unused;
+} DBGKD_GET_CONTEXT, *PDBGKD_GET_CONTEXT;
+
+typedef struct _DBGKD_SET_CONTEXT {
+    uint32_t ContextFlags;
+} DBGKD_SET_CONTEXT, *PDBGKD_SET_CONTEXT;
+
+typedef struct _DBGKD_WRITE_BREAKPOINT32 {
+    uint32_t BreakPointAddress;
+    uint32_t BreakPointHandle;
+} DBGKD_WRITE_BREAKPOINT32, *PDBGKD_WRITE_BREAKPOINT32;
+
+typedef struct _DBGKD_WRITE_BREAKPOINT64 {
+    uint64_t BreakPointAddress;
+    uint32_t BreakPointHandle;
+} DBGKD_WRITE_BREAKPOINT64, *PDBGKD_WRITE_BREAKPOINT64;
+
+typedef struct _DBGKD_RESTORE_BREAKPOINT {
+    uint32_t BreakPointHandle;
+} DBGKD_RESTORE_BREAKPOINT, *PDBGKD_RESTORE_BREAKPOINT;
+
+typedef struct _DBGKD_CONTINUE {
+    ntstatus_t ContinueStatus;
+} DBGKD_CONTINUE, *PDBGKD_CONTINUE;
+
+#pragma pack(push, 4)
+typedef struct _DBGKD_CONTINUE2 {
+    ntstatus_t ContinueStatus;
+    union {
+        DBGKD_CONTROL_SET ControlSet;
+        DBGKD_ANY_CONTROL_SET AnyControlSet;
+    };
+} DBGKD_CONTINUE2, *PDBGKD_CONTINUE2;
+#pragma pack(pop)
+
+typedef struct _DBGKD_READ_WRITE_IO32 {
+    uint32_t IoAddress;
+    uint32_t DataSize;
+    uint32_t DataValue;
+} DBGKD_READ_WRITE_IO32, *PDBGKD_READ_WRITE_IO32;
+
+typedef struct _DBGKD_READ_WRITE_IO64 {
+    uint64_t IoAddress;
+    uint32_t DataSize;
+    uint32_t DataValue;
+} DBGKD_READ_WRITE_IO64, *PDBGKD_READ_WRITE_IO64;
+
+typedef struct _DBGKD_READ_WRITE_IO_EXTENDED32 {
+    uint32_t DataSize;
+    uint32_t InterfaceType;
+    uint32_t BusNumber;
+    uint32_t AddressSpace;
+    uint32_t IoAddress;
+    uint32_t DataValue;
+} DBGKD_READ_WRITE_IO_EXTENDED32, *PDBGKD_READ_WRITE_IO_EXTENDED32;
+
+typedef struct _DBGKD_READ_WRITE_IO_EXTENDED64 {
+    uint32_t DataSize;
+    uint32_t InterfaceType;
+    uint32_t BusNumber;
+    uint32_t AddressSpace;
+    uint64_t IoAddress;
+    uint32_t DataValue;
+} DBGKD_READ_WRITE_IO_EXTENDED64, *PDBGKD_READ_WRITE_IO_EXTENDED64;
+
+typedef struct _DBGKD_READ_WRITE_MSR {
+    uint32_t Msr;
+    uint32_t DataValueLow;
+    uint32_t DataValueHigh;
+} DBGKD_READ_WRITE_MSR, *PDBGKD_READ_WRITE_MSR;
+
+typedef struct _DBGKD_QUERY_SPECIAL_CALLS {
+    uint32_t NumberOfSpecialCalls;
+} DBGKD_QUERY_SPECIAL_CALLS, *PDBGKD_QUERY_SPECIAL_CALLS;
+
+typedef struct _DBGKD_SET_SPECIAL_CALL32 {
+    uint32_t SpecialCall;
+} DBGKD_SET_SPECIAL_CALL32, *PDBGKD_SET_SPECIAL_CALL32;
+
+typedef struct _DBGKD_SET_SPECIAL_CALL64 {
+    uint64_t SpecialCall;
+} DBGKD_SET_SPECIAL_CALL64, *PDBGKD_SET_SPECIAL_CALL64;
+
+typedef struct _DBGKD_SET_INTERNAL_BREAKPOINT32 {
+    uint32_t BreakpointAddress;
+    uint32_t Flags;
+} DBGKD_SET_INTERNAL_BREAKPOINT32, *PDBGKD_SET_INTERNAL_BREAKPOINT32;
+
+typedef struct _DBGKD_SET_INTERNAL_BREAKPOINT64 {
+    uint64_t BreakpointAddress;
+    uint32_t Flags;
+} DBGKD_SET_INTERNAL_BREAKPOINT64, *PDBGKD_SET_INTERNAL_BREAKPOINT64;
+
+typedef struct _DBGKD_GET_INTERNAL_BREAKPOINT32 {
+    uint32_t BreakpointAddress;
+    uint32_t Flags;
+    uint32_t Calls;
+    uint32_t MaxCallsPerPeriod;
+    uint32_t MinInstructions;
+    uint32_t MaxInstructions;
+    uint32_t TotalInstructions;
+} DBGKD_GET_INTERNAL_BREAKPOINT32, *PDBGKD_GET_INTERNAL_BREAKPOINT32;
+
+typedef struct _DBGKD_GET_INTERNAL_BREAKPOINT64 {
+    uint64_t BreakpointAddress;
+    uint32_t Flags;
+    uint32_t Calls;
+    uint32_t MaxCallsPerPeriod;
+    uint32_t MinInstructions;
+    uint32_t MaxInstructions;
+    uint32_t TotalInstructions;
+} DBGKD_GET_INTERNAL_BREAKPOINT64, *PDBGKD_GET_INTERNAL_BREAKPOINT64;
+
+typedef struct _DBGKD_GET_VERSION32 {
+    uint16_t MajorVersion;
+    uint16_t MinorVersion;
+    uint16_t ProtocolVersion;
+    uint16_t Flags;
+    uint32_t KernBase;
+    uint32_t PsLoadedModuleList;
+    uint16_t MachineType;
+    uint16_t ThCallbackStack;
+    uint16_t NextCallback;
+    uint16_t FramePointer;
+    uint32_t KiCallUserMode;
+    uint32_t KeUserCallbackDispatcher;
+    uint32_t BreakpointWithStatus;
+    uint32_t DebuggerDataList;
+} DBGKD_GET_VERSION32, *PDBGKD_GET_VERSION32;
+
+typedef struct _DBGKD_GET_VERSION64 {
+    uint16_t MajorVersion;
+    uint16_t MinorVersion;
+    uint8_t ProtocolVersion;
+    uint8_t KdSecondaryVersion;
+    uint16_t Flags;
+    uint16_t MachineType;
+    uint8_t MaxPacketType;
+    uint8_t MaxStateChange;
+    uint8_t MaxManipulate;
+    uint8_t Simulation;
+    uint16_t Unused[1];
+    uint64_t KernBase;
+    uint64_t PsLoadedModuleList;
+    uint64_t DebuggerDataList;
+} DBGKD_GET_VERSION64, *PDBGKD_GET_VERSION64;
+
+typedef struct _DBGKD_BREAKPOINTEX {
+    uint32_t BreakPointCount;
+    ntstatus_t ContinueStatus;
+} DBGKD_BREAKPOINTEX, *PDBGKD_BREAKPOINTEX;
+
+typedef struct _DBGKD_SEARCH_MEMORY {
+    union {
+        uint64_t SearchAddress;
+        uint64_t FoundAddress;
+    };
+    uint64_t SearchLength;
+    uint32_t PatternLength;
+} DBGKD_SEARCH_MEMORY, *PDBGKD_SEARCH_MEMORY;
+
+typedef struct _DBGKD_GET_SET_BUS_DATA {
+    uint32_t BusDataType;
+    uint32_t BusNumber;
+    uint32_t SlotNumber;
+    uint32_t Offset;
+    uint32_t Length;
+} DBGKD_GET_SET_BUS_DATA, *PDBGKD_GET_SET_BUS_DATA;
+
+typedef struct _DBGKD_FILL_MEMORY {
+    uint64_t Address;
+    uint32_t Length;
+    uint16_t Flags;
+    uint16_t PatternLength;
+} DBGKD_FILL_MEMORY, *PDBGKD_FILL_MEMORY;
+
+typedef struct _DBGKD_QUERY_MEMORY {
+    uint64_t Address;
+    uint64_t Reserved;
+    uint32_t AddressSpace;
+    uint32_t Flags;
+} DBGKD_QUERY_MEMORY, *PDBGKD_QUERY_MEMORY;
+
+typedef struct _DBGKD_SWITCH_PARTITION {
+    uint32_t Partition;
+} DBGKD_SWITCH_PARTITION;
+
+/*
+ * DBGKD Structure for Manipulate
+ */
+typedef struct _DBGKD_MANIPULATE_STATE32 {
+    uint32_t ApiNumber;
+    uint16_t ProcessorLevel;
+    uint16_t Processor;
+    ntstatus_t ReturnStatus;
+    union {
+        DBGKD_READ_MEMORY32 ReadMemory;
+        DBGKD_WRITE_MEMORY32 WriteMemory;
+        DBGKD_READ_MEMORY64 ReadMemory64;
+        DBGKD_WRITE_MEMORY64 WriteMemory64;
+        DBGKD_GET_CONTEXT GetContext;
+        DBGKD_SET_CONTEXT SetContext;
+        DBGKD_WRITE_BREAKPOINT32 WriteBreakPoint;
+        DBGKD_RESTORE_BREAKPOINT RestoreBreakPoint;
+        DBGKD_CONTINUE Continue;
+        DBGKD_CONTINUE2 Continue2;
+        DBGKD_READ_WRITE_IO32 ReadWriteIo;
+        DBGKD_READ_WRITE_IO_EXTENDED32 ReadWriteIoExtended;
+        DBGKD_QUERY_SPECIAL_CALLS QuerySpecialCalls;
+        DBGKD_SET_SPECIAL_CALL32 SetSpecialCall;
+        DBGKD_SET_INTERNAL_BREAKPOINT32 SetInternalBreakpoint;
+        DBGKD_GET_INTERNAL_BREAKPOINT32 GetInternalBreakpoint;
+        DBGKD_GET_VERSION32 GetVersion32;
+        DBGKD_BREAKPOINTEX BreakPointEx;
+        DBGKD_READ_WRITE_MSR ReadWriteMsr;
+        DBGKD_SEARCH_MEMORY SearchMemory;
+        DBGKD_GET_SET_BUS_DATA GetSetBusData;
+        DBGKD_FILL_MEMORY FillMemory;
+        DBGKD_QUERY_MEMORY QueryMemory;
+        DBGKD_SWITCH_PARTITION SwitchPartition;
+    } u;
+} DBGKD_MANIPULATE_STATE32, *PDBGKD_MANIPULATE_STATE32;
+
+typedef struct _DBGKD_MANIPULATE_STATE64 {
+    uint32_t ApiNumber;
+    uint16_t ProcessorLevel;
+    uint16_t Processor;
+    ntstatus_t ReturnStatus;
+    union {
+        DBGKD_READ_MEMORY64 ReadMemory;
+        DBGKD_WRITE_MEMORY64 WriteMemory;
+        DBGKD_GET_CONTEXT GetContext;
+        DBGKD_SET_CONTEXT SetContext;
+        DBGKD_WRITE_BREAKPOINT64 WriteBreakPoint;
+        DBGKD_RESTORE_BREAKPOINT RestoreBreakPoint;
+        DBGKD_CONTINUE Continue;
+        DBGKD_CONTINUE2 Continue2;
+        DBGKD_READ_WRITE_IO64 ReadWriteIo;
+        DBGKD_READ_WRITE_IO_EXTENDED64 ReadWriteIoExtended;
+        DBGKD_QUERY_SPECIAL_CALLS QuerySpecialCalls;
+        DBGKD_SET_SPECIAL_CALL64 SetSpecialCall;
+        DBGKD_SET_INTERNAL_BREAKPOINT64 SetInternalBreakpoint;
+        DBGKD_GET_INTERNAL_BREAKPOINT64 GetInternalBreakpoint;
+        DBGKD_GET_VERSION64 GetVersion64;
+        DBGKD_BREAKPOINTEX BreakPointEx;
+        DBGKD_READ_WRITE_MSR ReadWriteMsr;
+        DBGKD_SEARCH_MEMORY SearchMemory;
+        DBGKD_GET_SET_BUS_DATA GetSetBusData;
+        DBGKD_FILL_MEMORY FillMemory;
+        DBGKD_QUERY_MEMORY QueryMemory;
+        DBGKD_SWITCH_PARTITION SwitchPartition;
+    } u;
+} DBGKD_MANIPULATE_STATE64, *PDBGKD_MANIPULATE_STATE64;
+
+/*
+ * File I/O Structure
+ */
+typedef struct _DBGKD_CREATE_FILE {
+    uint32_t DesiredAccess;
+    uint32_t FileAttributes;
+    uint32_t ShareAccess;
+    uint32_t CreateDisposition;
+    uint32_t CreateOptions;
+    uint64_t Handle;
+    uint64_t Length;
+} DBGKD_CREATE_FILE, *PDBGKD_CREATE_FILE;
+
+typedef struct _DBGKD_READ_FILE {
+    uint64_t Handle;
+    uint64_t Offset;
+    uint32_t Length;
+} DBGKD_READ_FILE, *PDBGKD_READ_FILE;
+
+typedef struct _DBGKD_WRITE_FILE {
+    uint64_t Handle;
+    uint64_t Offset;
+    uint32_t Length;
+} DBGKD_WRITE_FILE, *PDBGKD_WRITE_FILE;
+
+typedef struct _DBGKD_CLOSE_FILE {
+    uint64_t Handle;
+} DBGKD_CLOSE_FILE, *PDBGKD_CLOSE_FILE;
+
+typedef struct _DBGKD_FILE_IO {
+    uint32_t ApiNumber;
+    uint32_t Status;
+    union {
+        uint64_t ReserveSpace[7];
+        DBGKD_CREATE_FILE CreateFile;
+        DBGKD_READ_FILE ReadFile;
+        DBGKD_WRITE_FILE WriteFile;
+        DBGKD_CLOSE_FILE CloseFile;
+    } u;
+} DBGKD_FILE_IO, *PDBGKD_FILE_IO;
+
+
+/*
+ * Control Request Structure
+ */
+typedef struct _DBGKD_REQUEST_BREAKPOINT {
+    uint32_t HardwareBreakPointNumber;
+    uint32_t Available;
+} DBGKD_REQUEST_BREAKPOINT, *PDBGKD_REQUEST_BREAKPOINT;
+
+typedef struct _DBGKD_RELEASE_BREAKPOINT {
+    uint32_t HardwareBreakPointNumber;
+    uint32_t Released;
+} DBGKD_RELEASE_BREAKPOINT, *PDBGKD_RELEASE_BREAKPOINT;
+
+typedef struct _DBGKD_CONTROL_REQUEST {
+    uint32_t ApiNumber;
+    union {
+        DBGKD_REQUEST_BREAKPOINT RequestBreakpoint;
+        DBGKD_RELEASE_BREAKPOINT ReleaseBreakpoint;
+    } u;
+} DBGKD_CONTROL_REQUEST, *PDBGKD_CONTROL_REQUEST;
+
+/*
+ * Trace I/O Structure
+ */
+typedef struct _DBGKD_PRINT_TRACE {
+    uint32_t LengthOfData;
+} DBGKD_PRINT_TRACE, *PDBGKD_PRINT_TRACE;
+
+typedef struct _DBGKD_TRACE_IO {
+   uint32_t ApiNumber;
+   uint16_t ProcessorLevel;
+   uint16_t Processor;
+   union {
+       uint64_t ReserveSpace[7];
+       DBGKD_PRINT_TRACE PrintTrace;
+   } u;
+} DBGKD_TRACE_IO, *PDBGKD_TRACE_IO;
+
+#endif
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 67d190bf6c..2390597f1f 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -14,5 +14,6 @@
 
 #include "qemu/osdep.h"
 #include "exec/windbgstub.h"
+#include "exec/windbgkd.h"
 
 #endif

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 03/45] windbg: modified windbgkd.h
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 01/45] windbg: added empty windbgstub files Mihail Abakumov
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 02/45] windbg: added windbg's KD header file Mihail Abakumov
@ 2017-11-21 14:07 ` Mihail Abakumov
  2017-11-28 12:54   ` Ladi Prosek
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 04/45] windbg: added '-windbg' option Mihail Abakumov
                   ` (44 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added useful name arrays of some defines. Not used yet. Needs for the future.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgkd.h |   75 +++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 75 insertions(+)

diff --git a/include/exec/windbgkd.h b/include/exec/windbgkd.h
index b8f98925e7..40a23f8cd0 100755
--- a/include/exec/windbgkd.h
+++ b/include/exec/windbgkd.h
@@ -870,4 +870,79 @@ typedef struct _DBGKD_TRACE_IO {
    } u;
 } DBGKD_TRACE_IO, *PDBGKD_TRACE_IO;
 
+__attribute__ ((unused)) /* maybe unused */
+static const char *kd_api_names[] = {
+    "DbgKdReadVirtualMemoryApi",
+    "DbgKdWriteVirtualMemoryApi",
+    "DbgKdGetContextApi",
+    "DbgKdSetContextApi",
+    "DbgKdWriteBreakPointApi",
+    "DbgKdRestoreBreakPointApi",
+    "DbgKdContinueApi",
+    "DbgKdReadControlSpaceApi",
+    "DbgKdWriteControlSpaceApi",
+    "DbgKdReadIoSpaceApi",
+    "DbgKdWriteIoSpaceApi",
+    "DbgKdRebootApi",
+    "DbgKdContinueApi2",
+    "DbgKdReadPhysicalMemoryApi",
+    "DbgKdWritePhysicalMemoryApi",
+    "DbgKdQuerySpecialCallsApi",
+    "DbgKdSetSpecialCallApi",
+    "DbgKdClearSpecialCallsApi",
+    "DbgKdSetInternalBreakPointApi",
+    "DbgKdGetInternalBreakPointApi",
+    "DbgKdReadIoSpaceExtendedApi",
+    "DbgKdWriteIoSpaceExtendedApi",
+    "DbgKdGetVersionApi",
+    "DbgKdWriteBreakPointExApi",
+    "DbgKdRestoreBreakPointExApi",
+    "DbgKdCauseBugCheckApi",
+    "",
+    "",
+    "",
+    "",
+    "",
+    "",
+    "DbgKdSwitchProcessor",
+    "DbgKdPageInApi",
+    "DbgKdReadMachineSpecificRegister",
+    "DbgKdWriteMachineSpecificRegister",
+    "OldVlm1",
+    "OldVlm2",
+    "DbgKdSearchMemoryApi",
+    "DbgKdGetBusDataApi",
+    "DbgKdSetBusDataApi",
+    "DbgKdCheckLowMemoryApi",
+    "DbgKdClearAllInternalBreakpointsApi",
+    "DbgKdFillMemoryApi",
+    "DbgKdQueryMemoryApi",
+    "DbgKdSwitchPartition",
+    "DbgKdUnknownApi"
+};
+
+__attribute__ ((unused)) /* maybe unused */
+static const char *kd_packet_type_names[] = {
+    "PACKET_TYPE_UNUSED",
+    "PACKET_TYPE_KD_STATE_CHANGE32",
+    "PACKET_TYPE_KD_STATE_MANIPULATE",
+    "PACKET_TYPE_KD_DEBUG_IO",
+    "PACKET_TYPE_KD_ACKNOWLEDGE",
+    "PACKET_TYPE_KD_RESEND",
+    "PACKET_TYPE_KD_RESET",
+    "PACKET_TYPE_KD_STATE_CHANGE64",
+    "PACKET_TYPE_KD_POLL_BREAKIN",
+    "PACKET_TYPE_KD_TRACE_IO",
+    "PACKET_TYPE_KD_CONTROL_REQUEST",
+    "PACKET_TYPE_KD_FILE_IO",
+    "PACKET_TYPE_MAX"
+};
+
+#define KD_API_NAME(id) \
+    (id >= DbgKdMinimumManipulate && id < DbgKdMaximumManipulate) ? \
+        kd_api_names[id - DbgKdMinimumManipulate] : \
+        kd_api_names[DbgKdMaximumManipulate - DbgKdMinimumManipulate] \
+
+#define KD_PKT_TYPE_NAME(id) kd_packet_type_names[id]
+
 #endif

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 04/45] windbg: added '-windbg' option
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (2 preceding siblings ...)
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 03/45] windbg: modified windbgkd.h Mihail Abakumov
@ 2017-11-21 14:07 ` Mihail Abakumov
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 05/45] windbg: added helper features Mihail Abakumov
                   ` (43 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

This option starts windbg server.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Acked-by: Alistair Francis <alistair.francis@xilinx.com>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 qemu-options.hx |    8 ++++++++
 vl.c            |    8 ++++++++
 2 files changed, 16 insertions(+)

diff --git a/qemu-options.hx b/qemu-options.hx
index 9f6e2adfff..1c84eb56d9 100644
--- a/qemu-options.hx
+++ b/qemu-options.hx
@@ -3544,6 +3544,14 @@ Shorthand for -gdb tcp::1234, i.e. open a gdbserver on TCP port 1234
 (@pxref{gdb_usage}).
 ETEXI
 
+DEF("windbg", HAS_ARG, QEMU_OPTION_windbg, \
+    "-windbg         wait for windbg connection\n", QEMU_ARCH_I386)
+STEXI
+@item -windbg
+@findex -windbg
+Wait for windbg connection.
+ETEXI
+
 DEF("d", HAS_ARG, QEMU_OPTION_d, \
     "-d item1,...    enable logging of specified items (use '-d help' for a list of log items)\n",
     QEMU_ARCH_ALL)
diff --git a/vl.c b/vl.c
index 8e247cc2a2..d6378cf03f 100644
--- a/vl.c
+++ b/vl.c
@@ -80,6 +80,7 @@ int main(int argc, char **argv)
 #include "sysemu/sysemu.h"
 #include "sysemu/numa.h"
 #include "exec/gdbstub.h"
+#include "exec/windbgstub.h"
 #include "qemu/timer.h"
 #include "chardev/char.h"
 #include "qemu/bitmap.h"
@@ -2436,6 +2437,7 @@ struct device_config {
         DEV_VIRTCON,   /* -virtioconsole */
         DEV_DEBUGCON,  /* -debugcon */
         DEV_GDB,       /* -gdb, -s */
+        DEV_WINDBG,    /* -windbg */
         DEV_SCLP,      /* s390 sclp */
     } type;
     const char *cmdline;
@@ -3445,6 +3447,9 @@ int main(int argc, char **argv, char **envp)
             case QEMU_OPTION_gdb:
                 add_device_config(DEV_GDB, optarg);
                 break;
+            case QEMU_OPTION_windbg:
+                add_device_config(DEV_WINDBG, optarg);
+                break;
             case QEMU_OPTION_L:
                 if (is_help_option(optarg)) {
                     list_data_dirs = true;
@@ -4586,6 +4591,9 @@ int main(int argc, char **argv, char **envp)
         exit(1);
     }
 
+    if (foreach_device_config(DEV_WINDBG, windbg_server_start) < 0) {
+        exit(1);
+    }
     if (foreach_device_config(DEV_SERIAL, serial_parse) < 0)
         exit(1);
     if (foreach_device_config(DEV_PARALLEL, parallel_parse) < 0)

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 05/45] windbg: added helper features
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (3 preceding siblings ...)
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 04/45] windbg: added '-windbg' option Mihail Abakumov
@ 2017-11-21 14:07 ` Mihail Abakumov
  2017-11-28  8:18   ` Ladi Prosek
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 06/45] windbg: added WindbgState Mihail Abakumov
                   ` (42 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added some helper features for windbgstub.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |   27 +++++++++++++++++++++++++++
 include/exec/windbgstub.h       |    6 ++++++
 2 files changed, 33 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 2390597f1f..e9f5223e94 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -13,7 +13,34 @@
 #define WINDBGSTUB_UTILS_H
 
 #include "qemu/osdep.h"
+#include "qemu/error-report.h"
+#include "log.h"
+#include "cpu.h"
 #include "exec/windbgstub.h"
 #include "exec/windbgkd.h"
 
+#define WINDBG_DEBUG(...) do {             \
+    if (WINDBG_DEBUG_ON) {                 \
+        qemu_log(WINDBG ": " __VA_ARGS__); \
+        qemu_log("\n");                    \
+    }                                      \
+} while (false)
+
+#define WINDBG_ERROR(...) error_report(WINDBG ": " __VA_ARGS__)
+
+#define FMT_ADDR "addr:0x" TARGET_FMT_lx
+#define FMT_ERR  "Error:%d"
+
+#define UINT8_P(ptr) ((uint8_t *) (ptr))
+#define UINT32_P(ptr) ((uint32_t *) (ptr))
+#define PTR(var) UINT8_P(&var)
+
+#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
+
+#define READ_VMEM(cpu, addr, type) ({                         \
+    type _t;                                                  \
+    cpu_memory_rw_debug(cpu, addr, PTR(_t), sizeof(type), 0); \
+    _t;                                                       \
+})
+
 #endif
diff --git a/include/exec/windbgstub.h b/include/exec/windbgstub.h
index 1a6e1cc6e5..21bc552e58 100755
--- a/include/exec/windbgstub.h
+++ b/include/exec/windbgstub.h
@@ -12,6 +12,12 @@
 #ifndef WINDBGSTUB_H
 #define WINDBGSTUB_H
 
+#define WINDBG "windbg"
+
+#ifndef WINDBG_DEBUG_ON
+#define WINDBG_DEBUG_ON false
+#endif
+
 int windbg_server_start(const char *device);
 
 #endif

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 06/45] windbg: added WindbgState
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (4 preceding siblings ...)
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 05/45] windbg: added helper features Mihail Abakumov
@ 2017-11-21 14:07 ` Mihail Abakumov
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 07/45] windbg: added chardev Mihail Abakumov
                   ` (41 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added definition of the WindbgState struct and its initialization.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |   28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)

diff --git a/windbgstub.c b/windbgstub.c
index 3830446988..0863da73fd 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -10,10 +10,38 @@
  */
 
 #include "qemu/osdep.h"
+#include "qapi/error.h"
+#include "chardev/char.h"
+#include "chardev/char-fe.h"
+#include "qemu/cutils.h"
 #include "exec/windbgstub.h"
 #include "exec/windbgstub-utils.h"
 
+typedef struct WindbgState {
+    bool is_loaded;
+
+    uint32_t ctrl_packet_id;
+    uint32_t data_packet_id;
+} WindbgState;
+
+static WindbgState *windbg_state;
+
+static void windbg_exit(void)
+{
+    g_free(windbg_state);
+}
+
 int windbg_server_start(const char *device)
 {
+    if (windbg_state) {
+        WINDBG_ERROR("Multiple instances of windbg are not supported.");
+        exit(1);
+    }
+
+    windbg_state = g_new0(WindbgState, 1);
+    windbg_state->ctrl_packet_id = RESET_PACKET_ID;
+    windbg_state->data_packet_id = INITIAL_PACKET_ID;
+
+    atexit(windbg_exit);
     return 0;
 }

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 07/45] windbg: added chardev
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (5 preceding siblings ...)
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 06/45] windbg: added WindbgState Mihail Abakumov
@ 2017-11-21 14:07 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 08/45] windbg: hook to wrmsr operation Mihail Abakumov
                   ` (40 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:07 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added chardev for listening to windbg. Target device is a parameter in the '-windbg' option.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Acked-by: Alistair Francis <alistair.francis@xilinx.com>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |   30 ++++++++++++++++++++++++++++++
 1 file changed, 30 insertions(+)

diff --git a/windbgstub.c b/windbgstub.c
index 0863da73fd..e30b8500e0 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -20,12 +20,26 @@
 typedef struct WindbgState {
     bool is_loaded;
 
+    CharBackend chr;
+
     uint32_t ctrl_packet_id;
     uint32_t data_packet_id;
 } WindbgState;
 
 static WindbgState *windbg_state;
 
+static int windbg_chr_can_receive(void *opaque)
+{
+    return PACKET_MAX_SIZE;
+}
+
+static void windbg_chr_receive(void *opaque, const uint8_t *buf, int size)
+{
+    if (windbg_state->is_loaded) {
+        /* T0D0: parse data */
+    }
+}
+
 static void windbg_exit(void)
 {
     g_free(windbg_state);
@@ -33,15 +47,31 @@ static void windbg_exit(void)
 
 int windbg_server_start(const char *device)
 {
+    Chardev *chr = NULL;
+
     if (windbg_state) {
         WINDBG_ERROR("Multiple instances of windbg are not supported.");
         exit(1);
     }
 
+    if (!strstart(device, "pipe:", NULL)) {
+        WINDBG_ERROR("Unsupported device. Supported only pipe.");
+        exit(1);
+    }
+
     windbg_state = g_new0(WindbgState, 1);
     windbg_state->ctrl_packet_id = RESET_PACKET_ID;
     windbg_state->data_packet_id = INITIAL_PACKET_ID;
 
+    chr = qemu_chr_new_noreplay(WINDBG, device);
+    if (!chr) {
+        return -1;
+    }
+
+    qemu_chr_fe_init(&windbg_state->chr, chr, &error_abort);
+    qemu_chr_fe_set_handlers(&windbg_state->chr, windbg_chr_can_receive,
+                             windbg_chr_receive, NULL, NULL, NULL, NULL, true);
+
     atexit(windbg_exit);
     return 0;
 }

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 08/45] windbg: hook to wrmsr operation
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (6 preceding siblings ...)
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 07/45] windbg: added chardev Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 09/45] windbg: handler of fs/gs register Mihail Abakumov
                   ` (39 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Inserted hook to wrmsr operation. Windows Kernel put address on KPCR struct to fs/gs (x32/x64) register. Needs catch this moment and allow windbg server handle packets.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 ++
 include/exec/windbgstub.h       |    1 +
 stubs/windbgstub.c              |    3 +++
 target/i386/misc_helper.c       |    3 +++
 target/i386/windbgstub.c        |   10 ++++++++++
 windbgstub.c                    |   13 +++++++++++++
 6 files changed, 32 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index e9f5223e94..4232aeb59d 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -43,4 +43,6 @@
     _t;                                                       \
 })
 
+bool windbg_on_load(void);
+
 #endif
diff --git a/include/exec/windbgstub.h b/include/exec/windbgstub.h
index 21bc552e58..309f692383 100755
--- a/include/exec/windbgstub.h
+++ b/include/exec/windbgstub.h
@@ -18,6 +18,7 @@
 #define WINDBG_DEBUG_ON false
 #endif
 
+void windbg_try_load(void);
 int windbg_server_start(const char *device);
 
 #endif
diff --git a/stubs/windbgstub.c b/stubs/windbgstub.c
index 4951f59203..bd7e2dccd1 100755
--- a/stubs/windbgstub.c
+++ b/stubs/windbgstub.c
@@ -12,6 +12,9 @@
 #include "qemu/osdep.h"
 #include "exec/windbgstub.h"
 
+void windbg_try_load(void)
+{}
+
 int windbg_server_start(const char *device)
 {
     return 0;
diff --git a/target/i386/misc_helper.c b/target/i386/misc_helper.c
index 628f64aad5..ec1fcd2899 100644
--- a/target/i386/misc_helper.c
+++ b/target/i386/misc_helper.c
@@ -24,6 +24,7 @@
 #include "exec/exec-all.h"
 #include "exec/cpu_ldst.h"
 #include "exec/address-spaces.h"
+#include "exec/windbgstub.h"
 
 void helper_outb(CPUX86State *env, uint32_t port, uint32_t data)
 {
@@ -385,6 +386,8 @@ void helper_wrmsr(CPUX86State *env)
         /* XXX: exception? */
         break;
     }
+
+    windbg_try_load();
 }
 
 void helper_rdmsr(CPUX86State *env)
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index df89e1edd8..0938f738e6 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -10,3 +10,13 @@
  */
 
 #include "qemu/osdep.h"
+
+#ifndef TARGET_X86_64
+#include "exec/windbgstub-utils.h"
+
+bool windbg_on_load(void)
+{
+    return false;
+}
+
+#endif
diff --git a/windbgstub.c b/windbgstub.c
index e30b8500e0..a2a6eb81b4 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -16,6 +16,7 @@
 #include "qemu/cutils.h"
 #include "exec/windbgstub.h"
 #include "exec/windbgstub-utils.h"
+#include "sysemu/kvm.h"
 
 typedef struct WindbgState {
     bool is_loaded;
@@ -45,6 +46,13 @@ static void windbg_exit(void)
     g_free(windbg_state);
 }
 
+void windbg_try_load(void)
+{
+    if (windbg_state && !windbg_state->is_loaded) {
+        windbg_state->is_loaded = windbg_on_load();
+    }
+}
+
 int windbg_server_start(const char *device)
 {
     Chardev *chr = NULL;
@@ -54,6 +62,11 @@ int windbg_server_start(const char *device)
         exit(1);
     }
 
+    if (kvm_enabled()) {
+        WINDBG_ERROR("KVM is not supported.");
+        exit(1);
+    }
+
     if (!strstart(device, "pipe:", NULL)) {
         WINDBG_ERROR("Unsupported device. Supported only pipe.");
         exit(1);

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 09/45] windbg: handler of fs/gs register
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (7 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 08/45] windbg: hook to wrmsr operation Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 10/45] windbg: structures for parsing data stream Mihail Abakumov
                   ` (38 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added handler of fs/gs register. It tries to find and check KPCR and version address.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    8 ++++++
 target/i386/windbgstub.c        |   49 ++++++++++++++++++++++++++++++++++++++-
 windbgstub-utils.c              |   13 ++++++++++
 windbgstub.c                    |   10 ++++++++
 4 files changed, 79 insertions(+), 1 deletion(-)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 4232aeb59d..42dbca1e22 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -43,6 +43,14 @@
     _t;                                                       \
 })
 
+typedef struct InitedAddr {
+    target_ulong addr;
+    bool is_init;
+} InitedAddr;
+
+InitedAddr *windbg_get_KPCR(void);
+InitedAddr *windbg_get_version(void);
+
 bool windbg_on_load(void);
 
 #endif
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 0938f738e6..47ee5840ef 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -14,9 +14,56 @@
 #ifndef TARGET_X86_64
 #include "exec/windbgstub-utils.h"
 
+#ifdef TARGET_X86_64
+# define OFFSET_SELF_PCR         0x18
+# define OFFSET_VERS             0x108
+#else
+# define OFFSET_SELF_PCR         0x1C
+# define OFFSET_VERS             0x34
+#endif
+
 bool windbg_on_load(void)
 {
-    return false;
+    CPUState *cpu = qemu_get_cpu(0);
+    CPUArchState *env = cpu->env_ptr;
+    InitedAddr *KPCR = windbg_get_KPCR();
+    InitedAddr *version = windbg_get_version();
+
+    if (!KPCR->is_init) {
+
+ #ifdef TARGET_X86_64
+        KPCR->addr = env->segs[R_GS].base;
+ #else
+        KPCR->addr = env->segs[R_FS].base;
+ #endif
+
+        static target_ulong prev_KPCR;
+        if (!KPCR->addr || prev_KPCR == KPCR->addr) {
+            return false;
+        }
+        prev_KPCR = KPCR->addr;
+
+        if (KPCR->addr != READ_VMEM(cpu, KPCR->addr + OFFSET_SELF_PCR,
+                                    target_ulong)) {
+            return false;
+        }
+
+        KPCR->is_init = true;
+    }
+
+    if (!version->is_init && KPCR->is_init) {
+        version->addr = READ_VMEM(cpu, KPCR->addr + OFFSET_VERS,
+                                  target_ulong);
+        if (!version->addr) {
+            return false;
+        }
+        version->is_init = true;
+    }
+
+    WINDBG_DEBUG("windbg_on_load: KPCR " FMT_ADDR, KPCR->addr);
+    WINDBG_DEBUG("windbg_on_load: version " FMT_ADDR, version->addr);
+
+    return true;
 }
 
 #endif
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index dc5e505c63..347c61553a 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -10,3 +10,16 @@
  */
 
 #include "exec/windbgstub-utils.h"
+
+static InitedAddr KPCR;
+static InitedAddr version;
+
+InitedAddr *windbg_get_KPCR(void)
+{
+    return &KPCR;
+}
+
+InitedAddr *windbg_get_version(void)
+{
+    return &version;
+}
diff --git a/windbgstub.c b/windbgstub.c
index a2a6eb81b4..e9aabd807b 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -17,6 +17,7 @@
 #include "exec/windbgstub.h"
 #include "exec/windbgstub-utils.h"
 #include "sysemu/kvm.h"
+#include "sysemu/reset.h"
 
 typedef struct WindbgState {
     bool is_loaded;
@@ -46,6 +47,13 @@ static void windbg_exit(void)
     g_free(windbg_state);
 }
 
+static void windbg_handle_reset(void *opaque)
+{
+    windbg_state->is_loaded = false;
+    windbg_get_KPCR()->is_init = false;
+    windbg_get_version()->is_init = false;
+}
+
 void windbg_try_load(void)
 {
     if (windbg_state && !windbg_state->is_loaded) {
@@ -85,6 +93,8 @@ int windbg_server_start(const char *device)
     qemu_chr_fe_set_handlers(&windbg_state->chr, windbg_chr_can_receive,
                              windbg_chr_receive, NULL, NULL, NULL, NULL, true);
 
+    qemu_register_reset(windbg_handle_reset, NULL);
+
     atexit(windbg_exit);
     return 0;
 }

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 10/45] windbg: structures for parsing data stream
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (8 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 09/45] windbg: handler of fs/gs register Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-28 13:45   ` Ladi Prosek
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 11/45] windbg: " Mihail Abakumov
                   ` (37 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added structures for parsing data stream from windbg to packet.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |   11 +++++++++++
 windbgstub.c                    |   30 ++++++++++++++++++++++++++++++
 2 files changed, 41 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 42dbca1e22..2d74fb847a 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -48,6 +48,17 @@ typedef struct InitedAddr {
     bool is_init;
 } InitedAddr;
 
+typedef struct PacketData {
+    union {
+        struct {
+            DBGKD_MANIPULATE_STATE64 m64;
+            uint8_t extra[PACKET_MAX_SIZE - sizeof(DBGKD_MANIPULATE_STATE64)];
+        };
+        uint8_t buf[PACKET_MAX_SIZE];
+    };
+    uint16_t extra_size;
+} PacketData;
+
 InitedAddr *windbg_get_KPCR(void);
 InitedAddr *windbg_get_version(void);
 
diff --git a/windbgstub.c b/windbgstub.c
index e9aabd807b..395f244d4f 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -19,6 +19,36 @@
 #include "sysemu/kvm.h"
 #include "sysemu/reset.h"
 
+typedef enum ParsingState {
+    STATE_LEADER,
+    STATE_PACKET_TYPE,
+    STATE_PACKET_BYTE_COUNT,
+    STATE_PACKET_ID,
+    STATE_PACKET_CHECKSUM,
+    STATE_PACKET_DATA,
+    STATE_TRAILING_BYTE,
+} ParsingState;
+
+typedef enum ParsingResult {
+    RESULT_NONE,
+    RESULT_BREAKIN_BYTE,
+    RESULT_UNKNOWN_PACKET,
+    RESULT_CONTROL_PACKET,
+    RESULT_DATA_PACKET,
+    RESULT_ERROR,
+} ParsingResult;
+
+typedef struct ParsingContext {
+    /* index in the current buffer,
+       which depends on the current state */
+    int index;
+    ParsingState state;
+    ParsingResult result;
+    KD_PACKET packet;
+    PacketData data;
+    const char *name;
+} ParsingContext;
+
 typedef struct WindbgState {
     bool is_loaded;
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 11/45] windbg: parsing data stream
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (9 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 10/45] windbg: structures for parsing data stream Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 12/45] windbg: send data and control packets Mihail Abakumov
                   ` (36 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added function of parsing data stream from windbg to packet.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |  111 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 110 insertions(+), 1 deletion(-)

diff --git a/windbgstub.c b/windbgstub.c
index 395f244d4f..ace992e2cb 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -60,6 +60,105 @@ typedef struct WindbgState {
 
 static WindbgState *windbg_state;
 
+static void windbg_ctx_handler(ParsingContext *ctx)
+{}
+
+static void windbg_read_byte(ParsingContext *ctx, uint8_t byte)
+{
+    switch (ctx->state) {
+    case STATE_LEADER:
+        ctx->result = RESULT_NONE;
+        if (byte == PACKET_LEADER_BYTE || byte == CONTROL_PACKET_LEADER_BYTE) {
+            if (ctx->index > 0 && byte != PTR(ctx->packet.PacketLeader)[0]) {
+                ctx->index = 0;
+            }
+            PTR(ctx->packet.PacketLeader)[ctx->index] = byte;
+            ++ctx->index;
+            if (ctx->index == sizeof(ctx->packet.PacketLeader)) {
+                ctx->state = STATE_PACKET_TYPE;
+                ctx->index = 0;
+            }
+        } else if (byte == BREAKIN_PACKET_BYTE) {
+            ctx->result = RESULT_BREAKIN_BYTE;
+            ctx->index = 0;
+        } else {
+            ctx->index = 0;
+        }
+        break;
+
+    case STATE_PACKET_TYPE:
+        PTR(ctx->packet.PacketType)[ctx->index] = byte;
+        ++ctx->index;
+        if (ctx->index == sizeof(ctx->packet.PacketType)) {
+            ctx->packet.PacketType = lduw_p(&ctx->packet.PacketType);
+            if (ctx->packet.PacketType >= PACKET_TYPE_MAX) {
+                ctx->state = STATE_LEADER;
+                ctx->result = RESULT_UNKNOWN_PACKET;
+            } else {
+                ctx->state = STATE_PACKET_BYTE_COUNT;
+            }
+            ctx->index = 0;
+        }
+        break;
+
+    case STATE_PACKET_BYTE_COUNT:
+        PTR(ctx->packet.ByteCount)[ctx->index] = byte;
+        ++ctx->index;
+        if (ctx->index == sizeof(ctx->packet.ByteCount)) {
+            ctx->packet.ByteCount = lduw_p(&ctx->packet.ByteCount);
+            ctx->state = STATE_PACKET_ID;
+            ctx->index = 0;
+        }
+        break;
+
+    case STATE_PACKET_ID:
+        PTR(ctx->packet.PacketId)[ctx->index] = byte;
+        ++ctx->index;
+        if (ctx->index == sizeof(ctx->packet.PacketId)) {
+            ctx->packet.PacketId = ldl_p(&ctx->packet.PacketId);
+            ctx->state = STATE_PACKET_CHECKSUM;
+            ctx->index = 0;
+        }
+        break;
+
+    case STATE_PACKET_CHECKSUM:
+        PTR(ctx->packet.Checksum)[ctx->index] = byte;
+        ++ctx->index;
+        if (ctx->index == sizeof(ctx->packet.Checksum)) {
+            ctx->packet.Checksum = ldl_p(&ctx->packet.Checksum);
+            if (ctx->packet.PacketLeader == CONTROL_PACKET_LEADER) {
+                ctx->state = STATE_LEADER;
+                ctx->result = RESULT_CONTROL_PACKET;
+            } else if (ctx->packet.ByteCount > PACKET_MAX_SIZE) {
+                ctx->state = STATE_LEADER;
+                ctx->result = RESULT_ERROR;
+            } else {
+                ctx->state = STATE_PACKET_DATA;
+            }
+            ctx->index = 0;
+        }
+        break;
+
+    case STATE_PACKET_DATA:
+        ctx->data.buf[ctx->index] = byte;
+        ++ctx->index;
+        if (ctx->index == ctx->packet.ByteCount) {
+            ctx->state = STATE_TRAILING_BYTE;
+            ctx->index = 0;
+        }
+        break;
+
+    case STATE_TRAILING_BYTE:
+        if (byte == PACKET_TRAILING_BYTE) {
+            ctx->result = RESULT_DATA_PACKET;
+        } else {
+            ctx->result = RESULT_ERROR;
+        }
+        ctx->state = STATE_LEADER;
+        break;
+    }
+}
+
 static int windbg_chr_can_receive(void *opaque)
 {
     return PACKET_MAX_SIZE;
@@ -67,8 +166,18 @@ static int windbg_chr_can_receive(void *opaque)
 
 static void windbg_chr_receive(void *opaque, const uint8_t *buf, int size)
 {
+    static ParsingContext ctx = {
+        .state = STATE_LEADER,
+        .result = RESULT_NONE,
+        .name = ""
+    };
+
     if (windbg_state->is_loaded) {
-        /* T0D0: parse data */
+        int i;
+        for (i = 0; i < size; i++) {
+            windbg_read_byte(&ctx, buf[i]);
+            windbg_ctx_handler(&ctx);
+        }
     }
 }
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 12/45] windbg: send data and control packets
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (10 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 11/45] windbg: " Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 13/45] windbg: handler of parsing context Mihail Abakumov
                   ` (35 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added functions for send data and control packets to windbg.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |   56 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 56 insertions(+)

diff --git a/windbgstub.c b/windbgstub.c
index ace992e2cb..8c33e0de0a 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -60,6 +60,62 @@ typedef struct WindbgState {
 
 static WindbgState *windbg_state;
 
+static uint32_t compute_checksum(uint8_t *data, uint16_t len)
+{
+    uint32_t checksum = 0;
+    while (len) {
+        --len;
+        checksum += *data++;
+    }
+    return checksum;
+}
+
+__attribute__ ((unused)) /* unused yet */
+static void windbg_send_data_packet(uint8_t *data, uint16_t byte_count,
+                                    uint16_t type)
+{
+    uint8_t trailing_byte = PACKET_TRAILING_BYTE;
+
+    KD_PACKET packet = {
+        .PacketLeader = PACKET_LEADER,
+        .PacketType = type,
+        .ByteCount = byte_count,
+        .PacketId = windbg_state->data_packet_id,
+        .Checksum = compute_checksum(data, byte_count)
+    };
+
+    stw_p(&packet.PacketType, packet.PacketType);
+    stw_p(&packet.ByteCount, packet.ByteCount);
+    stl_p(&packet.PacketId, packet.PacketId);
+    stl_p(&packet.Checksum, packet.Checksum);
+
+    qemu_chr_fe_write(&windbg_state->chr, PTR(packet), sizeof(packet));
+    qemu_chr_fe_write(&windbg_state->chr, data, byte_count);
+    qemu_chr_fe_write(&windbg_state->chr, &trailing_byte,
+                      sizeof(trailing_byte));
+
+    windbg_state->data_packet_id ^= 1;
+}
+
+__attribute__ ((unused)) /* unused yet */
+static void windbg_send_control_packet(uint16_t type)
+{
+    KD_PACKET packet = {
+        .PacketLeader = CONTROL_PACKET_LEADER,
+        .PacketType = type,
+        .ByteCount = 0,
+        .PacketId = windbg_state->ctrl_packet_id,
+        .Checksum = 0
+    };
+
+    stw_p(&packet.PacketType, packet.PacketType);
+    stl_p(&packet.PacketId, packet.PacketId);
+
+    qemu_chr_fe_write(&windbg_state->chr, PTR(packet), sizeof(packet));
+
+    windbg_state->ctrl_packet_id ^= 1;
+}
+
 static void windbg_ctx_handler(ParsingContext *ctx)
 {}
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 13/45] windbg: handler of parsing context
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (11 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 12/45] windbg: send data and control packets Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 14/45] windbg: init DBGKD_ANY_WAIT_STATE_CHANGE Mihail Abakumov
                   ` (34 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Implemented handler of parsing context.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |   36 ++++++++++++++++++++++++++++++++++--
 1 file changed, 34 insertions(+), 2 deletions(-)

diff --git a/windbgstub.c b/windbgstub.c
index 8c33e0de0a..b71449e369 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -11,6 +11,7 @@
 
 #include "qemu/osdep.h"
 #include "qapi/error.h"
+#include "sysemu/sysemu.h"
 #include "chardev/char.h"
 #include "chardev/char-fe.h"
 #include "qemu/cutils.h"
@@ -97,7 +98,6 @@ static void windbg_send_data_packet(uint8_t *data, uint16_t byte_count,
     windbg_state->data_packet_id ^= 1;
 }
 
-__attribute__ ((unused)) /* unused yet */
 static void windbg_send_control_packet(uint16_t type)
 {
     KD_PACKET packet = {
@@ -116,9 +116,41 @@ static void windbg_send_control_packet(uint16_t type)
     windbg_state->ctrl_packet_id ^= 1;
 }
 
-static void windbg_ctx_handler(ParsingContext *ctx)
+static void windbg_process_data_packet(ParsingContext *ctx)
 {}
 
+static void windbg_process_control_packet(ParsingContext *ctx)
+{}
+
+static void windbg_ctx_handler(ParsingContext *ctx)
+{
+    switch (ctx->result) {
+    case RESULT_NONE:
+        break;
+
+    case RESULT_BREAKIN_BYTE:
+        vm_stop(RUN_STATE_PAUSED);
+        break;
+
+    case RESULT_CONTROL_PACKET:
+        windbg_process_control_packet(ctx);
+        break;
+
+    case RESULT_DATA_PACKET:
+        windbg_process_data_packet(ctx);
+        break;
+
+    case RESULT_UNKNOWN_PACKET:
+    case RESULT_ERROR:
+        windbg_state->ctrl_packet_id = 0;
+        windbg_send_control_packet(PACKET_TYPE_KD_RESEND);
+        break;
+
+    default:
+        break;
+    }
+}
+
 static void windbg_read_byte(ParsingContext *ctx, uint8_t byte)
 {
     switch (ctx->state) {

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 14/45] windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (12 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 13/45] windbg: handler of parsing context Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 15/45] windbg: sized data buffer Mihail Abakumov
                   ` (33 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added function for init DBGKD_ANY_WAIT_STATE_CHANGE. It is a header of 'state change' packets.


Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    8 ++++++
 target/i386/windbgstub.c        |   49 +++++++++++++++++++++++++++++++++++++++
 2 files changed, 57 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 2d74fb847a..6ce870beb1 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -43,6 +43,14 @@
     _t;                                                       \
 })
 
+#if TARGET_LONG_BITS == 64
+# define sttul_p(p, v) stq_p(p, v)
+# define ldtul_p(p) ldq_p(p)
+#else
+# define sttul_p(p, v) stl_p(p, v)
+# define ldtul_p(p) ldl_p(p)
+#endif
+
 typedef struct InitedAddr {
     target_ulong addr;
     bool is_init;
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 47ee5840ef..a3c433f756 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -17,9 +17,13 @@
 #ifdef TARGET_X86_64
 # define OFFSET_SELF_PCR         0x18
 # define OFFSET_VERS             0x108
+# define OFFSET_KPRCB            0x20
+# define OFFSET_KPRCB_CURRTHREAD 0x8
 #else
 # define OFFSET_SELF_PCR         0x1C
 # define OFFSET_VERS             0x34
+# define OFFSET_KPRCB            0x20
+# define OFFSET_KPRCB_CURRTHREAD 0x4
 #endif
 
 bool windbg_on_load(void)
@@ -66,4 +70,49 @@ bool windbg_on_load(void)
     return true;
 }
 
+__attribute__ ((unused)) /* unused yet */
+static void kd_init_state_change(CPUState *cpu,
+                                 DBGKD_ANY_WAIT_STATE_CHANGE *sc)
+{
+    CPUArchState *env = cpu->env_ptr;
+    DBGKD_CONTROL_REPORT *cr = &sc->ControlReport;
+    InitedAddr *KPCR = windbg_get_KPCR();
+    target_ulong KPRCB;
+    int err = 0;
+
+    /* T0D0: HEADER */
+
+    sc->Processor = 0;
+
+    sc->NumberProcessors = 0;
+    CPUState *cpu_tmp;
+    CPU_FOREACH(cpu_tmp) {
+        sc->NumberProcessors++;
+    }
+    stl_p(&sc->NumberProcessors, sc->NumberProcessors);
+
+    KPRCB = READ_VMEM(cpu, KPCR->addr + OFFSET_KPRCB, target_ulong);
+    sc->Thread = READ_VMEM(cpu, KPRCB + OFFSET_KPRCB_CURRTHREAD, target_ulong);
+    sttul_p(&sc->Thread, sc->Thread);
+    sttul_p(&sc->ProgramCounter, env->eip);
+
+    /* T0D0: CONTROL REPORT */
+
+    sttul_p(&cr->Dr6, env->dr[6]);
+    sttul_p(&cr->Dr7, env->dr[7]);
+    stw_p(&cr->ReportFlags, REPORT_INCLUDES_SEGS | REPORT_STANDARD_CS);
+    stw_p(&cr->SegCs, env->segs[R_CS].selector);
+    stw_p(&cr->SegDs, env->segs[R_DS].selector);
+    stw_p(&cr->SegEs, env->segs[R_ES].selector);
+    stw_p(&cr->SegFs, env->segs[R_FS].selector);
+    stl_p(&cr->EFlags, env->eflags);
+
+    err = cpu_memory_rw_debug(cpu, sc->ProgramCounter,
+                              PTR(cr->InstructionStream[0]),
+                              DBGKD_MAXSTREAM, 0);
+    if (!err) {
+        stw_p(&cr->InstructionCount, DBGKD_MAXSTREAM);
+    }
+}
+
 #endif

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 15/45] windbg: sized data buffer
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (13 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 14/45] windbg: init DBGKD_ANY_WAIT_STATE_CHANGE Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-28 14:07   ` Ladi Prosek
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 16/45] windbg: generate ExceptionStateChange Mihail Abakumov
                   ` (32 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Defined useful sized data buffer. It contains pointer to data and size of this data. Also, defined some macros for init and free.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |   16 ++++++++++++++++
 1 file changed, 16 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 6ce870beb1..b729cd604e 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -67,6 +67,22 @@ typedef struct PacketData {
     uint16_t extra_size;
 } PacketData;
 
+typedef struct SizedBuf {
+    uint8_t *data;
+    size_t size;
+} SizedBuf;
+
+#define SBUF_INIT(buf, mem_ptr, len) do { \
+    buf.data = mem_ptr;                   \
+    buf.size = len;                       \
+} while (false)
+#define SBUF_MALLOC(buf, size) SBUF_INIT(buf, g_malloc0(size), size)
+#define SBUF_FREE(buf) do { \
+    g_free(buf.data);       \
+    buf.data = NULL;        \
+    buf.size = 0;           \
+} while (false)
+
 InitedAddr *windbg_get_KPCR(void);
 InitedAddr *windbg_get_version(void);
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 16/45] windbg: generate ExceptionStateChange
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (14 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 15/45] windbg: sized data buffer Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 17/45] windbg: generate LoadSymbolsStateChange Mihail Abakumov
                   ` (31 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added function for generate ExceptionStateChange packet.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 ++
 target/i386/windbgstub.c        |   20 +++++++++++++++++++-
 2 files changed, 21 insertions(+), 1 deletion(-)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index b729cd604e..f35873eca0 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -86,6 +86,8 @@ typedef struct SizedBuf {
 InitedAddr *windbg_get_KPCR(void);
 InitedAddr *windbg_get_version(void);
 
+SizedBuf kd_gen_exception_sc(CPUState *cpu);
+
 bool windbg_on_load(void);
 
 #endif
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index a3c433f756..f0edd94dde 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -70,7 +70,6 @@ bool windbg_on_load(void)
     return true;
 }
 
-__attribute__ ((unused)) /* unused yet */
 static void kd_init_state_change(CPUState *cpu,
                                  DBGKD_ANY_WAIT_STATE_CHANGE *sc)
 {
@@ -115,4 +114,23 @@ static void kd_init_state_change(CPUState *cpu,
     }
 }
 
+SizedBuf kd_gen_exception_sc(CPUState *cpu)
+{
+    CPUArchState *env = cpu->env_ptr;
+    DBGKD_ANY_WAIT_STATE_CHANGE *sc;
+    DBGKM_EXCEPTION_RECORD64 *exc;
+    SizedBuf buf;
+
+    SBUF_MALLOC(buf, sizeof(DBGKD_ANY_WAIT_STATE_CHANGE) + sizeof(int));
+    sc = (DBGKD_ANY_WAIT_STATE_CHANGE *) buf.data;
+    exc = &sc->u.Exception.ExceptionRecord;
+    kd_init_state_change(cpu, sc);
+
+    stl_p(&sc->NewState, DbgKdExceptionStateChange);
+    stl_p(&exc->ExceptionCode, 0x80000003);
+    sttul_p(&exc->ExceptionAddress, env->eip);
+
+    return buf;
+}
+
 #endif

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 17/45] windbg: generate LoadSymbolsStateChange
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (15 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 16/45] windbg: generate ExceptionStateChange Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 18/45] windbg: windbg_vm_stop Mihail Abakumov
                   ` (30 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added function for generate LoadSymbolsStateChange packet.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    1 +
 target/i386/windbgstub.c        |   15 +++++++++++++++
 2 files changed, 16 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index f35873eca0..8558bc6c8a 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -87,6 +87,7 @@ InitedAddr *windbg_get_KPCR(void);
 InitedAddr *windbg_get_version(void);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
+SizedBuf kd_gen_load_symbols_sc(CPUState *cpu);
 
 bool windbg_on_load(void);
 
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index f0edd94dde..261e441db1 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -133,4 +133,19 @@ SizedBuf kd_gen_exception_sc(CPUState *cpu)
     return buf;
 }
 
+SizedBuf kd_gen_load_symbols_sc(CPUState *cpu)
+{
+    DBGKD_ANY_WAIT_STATE_CHANGE *sc;
+    SizedBuf buf;
+
+    SBUF_MALLOC(buf, sizeof(DBGKD_ANY_WAIT_STATE_CHANGE));
+    sc = (DBGKD_ANY_WAIT_STATE_CHANGE *) buf.data;
+    kd_init_state_change(cpu, sc);
+
+    stl_p(&sc->NewState, DbgKdLoadSymbolsStateChange);
+    stl_p(&sc->u.LoadSymbols.PathNameLength, 0);
+
+    return buf;
+}
+
 #endif

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 18/45] windbg: windbg_vm_stop
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (16 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 17/45] windbg: generate LoadSymbolsStateChange Mihail Abakumov
@ 2017-11-21 14:08 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 19/45] windbg: implemented windbg_process_control_packet Mihail Abakumov
                   ` (29 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:08 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added function for stop vm. Also, ExceptionStateChange data is generated and sent here.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |   13 +++++++++++--
 1 file changed, 11 insertions(+), 2 deletions(-)

diff --git a/windbgstub.c b/windbgstub.c
index b71449e369..dc9eba3e3c 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -71,7 +71,6 @@ static uint32_t compute_checksum(uint8_t *data, uint16_t len)
     return checksum;
 }
 
-__attribute__ ((unused)) /* unused yet */
 static void windbg_send_data_packet(uint8_t *data, uint16_t byte_count,
                                     uint16_t type)
 {
@@ -116,6 +115,16 @@ static void windbg_send_control_packet(uint16_t type)
     windbg_state->ctrl_packet_id ^= 1;
 }
 
+static void windbg_vm_stop(void)
+{
+    CPUState *cpu = qemu_get_cpu(0);
+    vm_stop(RUN_STATE_PAUSED);
+
+    SizedBuf buf = kd_gen_exception_sc(cpu);
+    windbg_send_data_packet(buf.data, buf.size, PACKET_TYPE_KD_STATE_CHANGE64);
+    SBUF_FREE(buf);
+}
+
 static void windbg_process_data_packet(ParsingContext *ctx)
 {}
 
@@ -129,7 +138,7 @@ static void windbg_ctx_handler(ParsingContext *ctx)
         break;
 
     case RESULT_BREAKIN_BYTE:
-        vm_stop(RUN_STATE_PAUSED);
+        windbg_vm_stop();
         break;
 
     case RESULT_CONTROL_PACKET:

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 19/45] windbg: implemented windbg_process_control_packet
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (17 preceding siblings ...)
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 18/45] windbg: windbg_vm_stop Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 20/45] windbg: implemented windbg_process_data_packet Mihail Abakumov
                   ` (28 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |   26 +++++++++++++++++++++++++-
 1 file changed, 25 insertions(+), 1 deletion(-)

diff --git a/windbgstub.c b/windbgstub.c
index dc9eba3e3c..b2d4881ee8 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -129,7 +129,31 @@ static void windbg_process_data_packet(ParsingContext *ctx)
 {}
 
 static void windbg_process_control_packet(ParsingContext *ctx)
-{}
+{
+    switch (ctx->packet.PacketType) {
+    case PACKET_TYPE_KD_ACKNOWLEDGE:
+        break;
+
+    case PACKET_TYPE_KD_RESET:
+    {
+        SizedBuf buf = kd_gen_load_symbols_sc(qemu_get_cpu(0));
+
+        windbg_send_data_packet(buf.data, buf.size,
+                                PACKET_TYPE_KD_STATE_CHANGE64);
+        windbg_send_control_packet(ctx->packet.PacketType);
+        windbg_state->ctrl_packet_id = INITIAL_PACKET_ID;
+        SBUF_FREE(buf);
+        break;
+    }
+    default:
+        WINDBG_ERROR("Caught unsupported control packet 0x%x",
+                     ctx->packet.PacketType);
+
+        windbg_state->ctrl_packet_id = 0;
+        windbg_send_control_packet(PACKET_TYPE_KD_RESEND);
+        break;
+    }
+}
 
 static void windbg_ctx_handler(ParsingContext *ctx)
 {

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 20/45] windbg: implemented windbg_process_data_packet
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (18 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 19/45] windbg: implemented windbg_process_control_packet Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 21/45] windbg: implemented windbg_process_manipulate_packet Mihail Abakumov
                   ` (27 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 windbgstub.c |   20 +++++++++++++++++++-
 1 file changed, 19 insertions(+), 1 deletion(-)

diff --git a/windbgstub.c b/windbgstub.c
index b2d4881ee8..8058972dc7 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -125,9 +125,27 @@ static void windbg_vm_stop(void)
     SBUF_FREE(buf);
 }
 
-static void windbg_process_data_packet(ParsingContext *ctx)
+static void windbg_process_manipulate_packet(ParsingContext *ctx)
 {}
 
+static void windbg_process_data_packet(ParsingContext *ctx)
+{
+    switch (ctx->packet.PacketType) {
+    case PACKET_TYPE_KD_STATE_MANIPULATE:
+        windbg_send_control_packet(PACKET_TYPE_KD_ACKNOWLEDGE);
+        windbg_process_manipulate_packet(ctx);
+        break;
+
+    default:
+        WINDBG_ERROR("Caught unsupported data packet 0x%x",
+                     ctx->packet.PacketType);
+
+        windbg_state->ctrl_packet_id = 0;
+        windbg_send_control_packet(PACKET_TYPE_KD_RESEND);
+        break;
+    }
+}
+
 static void windbg_process_control_packet(ParsingContext *ctx)
 {
     switch (ctx->packet.PacketType) {

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 21/45] windbg: implemented windbg_process_manipulate_packet
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (19 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 20/45] windbg: implemented windbg_process_data_packet Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 22/45] windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory Mihail Abakumov
                   ` (26 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 ++
 windbgstub-utils.c              |    8 ++++++++
 windbgstub.c                    |   26 +++++++++++++++++++++++++-
 3 files changed, 35 insertions(+), 1 deletion(-)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 8558bc6c8a..28fd53039a 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -86,6 +86,8 @@ typedef struct SizedBuf {
 InitedAddr *windbg_get_KPCR(void);
 InitedAddr *windbg_get_version(void);
 
+void kd_api_unsupported(CPUState *cpu, PacketData *pd);
+
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
 SizedBuf kd_gen_load_symbols_sc(CPUState *cpu);
 
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index 347c61553a..04a7e1cc7b 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -23,3 +23,11 @@ InitedAddr *windbg_get_version(void)
 {
     return &version;
 }
+
+void kd_api_unsupported(CPUState *cpu, PacketData *pd)
+{
+    WINDBG_ERROR("Caught unimplemented api %s",
+                 KD_API_NAME(pd->m64.ApiNumber));
+    pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    pd->extra_size = 0;
+}
diff --git a/windbgstub.c b/windbgstub.c
index 8058972dc7..2467d2d247 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -126,7 +126,31 @@ static void windbg_vm_stop(void)
 }
 
 static void windbg_process_manipulate_packet(ParsingContext *ctx)
-{}
+{
+    CPUState *cpu;
+
+    ctx->data.extra_size = ctx->packet.ByteCount -
+                           sizeof(DBGKD_MANIPULATE_STATE64);
+    ctx->data.m64.ReturnStatus = STATUS_SUCCESS;
+
+    cpu = qemu_get_cpu(ctx->data.m64.Processor);
+    if (cpu == NULL) {
+        cpu = qemu_get_cpu(0);
+    }
+
+    switch (ctx->data.m64.ApiNumber) {
+
+    default:
+        kd_api_unsupported(cpu, &ctx->data);
+        break;
+    }
+
+    stl_p(&ctx->data.m64.ReturnStatus, ctx->data.m64.ReturnStatus);
+
+    windbg_send_data_packet(ctx->data.buf, ctx->data.extra_size +
+                            sizeof(DBGKD_MANIPULATE_STATE64),
+                            ctx->packet.PacketType);
+}
 
 static void windbg_process_data_packet(ParsingContext *ctx)
 {

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 22/45] windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (20 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 21/45] windbg: implemented windbg_process_manipulate_packet Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 23/45] windbg: kernel's structures Mihail Abakumov
                   ` (25 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 ++
 windbgstub-utils.c              |   47 +++++++++++++++++++++++++++++++++++++++
 windbgstub.c                    |    8 +++++++
 3 files changed, 57 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 28fd53039a..827aabb6d3 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -86,6 +86,8 @@ typedef struct SizedBuf {
 InitedAddr *windbg_get_KPCR(void);
 InitedAddr *windbg_get_version(void);
 
+void kd_api_read_virtual_memory(CPUState *cpu, PacketData *pd);
+void kd_api_write_virtual_memory(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index 04a7e1cc7b..1e81c37501 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -24,6 +24,53 @@ InitedAddr *windbg_get_version(void)
     return &version;
 }
 
+void kd_api_read_virtual_memory(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_READ_MEMORY64 *mem = &pd->m64.u.ReadMemory;
+    uint32_t len;
+    target_ulong addr;
+    int err;
+
+    len = MIN(ldl_p(&mem->TransferCount),
+                    PACKET_MAX_SIZE - sizeof(DBGKD_MANIPULATE_STATE64));
+    addr = ldtul_p(&mem->TargetBaseAddress);
+    err = cpu_memory_rw_debug(cpu, addr, pd->extra, len, 0);
+
+    if (err) {
+        len = 0;
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+
+        WINDBG_DEBUG("read_virtual_memory: No physical page mapped: " FMT_ADDR,
+                     (target_ulong) mem->TargetBaseAddress);
+    }
+
+    pd->extra_size = len;
+    stl_p(&mem->ActualBytesRead, len);
+}
+
+void kd_api_write_virtual_memory(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_WRITE_MEMORY64 *mem = &pd->m64.u.WriteMemory;
+    uint32_t len;
+    target_ulong addr;
+    int err;
+
+    len = MIN(ldl_p(&mem->TransferCount), pd->extra_size);
+    addr = ldtul_p(&mem->TargetBaseAddress);
+    err = cpu_memory_rw_debug(cpu, addr, pd->extra, len, 1);
+
+    if (err) {
+        len = 0;
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+
+        WINDBG_DEBUG("read_write_memory: No physical page mapped: " FMT_ADDR,
+                     (target_ulong) mem->TargetBaseAddress);
+    }
+
+    pd->extra_size = 0;
+    stl_p(&mem->ActualBytesWritten, len);
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index 2467d2d247..1725107722 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -140,6 +140,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
 
     switch (ctx->data.m64.ApiNumber) {
 
+    case DbgKdReadVirtualMemoryApi:
+        kd_api_read_virtual_memory(cpu, &ctx->data);
+        break;
+
+    case DbgKdWriteVirtualMemoryApi:
+        kd_api_write_virtual_memory(cpu, &ctx->data);
+        break;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 23/45] windbg: kernel's structures
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (21 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 22/45] windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 24/45] windbg: implemented kd_api_get_context and kd_api_set_context Mihail Abakumov
                   ` (24 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Defined Windows kernel's structures (CPU_CONTEXT and CPU_KSPECIAL_REGISTERS) for i386 and x64_86.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |  247 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 247 insertions(+)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 261e441db1..43efb47471 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -26,6 +26,253 @@
 # define OFFSET_KPRCB_CURRTHREAD 0x4
 #endif
 
+/*
+ * Next code copied from winnt.h
+ */
+#ifdef TARGET_X86_64
+
+#define CPU_CONTEXT_AMD64 0x100000
+
+#define CPU_CONTEXT_CONTROL         (CPU_CONTEXT_AMD64 | 0x1)
+#define CPU_CONTEXT_INTEGER         (CPU_CONTEXT_AMD64 | 0x2)
+#define CPU_CONTEXT_SEGMENTS        (CPU_CONTEXT_AMD64 | 0x4)
+#define CPU_CONTEXT_FLOATING_POINT  (CPU_CONTEXT_AMD64 | 0x8)
+#define CPU_CONTEXT_DEBUG_REGISTERS (CPU_CONTEXT_AMD64 | 0x10)
+
+#define CPU_CONTEXT_FULL \
+    (CPU_CONTEXT_CONTROL | CPU_CONTEXT_INTEGER | CPU_CONTEXT_FLOATING_POINT)
+#define CPU_CONTEXT_ALL \
+    (CPU_CONTEXT_FULL | CPU_CONTEXT_SEGMENTS | CPU_CONTEXT_DEBUG_REGISTERS)
+
+typedef struct _CPU_DESCRIPTOR {
+    uint16_t Pad[3];
+    uint16_t Limit;
+    uint64_t Base;
+} CPU_DESCRIPTOR, *PCPU_DESCRIPTOR;
+
+typedef struct _CPU_KSPECIAL_REGISTERS {
+    uint64_t Cr0;
+    uint64_t Cr2;
+    uint64_t Cr3;
+    uint64_t Cr4;
+    uint64_t KernelDr0;
+    uint64_t KernelDr1;
+    uint64_t KernelDr2;
+    uint64_t KernelDr3;
+    uint64_t KernelDr6;
+    uint64_t KernelDr7;
+    CPU_DESCRIPTOR Gdtr;
+    CPU_DESCRIPTOR Idtr;
+    uint16_t Tr;
+    uint16_t Ldtr;
+    uint32_t MxCsr;
+    uint64_t DebugControl;
+    uint64_t LastBranchToRip;
+    uint64_t LastBranchFromRip;
+    uint64_t LastExceptionToRip;
+    uint64_t LastExceptionFromRip;
+    uint64_t Cr8;
+    uint64_t MsrGsBase;
+    uint64_t MsrGsSwap;
+    uint64_t MsrStar;
+    uint64_t MsrLStar;
+    uint64_t MsrCStar;
+    uint64_t MsrSyscallMask;
+    uint64_t Xcr0;
+} CPU_KSPECIAL_REGISTERS, *PCPU_KSPECIAL_REGISTERS;
+
+#pragma pack(push, 2)
+typedef struct _CPU_M128A {
+    uint64_t Low;
+    int64_t High;
+} CPU_M128A, *PCPU_M128A;
+#pragma pack(pop)
+
+typedef struct _CPU_XMM_SAVE_AREA32 {
+    uint16_t ControlWord;
+    uint16_t StatusWord;
+    uint8_t TagWord;
+    uint8_t Reserved1;
+    uint16_t ErrorOpcode;
+    uint32_t ErrorOffset;
+    uint16_t ErrorSelector;
+    uint16_t Reserved2;
+    uint32_t DataOffset;
+    uint16_t DataSelector;
+    uint16_t Reserved3;
+    uint32_t MxCsr;
+    uint32_t MxCsr_Mask;
+    CPU_M128A FloatRegisters[8];
+    CPU_M128A XmmRegisters[16];
+    uint8_t Reserved4[96];
+} CPU_XMM_SAVE_AREA32, *PCPU_XMM_SAVE_AREA32;
+
+#pragma pack(push, 2)
+typedef struct _CPU_CONTEXT { /* sizeof = 1232 */
+    uint64_t P1Home;
+    uint64_t P2Home;
+    uint64_t P3Home;
+    uint64_t P4Home;
+    uint64_t P5Home;
+    uint64_t P6Home;
+    uint32_t ContextFlags;
+    uint32_t MxCsr;
+    uint16_t SegCs;
+    uint16_t SegDs;
+    uint16_t SegEs;
+    uint16_t SegFs;
+    uint16_t SegGs;
+    uint16_t SegSs;
+    uint32_t EFlags;
+    uint64_t Dr0;
+    uint64_t Dr1;
+    uint64_t Dr2;
+    uint64_t Dr3;
+    uint64_t Dr6;
+    uint64_t Dr7;
+    uint64_t Rax;
+    uint64_t Rcx;
+    uint64_t Rdx;
+    uint64_t Rbx;
+    uint64_t Rsp;
+    uint64_t Rbp;
+    uint64_t Rsi;
+    uint64_t Rdi;
+    uint64_t R8;
+    uint64_t R9;
+    uint64_t R10;
+    uint64_t R11;
+    uint64_t R12;
+    uint64_t R13;
+    uint64_t R14;
+    uint64_t R15;
+    uint64_t Rip;
+    union {
+        CPU_XMM_SAVE_AREA32 FltSave;
+        CPU_XMM_SAVE_AREA32 FloatSave;
+        struct {
+            CPU_M128A Header[2];
+            CPU_M128A Legacy[8];
+            CPU_M128A Xmm0;
+            CPU_M128A Xmm1;
+            CPU_M128A Xmm2;
+            CPU_M128A Xmm3;
+            CPU_M128A Xmm4;
+            CPU_M128A Xmm5;
+            CPU_M128A Xmm6;
+            CPU_M128A Xmm7;
+            CPU_M128A Xmm8;
+            CPU_M128A Xmm9;
+            CPU_M128A Xmm10;
+            CPU_M128A Xmm11;
+            CPU_M128A Xmm12;
+            CPU_M128A Xmm13;
+            CPU_M128A Xmm14;
+            CPU_M128A Xmm15;
+        };
+    };
+    CPU_M128A VectorRegister[26];
+    uint64_t VectorControl;
+    uint64_t DebugControl;
+    uint64_t LastBranchToRip;
+    uint64_t LastBranchFromRip;
+    uint64_t LastExceptionToRip;
+    uint64_t LastExceptionFromRip;
+} CPU_CONTEXT, *PCPU_CONTEXT;
+#pragma pack(pop)
+
+#else
+
+#define SIZE_OF_X86_REG 80
+#define MAX_SUP_EXT 512
+
+#define CPU_CONTEXT_i386 0x10000
+
+#define CPU_CONTEXT_CONTROL            (CPU_CONTEXT_i386 | 0x1)
+#define CPU_CONTEXT_INTEGER            (CPU_CONTEXT_i386 | 0x2)
+#define CPU_CONTEXT_SEGMENTS           (CPU_CONTEXT_i386 | 0x4)
+#define CPU_CONTEXT_FLOATING_POINT     (CPU_CONTEXT_i386 | 0x8)
+#define CPU_CONTEXT_DEBUG_REGISTERS    (CPU_CONTEXT_i386 | 0x10)
+#define CPU_CONTEXT_EXTENDED_REGISTERS (CPU_CONTEXT_i386 | 0x20)
+
+#define CPU_CONTEXT_FULL \
+    (CPU_CONTEXT_CONTROL | CPU_CONTEXT_INTEGER | CPU_CONTEXT_SEGMENTS)
+#define CPU_CONTEXT_ALL \
+    (CPU_CONTEXT_FULL | CPU_CONTEXT_FLOATING_POINT | \
+     CPU_CONTEXT_DEBUG_REGISTERS | CPU_CONTEXT_EXTENDED_REGISTERS)
+
+typedef struct _CPU_DESCRIPTOR {
+    uint16_t Pad;
+    uint16_t Limit;
+    uint32_t Base;
+} CPU_DESCRIPTOR, *PCPU_DESCRIPTOR;
+
+typedef struct _CPU_KSPECIAL_REGISTERS {
+    uint32_t Cr0;
+    uint32_t Cr2;
+    uint32_t Cr3;
+    uint32_t Cr4;
+    uint32_t KernelDr0;
+    uint32_t KernelDr1;
+    uint32_t KernelDr2;
+    uint32_t KernelDr3;
+    uint32_t KernelDr6;
+    uint32_t KernelDr7;
+    CPU_DESCRIPTOR Gdtr;
+    CPU_DESCRIPTOR Idtr;
+    uint16_t Tr;
+    uint16_t Ldtr;
+    uint32_t Reserved[6];
+} CPU_KSPECIAL_REGISTERS, *PCPU_KSPECIAL_REGISTERS;
+
+typedef struct _CPU_FLOATING_SAVE_AREA {
+    uint32_t ControlWord;
+    uint32_t StatusWord;
+    uint32_t TagWord;
+    uint32_t ErrorOffset;
+    uint32_t ErrorSelector;
+    uint32_t DataOffset;
+    uint32_t DataSelector;
+    uint8_t RegisterArea[SIZE_OF_X86_REG];
+    uint32_t Cr0NpxState;
+} CPU_FLOATING_SAVE_AREA, *PCPU_FLOATING_SAVE_AREA;
+
+typedef struct _CPU_CONTEXT { /* sizeof = 716 */
+    uint32_t ContextFlags;
+    uint32_t Dr0;
+    uint32_t Dr1;
+    uint32_t Dr2;
+    uint32_t Dr3;
+    uint32_t Dr6;
+    uint32_t Dr7;
+    CPU_FLOATING_SAVE_AREA FloatSave;
+    uint32_t SegGs;
+    uint32_t SegFs;
+    uint32_t SegEs;
+    uint32_t SegDs;
+
+    uint32_t Edi;
+    uint32_t Esi;
+    uint32_t Ebx;
+    uint32_t Edx;
+    uint32_t Ecx;
+    uint32_t Eax;
+    uint32_t Ebp;
+    uint32_t Eip;
+    uint32_t SegCs;
+    uint32_t EFlags;
+    uint32_t Esp;
+    uint32_t SegSs;
+    uint8_t ExtendedRegisters[MAX_SUP_EXT];
+} CPU_CONTEXT, *PCPU_CONTEXT;
+
+#endif
+
+typedef struct _CPU_KPROCESSOR_STATE {
+    CPU_CONTEXT ContextFrame;
+    CPU_KSPECIAL_REGISTERS SpecialRegisters;
+} CPU_KPROCESSOR_STATE, *PCPU_KPROCESSOR_STATE;
+
 bool windbg_on_load(void)
 {
     CPUState *cpu = qemu_get_cpu(0);

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 24/45] windbg: implemented kd_api_get_context and kd_api_set_context
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (22 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 23/45] windbg: kernel's structures Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 25/45] windbg: implemented kd_api_read_control_space and kd_api_write_control_space Mihail Abakumov
                   ` (23 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 ++
 target/i386/windbgstub.c        |   39 +++++++++++++++++++++++++++++++++++++++
 windbgstub.c                    |    8 ++++++++
 3 files changed, 49 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 827aabb6d3..65be4793d3 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -88,6 +88,8 @@ InitedAddr *windbg_get_version(void);
 
 void kd_api_read_virtual_memory(CPUState *cpu, PacketData *pd);
 void kd_api_write_virtual_memory(CPUState *cpu, PacketData *pd);
+void kd_api_get_context(CPUState *cpu, PacketData *pd);
+void kd_api_set_context(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 43efb47471..be8fc21374 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -273,6 +273,45 @@ typedef struct _CPU_KPROCESSOR_STATE {
     CPU_KSPECIAL_REGISTERS SpecialRegisters;
 } CPU_KPROCESSOR_STATE, *PCPU_KPROCESSOR_STATE;
 
+static int windbg_read_context(CPUState *cpu, uint8_t *buf, int buf_size,
+                               int offset, int len)
+{
+    return 0;
+}
+
+static int windbg_write_context(CPUState *cpu, uint8_t *buf, int buf_size,
+                                int offset, int len)
+{
+    return 0;
+}
+
+void kd_api_get_context(CPUState *cpu, PacketData *pd)
+{
+    int err;
+
+    pd->extra_size = sizeof(CPU_CONTEXT);
+    err = windbg_read_context(cpu, pd->extra, pd->extra_size, 0,
+                              pd->extra_size);
+
+    if (err) {
+        pd->extra_size = 0;
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    }
+}
+
+void kd_api_set_context(CPUState *cpu, PacketData *pd)
+{
+    int err;
+
+    err = windbg_write_context(cpu, pd->extra, pd->extra_size, 0,
+                               sizeof(CPU_CONTEXT));
+    pd->extra_size = 0;
+
+    if (err) {
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    }
+}
+
 bool windbg_on_load(void)
 {
     CPUState *cpu = qemu_get_cpu(0);
diff --git a/windbgstub.c b/windbgstub.c
index 1725107722..ad8638b793 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -148,6 +148,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_write_virtual_memory(cpu, &ctx->data);
         break;
 
+    case DbgKdGetContextApi:
+        kd_api_get_context(cpu, &ctx->data);
+        break;
+
+    case DbgKdSetContextApi:
+        kd_api_set_context(cpu, &ctx->data);
+        break;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 25/45] windbg: implemented kd_api_read_control_space and kd_api_write_control_space
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (23 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 24/45] windbg: implemented kd_api_get_context and kd_api_set_context Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 26/45] windbg: implemented windbg_read_context Mihail Abakumov
                   ` (22 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 +
 target/i386/windbgstub.c        |   89 +++++++++++++++++++++++++++++++++++++++
 windbgstub.c                    |    8 ++++
 3 files changed, 99 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 65be4793d3..5e5893bac8 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -90,6 +90,8 @@ void kd_api_read_virtual_memory(CPUState *cpu, PacketData *pd);
 void kd_api_write_virtual_memory(CPUState *cpu, PacketData *pd);
 void kd_api_get_context(CPUState *cpu, PacketData *pd);
 void kd_api_set_context(CPUState *cpu, PacketData *pd);
+void kd_api_read_control_space(CPUState *cpu, PacketData *pd);
+void kd_api_write_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index be8fc21374..bf1afab1f8 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -285,6 +285,18 @@ static int windbg_write_context(CPUState *cpu, uint8_t *buf, int buf_size,
     return 0;
 }
 
+static int windbg_read_ks_regs(CPUState *cpu, uint8_t *buf, int buf_size,
+                               int offset, int len)
+{
+    return 0;
+}
+
+static int windbg_write_ks_regs(CPUState *cpu, uint8_t *buf, int buf_size,
+                                int offset, int len)
+{
+    return 0;
+}
+
 void kd_api_get_context(CPUState *cpu, PacketData *pd)
 {
     int err;
@@ -312,6 +324,83 @@ void kd_api_set_context(CPUState *cpu, PacketData *pd)
     }
 }
 
+void kd_api_read_control_space(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_READ_MEMORY64 *mem = &pd->m64.u.ReadMemory;
+    uint32_t len;
+    uint32_t context_len;
+    uint32_t ks_regs_len;
+    target_ulong addr;
+    int err = -1;
+
+    len = MIN(ldl_p(&mem->TransferCount),
+              PACKET_MAX_SIZE - sizeof(DBGKD_MANIPULATE_STATE64));
+    addr = ldtul_p(&mem->TargetBaseAddress);
+
+    if (addr < sizeof(CPU_KPROCESSOR_STATE)) {
+        len = MIN(len, sizeof(CPU_KPROCESSOR_STATE) - addr);
+
+        context_len = MAX(0, (int) (sizeof(CPU_CONTEXT) - addr));
+        ks_regs_len = len - context_len;
+
+        if (context_len > 0) {
+            err = windbg_read_context(cpu, pd->extra, context_len, addr,
+                                      context_len);
+        }
+        if (ks_regs_len > 0) {
+            addr = addr - sizeof(CPU_CONTEXT) + context_len;
+            err = windbg_read_ks_regs(cpu, pd->extra + context_len,
+                                      ks_regs_len, addr, ks_regs_len);
+        }
+    }
+
+    if (err) {
+        len = 0;
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    }
+
+    pd->extra_size = len;
+    stl_p(&mem->ActualBytesRead, len);
+}
+
+void kd_api_write_control_space(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_WRITE_MEMORY64 *mem = &pd->m64.u.WriteMemory;
+    uint32_t len;
+    uint32_t context_len;
+    uint32_t ks_regs_len;
+    target_ulong addr;
+    int err = -1;
+
+    len = MIN(ldl_p(&mem->TransferCount), pd->extra_size);
+    addr = ldtul_p(&mem->TargetBaseAddress);
+
+    if (addr < sizeof(CPU_KPROCESSOR_STATE)) {
+        len = MIN(len, sizeof(CPU_KPROCESSOR_STATE) - addr);
+
+        context_len = MAX(0, (int) (sizeof(CPU_CONTEXT) - addr));
+        ks_regs_len = len - context_len;
+
+        if (context_len > 0) {
+            err = windbg_write_context(cpu, pd->extra, context_len, addr,
+                                       context_len);
+        }
+        if (ks_regs_len > 0) {
+            addr = addr - sizeof(CPU_CONTEXT) + context_len;
+            err = windbg_write_ks_regs(cpu, pd->extra + context_len,
+                                       ks_regs_len, addr, ks_regs_len);
+        }
+    }
+
+    if (err) {
+        mem->ActualBytesWritten = 0;
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    }
+
+    pd->extra_size = 0;
+    stl_p(&mem->ActualBytesWritten, len);
+}
+
 bool windbg_on_load(void)
 {
     CPUState *cpu = qemu_get_cpu(0);
diff --git a/windbgstub.c b/windbgstub.c
index ad8638b793..5b0a15ea4e 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -156,6 +156,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_set_context(cpu, &ctx->data);
         break;
 
+    case DbgKdReadControlSpaceApi:
+        kd_api_read_control_space(cpu, &ctx->data);
+        break;
+
+    case DbgKdWriteControlSpaceApi:
+        kd_api_write_control_space(cpu, &ctx->data);
+        break;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 26/45] windbg: implemented windbg_read_context
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (24 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 25/45] windbg: implemented kd_api_read_control_space and kd_api_write_control_space Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-28 14:57   ` Ladi Prosek
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 27/45] windbg: implemented windbg_write_context Mihail Abakumov
                   ` (21 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |   96 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 96 insertions(+)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index bf1afab1f8..1fccd8eee7 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -276,6 +276,102 @@ typedef struct _CPU_KPROCESSOR_STATE {
 static int windbg_read_context(CPUState *cpu, uint8_t *buf, int buf_size,
                                int offset, int len)
 {
+    CPUArchState *env = cpu->env_ptr;
+    CPU_CONTEXT *cc;
+    bool new_mem;
+
+    if (len < 0 || len > buf_size) {
+        WINDBG_ERROR("windbg_read_context: incorrect length %d", len);
+        return 1;
+    }
+
+    if (offset < 0 || offset + len > sizeof(CPU_CONTEXT)) {
+        WINDBG_ERROR("windbg_read_context: incorrect offset %d", offset);
+        return 2;
+    }
+
+    new_mem = len != sizeof(CPU_CONTEXT) || offset != 0;
+    if (new_mem) {
+        cc = g_new0(CPU_CONTEXT, 1);
+    } else {
+        cc = (CPU_CONTEXT *) buf;
+        memset(cc, 0, sizeof(CPU_CONTEXT));
+    }
+
+    cc->ContextFlags = CPU_CONTEXT_ALL;
+
+    if (cc->ContextFlags & CPU_CONTEXT_SEGMENTS) {
+        stw_p(&cc->SegCs, env->segs[R_CS].selector);
+        stw_p(&cc->SegDs, env->segs[R_DS].selector);
+        stw_p(&cc->SegEs, env->segs[R_ES].selector);
+        stw_p(&cc->SegFs, env->segs[R_FS].selector);
+        stw_p(&cc->SegGs, env->segs[R_GS].selector);
+        stw_p(&cc->SegSs, env->segs[R_SS].selector);
+    }
+
+    if (cc->ContextFlags & CPU_CONTEXT_DEBUG_REGISTERS) {
+        sttul_p(&cc->Dr0, env->dr[0]);
+        sttul_p(&cc->Dr1, env->dr[1]);
+        sttul_p(&cc->Dr2, env->dr[2]);
+        sttul_p(&cc->Dr3, env->dr[3]);
+        sttul_p(&cc->Dr6, env->dr[6]);
+        sttul_p(&cc->Dr7, env->dr[7]);
+    }
+
+    if (cc->ContextFlags & CPU_CONTEXT_INTEGER) {
+        stl_p(&cc->Edi, env->regs[R_EDI]);
+        stl_p(&cc->Esi, env->regs[R_ESI]);
+        stl_p(&cc->Ebx, env->regs[R_EBX]);
+        stl_p(&cc->Edx, env->regs[R_EDX]);
+        stl_p(&cc->Ecx, env->regs[R_ECX]);
+        stl_p(&cc->Eax, env->regs[R_EAX]);
+        stl_p(&cc->Ebp, env->regs[R_EBP]);
+        stl_p(&cc->Esp, env->regs[R_ESP]);
+        stl_p(&cc->Eip, env->eip);
+        stl_p(&cc->EFlags, env->eflags);
+    }
+
+    if (cc->ContextFlags & CPU_CONTEXT_FLOATING_POINT) {
+        uint32_t swd = 0, twd = 0;
+        swd = env->fpus & ~(7 << 11);
+        swd |= (env->fpstt & 7) << 11;
+        int i;
+        for (i = 0; i < 8; ++i) {
+            twd |= (!env->fptags[i]) << i;
+        }
+
+        stl_p(&cc->FloatSave.ControlWord, env->fpuc);
+        stl_p(&cc->FloatSave.StatusWord, swd);
+        stl_p(&cc->FloatSave.TagWord, twd);
+        stl_p(&cc->FloatSave.ErrorOffset, UINT32_P(&env->fpip)[0]);
+        stl_p(&cc->FloatSave.ErrorSelector, UINT32_P(&env->fpip)[1]);
+        stl_p(&cc->FloatSave.DataOffset, UINT32_P(&env->fpdp)[0]);
+        stl_p(&cc->FloatSave.DataSelector, UINT32_P(&env->fpdp)[1]);
+        stl_p(&cc->FloatSave.Cr0NpxState, env->xcr0);
+
+        for (i = 0; i < 8; ++i) {
+            memcpy(PTR(cc->FloatSave.RegisterArea[i * 10]),
+                   PTR(env->fpregs[i]), 10);
+        }
+    }
+
+    if (cc->ContextFlags & CPU_CONTEXT_EXTENDED_REGISTERS) {
+        uint8_t *ptr = cc->ExtendedRegisters + 160;
+        int i;
+        for (i = 0; i < 8; ++i, ptr += 16) {
+            stq_p(ptr,     env->xmm_regs[i].ZMM_Q(0));
+            stq_p(ptr + 8, env->xmm_regs[i].ZMM_Q(1));
+        }
+
+        stl_p(cc->ExtendedRegisters + 24, env->mxcsr);
+    }
+
+    stl_p(&cc->ContextFlags, cc->ContextFlags);
+
+    if (new_mem) {
+        memcpy(buf, (uint8_t *) cc + offset, len);
+        g_free(cc);
+    }
     return 0;
 }
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 27/45] windbg: implemented windbg_write_context
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (25 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 26/45] windbg: implemented windbg_read_context Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 28/45] windbg: implemented windbg_read_ks_regs Mihail Abakumov
                   ` (20 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |  212 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 212 insertions(+)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 1fccd8eee7..dc2a10f8e6 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -273,6 +273,12 @@ typedef struct _CPU_KPROCESSOR_STATE {
     CPU_KSPECIAL_REGISTERS SpecialRegisters;
 } CPU_KPROCESSOR_STATE, *PCPU_KPROCESSOR_STATE;
 
+static void windbg_set_dr(CPUState *cpu, int index, target_ulong value)
+{}
+
+static void windbg_set_sr(CPUState *cpu, int sr, uint16_t selector)
+{}
+
 static int windbg_read_context(CPUState *cpu, uint8_t *buf, int buf_size,
                                int offset, int len)
 {
@@ -378,6 +384,212 @@ static int windbg_read_context(CPUState *cpu, uint8_t *buf, int buf_size,
 static int windbg_write_context(CPUState *cpu, uint8_t *buf, int buf_size,
                                 int offset, int len)
 {
+    CPUArchState *env = cpu->env_ptr;
+    int mem_size, i, tmp;
+    uint8_t *mem_ptr = buf;
+
+    if (len < 0 || len > buf_size) {
+        WINDBG_ERROR("windbg_write_context: incorrect length %d", len);
+        return 1;
+    }
+
+    if (offset < 0 || offset + len > sizeof(CPU_CONTEXT)) {
+        WINDBG_ERROR("windbg_write_context: incorrect offset %d", offset);
+        return 2;
+    }
+
+    while (len > 0 && offset < sizeof(CPU_CONTEXT)) {
+        mem_size = 1;
+        switch (offset) {
+
+        case offsetof(CPU_CONTEXT, ContextFlags):
+            mem_size = sizeof_field(CPU_CONTEXT, ContextFlags);
+            break;
+
+        case offsetof(CPU_CONTEXT, Dr0):
+            mem_size = sizeof_field(CPU_CONTEXT, Dr0);
+            windbg_set_dr(cpu, 0, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, Dr1):
+            mem_size = sizeof_field(CPU_CONTEXT, Dr1);
+            windbg_set_dr(cpu, 1, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, Dr2):
+            mem_size = sizeof_field(CPU_CONTEXT, Dr2);
+            windbg_set_dr(cpu, 2, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, Dr3):
+            mem_size = sizeof_field(CPU_CONTEXT, Dr3);
+            windbg_set_dr(cpu, 3, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, Dr6):
+            mem_size = sizeof_field(CPU_CONTEXT, Dr6);
+            windbg_set_dr(cpu, 6, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, Dr7):
+            mem_size = sizeof_field(CPU_CONTEXT, Dr7);
+            windbg_set_dr(cpu, 7, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.ControlWord):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.ControlWord);
+            cpu_set_fpuc(env, ldl_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.StatusWord):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.StatusWord);
+            tmp = ldl_p(buf + offset);
+            env->fpstt = (tmp >> 11) & 7;
+            env->fpus = tmp & ~0x3800;
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.TagWord):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.TagWord);
+            tmp = ldl_p(buf + offset);
+            for (i = 0; i < 8; ++i) {
+                env->fptags[i] = !((tmp >> i) & 1);
+            }
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.ErrorOffset):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.ErrorOffset);
+            UINT32_P(&env->fpip)[0] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.ErrorSelector):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.ErrorSelector);
+            UINT32_P(&env->fpip)[1] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.DataOffset):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.DataOffset);
+            UINT32_P(&env->fpdp)[0] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.DataSelector):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.DataSelector);
+            UINT32_P(&env->fpdp)[1] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.RegisterArea):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.RegisterArea);
+            for (i = 0; i < 8; ++i) {
+                memcpy(PTR(env->fpregs[i]), mem_ptr + i * 10, 10);
+            }
+            break;
+
+        case offsetof(CPU_CONTEXT, FloatSave.Cr0NpxState):
+            mem_size = sizeof_field(CPU_CONTEXT, FloatSave.Cr0NpxState);
+            env->xcr0 = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, SegGs):
+            mem_size = sizeof_field(CPU_CONTEXT, SegGs);
+            windbg_set_sr(cpu, R_GS, lduw_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, SegFs):
+            mem_size = sizeof_field(CPU_CONTEXT, SegFs);
+            windbg_set_sr(cpu, R_FS, lduw_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, SegEs):
+            mem_size = sizeof_field(CPU_CONTEXT, SegEs);
+            windbg_set_sr(cpu, R_ES, lduw_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, SegDs):
+            mem_size = sizeof_field(CPU_CONTEXT, SegDs);
+            windbg_set_sr(cpu, R_DS, lduw_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, Edi):
+            mem_size = sizeof_field(CPU_CONTEXT, Edi);
+            env->regs[R_EDI] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Esi):
+            mem_size = sizeof_field(CPU_CONTEXT, Esi);
+            env->regs[R_ESI] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Ebx):
+            mem_size = sizeof_field(CPU_CONTEXT, Ebx);
+            env->regs[R_EBX] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Edx):
+            mem_size = sizeof_field(CPU_CONTEXT, Edx);
+            env->regs[R_EDX] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Ecx):
+            mem_size = sizeof_field(CPU_CONTEXT, Ecx);
+            env->regs[R_ECX] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Eax):
+            mem_size = sizeof_field(CPU_CONTEXT, Eax);
+            env->regs[R_EAX] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Ebp):
+            mem_size = sizeof_field(CPU_CONTEXT, Ebp);
+            env->regs[R_EBP] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Eip):
+            mem_size = sizeof_field(CPU_CONTEXT, Eip);
+            env->eip = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, SegCs):
+            mem_size = sizeof_field(CPU_CONTEXT, SegCs);
+            windbg_set_sr(cpu, R_CS, lduw_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, EFlags):
+            mem_size = sizeof_field(CPU_CONTEXT, EFlags);
+            env->eflags = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, Esp):
+            mem_size = sizeof_field(CPU_CONTEXT, Esp);
+            env->regs[R_ESP] = ldl_p(buf + offset);
+            break;
+
+        case offsetof(CPU_CONTEXT, SegSs):
+            mem_size = sizeof_field(CPU_CONTEXT, SegSs);
+            windbg_set_sr(cpu, R_SS, lduw_p(buf + offset));
+            break;
+
+        case offsetof(CPU_CONTEXT, ExtendedRegisters):
+            mem_size = sizeof_field(CPU_CONTEXT, ExtendedRegisters);
+
+            uint8_t *ptr = mem_ptr + 160;
+            for (i = 0; i < 8; ++i, ptr += 16) {
+                env->xmm_regs[i].ZMM_Q(0) = ldl_p(ptr);
+                env->xmm_regs[i].ZMM_Q(1) = ldl_p(ptr + 8);
+            }
+
+            cpu_set_mxcsr(env, ldl_p(mem_ptr + 24));
+            break;
+
+        default:
+            WINDBG_ERROR("write_context: Unknown offset %d", offset);
+            return -1;
+        }
+
+        mem_ptr += mem_size;
+        offset += mem_size;
+        len -= mem_size;
+    }
+
     return 0;
 }
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 28/45] windbg: implemented windbg_read_ks_regs
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (26 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 27/45] windbg: implemented windbg_write_context Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 29/45] windbg: implemented windbg_write_ks_regs Mihail Abakumov
                   ` (19 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |   39 +++++++++++++++++++++++++++++++++++++++
 1 file changed, 39 insertions(+)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index dc2a10f8e6..c492ee58d8 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -596,6 +596,45 @@ static int windbg_write_context(CPUState *cpu, uint8_t *buf, int buf_size,
 static int windbg_read_ks_regs(CPUState *cpu, uint8_t *buf, int buf_size,
                                int offset, int len)
 {
+    CPUArchState *env = cpu->env_ptr;
+    CPU_KSPECIAL_REGISTERS *ckr;
+    bool new_mem;
+
+    new_mem = (len != sizeof(CPU_KSPECIAL_REGISTERS) || offset != 0);
+    if (new_mem) {
+        ckr = g_new(CPU_KSPECIAL_REGISTERS, 1);
+    } else {
+        ckr = (CPU_KSPECIAL_REGISTERS *) buf;
+    }
+
+    memset(ckr, 0, len);
+
+    ckr->Cr0 = ldl_p(&env->cr[0]);
+    ckr->Cr2 = ldl_p(&env->cr[2]);
+    ckr->Cr3 = ldl_p(&env->cr[3]);
+    ckr->Cr4 = ldl_p(&env->cr[4]);
+
+    ckr->KernelDr0 = ldtul_p(&env->dr[0]);
+    ckr->KernelDr1 = ldtul_p(&env->dr[1]);
+    ckr->KernelDr2 = ldtul_p(&env->dr[2]);
+    ckr->KernelDr3 = ldtul_p(&env->dr[3]);
+    ckr->KernelDr6 = ldtul_p(&env->dr[6]);
+    ckr->KernelDr7 = ldtul_p(&env->dr[7]);
+
+    ckr->Gdtr.Pad = lduw_p(&env->gdt.selector);
+    ckr->Idtr.Pad = lduw_p(&env->idt.selector);
+
+    ckr->Gdtr.Limit = lduw_p(&env->gdt.limit);
+    ckr->Gdtr.Base  = ldtul_p(&env->gdt.base);
+    ckr->Idtr.Limit = lduw_p(&env->idt.limit);
+    ckr->Idtr.Base  = ldtul_p(&env->idt.base);
+    ckr->Tr         = lduw_p(&env->tr.selector);
+    ckr->Ldtr       = lduw_p(&env->ldt.selector);
+
+    if (new_mem) {
+        memcpy(buf, (uint8_t *) ckr + offset, len);
+        g_free(ckr);
+    }
     return 0;
 }
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 29/45] windbg: implemented windbg_write_ks_regs
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (27 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 28/45] windbg: implemented windbg_read_ks_regs Mihail Abakumov
@ 2017-11-21 14:09 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 30/45] windbg: implemented windbg_set_sr Mihail Abakumov
                   ` (18 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:09 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |  111 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 111 insertions(+)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index c492ee58d8..63962b48dd 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -641,6 +641,117 @@ static int windbg_read_ks_regs(CPUState *cpu, uint8_t *buf, int buf_size,
 static int windbg_write_ks_regs(CPUState *cpu, uint8_t *buf, int buf_size,
                                 int offset, int len)
 {
+    CPUArchState *env = cpu->env_ptr;
+    int mem_size;
+    uint8_t *mem_ptr = buf;
+    while (len > 0 && offset < sizeof(CPU_KSPECIAL_REGISTERS)) {
+        mem_size = 1;
+        switch (offset) {
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Cr0):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Cr0);
+            cpu_x86_update_cr0(env, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Cr2):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Cr2);
+            env->cr[2] = ldtul_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Cr3):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Cr3);
+            cpu_x86_update_cr3(env, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Cr4):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Cr4);
+            cpu_x86_update_cr4(env, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, KernelDr0):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, KernelDr0);
+            windbg_set_dr(cpu, 0, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, KernelDr1):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, KernelDr1);
+            windbg_set_dr(cpu, 1, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, KernelDr2):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, KernelDr2);
+            windbg_set_dr(cpu, 2, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, KernelDr3):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, KernelDr3);
+            windbg_set_dr(cpu, 3, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, KernelDr6):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, KernelDr6);
+            windbg_set_dr(cpu, 6, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, KernelDr7):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, KernelDr7);
+            windbg_set_dr(cpu, 7, ldtul_p(buf + offset));
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Gdtr.Pad):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Gdtr.Pad);
+            env->gdt.selector = lduw_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Gdtr.Limit):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Gdtr.Limit);
+            env->gdt.limit = lduw_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Gdtr.Base):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Gdtr.Base);
+            env->gdt.base = ldtul_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Idtr.Pad):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Idtr.Pad);
+            env->idt.selector = lduw_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Idtr.Limit):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Idtr.Limit);
+            env->idt.limit = lduw_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Idtr.Base):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Idtr.Base);
+            env->idt.base = ldtul_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Tr):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Tr);
+            env->tr.selector = lduw_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Ldtr):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Ldtr);
+            env->ldt.selector = lduw_p(buf + offset);
+            break;
+
+        case offsetof(CPU_KSPECIAL_REGISTERS, Reserved):
+            mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Reserved);
+            break;
+
+        default:
+            WINDBG_ERROR("write_context: Unknown offset %d", offset);
+            return -1;
+        }
+
+        mem_ptr += mem_size;
+        offset += mem_size;
+        len -= mem_size;
+    }
+
     return 0;
 }
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 30/45] windbg: implemented windbg_set_sr
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (28 preceding siblings ...)
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 29/45] windbg: implemented windbg_write_ks_regs Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 31/45] windbg: implemented windbg_set_dr Mihail Abakumov
                   ` (17 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |   17 ++++++++++++++++-
 1 file changed, 16 insertions(+), 1 deletion(-)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 63962b48dd..c59d1401ad 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -277,7 +277,22 @@ static void windbg_set_dr(CPUState *cpu, int index, target_ulong value)
 {}
 
 static void windbg_set_sr(CPUState *cpu, int sr, uint16_t selector)
-{}
+{
+    CPUArchState *env = cpu->env_ptr;
+
+    if (selector != env->segs[sr].selector &&
+        (!(env->cr[0] & CR0_PE_MASK) || (env->eflags & VM_MASK))) {
+        unsigned int limit, flags;
+        target_ulong base;
+
+        int dpl = (env->eflags & VM_MASK) ? 3 : 0;
+        base = selector << 4;
+        limit = 0xffff;
+        flags = DESC_P_MASK | DESC_S_MASK | DESC_W_MASK |
+                DESC_A_MASK | (dpl << DESC_DPL_SHIFT);
+        cpu_x86_load_seg_cache(env, sr, selector, base, limit, flags);
+    }
+}
 
 static int windbg_read_context(CPUState *cpu, uint8_t *buf, int buf_size,
                                int offset, int len)

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 31/45] windbg: implemented windbg_set_dr
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (29 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 30/45] windbg: implemented windbg_set_sr Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 32/45] windbg: implemented windbg_set_dr7 Mihail Abakumov
                   ` (16 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Defined useful macros for breakpoints.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |   50 +++++++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 49 insertions(+), 1 deletion(-)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index c59d1401ad..14ad195107 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -14,6 +14,21 @@
 #ifndef TARGET_X86_64
 #include "exec/windbgstub-utils.h"
 
+#define IS_LOCAL_BP_ENABLED(dr7, index) (((dr7) >> ((index) * 2)) & 1)
+
+#define IS_GLOBAL_BP_ENABLED(dr7, index) (((dr7) >> ((index) * 2)) & 2)
+
+#define IS_BP_ENABLED(dr7, index) \
+    (IS_LOCAL_BP_ENABLED(dr7, index) | IS_GLOBAL_BP_ENABLED(dr7, index))
+
+#define BP_TYPE(dr7, index) \
+    ((int) ((dr7) >> (DR7_TYPE_SHIFT + ((index) * 4))) & 3)
+
+#define BP_LEN(dr7, index) ({                                    \
+    int _len = (((dr7) >> (DR7_LEN_SHIFT + ((index) * 4))) & 3); \
+    (_len == 2) ? 8 : _len + 1;                                  \
+})
+
 #ifdef TARGET_X86_64
 # define OFFSET_SELF_PCR         0x18
 # define OFFSET_VERS             0x108
@@ -273,9 +288,42 @@ typedef struct _CPU_KPROCESSOR_STATE {
     CPU_KSPECIAL_REGISTERS SpecialRegisters;
 } CPU_KPROCESSOR_STATE, *PCPU_KPROCESSOR_STATE;
 
-static void windbg_set_dr(CPUState *cpu, int index, target_ulong value)
+static int windbg_hw_breakpoint_insert(CPUState *cpu, int index)
+{
+    return 0;
+}
+
+static int windbg_hw_breakpoint_remove(CPUState *cpu, int index)
+{
+    return 0;
+}
+
+static void windbg_set_dr7(CPUState *cpu, target_ulong new_dr7)
 {}
 
+static void windbg_set_dr(CPUState *cpu, int index, target_ulong value)
+{
+    CPUArchState *env = cpu->env_ptr;
+
+    switch (index) {
+    case 0 ... 3:
+        if (IS_BP_ENABLED(env->dr[7], index) && env->dr[index] != value) {
+            windbg_hw_breakpoint_remove(cpu, index);
+            env->dr[index] = value;
+            windbg_hw_breakpoint_insert(cpu, index);
+        } else {
+            env->dr[index] = value;
+        }
+        return;
+    case 6:
+        env->dr[6] = value | DR6_FIXED_1;
+        return;
+    case 7:
+        windbg_set_dr7(cpu, value);
+        return;
+    }
+}
+
 static void windbg_set_sr(CPUState *cpu, int sr, uint16_t selector)
 {
     CPUArchState *env = cpu->env_ptr;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 32/45] windbg: implemented windbg_set_dr7
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (30 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 31/45] windbg: implemented windbg_set_dr Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 33/45] windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove Mihail Abakumov
                   ` (15 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |   27 ++++++++++++++++++++++++++-
 1 file changed, 26 insertions(+), 1 deletion(-)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 14ad195107..deb0e728e0 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -299,7 +299,32 @@ static int windbg_hw_breakpoint_remove(CPUState *cpu, int index)
 }
 
 static void windbg_set_dr7(CPUState *cpu, target_ulong new_dr7)
-{}
+{
+    CPUArchState *env = cpu->env_ptr;
+    target_ulong old_dr7 = env->dr[7];
+    int iobpt = 0;
+    int i;
+
+    new_dr7 |= DR7_FIXED_1;
+    if (new_dr7 == old_dr7) {
+        return;
+    }
+
+    for (i = 0; i < DR7_MAX_BP; i++) {
+        if (IS_BP_ENABLED(old_dr7, i) && !IS_BP_ENABLED(new_dr7, i)) {
+            windbg_hw_breakpoint_remove(cpu, i);
+        }
+    }
+
+    env->dr[7] = new_dr7;
+    for (i = 0; i < DR7_MAX_BP; i++) {
+        if (IS_BP_ENABLED(env->dr[7], i)) {
+            iobpt |= windbg_hw_breakpoint_insert(cpu, i);
+        }
+    }
+
+    env->hflags = (env->hflags & ~HF_IOBPT_MASK) | iobpt;
+}
 
 static void windbg_set_dr(CPUState *cpu, int index, target_ulong value)
 {

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 33/45] windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (31 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 32/45] windbg: implemented windbg_set_dr7 Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 34/45] windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint Mihail Abakumov
                   ` (14 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 target/i386/windbgstub.c |   56 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 56 insertions(+)

diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index deb0e728e0..43e6d45df9 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -290,11 +290,67 @@ typedef struct _CPU_KPROCESSOR_STATE {
 
 static int windbg_hw_breakpoint_insert(CPUState *cpu, int index)
 {
+    CPUArchState *env = cpu->env_ptr;
+
+    target_ulong addr = env->dr[index];
+    int type = BP_TYPE(env->dr[7], index);
+    int len = BP_LEN(env->dr[7], index);
+    int err = 0;
+
+    switch (type) {
+    case DR7_TYPE_DATA_WR:
+        err = cpu_watchpoint_insert(cpu, addr, len, BP_MEM_WRITE | BP_GDB,
+                                    &env->cpu_watchpoint[index]);
+        break;
+    case DR7_TYPE_DATA_RW:
+        err = cpu_watchpoint_insert(cpu, addr, len, BP_MEM_ACCESS | BP_GDB,
+                                    &env->cpu_watchpoint[index]);
+        break;
+    case DR7_TYPE_BP_INST:
+        err = cpu_breakpoint_insert(cpu, addr, BP_GDB,
+                                    &env->cpu_breakpoint[index]);
+        break;
+    case DR7_TYPE_IO_RW:
+        return HF_IOBPT_MASK;
+    default:
+        return 0;
+    }
+
+    if (!err) {
+        WINDBG_DEBUG("hw_breakpoint_insert: index(%d), " FMT_ADDR,
+                     index, addr);
+    } else {
+        env->cpu_breakpoint[index] = NULL;
+        WINDBG_ERROR("hw_breakpoint_insert: index(%d), " FMT_ADDR ", " FMT_ERR,
+                     index, addr, err);
+    }
     return 0;
 }
 
 static int windbg_hw_breakpoint_remove(CPUState *cpu, int index)
 {
+    CPUArchState *env = cpu->env_ptr;
+    int type = BP_TYPE(env->dr[7], index);
+
+    switch (type) {
+    case DR7_TYPE_BP_INST:
+        if (env->cpu_breakpoint[index]) {
+            cpu_breakpoint_remove_by_ref(cpu, env->cpu_breakpoint[index]);
+        }
+        break;
+    case DR7_TYPE_DATA_WR:
+    case DR7_TYPE_DATA_RW:
+        if (env->cpu_watchpoint[index]) {
+            cpu_watchpoint_remove_by_ref(cpu, env->cpu_watchpoint[index]);
+        }
+        break;
+    default:
+        return 0;
+    }
+
+    env->cpu_breakpoint[index] = NULL;
+    WINDBG_DEBUG("hw_breakpoint_remove: index(%d), " FMT_ADDR,
+                 index, env->dr[index]);
     return 0;
 }
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 34/45] windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (32 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 33/45] windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing Mihail Abakumov
                   ` (13 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added supporting of windbg breakpoints.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 +
 windbgstub-utils.c              |   62 +++++++++++++++++++++++++++++++++++++++
 windbgstub.c                    |   11 +++++++
 3 files changed, 75 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 5e5893bac8..0d9ccf9801 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -90,6 +90,8 @@ void kd_api_read_virtual_memory(CPUState *cpu, PacketData *pd);
 void kd_api_write_virtual_memory(CPUState *cpu, PacketData *pd);
 void kd_api_get_context(CPUState *cpu, PacketData *pd);
 void kd_api_set_context(CPUState *cpu, PacketData *pd);
+void kd_api_write_breakpoint(CPUState *cpu, PacketData *pd);
+void kd_api_restore_breakpoint(CPUState *cpu, PacketData *pd);
 void kd_api_read_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_write_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index 1e81c37501..f00dab2a9d 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -14,6 +14,8 @@
 static InitedAddr KPCR;
 static InitedAddr version;
 
+static InitedAddr bps[KD_BREAKPOINT_MAX];
+
 InitedAddr *windbg_get_KPCR(void)
 {
     return &KPCR;
@@ -71,6 +73,66 @@ void kd_api_write_virtual_memory(CPUState *cpu, PacketData *pd)
     stl_p(&mem->ActualBytesWritten, len);
 }
 
+void kd_api_write_breakpoint(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_WRITE_BREAKPOINT64 *m64c = &pd->m64.u.WriteBreakPoint;
+    target_ulong addr;
+    int i, err = 0;
+
+    addr = ldtul_p(&m64c->BreakPointAddress);
+
+    for (i = 0; i < KD_BREAKPOINT_MAX; ++i) {
+        if (!bps[i].is_init) {
+            err = cpu_breakpoint_insert(cpu, addr, BP_GDB, NULL);
+            if (!err) {
+                bps[i].addr = addr;
+                bps[i].is_init = true;
+                WINDBG_DEBUG("write_breakpoint: " FMT_ADDR, addr);
+                break;
+            } else {
+                WINDBG_ERROR("write_breakpoint: " FMT_ADDR ", " FMT_ERR,
+                             addr, err);
+                pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+                return;
+            }
+        } else if (addr == bps[i].addr) {
+            break;
+        }
+    }
+
+    if (!err) {
+        stl_p(&m64c->BreakPointHandle, i + 1);
+        pd->m64.ReturnStatus = STATUS_SUCCESS;
+    } else {
+        WINDBG_ERROR("write_breakpoint: All breakpoints occupied");
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    }
+}
+
+void kd_api_restore_breakpoint(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_RESTORE_BREAKPOINT *m64c = &pd->m64.u.RestoreBreakPoint;
+    uint8_t index;
+    int err = -1;
+
+    index = ldtul_p(&m64c->BreakPointHandle) - 1;
+
+    if (bps[index].is_init) {
+        err = cpu_breakpoint_remove(cpu, bps[index].addr, BP_GDB);
+        if (!err) {
+            WINDBG_DEBUG("restore_breakpoint: " FMT_ADDR ", index(%d)",
+                         bps[index].addr, index);
+        } else {
+            WINDBG_ERROR("restore_breakpoint: " FMT_ADDR ", index(%d), "
+                         FMT_ERR, bps[index].addr, index, err);
+        }
+        bps[index].is_init = false;
+        pd->m64.ReturnStatus = STATUS_SUCCESS;
+    } else {
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    }
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index 5b0a15ea4e..489abe6d6c 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -156,6 +156,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_set_context(cpu, &ctx->data);
         break;
 
+    case DbgKdWriteBreakPointApi:
+        kd_api_write_breakpoint(cpu, &ctx->data);
+        break;
+
+    case DbgKdRestoreBreakPointApi:
+        kd_api_restore_breakpoint(cpu, &ctx->data);
+        break;
+
     case DbgKdReadControlSpaceApi:
         kd_api_read_control_space(cpu, &ctx->data);
         break;
@@ -164,6 +172,9 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_write_control_space(cpu, &ctx->data);
         break;
 
+    case DbgKdClearAllInternalBreakpointsApi:
+        return;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (33 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 34/45] windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-29  7:13   ` Ladi Prosek
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 36/45] windbg: implemented kd_api_continue Mihail Abakumov
                   ` (12 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added handler registration of gdb debug exception. Its exception also can be used for windbg.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 cpus.c                  |   18 +++++++++++++++++-
 gdbstub.c               |    4 ++++
 include/sysemu/sysemu.h |    2 ++
 windbgstub.c            |   16 ++++++++++++----
 4 files changed, 35 insertions(+), 5 deletions(-)

diff --git a/cpus.c b/cpus.c
index 9bed61eefc..212553b7e3 100644
--- a/cpus.c
+++ b/cpus.c
@@ -77,6 +77,8 @@ int64_t max_advance;
 static QEMUTimer *throttle_timer;
 static unsigned int throttle_percentage;
 
+static void (*excp_debug_handler)(CPUState *cpu);
+
 #define CPU_THROTTLE_PCT_MIN 1
 #define CPU_THROTTLE_PCT_MAX 99
 #define CPU_THROTTLE_TIMESLICE_NS 10000000
@@ -960,9 +962,23 @@ static bool cpu_can_run(CPUState *cpu)
     return true;
 }
 
+bool register_excp_debug_handler(void (*handler)(CPUState *cpu))
+{
+    if (excp_debug_handler == NULL) {
+        excp_debug_handler = handler;
+        return true;
+    } else {
+        error_report("ERROR: Something debugger already using");
+        return false;
+    }
+}
+
 static void cpu_handle_guest_debug(CPUState *cpu)
 {
-    gdb_set_stop_cpu(cpu);
+    if (excp_debug_handler != NULL) {
+        excp_debug_handler(cpu);
+    }
+
     qemu_system_debug_request();
     cpu->stopped = true;
 }
diff --git a/gdbstub.c b/gdbstub.c
index 2a94030d3b..8c76f54117 100644
--- a/gdbstub.c
+++ b/gdbstub.c
@@ -2006,6 +2006,10 @@ int gdbserver_start(const char *device)
     s->mon_chr = mon_chr;
     s->current_syscall_cb = NULL;
 
+    if (!register_excp_debug_handler(gdb_set_stop_cpu)) {
+        exit(1);
+    }
+
     return 0;
 }
 
diff --git a/include/sysemu/sysemu.h b/include/sysemu/sysemu.h
index b21369672a..34588c99b4 100644
--- a/include/sysemu/sysemu.h
+++ b/include/sysemu/sysemu.h
@@ -193,6 +193,8 @@ QemuOpts *qemu_get_machine_opts(void);
 
 bool defaults_enabled(void);
 
+bool register_excp_debug_handler(void (*handler)(CPUState *cpu));
+
 extern QemuOptsList qemu_legacy_drive_opts;
 extern QemuOptsList qemu_common_drive_opts;
 extern QemuOptsList qemu_drive_opts;
diff --git a/windbgstub.c b/windbgstub.c
index 489abe6d6c..b33f412659 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -115,16 +115,20 @@ static void windbg_send_control_packet(uint16_t type)
     windbg_state->ctrl_packet_id ^= 1;
 }
 
-static void windbg_vm_stop(void)
+static void windbg_bp_handler(CPUState *cpu)
 {
-    CPUState *cpu = qemu_get_cpu(0);
-    vm_stop(RUN_STATE_PAUSED);
-
     SizedBuf buf = kd_gen_exception_sc(cpu);
     windbg_send_data_packet(buf.data, buf.size, PACKET_TYPE_KD_STATE_CHANGE64);
     SBUF_FREE(buf);
 }
 
+static void windbg_vm_stop(void)
+{
+    CPUState *cpu = qemu_get_cpu(0);
+    vm_stop(RUN_STATE_PAUSED);
+    windbg_bp_handler(cpu);
+}
+
 static void windbg_process_manipulate_packet(ParsingContext *ctx)
 {
     CPUState *cpu;
@@ -432,6 +436,10 @@ int windbg_server_start(const char *device)
 
     qemu_register_reset(windbg_handle_reset, NULL);
 
+    if (!register_excp_debug_handler(windbg_bp_handler)) {
+        exit(1);
+    }
+
     atexit(windbg_exit);
     return 0;
 }

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 36/45] windbg: implemented kd_api_continue
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (34 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 37/45] windbg: implemented kd_api_read_io_space and kd_api_write_io_space Mihail Abakumov
                   ` (11 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    1 +
 windbgstub-utils.c              |   15 +++++++++++++++
 windbgstub.c                    |    5 +++++
 3 files changed, 21 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 0d9ccf9801..2cfca92183 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -92,6 +92,7 @@ void kd_api_get_context(CPUState *cpu, PacketData *pd);
 void kd_api_set_context(CPUState *cpu, PacketData *pd);
 void kd_api_write_breakpoint(CPUState *cpu, PacketData *pd);
 void kd_api_restore_breakpoint(CPUState *cpu, PacketData *pd);
+void kd_api_continue(CPUState *cpu, PacketData *pd);
 void kd_api_read_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_write_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index f00dab2a9d..fe3adb0b88 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -10,6 +10,7 @@
  */
 
 #include "exec/windbgstub-utils.h"
+#include "sysemu/sysemu.h"
 
 static InitedAddr KPCR;
 static InitedAddr version;
@@ -133,6 +134,20 @@ void kd_api_restore_breakpoint(CPUState *cpu, PacketData *pd)
     }
 }
 
+void kd_api_continue(CPUState *cpu, PacketData *pd)
+{
+    uint32_t status = ldl_p(&pd->m64.u.Continue2.ContinueStatus);
+    uint32_t trace = ldl_p(&pd->m64.u.Continue2.ControlSet.TraceFlag);
+    int ssFlag = trace ? SSTEP_ENABLE | SSTEP_NOIRQ | SSTEP_NOTIMER : 0;
+
+    if (NT_SUCCESS(status)) {
+        cpu_single_step(cpu, ssFlag);
+        if (!runstate_needs_reset()) {
+            vm_start();
+        }
+    }
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index b33f412659..a04698b003 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -168,6 +168,11 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_restore_breakpoint(cpu, &ctx->data);
         break;
 
+    case DbgKdContinueApi:
+    case DbgKdContinueApi2:
+        kd_api_continue(cpu, &ctx->data);
+        return;
+
     case DbgKdReadControlSpaceApi:
         kd_api_read_control_space(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 37/45] windbg: implemented kd_api_read_io_space and kd_api_write_io_space
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (35 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 36/45] windbg: implemented kd_api_continue Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 38/45] windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory Mihail Abakumov
                   ` (10 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 +
 windbgstub-utils.c              |   62 +++++++++++++++++++++++++++++++++++++++
 windbgstub.c                    |    8 +++++
 3 files changed, 72 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 2cfca92183..7f52acbae3 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -95,6 +95,8 @@ void kd_api_restore_breakpoint(CPUState *cpu, PacketData *pd);
 void kd_api_continue(CPUState *cpu, PacketData *pd);
 void kd_api_read_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_write_control_space(CPUState *cpu, PacketData *pd);
+void kd_api_read_io_space(CPUState *cpu, PacketData *pd);
+void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index fe3adb0b88..3f8ce1f8be 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -11,6 +11,7 @@
 
 #include "exec/windbgstub-utils.h"
 #include "sysemu/sysemu.h"
+#include "exec/address-spaces.h"
 
 static InitedAddr KPCR;
 static InitedAddr version;
@@ -148,6 +149,67 @@ void kd_api_continue(CPUState *cpu, PacketData *pd)
     }
 }
 
+void kd_api_read_io_space(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_READ_WRITE_IO64 *io = &pd->m64.u.ReadWriteIo;
+    CPUArchState *env = cpu->env_ptr;
+
+    target_ulong addr = ldtul_p(&io->IoAddress);
+    uint32_t value = 0;
+
+    switch (io->DataSize) {
+    case 1:
+        value = address_space_ldub(&address_space_io, addr,
+                                   cpu_get_mem_attrs(env), NULL);
+        stl_p(&io->DataValue, value);
+        break;
+    case 2:
+        value = address_space_lduw(&address_space_io, addr,
+                                   cpu_get_mem_attrs(env), NULL);
+        stl_p(&io->DataValue, value);
+        break;
+    case 4:
+        value = address_space_ldl(&address_space_io, addr,
+                                  cpu_get_mem_attrs(env), NULL);
+        stl_p(&io->DataValue, value);
+        break;
+    default:
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+        return;
+    }
+
+    pd->m64.ReturnStatus = STATUS_SUCCESS;
+}
+
+void kd_api_write_io_space(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_READ_WRITE_IO64 *io = &pd->m64.u.ReadWriteIo;
+    CPUArchState *env = cpu->env_ptr;
+
+    target_ulong addr = ldtul_p(&io->IoAddress);
+    uint32_t value = ldl_p(&io->DataValue);
+
+    switch (io->DataSize) {
+    case 1:
+        address_space_stb(&address_space_io, addr, value,
+                          cpu_get_mem_attrs(env), NULL);
+        break;
+    case 2:
+        address_space_stw(&address_space_io, addr, value,
+                          cpu_get_mem_attrs(env), NULL);
+        break;
+    case 4:
+        address_space_stl(&address_space_io, addr, value,
+                          cpu_get_mem_attrs(env), NULL);
+        break;
+    default:
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+        return;
+    }
+
+    pd->m64.ReturnStatus = STATUS_SUCCESS;
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index a04698b003..397dedd9d1 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -168,6 +168,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_restore_breakpoint(cpu, &ctx->data);
         break;
 
+    case DbgKdReadIoSpaceApi:
+        kd_api_read_io_space(cpu, &ctx->data);
+        break;
+
+    case DbgKdWriteIoSpaceApi:
+        kd_api_write_io_space(cpu, &ctx->data);
+        break;
+
     case DbgKdContinueApi:
     case DbgKdContinueApi2:
         kd_api_continue(cpu, &ctx->data);

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 38/45] windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (36 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 37/45] windbg: implemented kd_api_read_io_space and kd_api_write_io_space Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version Mihail Abakumov
                   ` (9 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 ++
 windbgstub-utils.c              |   29 +++++++++++++++++++++++++++++
 windbgstub.c                    |    8 ++++++++
 3 files changed, 39 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 7f52acbae3..be48f69f40 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -97,6 +97,8 @@ void kd_api_read_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_write_control_space(CPUState *cpu, PacketData *pd);
 void kd_api_read_io_space(CPUState *cpu, PacketData *pd);
 void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
+void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd);
+void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index 3f8ce1f8be..6708e62798 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -210,6 +210,35 @@ void kd_api_write_io_space(CPUState *cpu, PacketData *pd)
     pd->m64.ReturnStatus = STATUS_SUCCESS;
 }
 
+void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_READ_MEMORY64 *mem = &pd->m64.u.ReadMemory;
+    uint32_t len;
+    target_ulong addr;
+
+    len = MIN(ldl_p(&mem->TransferCount),
+              PACKET_MAX_SIZE - sizeof(DBGKD_MANIPULATE_STATE64));
+    addr = ldtul_p(&mem->TargetBaseAddress);
+
+    cpu_physical_memory_rw(addr, pd->extra, len, 0);
+    pd->extra_size = len;
+    stl_p(&mem->ActualBytesRead, len);
+}
+
+void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_WRITE_MEMORY64 *mem = &pd->m64.u.WriteMemory;
+    uint32_t len;
+    target_ulong addr;
+
+    len = MIN(ldl_p(&mem->TransferCount), pd->extra_size);
+    addr = ldtul_p(&mem->TargetBaseAddress);
+
+    cpu_physical_memory_rw(addr, pd->extra, len, 1);
+    pd->extra_size = 0;
+    stl_p(&mem->ActualBytesWritten, len);
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index 397dedd9d1..72324ae53d 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -189,6 +189,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_write_control_space(cpu, &ctx->data);
         break;
 
+    case DbgKdReadPhysicalMemoryApi:
+        kd_api_read_physical_memory(cpu, &ctx->data);
+        break;
+
+    case DbgKdWritePhysicalMemoryApi:
+        kd_api_write_physical_memory(cpu, &ctx->data);
+        break;
+
     case DbgKdClearAllInternalBreakpointsApi:
         return;
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (37 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 38/45] windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory Mihail Abakumov
@ 2017-11-21 14:10 ` Mihail Abakumov
  2017-11-29  8:14   ` Ladi Prosek
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 40/45] windbg: implemented kd_api_read_msr and kd_api_write_msr Mihail Abakumov
                   ` (8 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:10 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    1 +
 windbgstub-utils.c              |   22 ++++++++++++++++++++++
 windbgstub.c                    |    4 ++++
 3 files changed, 27 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index be48f69f40..bc5b6a8468 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -99,6 +99,7 @@ void kd_api_read_io_space(CPUState *cpu, PacketData *pd);
 void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
 void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd);
 void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
+void kd_api_get_version(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index 6708e62798..7ef301bac7 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -239,6 +239,28 @@ void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd)
     stl_p(&mem->ActualBytesWritten, len);
 }
 
+void kd_api_get_version(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_GET_VERSION64 *kdver;
+    int err = cpu_memory_rw_debug(cpu, version.addr, PTR(pd->m64) + 0x10,
+                                  sizeof(DBGKD_MANIPULATE_STATE64) - 0x10, 0);
+    if (!err) {
+        kdver = (DBGKD_GET_VERSION64 *) (PTR(pd->m64) + 0x10);
+
+        stw_p(&kdver->MajorVersion, kdver->MajorVersion);
+        stw_p(&kdver->MinorVersion, kdver->MinorVersion);
+        stw_p(&kdver->Flags, kdver->Flags);
+        stw_p(&kdver->MachineType, kdver->MachineType);
+        stw_p(&kdver->Unused[0], kdver->Unused[0]);
+        sttul_p(&kdver->KernBase, kdver->KernBase);
+        sttul_p(&kdver->PsLoadedModuleList, kdver->PsLoadedModuleList);
+        sttul_p(&kdver->DebuggerDataList, kdver->DebuggerDataList);
+    } else {
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+        WINDBG_ERROR("get_version: " FMT_ERR, err);
+    }
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index 72324ae53d..ddca290694 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -197,6 +197,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_write_physical_memory(cpu, &ctx->data);
         break;
 
+    case DbgKdGetVersionApi:
+        kd_api_get_version(cpu, &ctx->data);
+        break;
+
     case DbgKdClearAllInternalBreakpointsApi:
         return;
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 40/45] windbg: implemented kd_api_read_msr and kd_api_write_msr
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (38 preceding siblings ...)
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version Mihail Abakumov
@ 2017-11-21 14:11 ` Mihail Abakumov
  2017-11-29  7:25   ` Ladi Prosek
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 41/45] windbg: implemented kd_api_search_memory Mihail Abakumov
                   ` (7 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:11 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 
 target/i386/windbgstub.c        |  319 +++++++++++++++++++++++++++++++++++++++
 windbgstub.c                    |    8 +
 3 files changed, 329 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index bc5b6a8468..73d49b774d 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -100,6 +100,8 @@ void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
 void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd);
 void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
 void kd_api_get_version(CPUState *cpu, PacketData *pd);
+void kd_api_read_msr(CPUState *cpu, PacketData *pd);
+void kd_api_write_msr(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 43e6d45df9..735b2edd5f 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -1003,6 +1003,325 @@ void kd_api_write_control_space(CPUState *cpu, PacketData *pd)
     stl_p(&mem->ActualBytesWritten, len);
 }
 
+void kd_api_read_msr(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_READ_WRITE_MSR *m64c = &pd->m64.u.ReadWriteMsr;
+    CPUArchState *env = cpu->env_ptr;
+
+    uint64_t val;
+
+    cpu_svm_check_intercept_param(env, SVM_EXIT_MSR, 0, 0);
+
+    switch ((uint32_t)env->regs[R_ECX]) {
+    case MSR_IA32_SYSENTER_CS:
+        val = env->sysenter_cs;
+        break;
+    case MSR_IA32_SYSENTER_ESP:
+        val = env->sysenter_esp;
+        break;
+    case MSR_IA32_SYSENTER_EIP:
+        val = env->sysenter_eip;
+        break;
+    case MSR_IA32_APICBASE:
+        val = cpu_get_apic_base(x86_env_get_cpu(env)->apic_state);
+        break;
+    case MSR_EFER:
+        val = env->efer;
+        break;
+    case MSR_STAR:
+        val = env->star;
+        break;
+    case MSR_PAT:
+        val = env->pat;
+        break;
+    case MSR_VM_HSAVE_PA:
+        val = env->vm_hsave;
+        break;
+    case MSR_IA32_PERF_STATUS:
+        /* tsc_increment_by_tick */
+        val = 1000ULL;
+        /* CPU multiplier */
+        val |= (((uint64_t)4ULL) << 40);
+        break;
+#ifdef TARGET_X86_64
+    case MSR_LSTAR:
+        val = env->lstar;
+        break;
+    case MSR_CSTAR:
+        val = env->cstar;
+        break;
+    case MSR_FMASK:
+        val = env->fmask;
+        break;
+    case MSR_FSBASE:
+        val = env->segs[R_FS].base;
+        break;
+    case MSR_GSBASE:
+        val = env->segs[R_GS].base;
+        break;
+    case MSR_KERNELGSBASE:
+        val = env->kernelgsbase;
+        break;
+    case MSR_TSC_AUX:
+        val = env->tsc_aux;
+        break;
+#endif
+    case MSR_MTRRphysBase(0):
+    case MSR_MTRRphysBase(1):
+    case MSR_MTRRphysBase(2):
+    case MSR_MTRRphysBase(3):
+    case MSR_MTRRphysBase(4):
+    case MSR_MTRRphysBase(5):
+    case MSR_MTRRphysBase(6):
+    case MSR_MTRRphysBase(7):
+        val = env->mtrr_var[((uint32_t)env->regs[R_ECX] -
+                             MSR_MTRRphysBase(0)) / 2].base;
+        break;
+    case MSR_MTRRphysMask(0):
+    case MSR_MTRRphysMask(1):
+    case MSR_MTRRphysMask(2):
+    case MSR_MTRRphysMask(3):
+    case MSR_MTRRphysMask(4):
+    case MSR_MTRRphysMask(5):
+    case MSR_MTRRphysMask(6):
+    case MSR_MTRRphysMask(7):
+        val = env->mtrr_var[((uint32_t)env->regs[R_ECX] -
+                             MSR_MTRRphysMask(0)) / 2].mask;
+        break;
+    case MSR_MTRRfix64K_00000:
+        val = env->mtrr_fixed[0];
+        break;
+    case MSR_MTRRfix16K_80000:
+    case MSR_MTRRfix16K_A0000:
+        val = env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
+                              MSR_MTRRfix16K_80000 + 1];
+        break;
+    case MSR_MTRRfix4K_C0000:
+    case MSR_MTRRfix4K_C8000:
+    case MSR_MTRRfix4K_D0000:
+    case MSR_MTRRfix4K_D8000:
+    case MSR_MTRRfix4K_E0000:
+    case MSR_MTRRfix4K_E8000:
+    case MSR_MTRRfix4K_F0000:
+    case MSR_MTRRfix4K_F8000:
+        val = env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
+                              MSR_MTRRfix4K_C0000 + 3];
+        break;
+    case MSR_MTRRdefType:
+        val = env->mtrr_deftype;
+        break;
+    case MSR_MTRRcap:
+        if (env->features[FEAT_1_EDX] & CPUID_MTRR) {
+            val = MSR_MTRRcap_VCNT | MSR_MTRRcap_FIXRANGE_SUPPORT |
+                MSR_MTRRcap_WC_SUPPORTED;
+        } else {
+            /* XXX: exception? */
+            val = 0;
+        }
+        break;
+    case MSR_MCG_CAP:
+        val = env->mcg_cap;
+        break;
+    case MSR_MCG_CTL:
+        if (env->mcg_cap & MCG_CTL_P) {
+            val = env->mcg_ctl;
+        } else {
+            val = 0;
+        }
+        break;
+    case MSR_MCG_STATUS:
+        val = env->mcg_status;
+        break;
+    case MSR_IA32_MISC_ENABLE:
+        val = env->msr_ia32_misc_enable;
+        break;
+    case MSR_IA32_BNDCFGS:
+        val = env->msr_bndcfgs;
+        break;
+    default:
+        if ((uint32_t)env->regs[R_ECX] >= MSR_MC0_CTL
+            && (uint32_t)env->regs[R_ECX] < MSR_MC0_CTL +
+            (4 * env->mcg_cap & 0xff)) {
+            uint32_t offset = (uint32_t)env->regs[R_ECX] - MSR_MC0_CTL;
+            val = env->mce_banks[offset];
+            break;
+        }
+        /* XXX: exception? */
+        val = 0;
+        break;
+    }
+
+    stq_p(&val, val);
+    m64c->DataValueLow  = UINT32_P(val)[0];
+    m64c->DataValueHigh = UINT32_P(val)[1];
+    pd->m64.ReturnStatus = STATUS_SUCCESS;
+}
+
+void kd_api_write_msr(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_READ_WRITE_MSR *m64c = &pd->m64.u.ReadWriteMsr;
+    CPUArchState *env = cpu->env_ptr;
+
+    uint64_t val;
+
+    cpu_svm_check_intercept_param(env, SVM_EXIT_MSR, 1, 0);
+
+    val = m64c->DataValueLow | ((uint64_t) m64c->DataValueHigh) << 32;
+    val = ldq_p(&val);
+
+    switch ((uint32_t)env->regs[R_ECX]) {
+    case MSR_IA32_SYSENTER_CS:
+        env->sysenter_cs = val & 0xffff;
+        break;
+    case MSR_IA32_SYSENTER_ESP:
+        env->sysenter_esp = val;
+        break;
+    case MSR_IA32_SYSENTER_EIP:
+        env->sysenter_eip = val;
+        break;
+    case MSR_IA32_APICBASE:
+        cpu_set_apic_base(x86_env_get_cpu(env)->apic_state, val);
+        break;
+    case MSR_EFER:
+        {
+            uint64_t update_mask;
+
+            update_mask = 0;
+            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_SYSCALL) {
+                update_mask |= MSR_EFER_SCE;
+            }
+            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
+                update_mask |= MSR_EFER_LME;
+            }
+            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_FFXSR) {
+                update_mask |= MSR_EFER_FFXSR;
+            }
+            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_NX) {
+                update_mask |= MSR_EFER_NXE;
+            }
+            if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
+                update_mask |= MSR_EFER_SVME;
+            }
+            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_FFXSR) {
+                update_mask |= MSR_EFER_FFXSR;
+            }
+            cpu_load_efer(env, (env->efer & ~update_mask) |
+                          (val & update_mask));
+        }
+        break;
+    case MSR_STAR:
+        env->star = val;
+        break;
+    case MSR_PAT:
+        env->pat = val;
+        break;
+    case MSR_VM_HSAVE_PA:
+        env->vm_hsave = val;
+        break;
+#ifdef TARGET_X86_64
+    case MSR_LSTAR:
+        env->lstar = val;
+        break;
+    case MSR_CSTAR:
+        env->cstar = val;
+        break;
+    case MSR_FMASK:
+        env->fmask = val;
+        break;
+    case MSR_FSBASE:
+        env->segs[R_FS].base = val;
+        break;
+    case MSR_GSBASE:
+        env->segs[R_GS].base = val;
+        break;
+    case MSR_KERNELGSBASE:
+        env->kernelgsbase = val;
+        break;
+#endif
+    case MSR_MTRRphysBase(0):
+    case MSR_MTRRphysBase(1):
+    case MSR_MTRRphysBase(2):
+    case MSR_MTRRphysBase(3):
+    case MSR_MTRRphysBase(4):
+    case MSR_MTRRphysBase(5):
+    case MSR_MTRRphysBase(6):
+    case MSR_MTRRphysBase(7):
+        env->mtrr_var[((uint32_t)env->regs[R_ECX] -
+                       MSR_MTRRphysBase(0)) / 2].base = val;
+        break;
+    case MSR_MTRRphysMask(0):
+    case MSR_MTRRphysMask(1):
+    case MSR_MTRRphysMask(2):
+    case MSR_MTRRphysMask(3):
+    case MSR_MTRRphysMask(4):
+    case MSR_MTRRphysMask(5):
+    case MSR_MTRRphysMask(6):
+    case MSR_MTRRphysMask(7):
+        env->mtrr_var[((uint32_t)env->regs[R_ECX] -
+                       MSR_MTRRphysMask(0)) / 2].mask = val;
+        break;
+    case MSR_MTRRfix64K_00000:
+        env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
+                        MSR_MTRRfix64K_00000] = val;
+        break;
+    case MSR_MTRRfix16K_80000:
+    case MSR_MTRRfix16K_A0000:
+        env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
+                        MSR_MTRRfix16K_80000 + 1] = val;
+        break;
+    case MSR_MTRRfix4K_C0000:
+    case MSR_MTRRfix4K_C8000:
+    case MSR_MTRRfix4K_D0000:
+    case MSR_MTRRfix4K_D8000:
+    case MSR_MTRRfix4K_E0000:
+    case MSR_MTRRfix4K_E8000:
+    case MSR_MTRRfix4K_F0000:
+    case MSR_MTRRfix4K_F8000:
+        env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
+                        MSR_MTRRfix4K_C0000 + 3] = val;
+        break;
+    case MSR_MTRRdefType:
+        env->mtrr_deftype = val;
+        break;
+    case MSR_MCG_STATUS:
+        env->mcg_status = val;
+        break;
+    case MSR_MCG_CTL:
+        if ((env->mcg_cap & MCG_CTL_P)
+            && (val == 0 || val == ~(uint64_t)0)) {
+            env->mcg_ctl = val;
+        }
+        break;
+    case MSR_TSC_AUX:
+        env->tsc_aux = val;
+        break;
+    case MSR_IA32_MISC_ENABLE:
+        env->msr_ia32_misc_enable = val;
+        break;
+    case MSR_IA32_BNDCFGS:
+        /* FIXME: #GP if reserved bits are set.  */
+        /* FIXME: Extend highest implemented bit of linear address.  */
+        env->msr_bndcfgs = val;
+        cpu_sync_bndcs_hflags(env);
+        break;
+    default:
+        if ((uint32_t)env->regs[R_ECX] >= MSR_MC0_CTL
+            && (uint32_t)env->regs[R_ECX] < MSR_MC0_CTL +
+            (4 * env->mcg_cap & 0xff)) {
+            uint32_t offset = (uint32_t)env->regs[R_ECX] - MSR_MC0_CTL;
+            if ((offset & 0x3) != 0
+                || (val == 0 || val == ~(uint64_t)0)) {
+                env->mce_banks[offset] = val;
+            }
+            break;
+        }
+        /* XXX: exception? */
+        break;
+    }
+
+    pd->m64.ReturnStatus = STATUS_SUCCESS;
+}
+
 bool windbg_on_load(void)
 {
     CPUState *cpu = qemu_get_cpu(0);
diff --git a/windbgstub.c b/windbgstub.c
index ddca290694..0268d0818e 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -197,6 +197,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_write_physical_memory(cpu, &ctx->data);
         break;
 
+    case DbgKdReadMachineSpecificRegister:
+        kd_api_read_msr(cpu, &ctx->data);
+        break;
+
+    case DbgKdWriteMachineSpecificRegister:
+        kd_api_write_msr(cpu, &ctx->data);
+        break;
+
     case DbgKdGetVersionApi:
         kd_api_get_version(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 41/45] windbg: implemented kd_api_search_memory
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (39 preceding siblings ...)
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 40/45] windbg: implemented kd_api_read_msr and kd_api_write_msr Mihail Abakumov
@ 2017-11-21 14:11 ` Mihail Abakumov
  2017-11-29  7:55   ` Ladi Prosek
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 42/45] windbg: implemented kd_api_fill_memory Mihail Abakumov
                   ` (6 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:11 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    1 +
 windbgstub-utils.c              |   33 +++++++++++++++++++++++++++++++++
 windbgstub.c                    |    4 ++++
 3 files changed, 38 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 73d49b774d..c2eb8a75a7 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -102,6 +102,7 @@ void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
 void kd_api_get_version(CPUState *cpu, PacketData *pd);
 void kd_api_read_msr(CPUState *cpu, PacketData *pd);
 void kd_api_write_msr(CPUState *cpu, PacketData *pd);
+void kd_api_search_memory(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index 7ef301bac7..1f4590f338 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -261,6 +261,39 @@ void kd_api_get_version(CPUState *cpu, PacketData *pd)
     }
 }
 
+void kd_api_search_memory(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_SEARCH_MEMORY *m64c = &pd->m64.u.SearchMemory;
+    int s_len = MAX(ldq_p(&m64c->SearchLength), 1);
+    int p_len = MIN(ldl_p(&m64c->PatternLength), pd->extra_size);
+    target_ulong addr = ldq_p(&m64c->SearchAddress);
+    int size = MIN(s_len, 10);
+    uint8_t mem[size + p_len];
+    int i, err;
+
+    pd->extra_size = 0;
+    pd->m64.ReturnStatus = STATUS_NO_MORE_ENTRIES;
+
+    while (s_len) {
+        err = cpu_memory_rw_debug(cpu, addr, mem, size + p_len, 0);
+        if (!err) {
+            for (i = 0; i < size; ++i) {
+                if (memcmp(mem + i, pd->extra, p_len) == 0) {
+                    stl_p(&m64c->FoundAddress, addr + i);
+                    pd->m64.ReturnStatus = STATUS_SUCCESS;
+                    return;
+                }
+            }
+        } else {
+            WINDBG_DEBUG("search_memory: No physical page mapped: " FMT_ADDR,
+                         addr);
+        }
+        s_len -= size;
+        addr += size;
+        size = MIN(s_len, 10);
+    }
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index 0268d0818e..d35ff6ba96 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -212,6 +212,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
     case DbgKdClearAllInternalBreakpointsApi:
         return;
 
+    case DbgKdSearchMemoryApi:
+        kd_api_search_memory(cpu, &ctx->data);
+        break;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 42/45] windbg: implemented kd_api_fill_memory
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (40 preceding siblings ...)
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 41/45] windbg: implemented kd_api_search_memory Mihail Abakumov
@ 2017-11-21 14:11 ` Mihail Abakumov
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 43/45] windbg: implemented kd_api_query_memory Mihail Abakumov
                   ` (5 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:11 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    1 +
 windbgstub-utils.c              |   39 +++++++++++++++++++++++++++++++++++++++
 windbgstub.c                    |    4 ++++
 3 files changed, 44 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index c2eb8a75a7..e144294b51 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -103,6 +103,7 @@ void kd_api_get_version(CPUState *cpu, PacketData *pd);
 void kd_api_read_msr(CPUState *cpu, PacketData *pd);
 void kd_api_write_msr(CPUState *cpu, PacketData *pd);
 void kd_api_search_memory(CPUState *cpu, PacketData *pd);
+void kd_api_fill_memory(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index 1f4590f338..fb2c378460 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -294,6 +294,45 @@ void kd_api_search_memory(CPUState *cpu, PacketData *pd)
     }
 }
 
+void kd_api_fill_memory(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_FILL_MEMORY *m64c = &pd->m64.u.FillMemory;
+    uint32_t len = ldl_p(&m64c->Length);
+    target_ulong addr = ldq_p(&m64c->Address);
+    uint16_t pattern = ldl_p(&m64c->PatternLength);
+    uint16_t flags = ldl_p(&m64c->Flags);
+    int err, offset = 0;
+
+    uint8_t mem[pattern];
+    memcpy(mem, pd->extra, pattern);
+
+    pd->extra_size = 0;
+
+    switch (flags) {
+    case DBGKD_FILL_MEMORY_VIRTUAL:
+        while (offset < len) {
+            err = cpu_memory_rw_debug(cpu, addr + offset, mem,
+                                      MIN(pattern, len - offset), 1);
+            offset += pattern;
+            if (err) {
+                WINDBG_DEBUG("fill_memory: No physical page mapped: " FMT_ADDR,
+                             addr);
+            }
+        }
+        break;
+
+    case DBGKD_FILL_MEMORY_PHYSICAL:
+        while (offset < len) {
+            cpu_physical_memory_rw(addr, mem, MIN(pattern, len - offset), 1);
+            offset += pattern;
+        }
+        break;
+
+    default:
+        break;
+    }
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index d35ff6ba96..b348028dfd 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -216,6 +216,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_search_memory(cpu, &ctx->data);
         break;
 
+    case DbgKdFillMemoryApi:
+        kd_api_fill_memory(cpu, &ctx->data);
+        break;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 43/45] windbg: implemented kd_api_query_memory
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (41 preceding siblings ...)
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 42/45] windbg: implemented kd_api_fill_memory Mihail Abakumov
@ 2017-11-21 14:11 ` Mihail Abakumov
  2017-11-29  8:03   ` Ladi Prosek
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 44/45] windbg: added new api functions Mihail Abakumov
                   ` (4 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:11 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    1 +
 windbgstub-utils.c              |   12 ++++++++++++
 windbgstub.c                    |    4 ++++
 3 files changed, 17 insertions(+)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index e144294b51..fa1ebbb6d2 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -105,6 +105,7 @@ void kd_api_write_msr(CPUState *cpu, PacketData *pd);
 void kd_api_search_memory(CPUState *cpu, PacketData *pd);
 void kd_api_fill_memory(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
+void kd_api_query_memory(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
 SizedBuf kd_gen_load_symbols_sc(CPUState *cpu);
diff --git a/windbgstub-utils.c b/windbgstub-utils.c
index fb2c378460..edd23c1971 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -333,6 +333,18 @@ void kd_api_fill_memory(CPUState *cpu, PacketData *pd)
     }
 }
 
+void kd_api_query_memory(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_QUERY_MEMORY *mem = &pd->m64.u.QueryMemory;
+
+    mem->AddressSpace = DBGKD_QUERY_MEMORY_PROCESS;
+    mem->Flags = DBGKD_QUERY_MEMORY_READ |
+                 DBGKD_QUERY_MEMORY_WRITE |
+                 DBGKD_QUERY_MEMORY_EXECUTE;
+    mem->AddressSpace = ldl_p(&mem->AddressSpace);
+    mem->Flags = ldl_p(&mem->Flags);
+}
+
 void kd_api_unsupported(CPUState *cpu, PacketData *pd)
 {
     WINDBG_ERROR("Caught unimplemented api %s",
diff --git a/windbgstub.c b/windbgstub.c
index b348028dfd..36372c0ea5 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -220,6 +220,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_fill_memory(cpu, &ctx->data);
         break;
 
+    case DbgKdQueryMemoryApi:
+        kd_api_query_memory(cpu, &ctx->data);
+        break;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 44/45] windbg: added new api functions
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (42 preceding siblings ...)
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 43/45] windbg: implemented kd_api_query_memory Mihail Abakumov
@ 2017-11-21 14:11 ` Mihail Abakumov
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 45/45] windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex Mihail Abakumov
                   ` (3 subsequent siblings)
  47 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:11 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Added some definitions for new windbg.

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgkd.h |   21 ++++++++++++++++++++-
 1 file changed, 20 insertions(+), 1 deletion(-)

diff --git a/include/exec/windbgkd.h b/include/exec/windbgkd.h
index 40a23f8cd0..e5b9bb3b37 100755
--- a/include/exec/windbgkd.h
+++ b/include/exec/windbgkd.h
@@ -112,7 +112,10 @@
 #define DbgKdFillMemoryApi                  0x0000315b
 #define DbgKdQueryMemoryApi                 0x0000315c
 #define DbgKdSwitchPartition                0x0000315d
-#define DbgKdMaximumManipulate              0x0000315e
+#define DbgKdWriteCustomBreakpointApi       0x0000315e
+#define DbgKdGetContextExApi                0x0000315f
+#define DbgKdSetContextExApi                0x00003160
+#define DbgKdMaximumManipulate              0x00003161
 
 /*
  * Debug I/O Types
@@ -723,6 +726,20 @@ typedef struct _DBGKD_SWITCH_PARTITION {
     uint32_t Partition;
 } DBGKD_SWITCH_PARTITION;
 
+typedef struct _DBGKD_CONTEXT_EX {
+   uint32_t Offset;
+   uint32_t ByteCount;
+   uint32_t BytesCopied;
+} DBGKD_CONTEXT_EX, *PDBGKD_CONTEXT_EX;
+
+typedef struct _DBGKD_WRITE_CUSTOM_BREAKPOINT {
+   uint64_t BreakPointAddress;
+   uint64_t BreakPointInstruction;
+   uint32_t BreakPointHandle;
+   uint16_t BreakPointInstructionSize;
+   uint16_t BreakPointInstructionAlignment;
+} DBGKD_WRITE_CUSTOM_BREAKPOINT, *PDBGKD_WRITE_CUSTOM_BREAKPOINT;
+
 /*
  * DBGKD Structure for Manipulate
  */
@@ -787,6 +804,8 @@ typedef struct _DBGKD_MANIPULATE_STATE64 {
         DBGKD_FILL_MEMORY FillMemory;
         DBGKD_QUERY_MEMORY QueryMemory;
         DBGKD_SWITCH_PARTITION SwitchPartition;
+        DBGKD_WRITE_CUSTOM_BREAKPOINT WriteCustomBreakpoint;
+        DBGKD_CONTEXT_EX ContextEx;
     } u;
 } DBGKD_MANIPULATE_STATE64, *PDBGKD_MANIPULATE_STATE64;
 

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* [Qemu-devel] [PATCH v3 45/45] windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (43 preceding siblings ...)
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 44/45] windbg: added new api functions Mihail Abakumov
@ 2017-11-21 14:11 ` Mihail Abakumov
  2017-11-28 12:44   ` Ladi Prosek
  2017-11-21 15:00 ` [Qemu-devel] [PATCH v3 00/45] Windbg supporting no-reply
                   ` (2 subsequent siblings)
  47 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-11-21 14:11 UTC (permalink / raw)
  To: qemu-devel; +Cc: sw, lprosek, dovgaluk, rkagan, pbonzini, den

Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
---
 include/exec/windbgstub-utils.h |    2 +
 target/i386/windbgstub.c        |  129 ++++++++++++++++++++++++++++-----------
 windbgstub.c                    |   14 +++-
 3 files changed, 105 insertions(+), 40 deletions(-)

diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index fa1ebbb6d2..ea6828b973 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -106,6 +106,8 @@ void kd_api_search_memory(CPUState *cpu, PacketData *pd);
 void kd_api_fill_memory(CPUState *cpu, PacketData *pd);
 void kd_api_unsupported(CPUState *cpu, PacketData *pd);
 void kd_api_query_memory(CPUState *cpu, PacketData *pd);
+void kd_api_get_context_ex(CPUState *cpu, PacketData *pd);
+void kd_api_set_context_ex(CPUState *cpu, PacketData *pd);
 
 SizedBuf kd_gen_exception_sc(CPUState *cpu);
 SizedBuf kd_gen_load_symbols_sc(CPUState *cpu);
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 735b2edd5f..aca4bfedec 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -899,6 +899,52 @@ static int windbg_write_ks_regs(CPUState *cpu, uint8_t *buf, int buf_size,
     return 0;
 }
 
+static int windbg_rw_context_ex(CPUState *cpu, uint8_t *buf, int buf_size,
+                                int offset, int len, bool is_read)
+{
+    uint32_t context_len;
+    uint32_t ks_regs_len;
+    int err = -1;
+
+    if (offset < sizeof(CPU_KPROCESSOR_STATE)) {
+        len = MIN(len, sizeof(CPU_KPROCESSOR_STATE) - offset);
+
+        context_len = MAX(0, (int) (sizeof(CPU_CONTEXT) - offset));
+        ks_regs_len = len - context_len;
+
+        if (context_len > 0) {
+            if (is_read) {
+                err = windbg_read_context(cpu, buf, context_len, offset,
+                                          context_len);
+            } else {
+                err = windbg_write_context(cpu, buf, context_len, offset,
+                                           context_len);
+            }
+
+            if (err) {
+                return err;
+            }
+        }
+
+        if (ks_regs_len > 0) {
+            offset += context_len - sizeof(CPU_CONTEXT);
+            if (is_read) {
+                err = windbg_read_ks_regs(cpu, buf + context_len, ks_regs_len,
+                                          offset, ks_regs_len);
+            } else {
+                err = windbg_write_ks_regs(cpu, buf + context_len, ks_regs_len,
+                                           offset, ks_regs_len);
+            }
+
+            if (err) {
+                return err;
+            }
+        }
+    }
+
+    return err;
+}
+
 void kd_api_get_context(CPUState *cpu, PacketData *pd)
 {
     int err;
@@ -930,31 +976,14 @@ void kd_api_read_control_space(CPUState *cpu, PacketData *pd)
 {
     DBGKD_READ_MEMORY64 *mem = &pd->m64.u.ReadMemory;
     uint32_t len;
-    uint32_t context_len;
-    uint32_t ks_regs_len;
     target_ulong addr;
-    int err = -1;
+    int err;
 
     len = MIN(ldl_p(&mem->TransferCount),
               PACKET_MAX_SIZE - sizeof(DBGKD_MANIPULATE_STATE64));
     addr = ldtul_p(&mem->TargetBaseAddress);
 
-    if (addr < sizeof(CPU_KPROCESSOR_STATE)) {
-        len = MIN(len, sizeof(CPU_KPROCESSOR_STATE) - addr);
-
-        context_len = MAX(0, (int) (sizeof(CPU_CONTEXT) - addr));
-        ks_regs_len = len - context_len;
-
-        if (context_len > 0) {
-            err = windbg_read_context(cpu, pd->extra, context_len, addr,
-                                      context_len);
-        }
-        if (ks_regs_len > 0) {
-            addr = addr - sizeof(CPU_CONTEXT) + context_len;
-            err = windbg_read_ks_regs(cpu, pd->extra + context_len,
-                                      ks_regs_len, addr, ks_regs_len);
-        }
-    }
+    err = windbg_rw_context_ex(cpu, pd->extra, len, addr, len, true);
 
     if (err) {
         len = 0;
@@ -969,38 +998,64 @@ void kd_api_write_control_space(CPUState *cpu, PacketData *pd)
 {
     DBGKD_WRITE_MEMORY64 *mem = &pd->m64.u.WriteMemory;
     uint32_t len;
-    uint32_t context_len;
-    uint32_t ks_regs_len;
     target_ulong addr;
-    int err = -1;
+    int err;
 
     len = MIN(ldl_p(&mem->TransferCount), pd->extra_size);
     addr = ldtul_p(&mem->TargetBaseAddress);
 
-    if (addr < sizeof(CPU_KPROCESSOR_STATE)) {
-        len = MIN(len, sizeof(CPU_KPROCESSOR_STATE) - addr);
+    err = windbg_rw_context_ex(cpu, pd->extra, len, addr, len, false);
 
-        context_len = MAX(0, (int) (sizeof(CPU_CONTEXT) - addr));
-        ks_regs_len = len - context_len;
+    if (err) {
+        len = 0;
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
+    }
 
-        if (context_len > 0) {
-            err = windbg_write_context(cpu, pd->extra, context_len, addr,
-                                       context_len);
-        }
-        if (ks_regs_len > 0) {
-            addr = addr - sizeof(CPU_CONTEXT) + context_len;
-            err = windbg_write_ks_regs(cpu, pd->extra + context_len,
-                                       ks_regs_len, addr, ks_regs_len);
-        }
+    pd->extra_size = 0;
+    stl_p(&mem->ActualBytesWritten, len);
+}
+
+void kd_api_get_context_ex(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_CONTEXT_EX *ctx = &pd->m64.u.ContextEx;
+    uint32_t offset;
+    uint32_t len;
+    int err;
+
+    len = MIN(ldl_p(&ctx->ByteCount),
+              PACKET_MAX_SIZE - sizeof(DBGKD_MANIPULATE_STATE64));
+    offset = ldl_p(&ctx->Offset);
+
+    err = windbg_rw_context_ex(cpu, pd->extra, len, offset, len, true);
+
+    if (err) {
+        len = 0;
+        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
     }
 
+    pd->extra_size = len;
+    stl_p(&ctx->BytesCopied, len);
+}
+
+void kd_api_set_context_ex(CPUState *cpu, PacketData *pd)
+{
+    DBGKD_CONTEXT_EX *ctx = &pd->m64.u.ContextEx;
+    uint32_t offset;
+    uint32_t len;
+    int err;
+
+    len = MIN(ldl_p(&ctx->ByteCount), pd->extra_size);
+    offset = ldl_p(&ctx->Offset);
+
+    err = windbg_rw_context_ex(cpu, pd->extra, len, offset, len, false);
+
     if (err) {
-        mem->ActualBytesWritten = 0;
+        len = 0;
         pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
     }
 
     pd->extra_size = 0;
-    stl_p(&mem->ActualBytesWritten, len);
+    stl_p(&ctx->BytesCopied, len);
 }
 
 void kd_api_read_msr(CPUState *cpu, PacketData *pd)
diff --git a/windbgstub.c b/windbgstub.c
index 36372c0ea5..3bcf6a8cbb 100755
--- a/windbgstub.c
+++ b/windbgstub.c
@@ -224,6 +224,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
         kd_api_query_memory(cpu, &ctx->data);
         break;
 
+    case DbgKdGetContextExApi:
+        kd_api_get_context_ex(cpu, &ctx->data);
+        break;
+
+    case DbgKdSetContextExApi:
+        kd_api_set_context_ex(cpu, &ctx->data);
+        break;
+
     default:
         kd_api_unsupported(cpu, &ctx->data);
         break;
@@ -262,12 +270,12 @@ static void windbg_process_control_packet(ParsingContext *ctx)
 
     case PACKET_TYPE_KD_RESET:
     {
-        SizedBuf buf = kd_gen_load_symbols_sc(qemu_get_cpu(0));
+        windbg_send_control_packet(ctx->packet.PacketType);
+        windbg_state->ctrl_packet_id = INITIAL_PACKET_ID;
 
+        SizedBuf buf = kd_gen_load_symbols_sc(qemu_get_cpu(0));
         windbg_send_data_packet(buf.data, buf.size,
                                 PACKET_TYPE_KD_STATE_CHANGE64);
-        windbg_send_control_packet(ctx->packet.PacketType);
-        windbg_state->ctrl_packet_id = INITIAL_PACKET_ID;
         SBUF_FREE(buf);
         break;
     }

^ permalink raw reply related	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 00/45] Windbg supporting
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (44 preceding siblings ...)
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 45/45] windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex Mihail Abakumov
@ 2017-11-21 15:00 ` no-reply
  2017-11-21 15:05 ` no-reply
  2017-11-21 16:23 ` no-reply
  47 siblings, 0 replies; 70+ messages in thread
From: no-reply @ 2017-11-21 15:00 UTC (permalink / raw)
  To: mikhail.abakumov
  Cc: famz, qemu-devel, sw, lprosek, dovgaluk, rkagan, pbonzini, den

Hi,

This series failed build test on s390x host. Please find the details below.

Subject: [Qemu-devel] [PATCH v3 00/45] Windbg supporting
Type: series
Message-id: 151127322955.6888.16198535123422076171.stgit@Misha-PC.lan02.inno

=== TEST SCRIPT BEGIN ===
#!/bin/bash
# Testing script will be invoked under the git checkout with
# HEAD pointing to a commit that has the patches applied on top of "base"
# branch
set -e
echo "=== ENV ==="
env
echo "=== PACKAGES ==="
rpm -qa
echo "=== TEST BEGIN ==="
CC=$HOME/bin/cc
INSTALL=$PWD/install
BUILD=$PWD/build
echo -n "Using CC: "
realpath $CC
mkdir -p $BUILD $INSTALL
SRC=$PWD
cd $BUILD
$SRC/configure --cc=$CC --prefix=$INSTALL
make -j4
# XXX: we need reliable clean up
# make check -j4 V=1
make install
=== TEST SCRIPT END ===

Updating 3c8cf5a9c21ff8782164d1def7f44bd888713384
From https://github.com/patchew-project/qemu
 * [new tag]         patchew/151127322955.6888.16198535123422076171.stgit@Misha-PC.lan02.inno -> patchew/151127322955.6888.16198535123422076171.stgit@Misha-PC.lan02.inno
 * [new tag]         patchew/20171121142538.22072-1-berrange@redhat.com -> patchew/20171121142538.22072-1-berrange@redhat.com
Switched to a new branch 'test'
d362b89 windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex
18aff3d windbg: added new api functions
2bcb5c3 windbg: implemented kd_api_query_memory
5ec1f61 windbg: implemented kd_api_fill_memory
62f31d7 windbg: implemented kd_api_search_memory
271fa73 windbg: implemented kd_api_read_msr and kd_api_write_msr
3acac8e windbg: implemented kd_api_get_version
9de41ff windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
6b29ad1 windbg: implemented kd_api_read_io_space and kd_api_write_io_space
c5b8c6d windbg: implemented kd_api_continue
dd48382 windbg: debug exception subscribing
f39bcbc windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
09dca42 windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
623796d windbg: implemented windbg_set_dr7
736fc3d windbg: implemented windbg_set_dr
7fdef2c windbg: implemented windbg_set_sr
1a4d2ae windbg: implemented windbg_write_ks_regs
811bd2a windbg: implemented windbg_read_ks_regs
65fbd06 windbg: implemented windbg_write_context
58e16be windbg: implemented windbg_read_context
d537b5a windbg: implemented kd_api_read_control_space and kd_api_write_control_space
e97babd windbg: implemented kd_api_get_context and kd_api_set_context
9dbe11a windbg: kernel's structures
77b3eba windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
7aecc04 windbg: implemented windbg_process_manipulate_packet
2aa0acc windbg: implemented windbg_process_data_packet
2bf0bd9 windbg: implemented windbg_process_control_packet
75c0091 windbg: windbg_vm_stop
a8181bf windbg: generate LoadSymbolsStateChange
05f4ef3 windbg: generate ExceptionStateChange
bd46bf1 windbg: sized data buffer
2032fcb windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
eee56f5 windbg: handler of parsing context
a906b8b windbg: send data and control packets
7ba62b6 windbg: parsing data stream
dfc08cb windbg: structures for parsing data stream
7d75076 windbg: handler of fs/gs register
4ccf74e windbg: hook to wrmsr operation
696a5b8 windbg: added chardev
3dd2e38 windbg: added WindbgState
71cde42 windbg: added helper features
8802776 windbg: added '-windbg' option
65edc4e windbg: modified windbgkd.h
d2114ac windbg: added windbg's KD header file
8b0599d windbg: added empty windbgstub files

=== OUTPUT BEGIN ===
=== ENV ===
XDG_SESSION_ID=101459
SHELL=/bin/sh
USER=fam
PATCHEW=/home/fam/patchew/patchew-cli -s http://patchew.org --nodebug
PATH=/usr/bin:/bin
PWD=/var/tmp/patchew-tester-tmp-j1ms6ngb/src
LANG=en_US.UTF-8
HOME=/home/fam
SHLVL=2
LOGNAME=fam
DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/1012/bus
XDG_RUNTIME_DIR=/run/user/1012
_=/usr/bin/env
=== PACKAGES ===
gpg-pubkey-873529b8-54e386ff
xz-libs-5.2.2-2.fc24.s390x
libxshmfence-1.2-3.fc24.s390x
giflib-4.1.6-15.fc24.s390x
trousers-lib-0.3.13-6.fc24.s390x
ncurses-base-6.0-6.20160709.fc25.noarch
gmp-6.1.1-1.fc25.s390x
libidn-1.33-1.fc25.s390x
slang-2.3.0-7.fc25.s390x
pkgconfig-0.29.1-1.fc25.s390x
alsa-lib-1.1.1-2.fc25.s390x
yum-metadata-parser-1.1.4-17.fc25.s390x
python3-slip-dbus-0.6.4-4.fc25.noarch
python2-cssselect-0.9.2-1.fc25.noarch
createrepo_c-libs-0.10.0-6.fc25.s390x
initscripts-9.69-1.fc25.s390x
parted-3.2-21.fc25.s390x
flex-2.6.0-3.fc25.s390x
colord-libs-1.3.4-1.fc25.s390x
python-osbs-client-0.33-3.fc25.noarch
perl-Pod-Simple-3.35-1.fc25.noarch
python2-simplejson-3.10.0-1.fc25.s390x
brltty-5.4-2.fc25.s390x
librados2-10.2.4-2.fc25.s390x
tcp_wrappers-7.6-83.fc25.s390x
libcephfs_jni1-10.2.4-2.fc25.s390x
nettle-devel-3.3-1.fc25.s390x
bzip2-devel-1.0.6-21.fc25.s390x
libuuid-2.28.2-2.fc25.s390x
python3-dnf-1.1.10-6.fc25.noarch
texlive-kpathsea-doc-svn41139-33.fc25.1.noarch
openssh-7.4p1-4.fc25.s390x
texlive-kpathsea-bin-svn40473-33.20160520.fc25.1.s390x
texlive-graphics-svn41015-33.fc25.1.noarch
texlive-dvipdfmx-def-svn40328-33.fc25.1.noarch
texlive-mfware-svn40768-33.fc25.1.noarch
texlive-texlive-scripts-svn41433-33.fc25.1.noarch
texlive-euro-svn22191.1.1-33.fc25.1.noarch
texlive-etex-svn37057.0-33.fc25.1.noarch
texlive-iftex-svn29654.0.2-33.fc25.1.noarch
texlive-palatino-svn31835.0-33.fc25.1.noarch
texlive-texlive-docindex-svn41430-33.fc25.1.noarch
texlive-xunicode-svn30466.0.981-33.fc25.1.noarch
texlive-koma-script-svn41508-33.fc25.1.noarch
texlive-pst-grad-svn15878.1.06-33.fc25.1.noarch
texlive-pst-blur-svn15878.2.0-33.fc25.1.noarch
texlive-jknapltx-svn19440.0-33.fc25.1.noarch
texinfo-6.1-4.fc25.s390x
openssl-devel-1.0.2k-1.fc25.s390x
jansson-2.10-2.fc25.s390x
fedora-repos-25-4.noarch
perl-Errno-1.25-387.fc25.s390x
acl-2.2.52-13.fc25.s390x
systemd-pam-231-17.fc25.s390x
NetworkManager-libnm-1.4.4-5.fc25.s390x
poppler-0.45.0-5.fc25.s390x
ccache-3.3.4-1.fc25.s390x
valgrind-3.12.0-9.fc25.s390x
perl-open-1.10-387.fc25.noarch
libgcc-6.4.1-1.fc25.s390x
libsoup-2.56.1-1.fc25.s390x
libstdc++-devel-6.4.1-1.fc25.s390x
libobjc-6.4.1-1.fc25.s390x
python2-rpm-4.13.0.1-2.fc25.s390x
python2-gluster-3.10.5-1.fc25.s390x
rpm-build-4.13.0.1-2.fc25.s390x
glibc-static-2.24-10.fc25.s390x
lz4-1.8.0-1.fc25.s390x
xapian-core-libs-1.2.24-1.fc25.s390x
elfutils-libelf-devel-0.169-1.fc25.s390x
nss-softokn-3.32.0-1.2.fc25.s390x
pango-1.40.9-1.fc25.s390x
glibc-debuginfo-common-2.24-10.fc25.s390x
libaio-0.3.110-6.fc24.s390x
libfontenc-1.1.3-3.fc24.s390x
lzo-2.08-8.fc24.s390x
isl-0.14-5.fc24.s390x
libXau-1.0.8-6.fc24.s390x
linux-atm-libs-2.5.1-14.fc24.s390x
libXext-1.3.3-4.fc24.s390x
libXxf86vm-1.1.4-3.fc24.s390x
bison-3.0.4-4.fc24.s390x
perl-srpm-macros-1-20.fc25.noarch
gawk-4.1.3-8.fc25.s390x
libwayland-client-1.12.0-1.fc25.s390x
perl-Exporter-5.72-366.fc25.noarch
perl-version-0.99.17-1.fc25.s390x
fftw-libs-double-3.3.5-3.fc25.s390x
libssh2-1.8.0-1.fc25.s390x
ModemManager-glib-1.6.4-1.fc25.s390x
newt-python3-0.52.19-2.fc25.s390x
python-munch-2.0.4-3.fc25.noarch
python-bugzilla-1.2.2-4.fc25.noarch
libedit-3.1-16.20160618cvs.fc25.s390x
createrepo_c-0.10.0-6.fc25.s390x
device-mapper-multipath-libs-0.4.9-83.fc25.s390x
yum-3.4.3-510.fc25.noarch
mozjs17-17.0.0-16.fc25.s390x
libselinux-2.5-13.fc25.s390x
python2-pyparsing-2.1.10-1.fc25.noarch
cairo-gobject-1.14.8-1.fc25.s390x
xorg-x11-proto-devel-7.7-20.fc25.noarch
brlapi-0.6.5-2.fc25.s390x
librados-devel-10.2.4-2.fc25.s390x
libXinerama-devel-1.1.3-6.fc24.s390x
lua-posix-33.3.1-3.fc25.s390x
usbredir-devel-0.7.1-2.fc24.s390x
python3-dnf-plugins-core-0.1.21-5.fc25.noarch
texlive-pdftex-doc-svn41149-33.fc25.1.noarch
openssh-clients-7.4p1-4.fc25.s390x
iptables-1.6.0-3.fc25.s390x
texlive-texlive.infra-svn41280-33.fc25.1.noarch
texlive-graphics-cfg-svn40269-33.fc25.1.noarch
texlive-bibtex-svn40768-33.fc25.1.noarch
texlive-mfware-bin-svn40473-33.20160520.fc25.1.s390x
texlive-texlive-scripts-bin-svn29741.0-33.20160520.fc25.1.noarch
texlive-sauerj-svn15878.0-33.fc25.1.noarch
texlive-enctex-svn34957.0-33.fc25.1.noarch
texlive-ifetex-svn24853.1.2-33.fc25.1.noarch
texlive-ntgclass-svn15878.2.1a-33.fc25.1.noarch
texlive-tex-gyre-math-svn41264-33.fc25.1.noarch
texlive-bera-svn20031.0-33.fc25.1.noarch
texlive-ms-svn29849.0-33.fc25.1.noarch
texlive-pst-fill-svn15878.1.01-33.fc25.1.noarch
texlive-ctable-svn38672-33.fc25.1.noarch
texlive-extsizes-svn17263.1.4a-33.fc25.1.noarch
texlive-collection-latexrecommended-svn35765.0-33.20160520.fc25.1.noarch
perl-Filter-1.57-1.fc25.s390x
python2-rpm-macros-3-12.fc25.noarch
gdbm-1.13-1.fc25.s390x
libtasn1-4.12-1.fc25.s390x
fedora-release-25-2.noarch
gdb-headless-7.12.1-48.fc25.s390x
perl-macros-5.24.2-387.fc25.s390x
pcre-devel-8.41-1.fc25.s390x
libX11-1.6.5-1.fc25.s390x
coreutils-8.25-17.fc25.s390x
python2-openidc-client-0-3.20170523git77cb3ee.fc25.noarch
systemtap-client-3.1-5.fc25.s390x
firewalld-0.4.4.5-1.fc25.noarch
glibc-2.24-10.fc25.s390x
libglvnd-egl-0.2.999-24.20170818git8d4d03f.fc25.s390x
libkadm5-1.14.4-8.fc25.s390x
glusterfs-fuse-3.10.5-1.fc25.s390x
libgfortran-6.4.1-1.fc25.s390x
python3-rpm-4.13.0.1-2.fc25.s390x
glusterfs-extra-xlators-3.10.5-1.fc25.s390x
dracut-config-rescue-046-2.git20170811.fc25.s390x
python2-sphinx-theme-alabaster-0.7.9-1.fc25.noarch
elfutils-devel-0.169-1.fc25.s390x
nss-3.32.0-1.1.fc25.s390x
pango-devel-1.40.9-1.fc25.s390x
glibc-debuginfo-2.24-10.fc25.s390x
gpg-pubkey-efe550f5-5220ba41
gpg-pubkey-81b46521-55b3ca9a
filesystem-3.2-37.fc24.s390x
libffi-3.1-9.fc24.s390x
keyutils-libs-1.5.9-8.fc24.s390x
libnfnetlink-1.0.1-8.fc24.s390x
libtheora-1.1.1-14.fc24.s390x
xml-common-0.6.3-44.fc24.noarch
autoconf-2.69-22.fc24.noarch
libXt-1.1.5-3.fc24.s390x
kbd-legacy-2.0.3-3.fc24.noarch
ghostscript-fonts-5.50-35.fc24.noarch
libXevie-1.0.3-11.fc24.s390x
libcap-2.25-2.fc25.s390x
mpfr-3.1.5-1.fc25.s390x
perl-Carp-1.40-365.fc25.noarch
libmnl-1.0.4-1.fc25.s390x
perl-Unicode-EastAsianWidth-1.33-8.fc25.noarch
libwayland-cursor-1.12.0-1.fc25.s390x
python-krbV-1.0.90-12.fc25.s390x
python2-urllib3-1.15.1-3.fc25.noarch
fipscheck-1.4.1-11.fc25.s390x
libndp-1.6-1.fc25.s390x
gnupg2-2.1.13-2.fc25.s390x
libXfixes-5.0.3-1.fc25.s390x
adwaita-icon-theme-3.22.0-1.fc25.noarch
dconf-0.26.0-1.fc25.s390x
ncurses-devel-6.0-6.20160709.fc25.s390x
dejagnu-1.6-1.fc25.noarch
device-mapper-1.02.136-3.fc25.s390x
libevent-2.0.22-1.fc25.s390x
atk-devel-2.22.0-1.fc25.s390x
libev-4.24-1.fc25.s390x
xorg-x11-fonts-Type1-7.5-16.fc24.noarch
brlapi-devel-0.6.5-2.fc25.s390x
pulseaudio-libs-10.0-2.fc25.s390x
glib2-2.50.3-1.fc25.s390x
dnf-1.1.10-6.fc25.noarch
texlive-metafont-bin-svn40987-33.20160520.fc25.1.s390x
texlive-xkeyval-svn35741.2.7a-33.fc25.1.noarch
texlive-euler-svn17261.2.5-33.fc25.1.noarch
texlive-mptopdf-svn41282-33.fc25.1.noarch
texlive-wasy-svn35831.0-33.fc25.1.noarch
texlive-avantgar-svn31835.0-33.fc25.1.noarch
texlive-eurosym-svn17265.1.4_subrfix-33.fc25.1.noarch
texlive-knuth-lib-svn35820.0-33.fc25.1.noarch
texlive-parallel-svn15878.0-33.fc25.1.noarch
texlive-texlive-msg-translations-svn41431-33.fc25.1.noarch
texlive-latex-svn40218-33.fc25.1.noarch
texlive-lualatex-math-svn40621-33.fc25.1.noarch
texlive-auto-pst-pdf-svn23723.0.6-33.fc25.1.noarch
texlive-powerdot-svn38984-33.fc25.1.noarch
texlive-wasysym-svn15878.2.0-33.fc25.1.noarch
ImageMagick-libs-6.9.3.0-6.fc25.s390x
geoclue2-2.4.5-1.fc25.s390x
perl-IO-Socket-IP-0.39-1.fc25.noarch
python2-pyasn1-0.2.3-1.fc25.noarch
at-spi2-core-devel-2.22.1-1.fc25.s390x
libacl-2.2.52-13.fc25.s390x
perl-libs-5.24.2-387.fc25.s390x
mesa-libglapi-17.0.5-3.fc25.s390x
python3-rpmconf-1.0.19-1.fc25.noarch
pcre-utf32-8.41-1.fc25.s390x
libX11-common-1.6.5-1.fc25.noarch
coreutils-common-8.25-17.fc25.s390x
mesa-libEGL-17.0.5-3.fc25.s390x
systemtap-runtime-3.1-5.fc25.s390x
NetworkManager-glib-1.4.4-5.fc25.s390x
audit-2.7.7-1.fc25.s390x
glibc-all-langpacks-2.24-10.fc25.s390x
libglvnd-glx-0.2.999-24.20170818git8d4d03f.fc25.s390x
glusterfs-api-3.10.5-1.fc25.s390x
libepoxy-devel-1.4.3-1.fc25.1.s390x
gtk3-3.22.17-2.fc25.s390x
rpm-4.13.0.1-2.fc25.s390x
net-snmp-agent-libs-5.7.3-15.fc25.s390x
pcre2-devel-10.23-9.fc25.s390x
subversion-1.9.7-1.fc25.s390x
libsndfile-1.0.28-6.fc25.s390x
lasi-1.1.2-6.fc24.s390x
python2-snowballstemmer-1.2.1-1.fc25.noarch
nss-util-devel-3.32.0-1.0.fc25.s390x
vim-common-8.0.1030-1.fc25.s390x
gd-2.2.5-1.fc25.s390x
gpg-pubkey-34ec9cba-54e38751
gpg-pubkey-030d5aed-55b577f0
basesystem-11-2.fc24.noarch
libmpc-1.0.2-5.fc24.s390x
libunistring-0.9.4-3.fc24.s390x
libmodman-2.0.1-12.fc24.s390x
lsscsi-0.28-3.fc24.s390x
kbd-misc-2.0.3-3.fc24.noarch
kmod-23-1.fc25.s390x
newt-0.52.19-2.fc25.s390x
perl-Text-Unidecode-1.27-3.fc25.noarch
plymouth-core-libs-0.9.3-0.6.20160620git0e65b86c.fc25.s390x
which-2.21-1.fc25.s390x
python3-slip-0.6.4-4.fc25.noarch
python3-systemd-232-1.fc25.s390x
python-lockfile-0.11.0-4.fc25.noarch
python2-requests-2.10.0-4.fc25.noarch
libnghttp2-1.13.0-2.fc25.s390x
python-urlgrabber-3.10.1-9.fc25.noarch
iputils-20161105-1.fc25.s390x
rest-0.8.0-1.fc25.s390x
adwaita-cursor-theme-3.22.0-1.fc25.noarch
authconfig-6.2.10-14.fc25.s390x
automake-1.15-7.fc25.noarch
shared-mime-info-1.8-1.fc25.s390x
pigz-2.3.4-1.fc25.s390x
device-mapper-libs-1.02.136-3.fc25.s390x
dnsmasq-2.76-2.fc25.s390x
fedora-packager-0.6.0.1-1.fc25.noarch
libwebp-0.5.2-1.fc25.s390x
boost-system-1.60.0-10.fc25.s390x
libasyncns-0.8-10.fc24.s390x
libXau-devel-1.0.8-6.fc24.s390x
libverto-libev-0.2.6-6.fc24.s390x
python3-html5lib-0.999-9.fc25.noarch
ttmkfdir-3.0.9-48.fc24.s390x
pulseaudio-libs-glib2-10.0-2.fc25.s390x
texlive-lib-2016-33.20160520.fc25.s390x
libXi-devel-1.7.9-1.fc25.s390x
python3-distro-1.0.3-1.fc25.noarch
texlive-texlive-common-doc-svn40682-33.fc25.1.noarch
packagedb-cli-2.14.1-1.fc25.noarch
texlive-metafont-svn40793-33.fc25.1.noarch
texlive-tools-svn40934-33.fc25.1.noarch
texlive-enumitem-svn24146.3.5.2-33.fc25.1.noarch
texlive-mptopdf-bin-svn18674.0-33.20160520.fc25.1.noarch
texlive-underscore-svn18261.0-33.fc25.1.noarch
texlive-anysize-svn15878.0-33.fc25.1.noarch
texlive-euenc-svn19795.0.1h-33.fc25.1.noarch
texlive-kastrup-svn15878.0-33.fc25.1.noarch
texlive-paralist-svn39247-33.fc25.1.noarch
texlive-texlive-en-svn41185-33.fc25.1.noarch
texlive-tipa-svn29349.1.3-33.fc25.1.noarch
texlive-currfile-svn40725-33.fc25.1.noarch
texlive-pst-node-svn40743-33.fc25.1.noarch
texlive-pst-slpe-svn24391.1.31-33.fc25.1.noarch
texlive-typehtml-svn17134.0-33.fc25.1.noarch
SDL2-devel-2.0.5-3.fc25.s390x
libcroco-0.6.11-3.fc25.s390x
bluez-libs-devel-5.44-1.fc25.s390x
firewalld-filesystem-0.4.4.5-1.fc25.noarch
pcre-cpp-8.41-1.fc25.s390x
python3-firewall-0.4.4.5-1.fc25.noarch
freetype-devel-2.6.5-9.fc25.s390x
pcre-utf16-8.41-1.fc25.s390x
linux-firmware-20170605-74.git37857004.fc25.noarch
kernel-modules-4.11.10-200.fc25.s390x
systemtap-devel-3.1-5.fc25.s390x
polkit-0.113-8.fc25.s390x
perl-SelfLoader-1.23-387.fc25.noarch
libdb-utils-5.3.28-24.fc25.s390x
glibc-common-2.24-10.fc25.s390x
libglvnd-0.2.999-24.20170818git8d4d03f.fc25.s390x
webkitgtk4-2.16.6-1.fc25.s390x
rpm-build-libs-4.13.0.1-2.fc25.s390x
libglvnd-core-devel-0.2.999-24.20170818git8d4d03f.fc25.s390x
rpm-devel-4.13.0.1-2.fc25.s390x
kernel-4.12.9-200.fc25.s390x
libtool-ltdl-2.4.6-14.fc25.s390x
gts-0.7.6-29.20121130.fc24.s390x
python2-imagesize-0.7.1-2.fc25.noarch
nss-softokn-freebl-3.32.0-1.2.fc25.s390x
selinux-policy-3.13.1-225.22.fc25.noarch
kernel-devel-4.12.11-200.fc25.s390x
fontpackages-filesystem-1.44-17.fc24.noarch
groff-base-1.22.3-8.fc24.s390x
ilmbase-2.2.0-5.fc24.s390x
OpenEXR-libs-2.2.0-5.fc24.s390x
hesiod-3.2.1-6.fc24.s390x
sysfsutils-2.1.0-19.fc24.s390x
ocaml-srpm-macros-2-4.fc24.noarch
mailx-12.5-19.fc24.s390x
ncurses-libs-6.0-6.20160709.fc25.s390x
ipset-libs-6.29-1.fc25.s390x
gmp-devel-6.1.1-1.fc25.s390x
python-pip-8.1.2-2.fc25.noarch
harfbuzz-1.3.2-1.fc25.s390x
python2-iniparse-0.4-20.fc25.noarch
python3-iniparse-0.4-20.fc25.noarch
python3-kickstart-2.32-1.fc25.noarch
perl-Net-SSLeay-1.78-1.fc25.s390x
drpm-0.3.0-3.fc25.s390x
glib-networking-2.50.0-1.fc25.s390x
webkitgtk3-2.4.11-3.fc25.s390x
libXaw-1.0.13-4.fc25.s390x
xorg-x11-font-utils-7.5-32.fc25.s390x
hardlink-1.1-1.fc25.s390x
libcom_err-1.43.3-1.fc25.s390x
python2-dateutil-2.6.0-1.fc25.noarch
libXpm-3.5.12-1.fc25.s390x
poppler-data-0.4.7-6.fc25.noarch
librbd1-10.2.4-2.fc25.s390x
perl-Digest-MD5-2.55-2.fc25.s390x
wayland-protocols-devel-1.7-1.fc25.noarch
texi2html-5.0-4.fc24.noarch
libxkbcommon-0.7.1-1.fc25.s390x
libuuid-devel-2.28.2-2.fc25.s390x
libcacard-2.5.3-1.fc25.s390x
libwmf-lite-0.2.8.4-50.fc25.s390x
texlive-tetex-svn41059-33.fc25.1.noarch
texlive-thumbpdf-svn34621.3.16-33.fc25.1.noarch
texlive-carlisle-svn18258.0-33.fc25.1.noarch
texlive-makeindex-bin-svn40473-33.20160520.fc25.1.s390x
texlive-pdftex-svn41149-33.fc25.1.noarch
texlive-csquotes-svn39538-33.fc25.1.noarch
texlive-courier-svn35058.0-33.fc25.1.noarch
texlive-helvetic-svn31835.0-33.fc25.1.noarch
texlive-mfnfss-svn19410.0-33.fc25.1.noarch
texlive-sepnum-svn20186.2.0-33.fc25.1.noarch
texlive-utopia-svn15878.0-33.fc25.1.noarch
texlive-luatexbase-svn38550-33.fc25.1.noarch
texlive-pst-3d-svn17257.1.10-33.fc25.1.noarch
texlive-latex-bin-bin-svn14050.0-33.20160520.fc25.1.noarch
texlive-l3experimental-svn41163-33.fc25.1.noarch
net-tools-2.0-0.40.20160329git.fc25.s390x
perl-Pod-Perldoc-3.28-1.fc25.noarch
openssl-1.0.2k-1.fc25.s390x
man-pages-4.06-4.fc25.noarch
libxml2-2.9.4-2.fc25.s390x
python3-dateutil-2.6.0-1.fc25.noarch
perl-threads-shared-1.57-1.fc25.s390x
libnotify-0.7.7-1.fc25.s390x
unzip-6.0-32.fc25.s390x
python-beautifulsoup4-4.6.0-1.fc25.noarch
dhcp-client-4.3.5-3.fc25.s390x
python2-fedora-0.9.0-6.fc25.noarch
gdb-7.12.1-48.fc25.s390x
sqlite-libs-3.14.2-3.fc25.s390x
webkitgtk4-jsc-2.16.6-1.fc25.s390x
libgomp-6.4.1-1.fc25.s390x
p11-kit-trust-0.23.8-1.fc25.s390x
gdk-pixbuf2-devel-2.36.9-1.fc25.s390x
rpm-plugin-selinux-4.13.0.1-2.fc25.s390x
mariadb-common-10.1.25-1.fc25.s390x
dbus-devel-1.11.16-1.fc25.s390x
lz4-libs-1.8.0-1.fc25.s390x
python2-jinja2-2.8.1-1.fc25.noarch
system-python-libs-3.5.4-1.fc25.s390x
python2-rpkg-1.50-2.fc25.noarch
libsolv-0.6.29-1.fc25.s390x
gpg-pubkey-95a43f54-5284415a
dejavu-fonts-common-2.35-3.fc24.noarch
libSM-1.2.2-4.fc24.s390x
diffutils-3.3-13.fc24.s390x
libogg-1.3.2-5.fc24.s390x
hunspell-en-US-0.20140811.1-5.fc24.noarch
libdaemon-0.14-10.fc24.s390x
patch-2.7.5-3.fc24.s390x
libsysfs-2.1.0-19.fc24.s390x
procmail-3.22-39.fc24.s390x
libXdamage-1.1.4-8.fc24.s390x
libotf-0.9.13-7.fc24.s390x
urw-fonts-2.4-22.fc24.noarch
crontabs-1.11-12.20150630git.fc24.noarch
ppp-2.4.7-9.fc24.s390x
cyrus-sasl-2.1.26-26.2.fc24.s390x
zlib-devel-1.2.8-10.fc24.s390x
time-1.7-49.fc24.s390x
gpg-pubkey-fdb19c98-56fd6333
libcap-ng-0.7.8-1.fc25.s390x
binutils-2.26.1-1.fc25.s390x
lcms2-2.8-2.fc25.s390x
libcomps-0.1.7-5.fc25.s390x
perl-constant-1.33-367.fc25.noarch
perl-Data-Dumper-2.161-1.fc25.s390x
ipcalc-0.1.8-1.fc25.s390x
gmp-c++-6.1.1-1.fc25.s390x
fontconfig-2.12.1-1.fc25.s390x
enchant-1.6.0-14.fc25.s390x
pyliblzma-0.5.3-16.fc25.s390x
libsepol-devel-2.5-10.fc25.s390x
python3-ordered-set-2.0.0-4.fc25.noarch
python-ipaddress-1.0.16-3.fc25.noarch
python2-kerberos-1.2.5-1.fc25.s390x
python2-pysocks-1.5.6-5.fc25.noarch
fipscheck-lib-1.4.1-11.fc25.s390x
libatomic_ops-7.4.4-1.fc25.s390x
python2-pygpgme-0.3-18.fc25.s390x
orc-0.4.26-1.fc25.s390x
yum-utils-1.1.31-511.fc25.noarch
libXrender-0.9.10-1.fc25.s390x
libXrandr-1.5.1-1.fc25.s390x
go-srpm-macros-2-7.fc25.noarch
gnupg2-smime-2.1.13-2.fc25.s390x
guile-devel-2.0.13-1.fc25.s390x
uboot-tools-2016.09.01-2.fc25.s390x
pykickstart-2.32-1.fc25.noarch
python-bunch-1.0.1-9.fc25.noarch
perl-generators-1.10-1.fc25.noarch
perl-Mozilla-CA-20160104-3.fc25.noarch
bzip2-libs-1.0.6-21.fc25.s390x
libpng-1.6.27-1.fc25.s390x
desktop-file-utils-0.23-2.fc25.s390x
python2-cccolutils-1.4-1.fc25.s390x
python2-lxml-3.7.2-1.fc25.s390x
redhat-rpm-config-45-1.fc25.noarch
device-mapper-event-libs-1.02.136-3.fc25.s390x
lvm2-libs-2.02.167-3.fc25.s390x
libselinux-python-2.5-13.fc25.s390x
boost-thread-1.60.0-10.fc25.s390x
librbd-devel-10.2.4-2.fc25.s390x
libXcursor-devel-1.1.14-6.fc24.s390x
latex2html-2012-7.fc24.noarch
lksctp-tools-1.0.16-5.fc24.s390x
libfdt-1.4.2-1.fc25.s390x
libXft-devel-2.3.2-4.fc24.s390x
libattr-devel-2.4.47-16.fc24.s390x
libiscsi-devel-1.15.0-2.fc24.s390x
gettext-0.19.8.1-3.fc25.s390x
libjpeg-turbo-devel-1.5.1-0.fc25.s390x
pulseaudio-libs-devel-10.0-2.fc25.s390x
libmount-2.28.2-2.fc25.s390x
python3-decorator-4.0.11-1.fc25.noarch
tzdata-java-2017b-1.fc25.noarch
python-srpm-macros-3-12.fc25.noarch
libsmartcols-2.28.2-2.fc25.s390x
texlive-kpathsea-svn41139-33.fc25.1.noarch
texlive-amsmath-svn41561-33.fc25.1.noarch
texlive-thumbpdf-bin-svn6898.0-33.20160520.fc25.1.noarch
texlive-psnfss-svn33946.9.2a-33.fc25.1.noarch
texlive-subfig-svn15878.1.3-33.fc25.1.noarch
texlive-fancybox-svn18304.1.4-33.fc25.1.noarch
texlive-lua-alt-getopt-svn29349.0.7.0-33.fc25.1.noarch
texlive-natbib-svn20668.8.31b-33.fc25.1.noarch
texlive-pdftex-bin-svn40987-33.20160520.fc25.1.s390x
texlive-xdvi-svn40768-33.fc25.1.noarch
texlive-crop-svn15878.1.5-33.fc25.1.noarch
texlive-babel-english-svn30264.3.3p-33.fc25.1.noarch
texlive-cmextra-svn32831.0-33.fc25.1.noarch
texlive-fancyhdr-svn15878.3.1-33.fc25.1.noarch
texlive-luatex-svn40963-33.fc25.1.noarch
texlive-knuth-local-svn38627-33.fc25.1.noarch
texlive-mflogo-font-svn36898.1.002-33.fc25.1.noarch
texlive-parskip-svn19963.2.0-33.fc25.1.noarch
texlive-section-svn20180.0-33.fc25.1.noarch
texlive-textcase-svn15878.0-33.fc25.1.noarch
texlive-updmap-map-svn41159-33.fc25.1.noarch
texlive-attachfile-svn38830-33.fc25.1.noarch
libtiff-4.0.8-1.fc25.s390x
libdb-5.3.28-24.fc25.s390x
bind-license-9.10.5-2.P2.fc25.noarch
mesa-libGLES-17.0.5-3.fc25.s390x
python3-requests-kerberos-0.10.0-2.fc25.noarch
python3-pyOpenSSL-16.2.0-1.fc25.noarch
perl-threads-2.16-1.fc25.s390x
cryptsetup-libs-1.7.5-1.fc25.s390x
netpbm-10.79.00-1.fc25.s390x
qrencode-libs-3.4.4-1.fc25.s390x
gstreamer1-plugins-base-1.10.5-1.fc25.s390x
elfutils-default-yama-scope-0.169-1.fc25.noarch
systemd-udev-231-17.fc25.s390x
python2-koji-1.13.0-2.fc25.noarch
unbound-libs-1.6.3-1.fc25.s390x
openldap-2.4.44-11.fc25.s390x
koji-1.13.0-2.fc25.noarch
bind99-libs-9.9.10-2.P3.fc25.s390x
mesa-libGL-devel-17.0.5-3.fc25.s390x
graphite2-devel-1.3.10-1.fc25.s390x
systemtap-sdt-devel-3.1-5.fc25.s390x
iproute-tc-4.11.0-1.fc25.s390x
libarchive-3.2.2-2.fc25.s390x
publicsuffix-list-dafsa-20170424-1.fc25.noarch
expat-2.2.3-1.fc25.s390x
p11-kit-0.23.8-1.fc25.s390x
kernel-core-4.12.9-200.fc25.s390x
emacs-filesystem-25.2-3.fc25.noarch
ca-certificates-2017.2.16-1.0.fc25.noarch
librsvg2-2.40.18-1.fc25.s390x
gtk-update-icon-cache-3.22.17-2.fc25.s390x
libidn2-2.0.4-1.fc25.s390x
rpm-libs-4.13.0.1-2.fc25.s390x
mariadb-libs-10.1.25-1.fc25.s390x
java-1.8.0-openjdk-headless-1.8.0.144-5.b01.fc25.s390x
gcc-objc-6.4.1-1.fc25.s390x
p11-kit-devel-0.23.8-1.fc25.s390x
ethtool-4.11-1.fc25.s390x
python2-sssdconfig-1.15.3-1.fc25.noarch
xorg-x11-fonts-ISO8859-1-100dpi-7.5-16.fc24.noarch
lato-fonts-2.015-2.fc24.noarch
python-sphinx-locale-1.5.2-2.fc25.noarch
dpkg-1.17.27-1.fc25.s390x
gnutls-3.5.15-1.fc25.s390x
nss-softokn-freebl-devel-3.32.0-1.2.fc25.s390x
vim-filesystem-8.0.1030-1.fc25.s390x
gnutls-devel-3.5.15-1.fc25.s390x
kernel-headers-4.12.11-200.fc25.s390x
mock-1.4.6-1.fc25.noarch
texlive-luaotfload-svn40902-33.fc25.1.noarch
texlive-unicode-math-svn38462-33.fc25.1.noarch
texlive-fancyvrb-svn18492.2.8-33.fc25.1.noarch
texlive-pst-pdf-bin-svn7838.0-33.20160520.fc25.1.noarch
texlive-amscls-svn36804.0-33.fc25.1.noarch
texlive-ltxmisc-svn21927.0-33.fc25.1.noarch
texlive-breqn-svn38099.0.98d-33.fc25.1.noarch
texlive-xetex-def-svn40327-33.fc25.1.noarch
openssh-server-7.4p1-4.fc25.s390x
sendmail-8.15.2-8.fc25.s390x
tzdata-2017b-1.fc25.noarch
hunspell-1.4.1-2.fc25.s390x
gpg-pubkey-8e1431d5-53bcbac7
zlib-1.2.8-10.fc24.s390x
sed-4.2.2-15.fc24.s390x
psmisc-22.21-8.fc24.s390x
gpm-libs-1.20.7-9.fc24.s390x
zip-3.0-16.fc24.s390x
libyubikey-1.13-2.fc24.s390x
sg3_utils-libs-1.41-3.fc24.s390x
polkit-pkla-compat-0.1-7.fc24.s390x
passwd-0.79-8.fc24.s390x
trousers-0.3.13-6.fc24.s390x
grubby-8.40-3.fc24.s390x
rootfiles-8.1-19.fc24.noarch
nettle-3.3-1.fc25.s390x
libksba-1.3.5-1.fc25.s390x
perl-Text-ParseWords-3.30-365.fc25.noarch
perl-PathTools-3.63-366.fc25.s390x
perl-File-Temp-0.23.04-365.fc25.noarch
fuse-libs-2.9.7-1.fc25.s390x
perl-Pod-Escapes-1.07-365.fc25.noarch
perl-Term-ANSIColor-4.05-2.fc25.noarch
perl-URI-1.71-5.fc25.noarch
libXfont-1.5.2-1.fc25.s390x
python-six-1.10.0-3.fc25.noarch
dbus-glib-0.108-1.fc25.s390x
gobject-introspection-1.50.0-1.fc25.s390x
libpwquality-1.3.0-6.fc25.s390x
python-gobject-base-3.22.0-1.fc25.s390x
python-html5lib-0.999-9.fc25.noarch
python3-dbus-1.2.4-2.fc25.s390x
python3-chardet-2.3.0-1.fc25.noarch
python3-urllib3-1.15.1-3.fc25.noarch
python-offtrac-0.1.0-7.fc25.noarch
python2-cryptography-1.5.3-3.fc25.s390x
python2-requests-kerberos-0.10.0-2.fc25.noarch
libserf-1.3.9-1.fc25.s390x
libdatrie-0.2.9-3.fc25.s390x
s390utils-base-1.36.0-1.fc25.s390x
kpartx-0.4.9-83.fc25.s390x
s390utils-cpuplugd-1.36.0-1.fc25.s390x
s390utils-osasnmpd-1.36.0-1.fc25.s390x
python-dnf-plugins-extras-common-0.0.12-4.fc25.noarch
fpc-srpm-macros-1.0-1.fc25.noarch
libuser-0.62-4.fc25.s390x
man-db-2.7.5-3.fc25.s390x
python-systemd-doc-232-1.fc25.s390x
bodhi-client-0.9.12.2-6.fc25.noarch
cairo-1.14.8-1.fc25.s390x
cracklib-dicts-2.9.6-4.fc25.s390x
libselinux-python3-2.5-13.fc25.s390x
python2-enchant-1.6.8-1.fc25.noarch
boost-iostreams-1.60.0-10.fc25.s390x
userspace-rcu-0.9.2-2.fc25.s390x
libXext-devel-1.3.3-4.fc24.s390x
libXrandr-devel-1.5.1-1.fc25.s390x
python3-lxml-3.7.2-1.fc25.s390x
libiscsi-1.15.0-2.fc24.s390x
fontconfig-devel-2.12.1-1.fc25.s390x
libfdt-devel-1.4.2-1.fc25.s390x
ceph-devel-compat-10.2.4-2.fc25.s390x
zlib-static-1.2.8-10.fc24.s390x
chrpath-0.16-3.fc24.s390x
info-6.1-4.fc25.s390x
iptables-libs-1.6.0-3.fc25.s390x
libfdisk-2.28.2-2.fc25.s390x
dnf-plugins-core-0.1.21-5.fc25.noarch
perl-Storable-2.56-368.fc25.s390x
python2-decorator-4.0.11-1.fc25.noarch
libnetfilter_conntrack-1.0.6-2.fc25.s390x
texlive-texlive.infra-bin-svn40312-33.20160520.fc25.1.s390x
texlive-ifluatex-svn41346-33.fc25.1.noarch
texlive-fp-svn15878.0-33.fc25.1.noarch
texlive-latex-fonts-svn28888.0-33.fc25.1.noarch
texlive-bibtex-bin-svn40473-33.20160520.fc25.1.s390x
texlive-glyphlist-svn28576.0-33.fc25.1.noarch
texlive-marvosym-svn29349.2.2a-33.fc25.1.noarch
texlive-tex-bin-svn40987-33.20160520.fc25.1.s390x
texlive-texconfig-svn40768-33.fc25.1.noarch
texlive-wasy2-ps-svn35830.0-33.fc25.1.noarch
texlive-psfrag-svn15878.3.04-33.fc25.1.noarch
texlive-charter-svn15878.0-33.fc25.1.noarch
texlive-ec-svn25033.1.0-33.fc25.1.noarch
texlive-lineno-svn21442.4.41-33.fc25.1.noarch
texlive-hyphen-base-svn41138-33.fc25.1.noarch
texlive-manfnt-font-svn35799.0-33.fc25.1.noarch
texlive-ncntrsbk-svn31835.0-33.fc25.1.noarch
texlive-pst-math-svn34786.0.63-33.fc25.1.noarch
texlive-symbol-svn31835.0-33.fc25.1.noarch
texlive-environ-svn33821.0.3-33.fc25.1.noarch
texlive-algorithms-svn38085.0.1-33.fc25.1.noarch
python3-hawkey-0.6.4-3.fc25.s390x
freetype-2.6.5-9.fc25.s390x
mesa-libwayland-egl-17.0.5-3.fc25.s390x
libicu-57.1-5.fc25.s390x
libnl3-cli-3.2.29-3.fc25.s390x
cups-libs-2.2.0-9.fc25.s390x
bind-libs-lite-9.10.5-2.P2.fc25.s390x
python3-kerberos-1.2.5-1.fc25.s390x
python3-cryptography-1.5.3-3.fc25.s390x
perl-IO-1.36-387.fc25.s390x
dhcp-libs-4.3.5-3.fc25.s390x
rsync-3.1.2-4.fc25.s390x
make-4.1-6.fc25.s390x
quota-4.03-8.fc25.s390x
libX11-devel-1.6.5-1.fc25.s390x
ghostscript-9.20-9.fc25.s390x
rpcbind-0.2.4-6.rc2.fc25.s390x
pyOpenSSL-16.2.0-1.fc25.noarch
python3-pycurl-7.43.0-6.fc25.s390x
bind99-license-9.9.10-2.P3.fc25.noarch
python-firewall-0.4.4.5-1.fc25.noarch
netpbm-progs-10.79.00-1.fc25.s390x
wget-1.18-3.fc25.s390x
libsemanage-2.5-9.fc25.s390x
telnet-0.17-68.fc25.s390x
gdk-pixbuf2-2.36.9-1.fc25.s390x
dbus-libs-1.11.16-1.fc25.s390x
glusterfs-client-xlators-3.10.5-1.fc25.s390x
libepoxy-1.4.3-1.fc25.1.s390x
dracut-046-2.git20170811.fc25.s390x
net-snmp-libs-5.7.3-15.fc25.s390x
libgo-devel-6.4.1-1.fc25.s390x
libglvnd-opengl-0.2.999-24.20170818git8d4d03f.fc25.s390x
sqlite-devel-3.14.2-3.fc25.s390x
cpp-6.4.1-1.fc25.s390x
git-2.9.5-1.fc25.s390x
pcre2-10.23-9.fc25.s390x
python2-GitPython-2.1.5-1.fc25.noarch
glusterfs-devel-3.10.5-1.fc25.s390x
net-snmp-5.7.3-15.fc25.s390x
rpm-plugin-systemd-inhibit-4.13.0.1-2.fc25.s390x
emacs-25.2-3.fc25.s390x
libstdc++-static-6.4.1-1.fc25.s390x
expat-devel-2.2.3-1.fc25.s390x
perl-Time-HiRes-1.9744-1.fc25.s390x
fontawesome-fonts-4.7.0-1.fc25.noarch
python-markupsafe-0.23-10.fc25.s390x
pytz-2016.6.1-1.fc25.noarch
python2-sphinx-1.5.2-2.fc25.noarch
nss-util-3.32.0-1.0.fc25.s390x
nss-sysinit-3.32.0-1.1.fc25.s390x
python3-3.5.4-1.fc25.s390x
selinux-policy-targeted-3.13.1-225.22.fc25.noarch
vim-minimal-8.0.1030-1.fc25.s390x
texlive-ifplatform-svn21156.0.4-33.fc25.1.noarch
texlive-eso-pic-svn37925.2.0g-33.fc25.1.noarch
texlive-xcolor-svn41044-33.fc25.1.noarch
texlive-pst-eps-svn15878.1.0-33.fc25.1.noarch
texlive-pst-text-svn15878.1.00-33.fc25.1.noarch
texlive-rotating-svn16832.2.16b-33.fc25.1.noarch
texlive-pdfpages-svn40638-33.fc25.1.noarch
texlive-cm-super-svn15878.0-33.fc25.1.noarch
texlive-xetex-svn41438-33.fc25.1.noarch
dnf-yum-1.1.10-6.fc25.noarch
libseccomp-devel-2.3.2-1.fc25.s390x
gpgme-1.8.0-10.fc25.s390x
apr-util-1.5.4-3.fc24.s390x
jbigkit-libs-2.1-5.fc24.s390x
pixman-0.34.0-2.fc24.s390x
dwz-0.12-2.fc24.s390x
expect-5.45-22.fc24.s390x
libsigsegv-2.10-10.fc24.s390x
fakeroot-libs-1.20.2-4.fc24.s390x
m17n-lib-1.7.0-5.fc24.s390x
libverto-0.2.6-6.fc24.s390x
libXmu-1.1.2-4.fc24.s390x
libXcursor-1.1.14-6.fc24.s390x
python-kitchen-1.2.4-2.fc24.noarch
fakeroot-1.20.2-4.fc24.s390x
blktrace-1.1.0-3.fc24.s390x
usermode-1.111-8.fc24.s390x
kbd-2.0.3-3.fc24.s390x
libaio-devel-0.3.110-6.fc24.s390x
web-assets-filesystem-5-4.fc24.noarch
libgpg-error-1.24-1.fc25.s390x
findutils-4.6.0-8.fc25.s390x
libassuan-2.4.3-1.fc25.s390x
libusbx-1.0.21-1.fc25.s390x
libxslt-1.1.28-13.fc25.s390x
libmetalink-0.1.3-1.fc25.s390x
perl-MIME-Base64-3.15-365.fc25.s390x
ncurses-6.0-6.20160709.fc25.s390x
libwayland-server-1.12.0-1.fc25.s390x
perl-Fedora-VSP-0.001-4.fc25.noarch
perl-libintl-perl-1.26-1.fc25.s390x
shadow-utils-4.2.1-11.fc25.s390x
atk-2.22.0-1.fc25.s390x
pam-1.3.0-1.fc25.s390x
harfbuzz-icu-1.3.2-1.fc25.s390x
libsecret-0.18.5-2.fc25.s390x
s390utils-iucvterm-1.36.0-1.fc25.s390x
python3-requests-2.10.0-4.fc25.noarch
pyusb-1.0.0-2.fc25.noarch
python-enum34-1.0.4-6.fc25.noarch
pyxattr-0.5.3-8.fc25.s390x
libbabeltrace-1.4.0-3.fc25.s390x
libthai-0.1.25-1.fc25.s390x
deltarpm-3.6-17.fc25.s390x
s390utils-mon_statd-1.36.0-1.fc25.s390x
device-mapper-multipath-0.4.9-83.fc25.s390x
python3-pygpgme-0.3-18.fc25.s390x
libreport-filesystem-2.8.0-1.fc25.s390x
ghc-srpm-macros-1.4.2-4.fc25.noarch
rpmdevtools-8.9-1.fc25.noarch
python-dnf-plugins-extras-migrate-0.0.12-4.fc25.noarch
perl-IO-Socket-SSL-2.038-1.fc25.noarch
perl-File-ShareDir-1.102-7.fc25.noarch
tcl-8.6.6-1.fc25.s390x
bzip2-1.0.6-21.fc25.s390x
libss-1.43.3-1.fc25.s390x
libselinux-utils-2.5-13.fc25.s390x
python3-enchant-1.6.8-1.fc25.noarch
python2-dockerfile-parse-0.0.5-7.fc25.noarch
systemd-bootchart-231-2.fc25.s390x
e2fsprogs-1.43.3-1.fc25.s390x
libpng-devel-1.6.27-1.fc25.s390x
perl-XML-Parser-2.44-5.fc25.s390x
lttng-ust-2.8.1-2.fc25.s390x
libXfixes-devel-5.0.3-1.fc25.s390x
libXcomposite-devel-0.4.4-8.fc24.s390x
python3-javapackages-4.7.0-6.1.fc25.noarch
libcephfs_jni-devel-10.2.4-2.fc25.s390x
keyutils-libs-devel-1.5.9-8.fc24.s390x
harfbuzz-devel-1.3.2-1.fc25.s390x
libidn-devel-1.33-1.fc25.s390x
libnfs-1.9.8-2.fc24.s390x
libssh2-devel-1.8.0-1.fc25.s390x
qemu-sanity-check-nodeps-1.1.5-5.fc24.s390x
alsa-lib-devel-1.1.1-2.fc25.s390x
libpsl-0.17.0-1.fc25.s390x
libseccomp-2.3.2-1.fc25.s390x
json-glib-1.2.6-1.fc25.s390x
python2-dnf-1.1.10-6.fc25.noarch
texlive-tetex-bin-svn36770.0-33.20160520.fc25.1.noarch
texlive-amsfonts-svn29208.3.04-33.fc25.1.noarch
texlive-babel-svn40706-33.fc25.1.noarch
texlive-colortbl-svn29803.v1.0a-33.fc25.1.noarch
texlive-babelbib-svn25245.1.31-33.fc25.1.noarch
texlive-footmisc-svn23330.5.5b-33.fc25.1.noarch
texlive-makeindex-svn40768-33.fc25.1.noarch
texlive-plain-svn40274-33.fc25.1.noarch
texlive-texconfig-bin-svn29741.0-33.20160520.fc25.1.noarch
texlive-zapfding-svn31835.0-33.fc25.1.noarch
texlive-microtype-svn41127-33.fc25.1.noarch
texlive-bookman-svn31835.0-33.fc25.1.noarch
texlive-dvisvgm-def-svn41011-33.fc25.1.noarch
texlive-finstrut-svn21719.0.5-33.fc25.1.noarch
texlive-hyph-utf8-svn41189-33.fc25.1.noarch
texlive-lualibs-svn40370-33.fc25.1.noarch
python2-hawkey-0.6.4-3.fc25.s390x
elfutils-libelf-0.169-1.fc25.s390x
libnl3-3.2.29-3.fc25.s390x
gstreamer1-1.10.5-1.fc25.s390x
polkit-libs-0.113-8.fc25.s390x
libtirpc-1.0.2-0.fc25.s390x
libteam-1.27-1.fc25.s390x
python3-pyasn1-0.2.3-1.fc25.noarch
perl-File-Path-2.12-366.fc25.noarch
mesa-libwayland-egl-devel-17.0.5-3.fc25.s390x
libacl-devel-2.2.52-13.fc25.s390x
lua-libs-5.3.4-3.fc25.s390x
quota-nls-4.03-8.fc25.noarch
ghostscript-x11-9.20-9.fc25.s390x
systemd-231-17.fc25.s390x
dhcp-common-4.3.5-3.fc25.noarch
vte291-devel-0.46.2-1.fc25.s390x
python-devel-2.7.13-2.fc25.s390x
elfutils-0.169-1.fc25.s390x
lua-5.3.4-3.fc25.s390x
python3-beautifulsoup4-4.6.0-1.fc25.noarch
libmicrohttpd-0.9.55-1.fc25.s390x
screen-4.6.1-1.fc25.s390x
strace-4.18-1.fc25.s390x
libstdc++-6.4.1-1.fc25.s390x
glusterfs-3.10.5-1.fc25.s390x
file-5.29-9.fc25.s390x
libgo-6.4.1-1.fc25.s390x
tar-1.29-4.fc25.s390x
subversion-libs-1.9.7-1.fc25.s390x
libglvnd-gles-0.2.999-24.20170818git8d4d03f.fc25.s390x
gdk-pixbuf2-modules-2.36.9-1.fc25.s390x
gcc-6.4.1-1.fc25.s390x
curl-7.51.0-9.fc25.s390x
pcre2-utf16-10.23-9.fc25.s390x
mariadb-config-10.1.25-1.fc25.s390x
libcurl-devel-7.51.0-9.fc25.s390x
gtk3-devel-3.22.17-2.fc25.s390x
krb5-devel-1.14.4-8.fc25.s390x
wpa_supplicant-2.6-3.fc25.s390x
fontawesome-fonts-web-4.7.0-1.fc25.noarch
python2-pygments-2.2.0-7.fc25.noarch
python2-babel-2.3.4-2.fc25.noarch
doxygen-1.8.13-9.fc25.s390x
nspr-devel-4.16.0-1.fc25.s390x
kernel-core-4.12.11-200.fc25.s390x
rpmlint-1.10-3.fc25.noarch
vim-enhanced-8.0.1030-1.fc25.s390x
openjpeg2-2.2.0-3.fc25.s390x
distribution-gpg-keys-1.15-1.fc25.noarch
texlive-mparhack-svn15878.1.4-33.fc25.1.noarch
texlive-pspicture-svn15878.0-33.fc25.1.noarch
texlive-soul-svn15878.2.4-33.fc25.1.noarch
texlive-trimspaces-svn15878.1.1-33.fc25.1.noarch
texlive-varwidth-svn24104.0.92-33.fc25.1.noarch
texlive-geometry-svn19716.5.6-33.fc25.1.noarch
texlive-memoir-svn41203-33.fc25.1.noarch
texlive-pgf-svn40966-33.fc25.1.noarch
texlive-pst-coil-svn37377.1.07-33.fc25.1.noarch
texlive-pst-plot-svn41242-33.fc25.1.noarch
texlive-latex-bin-svn41438-33.fc25.1.noarch
texlive-ucs-svn35853.2.2-33.fc25.1.noarch
texlive-ae-svn15878.1.4-33.fc25.1.noarch
texlive-xetex-bin-svn41091-33.20160520.fc25.1.s390x
fedora-upgrade-26.1-1.fc25.noarch
perl-Thread-Queue-3.12-1.fc25.noarch
cdparanoia-libs-10.2-21.fc24.s390x
ustr-1.0.4-21.fc24.s390x
libusb-0.1.5-7.fc24.s390x
readline-devel-6.3-8.fc24.s390x
chkconfig-1.8-1.fc25.s390x
avahi-libs-0.6.32-4.fc25.s390x
perl-Unicode-Normalize-1.25-365.fc25.s390x
perl-libnet-3.10-1.fc25.noarch
perl-podlators-4.09-1.fc25.noarch
dbus-python-1.2.4-2.fc25.s390x
libgnome-keyring-3.12.0-7.fc25.s390x
python-backports-1.0-8.fc25.s390x
python-pycparser-2.14-7.fc25.noarch
plymouth-scripts-0.9.3-0.6.20160620git0e65b86c.fc25.s390x
cronie-1.5.1-2.fc25.s390x
python2-librepo-1.7.18-3.fc25.s390x
libXv-1.0.11-1.fc25.s390x
python2-ndg_httpsclient-0.4.0-4.fc25.noarch
btrfs-progs-4.6.1-1.fc25.s390x
perl-Encode-2.88-5.fc25.s390x
cracklib-2.9.6-4.fc25.s390x
python3-dnf-plugin-system-upgrade-0.7.1-4.fc25.noarch
boost-random-1.60.0-10.fc25.s390x
libref_array-0.1.5-29.fc25.s390x
libXrender-devel-0.9.10-1.fc25.s390x
javapackages-tools-4.7.0-6.1.fc25.noarch
keyutils-1.5.9-8.fc24.s390x
libcom_err-devel-1.43.3-1.fc25.s390x
lzo-minilzo-2.08-8.fc24.s390x
libusbx-devel-1.0.21-1.fc25.s390x
virglrenderer-devel-0.5.0-1.20160411git61846f92f.fc25.s390x
acpica-tools-20160831-1.fc25.s390x
grep-2.27-2.fc25.s390x
dnf-conf-1.1.10-6.fc25.noarch
crypto-policies-20160921-4.gitf3018dd.fc25.noarch
libnfsidmap-0.27-1.fc25.s390x
SDL2-2.0.5-3.fc25.s390x
texlive-etex-pkg-svn39355-33.fc25.1.noarch
texlive-multido-svn18302.1.42-33.fc25.1.noarch
texlive-gsftopk-svn40768-33.fc25.1.noarch
texlive-pst-ovl-svn40873-33.fc25.1.noarch
texlive-ltabptch-svn17533.1.74d-33.fc25.1.noarch
texlive-cite-svn36428.5.5-33.fc25.1.noarch
texlive-fpl-svn15878.1.002-33.fc25.1.noarch
texlive-mathpazo-svn15878.1.003-33.fc25.1.noarch
texlive-rcs-svn15878.0-33.fc25.1.noarch
texlive-type1cm-svn21820.0-33.fc25.1.noarch
texlive-l3kernel-svn41246-33.fc25.1.noarch
texlive-hyperref-svn41396-33.fc25.1.noarch
texlive-pst-tree-svn24142.1.12-33.fc25.1.noarch
texlive-sansmathaccent-svn30187.0-33.fc25.1.noarch
texlive-dvipdfmx-bin-svn40273-33.20160520.fc25.1.s390x
texlive-zapfchan-svn31835.0-33.fc25.1.noarch
glib2-static-2.50.3-1.fc25.s390x
bash-completion-2.5-1.fc25.noarch
hyphen-2.8.8-4.fc24.s390x
python3-idna-2.5-1.fc25.noarch
less-481-7.fc25.s390x
rpmconf-base-1.0.19-1.fc25.noarch
gtk2-2.24.31-2.fc25.s390x
mesa-libgbm-17.0.5-3.fc25.s390x
nfs-utils-2.1.1-5.rc4.fc25.s390x
mc-4.8.19-5.fc25.s390x
pcre-static-8.41-1.fc25.s390x
bind-libs-9.10.5-2.P2.fc25.s390x
libproxy-0.4.15-2.fc25.s390x
file-libs-5.29-9.fc25.s390x
glibc-devel-2.24-10.fc25.s390x
glusterfs-server-3.10.5-1.fc25.s390x
git-core-doc-2.9.5-1.fc25.s390x
python2-smmap-2.0.3-1.fc25.noarch
glusterfs-api-devel-3.10.5-1.fc25.s390x
gcc-gdb-plugin-6.4.1-1.fc25.s390x
python3-magic-5.29-9.fc25.noarch
GeoIP-GeoLite-data-2017.07-1.fc25.noarch
python2-funcsigs-1.0.2-2.fc25.noarch
dos2unix-7.3.4-1.fc25.s390x
gnutls-c++-3.5.15-1.fc25.s390x
nss-tools-3.32.0-1.1.fc25.s390x
gpg-pubkey-a29cb19c-53bcbba6
m4-1.4.17-9.fc24.s390x
liblockfile-1.09-4.fc24.s390x
sg3_utils-1.41-3.fc24.s390x
libXinerama-1.1.3-6.fc24.s390x
libXft-2.3.2-4.fc24.s390x
tcp_wrappers-libs-7.6-83.fc25.s390x
perl-Text-Tabs+Wrap-2013.0523-365.fc25.noarch
perl-Error-0.17024-7.fc25.noarch
perl-Term-Cap-1.17-365.fc25.noarch
perl-Pod-Usage-1.69-1.fc25.noarch
device-mapper-persistent-data-0.6.3-1.fc25.s390x
python3-six-1.10.0-3.fc25.noarch
python3-pysocks-1.5.6-5.fc25.noarch
python-chardet-2.3.0-1.fc25.noarch
python2-cffi-1.7.0-2.fc25.s390x
gc-devel-7.4.4-1.fc25.s390x
plymouth-0.9.3-0.6.20160620git0e65b86c.fc25.s390x
ebtables-2.0.10-21.fc25.s390x
python3-librepo-1.7.18-3.fc25.s390x
at-spi2-atk-2.22.0-1.fc25.s390x
avahi-autoipd-0.6.32-4.fc25.s390x
pyparsing-2.1.10-1.fc25.noarch
python3-pyparsing-2.1.10-1.fc25.noarch
libcollection-0.7.0-29.fc25.s390x
libcephfs-devel-10.2.4-2.fc25.s390x
libXdamage-devel-1.1.4-8.fc24.s390x
libverto-devel-0.2.6-6.fc24.s390x
snappy-1.1.3-2.fc24.s390x
cairo-gobject-devel-1.14.8-1.fc25.s390x
cyrus-sasl-devel-2.1.26-26.2.fc24.s390x
libXi-1.7.9-1.fc25.s390x
texlive-base-2016-33.20160520.fc25.noarch
texlive-booktabs-svn40846-33.fc25.1.noarch
texlive-lm-svn28119.2.004-33.fc25.1.noarch
texlive-gsftopk-bin-svn40473-33.20160520.fc25.1.s390x
texlive-tex-svn40793-33.fc25.1.noarch
texlive-fancyref-svn15878.0.9c-33.fc25.1.noarch
texlive-chngcntr-svn17157.1.0a-33.fc25.1.noarch
texlive-fix2col-svn38770-33.fc25.1.noarch
texlive-marginnote-svn41382-33.fc25.1.noarch
texlive-pxfonts-svn15878.0-33.fc25.1.noarch
texlive-txfonts-svn15878.0-33.fc25.1.noarch
texlive-l3packages-svn41246-33.fc25.1.noarch
texlive-oberdiek-svn41346-33.fc25.1.noarch
texlive-pst-tools-svn34067.0.05-33.fc25.1.noarch
texlive-tex-gyre-svn18651.2.004-33.fc25.1.noarch
texlive-dvipdfmx-svn41149-33.fc25.1.noarch
texlive-collection-fontsrecommended-svn35830.0-33.20160520.fc25.1.noarch
libcacard-devel-2.5.3-1.fc25.s390x
ykpers-1.18.0-2.fc25.s390x
python2-idna-2.5-1.fc25.noarch
policycoreutils-2.5-20.fc25.s390x
libgcrypt-1.7.8-1.fc25.s390x
pcre-8.41-1.fc25.s390x
GeoIP-1.6.11-1.fc25.s390x
ghostscript-core-9.20-9.fc25.s390x
python3-cffi-1.7.0-2.fc25.s390x
json-c-0.12.1-2.fc25.s390x
vte291-0.46.2-1.fc25.s390x
gssproxy-0.7.0-9.fc25.s390x
systemtap-3.1-5.fc25.s390x
mesa-libgbm-devel-17.0.5-3.fc25.s390x
libgusb-0.2.10-1.fc25.s390x
kernel-modules-4.12.9-200.fc25.s390x
sqlite-3.14.2-3.fc25.s390x
perl-Git-2.9.5-1.fc25.noarch
python2-gitdb-2.0.2-1.fc25.noarch
libglvnd-devel-0.2.999-24.20170818git8d4d03f.fc25.s390x
gcc-c++-6.4.1-1.fc25.s390x
python-magic-5.29-9.fc25.noarch
kernel-devel-4.12.9-200.fc25.s390x
python2-mock-2.0.0-2.fc25.noarch
nspr-4.16.0-1.fc25.s390x
python3-libs-3.5.4-1.fc25.s390x
system-python-3.5.4-1.fc25.s390x
python-async-0.6.1-9.fc22.s390x
dejavu-sans-mono-fonts-2.35-3.fc24.noarch
popt-1.16-7.fc24.s390x
cyrus-sasl-lib-2.1.26-26.2.fc24.s390x
xz-5.2.2-2.fc24.s390x
libpipeline-1.4.1-2.fc24.s390x
pinentry-0.9.7-2.fc24.s390x
pth-2.0.7-27.fc24.s390x
libsepol-2.5-10.fc25.s390x
libxcb-1.12-1.fc25.s390x
perl-Getopt-Long-2.49.1-1.fc25.noarch
avahi-glib-0.6.32-4.fc25.s390x
python3-pip-8.1.2-2.fc25.noarch
python3-libcomps-0.1.7-5.fc25.s390x
python-slip-0.6.4-4.fc25.noarch
python2-libcomps-0.1.7-5.fc25.s390x
gc-7.4.4-1.fc25.s390x
s390utils-cmsfs-1.36.0-1.fc25.s390x
newt-python-0.52.19-2.fc25.s390x
qt5-srpm-macros-5.7.1-1.fc25.noarch
device-mapper-event-1.02.136-3.fc25.s390x
perl-Class-Inspector-1.31-2.fc25.noarch
libbasicobjects-0.1.1-29.fc25.s390x
libradosstriper1-10.2.4-2.fc25.s390x
libXxf86vm-devel-1.1.4-3.fc24.s390x
zziplib-0.13.62-7.fc24.s390x
libpaper-1.1.24-12.fc24.s390x
libini_config-1.3.0-29.fc25.s390x
snappy-devel-1.1.3-2.fc24.s390x
libcap-ng-devel-0.7.8-1.fc25.s390x
libxkbcommon-devel-0.7.1-1.fc25.s390x
openssl-libs-1.0.2k-1.fc25.s390x
util-linux-2.28.2-2.fc25.s390x
texlive-etoolbox-svn38031.2.2a-33.fc25.1.noarch
texlive-dvips-svn41149-33.fc25.1.noarch
texlive-latexconfig-svn40274-33.fc25.1.noarch
texlive-tex-ini-files-svn40533-33.fc25.1.noarch
texlive-qstest-svn15878.0-33.fc25.1.noarch
texlive-cmap-svn41168-33.fc25.1.noarch
texlive-luatex-bin-svn41091-33.20160520.fc25.1.s390x
texlive-mflogo-svn38628-33.fc25.1.noarch
texlive-sansmath-svn17997.1.1-33.fc25.1.noarch
texlive-unicode-data-svn39808-33.fc25.1.noarch
texlive-luaotfload-bin-svn34647.0-33.20160520.fc25.1.noarch
texlive-listings-svn37534.1.6-33.fc25.1.noarch
texlive-pstricks-svn41321-33.fc25.1.noarch
texlive-metalogo-svn18611.0.12-33.fc25.1.noarch
texlive-collection-latex-svn41011-33.20160520.fc25.1.noarch
python2-dnf-plugins-core-0.1.21-5.fc25.noarch
xkeyboard-config-2.20-2.fc25.noarch
perl-Test-Harness-3.39-1.fc25.noarch
systemd-libs-231-17.fc25.s390x
python3-pycparser-2.14-7.fc25.noarch
kernel-devel-4.11.10-200.fc25.s390x
gsm-1.0.17-1.fc25.s390x
python-2.7.13-2.fc25.s390x
kernel-4.11.10-200.fc25.s390x
rpmconf-1.0.19-1.fc25.noarch
teamd-1.27-1.fc25.s390x
jasper-libs-1.900.13-4.fc25.s390x
glusterfs-libs-3.10.5-1.fc25.s390x
libcrypt-nss-2.24-10.fc25.s390x
emacs-common-25.2-3.fc25.s390x
libcurl-7.51.0-9.fc25.s390x
java-1.8.0-openjdk-1.8.0.144-5.b01.fc25.s390x
gcc-go-6.4.1-1.fc25.s390x
perl-XML-XPath-1.39-2.fc25.noarch
python2-sphinx_rtd_theme-0.1.9-2.fc24.noarch
libxml2-devel-2.9.4-2.fc25.s390x
nss-softokn-devel-3.32.0-1.2.fc25.s390x
nss-devel-3.32.0-1.1.fc25.s390x
libattr-2.4.47-16.fc24.s390x
libvisual-0.4.0-20.fc24.s390x
libpcap-1.7.4-2.fc24.s390x
libutempter-1.1.6-8.fc24.s390x
libgudev-230-3.fc24.s390x
popt-devel-1.16-7.fc24.s390x
hicolor-icon-theme-0.15-3.fc24.noarch
setup-2.10.4-1.fc25.noarch
bash-4.3.43-4.fc25.s390x
libjpeg-turbo-1.5.1-0.fc25.s390x
perl-Socket-2.024-1.fc25.s390x
perl-HTTP-Tiny-0.070-1.fc25.noarch
ipset-6.29-1.fc25.s390x
python2-setuptools-25.1.1-1.fc25.noarch
gsettings-desktop-schemas-3.22.0-1.fc25.s390x
python3-setuptools-25.1.1-1.fc25.noarch
python-slip-dbus-0.6.4-4.fc25.noarch
python2-ply-3.8-2.fc25.noarch
dtc-1.4.2-1.fc25.s390x
guile-2.0.13-1.fc25.s390x
cronie-anacron-1.5.1-2.fc25.s390x
libXtst-1.2.3-1.fc25.s390x
iso-codes-3.70-1.fc25.noarch
s390utils-1.36.0-1.fc25.s390x
python-backports-ssl_match_hostname-3.5.0.1-3.fc25.noarch
fedora-cert-0.6.0.1-1.fc25.noarch
dnf-plugin-system-upgrade-0.7.1-4.fc25.noarch
lvm2-2.02.167-3.fc25.s390x
libselinux-devel-2.5-13.fc25.s390x
perl-Time-Local-1.250-1.fc25.noarch
libradosstriper-devel-10.2.4-2.fc25.s390x
flac-libs-1.3.2-1.fc25.s390x
perl-Digest-1.17-366.fc25.noarch
teckit-2.5.1-15.fc24.s390x
libpath_utils-0.2.1-29.fc25.s390x
attr-2.4.47-16.fc24.s390x
usbredir-0.7.1-2.fc24.s390x
cairo-devel-1.14.8-1.fc25.s390x
lzo-devel-2.08-8.fc24.s390x
libcap-devel-2.25-2.fc25.s390x
libbsd-0.8.3-1.fc25.s390x
texlive-url-svn32528.3.4-33.fc25.1.noarch
texlive-dvips-bin-svn40987-33.20160520.fc25.1.s390x
texlive-index-svn24099.4.1beta-33.fc25.1.noarch
texlive-setspace-svn24881.6.7a-33.fc25.1.noarch
texlive-mathtools-svn38833-33.fc25.1.noarch
texlive-cm-svn32865.0-33.fc25.1.noarch
texlive-graphics-def-svn41879-33.fc25.1.noarch
texlive-mdwtools-svn15878.1.05.4-33.fc25.1.noarch
texlive-rsfs-svn15878.0-33.fc25.1.noarch
texlive-ucharcat-svn38907-33.fc25.1.noarch
texlive-fontspec-svn41262-33.fc25.1.noarch
texlive-showexpl-svn32737.v0.3l-33.fc25.1.noarch
texlive-pstricks-add-svn40744-33.fc25.1.noarch
texlive-beamer-svn36461.3.36-33.fc25.1.noarch
texlive-collection-basic-svn41149-33.20160520.fc25.1.noarch
xemacs-filesystem-21.5.34-20.20170124hgf412e9f093d4.fc25.noarch
hawkey-0.6.4-3.fc25.s390x
bluez-libs-5.44-1.fc25.s390x
audit-libs-2.7.7-1.fc25.s390x
iproute-4.11.0-1.fc25.s390x
libICE-1.0.9-9.fc25.s390x
python3-ply-3.8-2.fc25.noarch
perl-5.24.2-387.fc25.s390x
graphite2-1.3.10-1.fc25.s390x
vte-profile-0.46.2-1.fc25.s390x
python-libs-2.7.13-2.fc25.s390x
mesa-libGL-17.0.5-3.fc25.s390x
python2-pycurl-7.43.0-6.fc25.s390x
NetworkManager-1.4.4-5.fc25.s390x
mesa-libEGL-devel-17.0.5-3.fc25.s390x
mesa-libGLES-devel-17.0.5-3.fc25.s390x
hostname-3.15-8.fc25.s390x
glibc-headers-2.24-10.fc25.s390x
glusterfs-cli-3.10.5-1.fc25.s390x
git-core-2.9.5-1.fc25.s390x
gcc-gfortran-6.4.1-1.fc25.s390x
webkitgtk4-plugin-process-gtk2-2.16.6-1.fc25.s390x
perl-Module-CoreList-5.20170821-1.fc25.noarch
python2-pbr-1.10.0-1.fc25.noarch
libtool-2.4.6-14.fc25.s390x
gnutls-dane-3.5.15-1.fc25.s390x
kernel-4.12.11-200.fc25.s390x
gpg-pubkey-a0a7badb-52844296
readline-6.3-8.fc24.s390x
cpio-2.12-3.fc24.s390x
libXcomposite-0.4.4-8.fc24.s390x
procps-ng-3.3.10-11.fc24.s390x
GConf2-3.2.6-16.fc24.s390x
xz-devel-5.2.2-2.fc24.s390x
fedora-logos-22.0.0-3.fc24.s390x
gpg-pubkey-e372e838-56fd7943
kmod-libs-23-1.fc25.s390x
perl-parent-0.236-1.fc25.noarch
perl-TermReadKey-2.37-1.fc25.s390x
ncurses-c++-libs-6.0-6.20160709.fc25.s390x
gzip-1.8-1.fc25.s390x
python3-gobject-base-3.22.0-1.fc25.s390x
python2-yubico-1.3.2-3.fc25.noarch
s390utils-ziomon-1.36.0-1.fc25.s390x
librepo-1.7.18-3.fc25.s390x
gnat-srpm-macros-4-1.fc25.noarch
python-decoratortools-1.8-12.fc25.noarch
m17n-db-1.7.0-7.fc25.noarch
e2fsprogs-libs-1.43.3-1.fc25.s390x
libvorbis-1.3.5-1.fc25.s390x
npth-1.3-1.fc25.s390x
libcephfs1-10.2.4-2.fc25.s390x
wayland-devel-1.12.0-1.fc25.s390x
libxcb-devel-1.12-1.fc25.s390x
perl-encoding-2.19-5.fc25.s390x
python3-cssselect-0.9.2-1.fc25.noarch
gettext-libs-0.19.8.1-3.fc25.s390x
at-spi2-atk-devel-2.22.0-1.fc25.s390x
virglrenderer-0.5.0-1.20160411git61846f92f.fc25.s390x
pixman-devel-0.34.0-2.fc24.s390x
libnfs-devel-1.9.8-2.fc24.s390x
libblkid-2.28.2-2.fc25.s390x
glib2-devel-2.50.3-1.fc25.s390x
texlive-ifxetex-svn19685.0.5-33.fc25.1.noarch
texlive-caption-svn41409-33.fc25.1.noarch
texlive-float-svn15878.1.3d-33.fc25.1.noarch
texlive-pdftex-def-svn22653.0.06d-33.fc25.1.noarch
texlive-xdvi-bin-svn40750-33.20160520.fc25.1.s390x
texlive-beton-svn15878.0-33.fc25.1.noarch
texlive-filecontents-svn24250.1.3-33.fc25.1.noarch
texlive-lm-math-svn36915.1.959-33.fc25.1.noarch
texlive-pslatex-svn16416.0-33.fc25.1.noarch
texlive-times-svn35058.0-33.fc25.1.noarch
texlive-breakurl-svn29901.1.40-33.fc25.1.noarch
texlive-filehook-svn24280.0.5d-33.fc25.1.noarch
texlive-pst-pdf-svn31660.1.1v-33.fc25.1.noarch
texlive-seminar-svn34011.1.62-33.fc25.1.noarch
texlive-xetexconfig-svn41133-33.fc25.1.noarch
python-rpm-macros-3-12.fc25.noarch
nss-pem-1.0.3-3.fc25.s390x
at-spi2-core-2.22.1-1.fc25.s390x
perl-Scalar-List-Utils-1.48-1.fc25.s390x
libtasn1-devel-4.12-1.fc25.s390x
python3-koji-1.13.0-2.fc25.noarch
opus-1.1.5-1.fc25.s390x
elfutils-libs-0.169-1.fc25.s390x
kernel-core-4.11.10-200.fc25.s390x
systemd-container-231-17.fc25.s390x
sudo-1.8.20p2-1.fc25.s390x
libicu-devel-57.1-5.fc25.s390x
js-jquery-2.2.4-3.fc25.noarch
krb5-libs-1.14.4-8.fc25.s390x
apr-1.6.2-1.fc25.s390x
dbus-1.11.16-1.fc25.s390x
libdrm-2.4.82-1.fc25.s390x
pcre2-utf32-10.23-9.fc25.s390x
copy-jdk-configs-2.3-1.fc25.noarch
libdrm-devel-2.4.82-1.fc25.s390x
krb5-workstation-1.14.4-8.fc25.s390x
python3-sssdconfig-1.15.3-1.fc25.noarch
python2-docutils-0.13.1-3.fc25.noarch
graphviz-2.38.0-39.fc25.s390x
kernel-modules-4.12.11-200.fc25.s390x
fedpkg-1.29-3.fc25.noarch
mock-core-configs-27.4-1.fc25.noarch
=== TEST BEGIN ===
Using CC: /home/fam/bin/cc
Install prefix    /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install
BIOS directory    /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/share/qemu
firmware path     /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/share/qemu-firmware
binary directory  /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/bin
library directory /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/lib
module directory  /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/lib/qemu
libexec directory /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/libexec
include directory /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/include
config directory  /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/etc
local state directory   /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/var
Manual directory  /var/tmp/patchew-tester-tmp-j1ms6ngb/src/install/share/man
ELF interp prefix /usr/gnemul/qemu-%M
Source path       /var/tmp/patchew-tester-tmp-j1ms6ngb/src
GIT binary        git
GIT submodules    ui/keycodemapdb capstone
C compiler        /home/fam/bin/cc
Host C compiler   cc
C++ compiler      c++
Objective-C compiler /home/fam/bin/cc
ARFLAGS           rv
CFLAGS            -O2 -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 -g 
QEMU_CFLAGS       -I/usr/include/pixman-1  -Werror -DHAS_LIBSSH2_SFTP_FSYNC -pthread -I/usr/include/glib-2.0 -I/usr/lib64/glib-2.0/include -DNCURSES_WIDECHAR -D_GNU_SOURCE -m64 -D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -Wstrict-prototypes -Wredundant-decls -Wall -Wundef -Wwrite-strings -Wmissing-prototypes -fno-strict-aliasing -fno-common -fwrapv  -Wendif-labels -Wno-shift-negative-value -Wno-missing-include-dirs -Wempty-body -Wnested-externs -Wformat-security -Wformat-y2k -Winit-self -Wignored-qualifiers -Wold-style-declaration -Wold-style-definition -Wtype-limits -fstack-protector-strong -I/usr/include/p11-kit-1    -I/usr/include/libpng16 -I/usr/include/libdrm  -I$(SRC_PATH)/capstone/include
LDFLAGS           -Wl,--warn-common -m64 -g 
make              make
install           install
python            python -B
smbd              /usr/sbin/smbd
module support    no
host CPU          s390x
host big endian   yes
target list       aarch64-softmmu alpha-softmmu arm-softmmu cris-softmmu i386-softmmu lm32-softmmu m68k-softmmu microblazeel-softmmu microblaze-softmmu mips64el-softmmu mips64-softmmu mipsel-softmmu mips-softmmu moxie-softmmu nios2-softmmu or1k-softmmu ppc64-softmmu ppcemb-softmmu ppc-softmmu s390x-softmmu sh4eb-softmmu sh4-softmmu sparc64-softmmu sparc-softmmu tricore-softmmu unicore32-softmmu x86_64-softmmu xtensaeb-softmmu xtensa-softmmu aarch64-linux-user alpha-linux-user armeb-linux-user arm-linux-user cris-linux-user hppa-linux-user i386-linux-user m68k-linux-user microblazeel-linux-user microblaze-linux-user mips64el-linux-user mips64-linux-user mipsel-linux-user mips-linux-user mipsn32el-linux-user mipsn32-linux-user nios2-linux-user or1k-linux-user ppc64abi32-linux-user ppc64le-linux-user ppc64-linux-user ppc-linux-user s390x-linux-user sh4eb-linux-user sh4-linux-user sparc32plus-linux-user sparc64-linux-user sparc-linux-user tilegx-linux-user x86_64-linux-user
gprof enabled     no
sparse enabled    no
strip binaries    yes
profiler          no
static build      no
SDL support       yes (2.0.5)
GTK support       yes (3.22.17)
GTK GL support    yes
VTE support       yes (0.46.2)
TLS priority      NORMAL
GNUTLS support    yes
GNUTLS rnd        yes
libgcrypt         no
libgcrypt kdf     no
nettle            yes (3.3)
nettle kdf        yes
libtasn1          yes
curses support    yes
virgl support     yes
curl support      yes
mingw32 support   no
Audio drivers     oss
Block whitelist (rw) 
Block whitelist (ro) 
VirtFS support    yes
Multipath support no
VNC support       yes
VNC SASL support  yes
VNC JPEG support  yes
VNC PNG support   yes
xen support       no
brlapi support    yes
bluez  support    yes
Documentation     yes
PIE               no
vde support       no
netmap support    no
Linux AIO support yes
ATTR/XATTR support yes
Install blobs     yes
KVM support       yes
HAX support       no
TCG support       yes
TCG debug enabled no
TCG interpreter   no
RDMA support      no
fdt support       yes
preadv support    yes
fdatasync         yes
madvise           yes
posix_madvise     yes
libcap-ng support yes
vhost-net support yes
vhost-scsi support yes
vhost-vsock support yes
vhost-user support yes
Trace backends    log
spice support     no 
rbd support       yes
xfsctl support    no
smartcard support yes
libusb            yes
usb net redir     yes
OpenGL support    yes
OpenGL dmabufs    yes
libiscsi support  yes
libnfs support    yes
build guest agent yes
QGA VSS support   no
QGA w32 disk info no
QGA MSI support   no
seccomp support   yes
coroutine backend ucontext
coroutine pool    yes
debug stack usage no
crypto afalg      no
GlusterFS support yes
gcov              gcov
gcov enabled      no
TPM support       yes
libssh2 support   yes
TPM passthrough   no
TPM emulator      yes
QOM debugging     yes
Live block migration yes
lzo support       yes
snappy support    yes
bzip2 support     yes
NUMA host support no
tcmalloc support  no
jemalloc support  no
avx2 optimization no
replication support yes
VxHS block device no
capstone          git
  GEN     aarch64-softmmu/config-devices.mak.tmp
  GEN     alpha-softmmu/config-devices.mak.tmp
  GEN     arm-softmmu/config-devices.mak.tmp
  GEN     cris-softmmu/config-devices.mak.tmp
  GEN     cris-softmmu/config-devices.mak
  GEN     i386-softmmu/config-devices.mak.tmp
  GEN     arm-softmmu/config-devices.mak
  GEN     alpha-softmmu/config-devices.mak
  GEN     aarch64-softmmu/config-devices.mak
  GEN     lm32-softmmu/config-devices.mak.tmp
  GEN     m68k-softmmu/config-devices.mak.tmp
  GEN     microblazeel-softmmu/config-devices.mak.tmp
  GEN     lm32-softmmu/config-devices.mak
  GEN     m68k-softmmu/config-devices.mak
  GEN     i386-softmmu/config-devices.mak
  GEN     microblazeel-softmmu/config-devices.mak
  GEN     microblaze-softmmu/config-devices.mak.tmp
  GEN     mips64el-softmmu/config-devices.mak.tmp
  GEN     mips64-softmmu/config-devices.mak.tmp
  GEN     mipsel-softmmu/config-devices.mak.tmp
  GEN     microblaze-softmmu/config-devices.mak
  GEN     mips-softmmu/config-devices.mak.tmp
  GEN     mips64el-softmmu/config-devices.mak
  GEN     mipsel-softmmu/config-devices.mak
  GEN     moxie-softmmu/config-devices.mak.tmp
  GEN     mips64-softmmu/config-devices.mak
  GEN     nios2-softmmu/config-devices.mak.tmp
  GEN     or1k-softmmu/config-devices.mak.tmp
  GEN     nios2-softmmu/config-devices.mak
  GEN     moxie-softmmu/config-devices.mak
  GEN     mips-softmmu/config-devices.mak
  GEN     or1k-softmmu/config-devices.mak
  GEN     ppc64-softmmu/config-devices.mak.tmp
  GEN     ppcemb-softmmu/config-devices.mak.tmp
  GEN     ppc-softmmu/config-devices.mak.tmp
  GEN     s390x-softmmu/config-devices.mak.tmp
  GEN     s390x-softmmu/config-devices.mak
  GEN     ppcemb-softmmu/config-devices.mak
  GEN     sh4eb-softmmu/config-devices.mak.tmp
  GEN     sh4-softmmu/config-devices.mak.tmp
  GEN     ppc64-softmmu/config-devices.mak
  GEN     ppc-softmmu/config-devices.mak
  GEN     sparc64-softmmu/config-devices.mak.tmp
  GEN     sparc-softmmu/config-devices.mak.tmp
  GEN     sh4eb-softmmu/config-devices.mak
  GEN     tricore-softmmu/config-devices.mak.tmp
  GEN     sh4-softmmu/config-devices.mak
  GEN     sparc-softmmu/config-devices.mak
  GEN     unicore32-softmmu/config-devices.mak.tmp
  GEN     x86_64-softmmu/config-devices.mak.tmp
  GEN     sparc64-softmmu/config-devices.mak
  GEN     tricore-softmmu/config-devices.mak
  GEN     xtensaeb-softmmu/config-devices.mak.tmp
  GEN     xtensa-softmmu/config-devices.mak.tmp
  GEN     unicore32-softmmu/config-devices.mak
  GEN     aarch64-linux-user/config-devices.mak.tmp
  GEN     xtensa-softmmu/config-devices.mak
  GEN     xtensaeb-softmmu/config-devices.mak
  GEN     x86_64-softmmu/config-devices.mak
  GEN     armeb-linux-user/config-devices.mak.tmp
  GEN     alpha-linux-user/config-devices.mak.tmp
  GEN     arm-linux-user/config-devices.mak.tmp
  GEN     aarch64-linux-user/config-devices.mak
  GEN     alpha-linux-user/config-devices.mak
  GEN     arm-linux-user/config-devices.mak
  GEN     cris-linux-user/config-devices.mak.tmp
  GEN     hppa-linux-user/config-devices.mak.tmp
  GEN     armeb-linux-user/config-devices.mak
  GEN     i386-linux-user/config-devices.mak.tmp
  GEN     m68k-linux-user/config-devices.mak.tmp
  GEN     cris-linux-user/config-devices.mak
  GEN     hppa-linux-user/config-devices.mak
  GEN     microblazeel-linux-user/config-devices.mak.tmp
  GEN     i386-linux-user/config-devices.mak
  GEN     m68k-linux-user/config-devices.mak
  GEN     microblaze-linux-user/config-devices.mak.tmp
  GEN     mips64el-linux-user/config-devices.mak.tmp
  GEN     mips64-linux-user/config-devices.mak.tmp
  GEN     microblazeel-linux-user/config-devices.mak
  GEN     microblaze-linux-user/config-devices.mak
  GEN     mipsel-linux-user/config-devices.mak.tmp
  GEN     mips64-linux-user/config-devices.mak
  GEN     mips-linux-user/config-devices.mak.tmp
  GEN     mipsn32el-linux-user/config-devices.mak.tmp
  GEN     mips64el-linux-user/config-devices.mak
  GEN     mipsn32-linux-user/config-devices.mak.tmp
  GEN     mipsel-linux-user/config-devices.mak
  GEN     mips-linux-user/config-devices.mak
  GEN     nios2-linux-user/config-devices.mak.tmp
  GEN     mipsn32el-linux-user/config-devices.mak
  GEN     or1k-linux-user/config-devices.mak.tmp
  GEN     mipsn32-linux-user/config-devices.mak
  GEN     ppc64abi32-linux-user/config-devices.mak.tmp
  GEN     ppc64le-linux-user/config-devices.mak.tmp
  GEN     nios2-linux-user/config-devices.mak
  GEN     or1k-linux-user/config-devices.mak
  GEN     ppc64-linux-user/config-devices.mak.tmp
  GEN     ppc64abi32-linux-user/config-devices.mak
  GEN     ppc64le-linux-user/config-devices.mak
  GEN     ppc-linux-user/config-devices.mak.tmp
  GEN     s390x-linux-user/config-devices.mak.tmp
  GEN     sh4eb-linux-user/config-devices.mak.tmp
  GEN     ppc64-linux-user/config-devices.mak
  GEN     ppc-linux-user/config-devices.mak
  GEN     sh4-linux-user/config-devices.mak.tmp
  GEN     sparc32plus-linux-user/config-devices.mak.tmp
  GEN     sh4eb-linux-user/config-devices.mak
  GEN     s390x-linux-user/config-devices.mak
  GEN     sparc64-linux-user/config-devices.mak.tmp
  GEN     sparc-linux-user/config-devices.mak.tmp
  GEN     sh4-linux-user/config-devices.mak
  GEN     sparc64-linux-user/config-devices.mak
  GEN     sparc32plus-linux-user/config-devices.mak
  GEN     tilegx-linux-user/config-devices.mak.tmp
  GEN     x86_64-linux-user/config-devices.mak.tmp
  GEN     sparc-linux-user/config-devices.mak
  GEN     config-host.h
  GEN     tilegx-linux-user/config-devices.mak
  GIT     ui/keycodemapdb capstone
  GEN     x86_64-linux-user/config-devices.mak
  GEN     qemu-options.def
  GEN     qmp-commands.h
  GEN     qapi-types.h
  GEN     qapi-visit.h
  GEN     qapi-event.h
  GEN     qmp-marshal.c
  GEN     qapi-types.c
  GEN     qapi-visit.c
  GEN     qapi-event.c
Submodule 'capstone' (git://git.qemu.org/capstone.git) registered for path 'capstone'
  GEN     qmp-introspect.h
Submodule 'ui/keycodemapdb' (git://git.qemu.org/keycodemapdb.git) registered for path 'ui/keycodemapdb'
Cloning into '/var/tmp/patchew-tester-tmp-j1ms6ngb/src/capstone'...
  GEN     qmp-introspect.c
  GEN     trace/generated-tcg-tracers.h
  GEN     trace/generated-helpers-wrappers.h
  GEN     trace/generated-helpers.h
  GEN     trace/generated-helpers.c
  GEN     module_block.h
  GEN     tests/test-qapi-types.h
  GEN     tests/test-qapi-visit.h
  GEN     tests/test-qmp-commands.h
  GEN     tests/test-qapi-event.h
  GEN     tests/test-qmp-introspect.h
  GEN     trace-root.h
  GEN     util/trace.h
  GEN     crypto/trace.h
  GEN     io/trace.h
  GEN     migration/trace.h
  GEN     block/trace.h
  GEN     chardev/trace.h
  GEN     hw/block/trace.h
  GEN     hw/block/dataplane/trace.h
  GEN     hw/char/trace.h
  GEN     hw/intc/trace.h
  GEN     hw/net/trace.h
  GEN     hw/virtio/trace.h
  GEN     hw/audio/trace.h
  GEN     hw/misc/trace.h
  GEN     hw/usb/trace.h
  GEN     hw/scsi/trace.h
  GEN     hw/nvram/trace.h
  GEN     hw/display/trace.h
  GEN     hw/input/trace.h
  GEN     hw/timer/trace.h
  GEN     hw/dma/trace.h
  GEN     hw/sparc/trace.h
  GEN     hw/sd/trace.h
  GEN     hw/isa/trace.h
  GEN     hw/mem/trace.h
  GEN     hw/i386/trace.h
  GEN     hw/i386/xen/trace.h
  GEN     hw/9pfs/trace.h
  GEN     hw/ppc/trace.h
  GEN     hw/pci/trace.h
  GEN     hw/s390x/trace.h
  GEN     hw/vfio/trace.h
  GEN     hw/acpi/trace.h
  GEN     hw/arm/trace.h
  GEN     hw/alpha/trace.h
  GEN     hw/xen/trace.h
  GEN     hw/ide/trace.h
  GEN     ui/trace.h
  GEN     audio/trace.h
  GEN     net/trace.h
  GEN     target/arm/trace.h
  GEN     target/i386/trace.h
  GEN     target/mips/trace.h
  GEN     target/sparc/trace.h
  GEN     target/s390x/trace.h
  GEN     target/ppc/trace.h
  GEN     qom/trace.h
  GEN     linux-user/trace.h
  GEN     qapi/trace.h
  GEN     accel/tcg/trace.h
  GEN     accel/kvm/trace.h
  GEN     nbd/trace.h
  GEN     scsi/trace.h
  GEN     trace-root.c
  GEN     util/trace.c
  GEN     crypto/trace.c
  GEN     io/trace.c
  GEN     migration/trace.c
  GEN     block/trace.c
  GEN     chardev/trace.c
  GEN     hw/block/trace.c
  GEN     hw/block/dataplane/trace.c
  GEN     hw/char/trace.c
  GEN     hw/intc/trace.c
  GEN     hw/net/trace.c
  GEN     hw/virtio/trace.c
  GEN     hw/audio/trace.c
  GEN     hw/misc/trace.c
  GEN     hw/usb/trace.c
  GEN     hw/scsi/trace.c
  GEN     hw/nvram/trace.c
  GEN     hw/display/trace.c
  GEN     hw/input/trace.c
  GEN     hw/timer/trace.c
  GEN     hw/dma/trace.c
  GEN     hw/sparc/trace.c
  GEN     hw/sd/trace.c
  GEN     hw/isa/trace.c
  GEN     hw/mem/trace.c
  GEN     hw/i386/trace.c
  GEN     hw/i386/xen/trace.c
  GEN     hw/9pfs/trace.c
  GEN     hw/ppc/trace.c
  GEN     hw/pci/trace.c
  GEN     hw/s390x/trace.c
  GEN     hw/vfio/trace.c
  GEN     hw/acpi/trace.c
  GEN     hw/arm/trace.c
  GEN     hw/alpha/trace.c
  GEN     hw/xen/trace.c
  GEN     hw/ide/trace.c
  GEN     ui/trace.c
  GEN     audio/trace.c
  GEN     net/trace.c
  GEN     target/arm/trace.c
  GEN     target/i386/trace.c
  GEN     target/mips/trace.c
  GEN     target/sparc/trace.c
  GEN     target/s390x/trace.c
  GEN     target/ppc/trace.c
  GEN     qom/trace.c
  GEN     linux-user/trace.c
  GEN     qapi/trace.c
  GEN     accel/tcg/trace.c
  GEN     accel/kvm/trace.c
  GEN     nbd/trace.c
  GEN     scsi/trace.c
  GEN     config-all-devices.mak
Cloning into '/var/tmp/patchew-tester-tmp-j1ms6ngb/src/ui/keycodemapdb'...
  GEN     ui/input-keymap-linux-to-qcode.c
  GEN     ui/input-keymap-qcode-to-qnum.c
  GEN     ui/input-keymap-qnum-to-qcode.c
  CC      cs.o
  CC      SStream.o
  CC      MCInstrDesc.o
  CC      utils.o
  CC      MCRegisterInfo.o
  CC      arch/ARM/ARMDisassembler.o
  CC      arch/ARM/ARMMapping.o
  CC      arch/ARM/ARMInstPrinter.o
  CC      arch/ARM/ARMModule.o
  CC      arch/AArch64/AArch64BaseInfo.o
  CC      arch/AArch64/AArch64Disassembler.o
  CC      arch/AArch64/AArch64InstPrinter.o
  CC      arch/AArch64/AArch64Mapping.o
  CC      arch/AArch64/AArch64Module.o
  CC      arch/Mips/MipsDisassembler.o
  CC      arch/Mips/MipsInstPrinter.o
  CC      arch/Mips/MipsMapping.o
  CC      arch/Mips/MipsModule.o
  CC      arch/PowerPC/PPCDisassembler.o
  CC      arch/PowerPC/PPCInstPrinter.o
  CC      arch/PowerPC/PPCMapping.o
  CC      arch/PowerPC/PPCModule.o
  CC      arch/Sparc/SparcDisassembler.o
  CC      arch/Sparc/SparcInstPrinter.o
  CC      arch/Sparc/SparcMapping.o
  CC      arch/Sparc/SparcModule.o
  CC      arch/SystemZ/SystemZDisassembler.o
  CC      arch/SystemZ/SystemZInstPrinter.o
  CC      arch/SystemZ/SystemZMapping.o
  CC      arch/SystemZ/SystemZModule.o
  CC      arch/SystemZ/SystemZMCTargetDesc.o
  CC      arch/X86/X86DisassemblerDecoder.o
  CC      arch/X86/X86Disassembler.o
  CC      arch/X86/X86IntelInstPrinter.o
  CC      arch/X86/X86ATTInstPrinter.o
  CC      arch/X86/X86Mapping.o
  CC      arch/X86/X86Module.o
  CC      arch/XCore/XCoreDisassembler.o
  CC      arch/XCore/XCoreInstPrinter.o
  CC      arch/XCore/XCoreMapping.o
  CC      MCInst.o
  CC      arch/XCore/XCoreModule.o
  AR      libcapstone.a
ar: creating /var/tmp/patchew-tester-tmp-j1ms6ngb/src/build/capstone/libcapstone.a
make[1]: '/var/tmp/patchew-tester-tmp-j1ms6ngb/src/build/capstone/libcapstone.a' is up to date.
  CC      tests/qemu-iotests/socket_scm_helper.o
  GEN     docs/version.texi
  GEN     qemu-monitor.texi
  GEN     qemu-options.texi
  GEN     qemu-img-cmds.texi
  GEN     qemu-monitor-info.texi
  GEN     qemu-img.1
  GEN     qemu-nbd.8
  GEN     qemu-ga.8
  GEN     docs/interop/qemu-qmp-qapi.texi
  GEN     docs/interop/qemu-ga-qapi.texi
  GEN     docs/qemu-block-drivers.7
  GEN     fsdev/virtfs-proxy-helper.1
  GEN     qga/qapi-generated/qga-qapi-types.h
  GEN     qga/qapi-generated/qga-qapi-visit.h
  GEN     qga/qapi-generated/qga-qapi-types.c
  GEN     qga/qapi-generated/qga-qmp-commands.h
  GEN     qga/qapi-generated/qga-qapi-visit.c
  CC      qmp-introspect.o
  GEN     qga/qapi-generated/qga-qmp-marshal.c
  CC      qapi-types.o
  CC      qapi-visit.o
  CC      qapi-event.o
  CC      qapi/qapi-visit-core.o
  CC      qapi/qapi-dealloc-visitor.o
  CC      qapi/qobject-input-visitor.o
  CC      qapi/qobject-output-visitor.o
  CC      qapi/qmp-registry.o
  CC      qapi/qmp-dispatch.o
  CC      qapi/string-output-visitor.o
  CC      qapi/string-input-visitor.o
  CC      qapi/opts-visitor.o
  CC      qapi/qapi-clone-visitor.o
  CC      qapi/qmp-event.o
  CC      qapi/qapi-util.o
  CC      qobject/qnull.o
  CC      qobject/qnum.o
  CC      qobject/qstring.o
  CC      qobject/qdict.o
  CC      qobject/qlist.o
  CC      qobject/qbool.o
  CC      qobject/qlit.o
  CC      qobject/qjson.o
  CC      qobject/qobject.o
  CC      qobject/json-lexer.o
  CC      qobject/json-streamer.o
  CC      qobject/json-parser.o
  CC      trace/control.o
  CC      trace/qmp.o
  CC      util/osdep.o
  CC      util/cutils.o
  CC      util/qemu-timer-common.o
  CC      util/unicode.o
  CC      util/bufferiszero.o
  CC      util/lockcnt.o
  CC      util/aiocb.o
  CC      util/async.o
  CC      util/thread-pool.o
  CC      util/qemu-timer.o
  CC      util/main-loop.o
  CC      util/iohandler.o
  CC      util/aio-posix.o
  CC      util/compatfd.o
  CC      util/event_notifier-posix.o
  CC      util/mmap-alloc.o
  CC      util/oslib-posix.o
  CC      util/qemu-openpty.o
  CC      util/qemu-thread-posix.o
  CC      util/memfd.o
  CC      util/envlist.o
  CC      util/path.o
  CC      util/module.o
  CC      util/host-utils.o
  CC      util/bitmap.o
  CC      util/bitops.o
  CC      util/hbitmap.o
  CC      util/fifo8.o
  CC      util/acl.o
  CC      util/cacheinfo.o
  CC      util/error.o
  CC      util/qemu-error.o
  CC      util/iov.o
  CC      util/id.o
  CC      util/qemu-config.o
  CC      util/qemu-sockets.o
  CC      util/uri.o
  CC      util/notify.o
  CC      util/qemu-option.o
  CC      util/qemu-progress.o
  CC      util/keyval.o
  CC      util/hexdump.o
  CC      util/crc32c.o
  CC      util/uuid.o
  CC      util/throttle.o
  CC      util/getauxval.o
  CC      util/readline.o
  CC      util/rcu.o
  CC      util/qemu-coroutine.o
  CC      util/qemu-coroutine-lock.o
  CC      util/qemu-coroutine-io.o
  CC      util/qemu-coroutine-sleep.o
  CC      util/coroutine-ucontext.o
  CC      util/buffer.o
  CC      util/timed-average.o
  CC      util/base64.o
  CC      util/log.o
  CC      util/pagesize.o
  CC      util/qdist.o
  CC      util/qht.o
  CC      util/range.o
  CC      util/stats64.o
  CC      util/systemd.o
  CC      trace-root.o
  CC      util/trace.o
  CC      crypto/trace.o
  CC      io/trace.o
  CC      migration/trace.o
  CC      block/trace.o
  CC      chardev/trace.o
  CC      hw/block/trace.o
  CC      hw/block/dataplane/trace.o
  CC      hw/char/trace.o
  CC      hw/intc/trace.o
  CC      hw/net/trace.o
  CC      hw/virtio/trace.o
  CC      hw/audio/trace.o
  CC      hw/misc/trace.o
  CC      hw/usb/trace.o
  CC      hw/nvram/trace.o
  CC      hw/scsi/trace.o
  CC      hw/display/trace.o
  CC      hw/timer/trace.o
  CC      hw/input/trace.o
  CC      hw/dma/trace.o
  CC      hw/sparc/trace.o
  CC      hw/sd/trace.o
  CC      hw/isa/trace.o
  CC      hw/mem/trace.o
  CC      hw/i386/trace.o
  CC      hw/i386/xen/trace.o
  CC      hw/9pfs/trace.o
  CC      hw/ppc/trace.o
  CC      hw/pci/trace.o
  CC      hw/s390x/trace.o
  CC      hw/vfio/trace.o
  CC      hw/acpi/trace.o
  CC      hw/arm/trace.o
  CC      hw/alpha/trace.o
  CC      hw/xen/trace.o
  CC      hw/ide/trace.o
  CC      ui/trace.o
  CC      audio/trace.o
  CC      net/trace.o
  CC      target/arm/trace.o
  CC      target/mips/trace.o
  CC      target/i386/trace.o
  CC      target/sparc/trace.o
  CC      target/s390x/trace.o
  CC      target/ppc/trace.o
  CC      qom/trace.o
  CC      linux-user/trace.o
  CC      qapi/trace.o
  CC      accel/tcg/trace.o
  CC      accel/kvm/trace.o
  CC      nbd/trace.o
  CC      scsi/trace.o
  CC      crypto/pbkdf-stub.o
  CC      stubs/arch-query-cpu-def.o
  CC      stubs/arch-query-cpu-model-expansion.o
  CC      stubs/arch-query-cpu-model-comparison.o
  CC      stubs/arch-query-cpu-model-baseline.o
  CC      stubs/bdrv-next-monitor-owned.o
  CC      stubs/blk-commit-all.o
  CC      stubs/blockdev-close-all-bdrv-states.o
  CC      stubs/clock-warp.o
  CC      stubs/cpu-get-clock.o
  CC      stubs/cpu-get-icount.o
  CC      stubs/dump.o
  CC      stubs/error-printf.o
  CC      stubs/fdset.o
  CC      stubs/gdbstub.o
  CC      stubs/windbgstub.o
  CC      stubs/get-vm-name.o
  CC      stubs/iothread.o
  CC      stubs/iothread-lock.o
  CC      stubs/is-daemonized.o
  CC      stubs/linux-aio.o
  CC      stubs/machine-init-done.o
  CC      stubs/migr-blocker.o
  CC      stubs/change-state-handler.o
  CC      stubs/monitor.o
  CC      stubs/notify-event.o
  CC      stubs/qtest.o
  CC      stubs/replay.o
  CC      stubs/runstate-check.o
  CC      stubs/set-fd-handler.o
  CC      stubs/slirp.o
  CC      stubs/sysbus.o
  CC      stubs/tpm.o
  CC      stubs/trace-control.o
  CC      stubs/uuid.o
  CC      stubs/vmstate.o
  CC      stubs/vm-stop.o
  CC      stubs/qmp_pc_dimm.o
  CC      stubs/target-monitor-defs.o
  CC      stubs/target-get-monitor-def.o
  CC      stubs/pc_madt_cpu_entry.o
  CC      stubs/vmgenid.o
  CC      stubs/xen-common.o
  CC      stubs/pci-host-piix.o
  CC      stubs/xen-hvm.o
  CC      qemu-keymap.o
  CC      ui/input-keymap.o
  CC      contrib/ivshmem-client/ivshmem-client.o
  CC      contrib/ivshmem-client/main.o
  CC      contrib/ivshmem-server/ivshmem-server.o
  CC      contrib/ivshmem-server/main.o
  CC      qemu-nbd.o
  CC      block.o
  CC      blockjob.o
  CC      qemu-io-cmds.o
  CC      replication.o
  CC      block/raw-format.o
  CC      block/qcow.o
  CC      block/vdi.o
  CC      block/vmdk.o
  CC      block/cloop.o
  CC      block/bochs.o
  CC      block/vpc.o
  CC      block/vvfat.o
  CC      block/dmg.o
  CC      block/qcow2.o
  CC      block/qcow2-refcount.o
  CC      block/qcow2-cluster.o
  CC      block/qcow2-snapshot.o
  CC      block/qcow2-cache.o
  CC      block/qcow2-bitmap.o
  CC      block/qed.o
  CC      block/qed-l2-cache.o
  CC      block/qed-table.o
  CC      block/qed-cluster.o
  CC      block/qed-check.o
  CC      block/vhdx.o
  CC      block/vhdx-endian.o
  CC      block/vhdx-log.o
  CC      block/quorum.o
  CC      block/parallels.o
  CC      block/blkdebug.o
  CC      block/blkverify.o
  CC      block/blkreplay.o
  CC      block/block-backend.o
  CC      block/snapshot.o
  CC      block/qapi.o
  CC      block/file-posix.o
  CC      block/linux-aio.o
  CC      block/null.o
  CC      block/mirror.o
  CC      block/commit.o
  CC      block/io.o
  CC      block/throttle-groups.o
  CC      block/nbd.o
  CC      block/nbd-client.o
  CC      block/sheepdog.o
  CC      block/iscsi-opts.o
  CC      block/accounting.o
  CC      block/dirty-bitmap.o
  CC      block/write-threshold.o
  CC      block/backup.o
  CC      block/throttle.o
  CC      block/replication.o
  CC      block/crypto.o
  CC      nbd/server.o
  CC      nbd/client.o
  CC      nbd/common.o
  CC      scsi/utils.o
  CC      scsi/pr-manager.o
  CC      scsi/pr-manager-helper.o
  CC      block/iscsi.o
  CC      block/nfs.o
  CC      block/curl.o
  CC      block/rbd.o
  CC      block/gluster.o
  CC      block/ssh.o
  CC      block/dmg-bz2.o
  CC      crypto/init.o
  CC      crypto/hash.o
  CC      crypto/hash-nettle.o
  CC      crypto/hmac.o
  CC      crypto/hmac-nettle.o
  CC      crypto/aes.o
  CC      crypto/desrfb.o
  CC      crypto/cipher.o
  CC      crypto/tlscreds.o
  CC      crypto/tlscredsanon.o
  CC      crypto/tlscredsx509.o
  CC      crypto/tlssession.o
  CC      crypto/secret.o
  CC      crypto/random-gnutls.o
  CC      crypto/pbkdf.o
  CC      crypto/pbkdf-nettle.o
  CC      crypto/ivgen.o
  CC      crypto/ivgen-essiv.o
  CC      crypto/ivgen-plain.o
  CC      crypto/ivgen-plain64.o
  CC      crypto/afsplit.o
  CC      crypto/xts.o
  CC      crypto/block.o
  CC      crypto/block-qcow.o
  CC      crypto/block-luks.o
  CC      io/channel.o
  CC      io/channel-buffer.o
  CC      io/channel-command.o
  CC      io/channel-file.o
  CC      io/channel-socket.o
  CC      io/channel-tls.o
  CC      io/channel-watch.o
  CC      io/channel-websock.o
  CC      io/channel-util.o
  CC      io/dns-resolver.o
  CC      io/task.o
  CC      qom/object.o
  CC      qom/container.o
  CC      qom/qom-qobject.o
  CC      qom/object_interfaces.o
  GEN     qemu-img-cmds.h
  CC      qemu-io.o
  CC      fsdev/virtfs-proxy-helper.o
  CC      fsdev/9p-marshal.o
  CC      fsdev/9p-iov-marshal.o
  CC      scsi/qemu-pr-helper.o
  CC      qemu-bridge-helper.o
  CC      blockdev.o
  CC      blockdev-nbd.o
  CC      bootdevice.o
  CC      iothread.o
  CC      qdev-monitor.o
  CC      device-hotplug.o
  CC      os-posix.o
  CC      bt-host.o
  CC      bt-vhci.o
  CC      dma-helpers.o
  CC      vl.o
  CC      tpm.o
  CC      qemu-seccomp.o
  CC      device_tree.o
  CC      qmp-marshal.o
  CC      qmp.o
  CC      hmp.o
  CC      cpus-common.o
  CC      audio/audio.o
  CC      audio/noaudio.o
  CC      audio/wavaudio.o
  CC      audio/mixeng.o
  CC      audio/sdlaudio.o
  CC      audio/ossaudio.o
  CC      audio/wavcapture.o
  CC      backends/rng.o
  CC      backends/rng-egd.o
  CC      backends/rng-random.o
  CC      backends/tpm.o
  CC      backends/hostmem.o
  CC      backends/hostmem-ram.o
  CC      backends/hostmem-file.o
  CC      backends/cryptodev-builtin.o
  CC      backends/cryptodev.o
  CC      block/stream.o
  CC      chardev/msmouse.o
  CC      chardev/wctablet.o
  CC      chardev/testdev.o
  CC      chardev/baum.o
  CC      disas/alpha.o
  CC      disas/arm.o
  CXX     disas/arm-a64.o
  CC      disas/cris.o
  CC      disas/hppa.o
  CC      disas/i386.o
  CC      disas/m68k.o
  CC      disas/microblaze.o
  CC      disas/mips.o
  CC      disas/nios2.o
  CC      disas/moxie.o
  CC      disas/ppc.o
  CC      disas/s390.o
  CC      disas/sh4.o
  CC      disas/sparc.o
  CC      disas/lm32.o
  CXX     disas/libvixl/vixl/utils.o
  CXX     disas/libvixl/vixl/compiler-intrinsics.o
  CXX     disas/libvixl/vixl/a64/instructions-a64.o
  CXX     disas/libvixl/vixl/a64/decoder-a64.o
  CXX     disas/libvixl/vixl/a64/disasm-a64.o
  CC      fsdev/qemu-fsdev.o
  CC      fsdev/qemu-fsdev-opts.o
  CC      fsdev/qemu-fsdev-throttle.o
  CC      fsdev/qemu-fsdev-dummy.o
  CC      hw/9pfs/9p.o
  CC      hw/9pfs/9p-util.o
  CC      hw/9pfs/9p-local.o
  CC      hw/9pfs/9p-xattr.o
  CC      hw/9pfs/9p-xattr-user.o
  CC      hw/9pfs/9p-posix-acl.o
  CC      hw/9pfs/coth.o
  CC      hw/9pfs/cofs.o
  CC      hw/9pfs/codir.o
  CC      hw/9pfs/cofile.o
  CC      hw/9pfs/coxattr.o
  CC      hw/9pfs/9p-synth.o
  CC      hw/9pfs/9p-handle.o
  CC      hw/9pfs/9p-proxy.o
  CC      hw/acpi/core.o
  CC      hw/acpi/piix4.o
  CC      hw/acpi/pcihp.o
  CC      hw/acpi/ich9.o
  CC      hw/acpi/tco.o
  CC      hw/acpi/cpu_hotplug.o
  CC      hw/acpi/memory_hotplug.o
  CC      hw/acpi/cpu.o
  CC      hw/acpi/nvdimm.o
  CC      hw/acpi/vmgenid.o
  CC      hw/acpi/acpi_interface.o
  CC      hw/acpi/bios-linker-loader.o
  CC      hw/acpi/aml-build.o
  CC      hw/acpi/ipmi.o
  CC      hw/acpi/acpi-stub.o
  CC      hw/acpi/ipmi-stub.o
  CC      hw/audio/sb16.o
  CC      hw/audio/es1370.o
  CC      hw/audio/ac97.o
  CC      hw/audio/fmopl.o
  CC      hw/audio/adlib.o
  CC      hw/audio/gus.o
  CC      hw/audio/gusemu_mixer.o
  CC      hw/audio/gusemu_hal.o
  CC      hw/audio/cs4231a.o
  CC      hw/audio/intel-hda.o
  CC      hw/audio/hda-codec.o
  CC      hw/audio/pcspk.o
  CC      hw/audio/wm8750.o
  CC      hw/audio/pl041.o
  CC      hw/audio/lm4549.o
  CC      hw/audio/cs4231.o
  CC      hw/audio/marvell_88w8618.o
  CC      hw/audio/milkymist-ac97.o
  CC      hw/audio/soundhw.o
  CC      hw/block/block.o
  CC      hw/block/cdrom.o
  CC      hw/block/hd-geometry.o
  CC      hw/block/fdc.o
  CC      hw/block/m25p80.o
  CC      hw/block/nand.o
  CC      hw/block/pflash_cfi01.o
  CC      hw/block/ecc.o
  CC      hw/block/pflash_cfi02.o
  CC      hw/block/onenand.o
  CC      hw/block/nvme.o
  CC      hw/bt/core.o
  CC      hw/bt/l2cap.o
  CC      hw/bt/sdp.o
  CC      hw/bt/hci.o
  CC      hw/bt/hid.o
  CC      hw/bt/hci-csr.o
  CC      hw/char/ipoctal232.o
  CC      hw/char/escc.o
  CC      hw/char/parallel.o
  CC      hw/char/pl011.o
  CC      hw/char/serial.o
  CC      hw/char/serial-isa.o
  CC      hw/char/serial-pci.o
  CC      hw/char/virtio-console.o
  CC      hw/char/xilinx_uartlite.o
  CC      hw/char/cadence_uart.o
  CC      hw/char/cmsdk-apb-uart.o
  CC      hw/char/etraxfs_ser.o
  CC      hw/char/debugcon.o
  CC      hw/char/grlib_apbuart.o
  CC      hw/char/imx_serial.o
  CC      hw/char/lm32_juart.o
  CC      hw/char/lm32_uart.o
  CC      hw/char/milkymist-uart.o
  CC      hw/char/sclpconsole.o
  CC      hw/char/sclpconsole-lm.o
  CC      hw/core/qdev.o
  CC      hw/core/qdev-properties.o
  CC      hw/core/bus.o
  CC      hw/core/reset.o
  CC      hw/core/fw-path-provider.o
  CC      hw/core/irq.o
  CC      hw/core/hotplug.o
  CC      hw/core/nmi.o
  CC      hw/core/empty_slot.o
  CC      hw/core/stream.o
  CC      hw/core/ptimer.o
  CC      hw/core/sysbus.o
  CC      hw/core/machine.o
  CC      hw/core/loader.o
  CC      hw/core/loader-fit.o
  CC      hw/core/qdev-properties-system.o
  CC      hw/core/or-irq.o
  CC      hw/core/register.o
  CC      hw/core/platform-bus.o
  CC      hw/cpu/core.o
  CC      hw/display/ads7846.o
  CC      hw/display/cirrus_vga.o
  CC      hw/display/g364fb.o
  CC      hw/display/jazz_led.o
  CC      hw/display/pl110.o
  CC      hw/display/ssd0303.o
  CC      hw/display/ssd0323.o
  CC      hw/display/vga-pci.o
  CC      hw/display/vga-isa.o
  CC      hw/display/vga-isa-mm.o
  CC      hw/display/vmware_vga.o
  CC      hw/display/blizzard.o
  CC      hw/display/exynos4210_fimd.o
  CC      hw/display/framebuffer.o
  CC      hw/display/milkymist-vgafb.o
  CC      hw/display/tc6393xb.o
  CC      hw/display/milkymist-tmu2.o
  CC      hw/dma/puv3_dma.o
  CC      hw/dma/rc4030.o
  CC      hw/dma/pl080.o
  CC      hw/dma/pl330.o
  CC      hw/dma/i82374.o
  CC      hw/dma/i8257.o
  CC      hw/dma/xilinx_axidma.o
  CC      hw/dma/xlnx-zynq-devcfg.o
  CC      hw/dma/etraxfs_dma.o
  CC      hw/dma/sparc32_dma.o
  CC      hw/dma/sun4m_iommu.o
  CC      hw/gpio/max7310.o
  CC      hw/gpio/pl061.o
  CC      hw/gpio/puv3_gpio.o
  CC      hw/gpio/zaurus.o
  CC      hw/gpio/mpc8xxx.o
  CC      hw/gpio/gpio_key.o
  CC      hw/i2c/core.o
  CC      hw/i2c/smbus.o
  CC      hw/i2c/smbus_eeprom.o
  CC      hw/i2c/versatile_i2c.o
  CC      hw/i2c/i2c-ddc.o
  CC      hw/i2c/smbus_ich9.o
  CC      hw/i2c/pm_smbus.o
  CC      hw/i2c/bitbang_i2c.o
  CC      hw/i2c/exynos4210_i2c.o
  CC      hw/i2c/imx_i2c.o
  CC      hw/i2c/aspeed_i2c.o
  CC      hw/ide/core.o
  CC      hw/ide/atapi.o
  CC      hw/ide/qdev.o
  CC      hw/ide/pci.o
  CC      hw/ide/isa.o
  CC      hw/ide/piix.o
  CC      hw/ide/cmd646.o
  CC      hw/ide/macio.o
  CC      hw/ide/mmio.o
  CC      hw/ide/via.o
  CC      hw/ide/microdrive.o
  CC      hw/ide/ahci.o
  CC      hw/ide/ich.o
  CC      hw/ide/ahci-allwinner.o
  CC      hw/input/adb.o
  CC      hw/input/hid.o
  CC      hw/input/lm832x.o
  CC      hw/input/pckbd.o
  CC      hw/input/pl050.o
  CC      hw/input/ps2.o
  CC      hw/input/stellaris_input.o
  CC      hw/input/tsc2005.o
  CC      hw/input/vmmouse.o
  CC      hw/input/virtio-input.o
  CC      hw/input/virtio-input-hid.o
  CC      hw/input/virtio-input-host.o
  CC      hw/intc/heathrow_pic.o
  CC      hw/intc/i8259_common.o
  CC      hw/intc/i8259.o
  CC      hw/intc/pl190.o
  CC      hw/intc/puv3_intc.o
  CC      hw/intc/xilinx_intc.o
  CC      hw/intc/etraxfs_pic.o
  CC      hw/intc/imx_avic.o
  CC      hw/intc/lm32_pic.o
  CC      hw/intc/realview_gic.o
  CC      hw/intc/slavio_intctl.o
  CC      hw/intc/ioapic_common.o
  CC      hw/intc/arm_gic_common.o
  CC      hw/intc/arm_gic.o
  CC      hw/intc/arm_gicv2m.o
  CC      hw/intc/arm_gicv3_common.o
  CC      hw/intc/arm_gicv3.o
  CC      hw/intc/arm_gicv3_dist.o
  CC      hw/intc/arm_gicv3_redist.o
  CC      hw/intc/arm_gicv3_its_common.o
  CC      hw/intc/openpic.o
  CC      hw/intc/intc.o
  CC      hw/ipack/ipack.o
  CC      hw/ipack/tpci200.o
  CC      hw/ipmi/ipmi.o
  CC      hw/ipmi/ipmi_bmc_sim.o
  CC      hw/ipmi/ipmi_bmc_extern.o
  CC      hw/ipmi/isa_ipmi_kcs.o
  CC      hw/ipmi/isa_ipmi_bt.o
  CC      hw/isa/isa-bus.o
  CC      hw/isa/apm.o
  CC      hw/isa/i82378.o
  CC      hw/isa/pc87312.o
  CC      hw/isa/piix4.o
  CC      hw/isa/vt82c686.o
  CC      hw/mem/pc-dimm.o
  CC      hw/mem/nvdimm.o
  CC      hw/misc/applesmc.o
  CC      hw/misc/max111x.o
  CC      hw/misc/tmp105.o
  CC      hw/misc/tmp421.o
  CC      hw/misc/debugexit.o
  CC      hw/misc/sga.o
  CC      hw/misc/pc-testdev.o
  CC      hw/misc/pci-testdev.o
  CC      hw/misc/edu.o
  CC      hw/misc/unimp.o
  CC      hw/misc/vmcoreinfo.o
  CC      hw/misc/arm_l2x0.o
  CC      hw/misc/arm_integrator_debug.o
  CC      hw/misc/a9scu.o
  CC      hw/misc/arm11scu.o
  CC      hw/misc/puv3_pm.o
  CC      hw/misc/macio/macio.o
  CC      hw/misc/macio/cuda.o
  CC      hw/misc/macio/mac_dbdma.o
  CC      hw/net/dp8393x.o
  CC      hw/net/ne2000.o
  CC      hw/net/eepro100.o
  CC      hw/net/pcnet-pci.o
  CC      hw/net/pcnet.o
  CC      hw/net/e1000.o
  CC      hw/net/e1000x_common.o
  CC      hw/net/net_tx_pkt.o
  CC      hw/net/net_rx_pkt.o
  CC      hw/net/e1000e.o
  CC      hw/net/e1000e_core.o
  CC      hw/net/rtl8139.o
  CC      hw/net/vmxnet3.o
  CC      hw/net/smc91c111.o
  CC      hw/net/lan9118.o
  CC      hw/net/ne2000-isa.o
  CC      hw/net/opencores_eth.o
  CC      hw/net/xgmac.o
  CC      hw/net/mipsnet.o
  CC      hw/net/xilinx_axienet.o
  CC      hw/net/allwinner_emac.o
  CC      hw/net/imx_fec.o
  CC      hw/net/cadence_gem.o
  CC      hw/net/stellaris_enet.o
  CC      hw/net/lance.o
  CC      hw/net/sunhme.o
  CC      hw/net/ftgmac100.o
  CC      hw/net/sungem.o
  CC      hw/net/rocker/rocker.o
  CC      hw/net/rocker/rocker_fp.o
  CC      hw/net/rocker/rocker_desc.o
  CC      hw/net/rocker/rocker_world.o
  CC      hw/net/rocker/rocker_of_dpa.o
  CC      hw/nvram/ds1225y.o
  CC      hw/nvram/eeprom93xx.o
  CC      hw/nvram/fw_cfg.o
  CC      hw/nvram/chrp_nvram.o
  CC      hw/nvram/mac_nvram.o
  CC      hw/pci-bridge/pci_bridge_dev.o
  CC      hw/pci-bridge/pcie_root_port.o
  CC      hw/pci-bridge/gen_pcie_root_port.o
  CC      hw/pci-bridge/pcie_pci_bridge.o
  CC      hw/pci-bridge/pci_expander_bridge.o
  CC      hw/pci-bridge/xio3130_upstream.o
  CC      hw/pci-bridge/xio3130_downstream.o
  CC      hw/pci-bridge/ioh3420.o
  CC      hw/pci-bridge/i82801b11.o
  CC      hw/pci-bridge/dec.o
  CC      hw/pci-host/pam.o
  CC      hw/pci-host/prep.o
  CC      hw/pci-host/grackle.o
  CC      hw/pci-host/uninorth.o
  CC      hw/pci-host/ppce500.o
  CC      hw/pci-host/versatile.o
  CC      hw/pci-host/apb.o
  CC      hw/pci-host/bonito.o
  CC      hw/pci-host/piix.o
  CC      hw/pci-host/q35.o
  CC      hw/pci-host/gpex.o
  CC      hw/pci-host/xilinx-pcie.o
  CC      hw/pci/pci.o
  CC      hw/pci/pci_bridge.o
  CC      hw/pci/msix.o
  CC      hw/pci/msi.o
  CC      hw/pci/shpc.o
  CC      hw/pci/slotid_cap.o
  CC      hw/pci/pci_host.o
  CC      hw/pci/pcie_host.o
  CC      hw/pci/pcie.o
  CC      hw/pci/pcie_aer.o
  CC      hw/pci/pcie_port.o
  CC      hw/pci/pci-stub.o
  CC      hw/pcmcia/pcmcia.o
  CC      hw/scsi/scsi-disk.o
  CC      hw/scsi/scsi-generic.o
  CC      hw/scsi/scsi-bus.o
  CC      hw/scsi/lsi53c895a.o
  CC      hw/scsi/mptsas.o
  CC      hw/scsi/mptconfig.o
  CC      hw/scsi/mptendian.o
  CC      hw/scsi/megasas.o
  CC      hw/scsi/vmw_pvscsi.o
  CC      hw/scsi/esp.o
  CC      hw/scsi/esp-pci.o
  CC      hw/sd/pl181.o
  CC      hw/sd/ssi-sd.o
  CC      hw/sd/sd.o
  CC      hw/sd/core.o
  CC      hw/sd/sdhci.o
  CC      hw/smbios/smbios.o
  CC      hw/smbios/smbios_type_38.o
  CC      hw/smbios/smbios-stub.o
  CC      hw/smbios/smbios_type_38-stub.o
  CC      hw/ssi/pl022.o
  CC      hw/ssi/ssi.o
  CC      hw/ssi/xilinx_spi.o
  CC      hw/ssi/xilinx_spips.o
  CC      hw/ssi/aspeed_smc.o
  CC      hw/ssi/stm32f2xx_spi.o
  CC      hw/ssi/mss-spi.o
  CC      hw/timer/arm_timer.o
  CC      hw/timer/arm_mptimer.o
  CC      hw/timer/armv7m_systick.o
  CC      hw/timer/a9gtimer.o
  CC      hw/timer/cadence_ttc.o
  CC      hw/timer/ds1338.o
  CC      hw/timer/hpet.o
  CC      hw/timer/i8254_common.o
  CC      hw/timer/i8254.o
  CC      hw/timer/m48t59.o
  CC      hw/timer/m48t59-isa.o
  CC      hw/timer/pl031.o
  CC      hw/timer/puv3_ost.o
  CC      hw/timer/twl92230.o
  CC      hw/timer/xilinx_timer.o
  CC      hw/timer/slavio_timer.o
  CC      hw/timer/etraxfs_timer.o
  CC      hw/timer/grlib_gptimer.o
  CC      hw/timer/imx_epit.o
  CC      hw/timer/imx_gpt.o
  CC      hw/timer/milkymist-sysctl.o
  CC      hw/timer/lm32_timer.o
  CC      hw/timer/stm32f2xx_timer.o
  CC      hw/timer/aspeed_timer.o
  CC      hw/timer/cmsdk-apb-timer.o
  CC      hw/timer/sun4v-rtc.o
  CC      hw/timer/mss-timer.o
  CC      hw/tpm/tpm_tis.o
  CC      hw/tpm/tpm_emulator.o
  CC      hw/tpm/tpm_util.o
  CC      hw/usb/core.o
  CC      hw/usb/combined-packet.o
  CC      hw/usb/bus.o
  CC      hw/usb/libhw.o
  CC      hw/usb/desc.o
  CC      hw/usb/desc-msos.o
  CC      hw/usb/hcd-uhci.o
  CC      hw/usb/hcd-ohci.o
  CC      hw/usb/hcd-ehci.o
  CC      hw/usb/hcd-ehci-pci.o
  CC      hw/usb/hcd-ehci-sysbus.o
  CC      hw/usb/hcd-xhci.o
  CC      hw/usb/hcd-xhci-nec.o
  CC      hw/usb/hcd-musb.o
  CC      hw/usb/dev-hub.o
  CC      hw/usb/dev-hid.o
  CC      hw/usb/dev-wacom.o
  CC      hw/usb/dev-storage.o
  CC      hw/usb/dev-uas.o
  CC      hw/usb/dev-audio.o
  CC      hw/usb/dev-serial.o
  CC      hw/usb/dev-network.o
  CC      hw/usb/dev-bluetooth.o
  CC      hw/usb/dev-smartcard-reader.o
  CC      hw/usb/ccid-card-passthru.o
  CC      hw/usb/ccid-card-emulated.o
  CC      hw/usb/dev-mtp.o
  CC      hw/usb/redirect.o
  CC      hw/usb/quirks.o
  CC      hw/usb/host-libusb.o
  CC      hw/usb/host-legacy.o
  CC      hw/usb/host-stub.o
  CC      hw/virtio/virtio-rng.o
  CC      hw/virtio/virtio-pci.o
  CC      hw/virtio/virtio-bus.o
  CC      hw/virtio/virtio-mmio.o
  CC      hw/virtio/vhost-stub.o
  CC      hw/watchdog/watchdog.o
  CC      hw/watchdog/wdt_i6300esb.o
  CC      hw/watchdog/wdt_ib700.o
  CC      hw/watchdog/wdt_diag288.o
  CC      hw/watchdog/wdt_aspeed.o
  CC      migration/migration.o
  CC      migration/socket.o
  CC      migration/fd.o
  CC      migration/exec.o
  CC      migration/tls.o
  CC      migration/channel.o
  CC      migration/savevm.o
  CC      migration/colo-comm.o
  CC      migration/colo.o
  CC      migration/colo-failover.o
  CC      migration/vmstate.o
  CC      migration/vmstate-types.o
  CC      migration/page_cache.o
  CC      migration/qemu-file.o
  CC      migration/global_state.o
  CC      migration/qemu-file-channel.o
  CC      migration/xbzrle.o
  CC      migration/postcopy-ram.o
  CC      migration/qjson.o
  CC      migration/block.o
  CC      net/net.o
  CC      net/queue.o
  CC      net/checksum.o
  CC      net/util.o
  CC      net/hub.o
  CC      net/socket.o
  CC      net/dump.o
  CC      net/eth.o
  CC      net/l2tpv3.o
  CC      net/vhost-user.o
  CC      net/filter.o
  CC      net/slirp.o
  CC      net/filter-buffer.o
  CC      net/filter-mirror.o
  CC      net/colo-compare.o
  CC      net/filter-rewriter.o
  CC      net/colo.o
  CC      net/filter-replay.o
  CC      net/tap-linux.o
  CC      net/tap.o
  CC      qom/cpu.o
  CC      replay/replay.o
  CC      replay/replay-internal.o
  CC      replay/replay-events.o
  CC      replay/replay-input.o
  CC      replay/replay-time.o
  CC      replay/replay-char.o
  CC      replay/replay-snapshot.o
  CC      replay/replay-net.o
  CC      replay/replay-audio.o
  CC      slirp/cksum.o
  CC      slirp/if.o
  CC      slirp/ip_icmp.o
  CC      slirp/ip6_icmp.o
  CC      slirp/ip6_input.o
  CC      slirp/ip6_output.o
  CC      slirp/ip_input.o
  CC      slirp/ip_output.o
  CC      slirp/dnssearch.o
  CC      slirp/dhcpv6.o
  CC      slirp/slirp.o
  CC      slirp/mbuf.o
  CC      slirp/misc.o
  CC      slirp/sbuf.o
  CC      slirp/socket.o
  CC      slirp/tcp_input.o
  CC      slirp/tcp_output.o
  CC      slirp/tcp_subr.o
  CC      slirp/tcp_timer.o
  CC      slirp/udp.o
  CC      slirp/udp6.o
  CC      slirp/bootp.o
  CC      slirp/tftp.o
  CC      slirp/arp_table.o
  CC      slirp/ndp_table.o
  CC      slirp/ncsi.o
  CC      ui/keymaps.o
  CC      ui/cursor.o
  CC      ui/console.o
  CC      ui/qemu-pixman.o
  CC      ui/input.o
  CC      ui/input-legacy.o
  CC      ui/input-linux.o
  CC      ui/sdl2.o
  CC      ui/sdl2-input.o
  CC      ui/sdl2-2d.o
  CC      ui/sdl2-gl.o
  CC      ui/x_keymap.o
  CC      ui/curses.o
  CC      ui/vnc.o
  CC      ui/vnc-enc-zlib.o
  CC      ui/vnc-enc-hextile.o
  CC      ui/vnc-enc-tight.o
  CC      ui/vnc-palette.o
  CC      ui/vnc-enc-zrle.o
  CC      ui/vnc-auth-vencrypt.o
  CC      ui/vnc-auth-sasl.o
  CC      ui/vnc-ws.o
  CC      ui/vnc-jobs.o
  CC      ui/gtk.o
  VERT    ui/shader/texture-blit-vert.h
  VERT    ui/shader/texture-blit-flip-vert.h
  FRAG    ui/shader/texture-blit-frag.h
  CC      ui/console-gl.o
  CC      ui/egl-helpers.o
  CC      ui/egl-context.o
  CC      ui/egl-headless.o
  CC      ui/gtk-gl-area.o
  CC      chardev/char.o
  CC      chardev/char-fd.o
  CC      chardev/char-fe.o
  CC      chardev/char-file.o
  CC      chardev/char-io.o
  CC      chardev/char-mux.o
  CC      chardev/char-null.o
  CC      chardev/char-parallel.o
  CC      chardev/char-pipe.o
  CC      chardev/char-pty.o
  CC      chardev/char-ringbuf.o
  CC      chardev/char-serial.o
  CC      chardev/char-socket.o
  CC      chardev/char-stdio.o
  CC      chardev/char-udp.o
  LINK    tests/qemu-iotests/socket_scm_helper
  CCAS    s390-ccw/start.o
  CC      s390-ccw/main.o
  CC      s390-ccw/bootmap.o
  CC      s390-ccw/sclp.o
  CC      s390-ccw/virtio.o
  GEN     qemu-doc.html
  GEN     qemu-doc.txt
  CC      s390-ccw/virtio-scsi.o
  CC      s390-ccw/virtio-blkdev.o
  GEN     qemu.1
s390-netboot.img not built since roms/SLOF/ is not available.
  BUILD   s390-ccw/s390-ccw.elf
  STRIP   s390-ccw/s390-ccw.img
  GEN     docs/interop/qemu-qmp-ref.html
  GEN     docs/interop/qemu-qmp-ref.txt
  GEN     docs/interop/qemu-qmp-ref.7
  GEN     docs/interop/qemu-ga-ref.html
  GEN     docs/interop/qemu-ga-ref.txt
  GEN     docs/interop/qemu-ga-ref.7
  CC      qga/commands.o
  CC      qga/guest-agent-command-state.o
  CC      qga/main.o
  CC      qga/commands-posix.o
  CC      qga/channel-posix.o
  CC      qga/qapi-generated/qga-qapi-types.o
  CC      qga/qapi-generated/qga-qapi-visit.o
  CC      qga/qapi-generated/qga-qmp-marshal.o
  AR      libqemuutil.a
  CC      qemu-img.o
  CC      ui/shader.o
  LINK    qemu-keymap
  LINK    ivshmem-client
  LINK    ivshmem-server
  LINK    qemu-nbd
  LINK    qemu-io
  LINK    fsdev/virtfs-proxy-helper
  LINK    scsi/qemu-pr-helper
  LINK    qemu-bridge-helper
  GEN     alpha-softmmu/hmp-commands.h
  GEN     cris-softmmu/hmp-commands.h
  GEN     cris-softmmu/hmp-commands-info.h
  GEN     cris-softmmu/config-target.h
  GEN     alpha-softmmu/hmp-commands-info.h
  CC      cris-softmmu/exec.o
  GEN     alpha-softmmu/config-target.h
  CC      alpha-softmmu/exec.o
  GEN     aarch64-softmmu/hmp-commands.h
  GEN     aarch64-softmmu/hmp-commands-info.h
  GEN     aarch64-softmmu/config-target.h
  CC      aarch64-softmmu/exec.o
  GEN     arm-softmmu/hmp-commands.h
  GEN     arm-softmmu/hmp-commands-info.h
  GEN     arm-softmmu/config-target.h
  CC      arm-softmmu/exec.o
  CC      alpha-softmmu/tcg/tcg.o
  CC      cris-softmmu/tcg/tcg.o
  CC      aarch64-softmmu/tcg/tcg.o
  CC      arm-softmmu/tcg/tcg.o
  CC      alpha-softmmu/tcg/tcg-op.o
  CC      aarch64-softmmu/tcg/tcg-op.o
  CC      cris-softmmu/tcg/tcg-op.o
  CC      arm-softmmu/tcg/tcg-op.o
  CC      alpha-softmmu/tcg/optimize.o
  CC      aarch64-softmmu/tcg/optimize.o
  CC      alpha-softmmu/tcg/tcg-common.o
  CC      cris-softmmu/tcg/optimize.o
  CC      alpha-softmmu/fpu/softfloat.o
  CC      aarch64-softmmu/tcg/tcg-common.o
  CC      cris-softmmu/tcg/tcg-common.o
  CC      aarch64-softmmu/fpu/softfloat.o
  CC      arm-softmmu/tcg/optimize.o
  CC      cris-softmmu/fpu/softfloat.o
  CC      arm-softmmu/tcg/tcg-common.o
  CC      alpha-softmmu/disas.o
  CC      arm-softmmu/fpu/softfloat.o
  CC      alpha-softmmu/arch_init.o
  CC      aarch64-softmmu/disas.o
  CC      alpha-softmmu/cpus.o
  CC      cris-softmmu/disas.o
  GEN     aarch64-softmmu/gdbstub-xml.c
  CC      cris-softmmu/arch_init.o
  CC      alpha-softmmu/monitor.o
  CC      cris-softmmu/cpus.o
  CC      aarch64-softmmu/arch_init.o
  CC      cris-softmmu/monitor.o
  CC      aarch64-softmmu/cpus.o
  CC      arm-softmmu/disas.o
  CC      alpha-softmmu/gdbstub.o
  CC      aarch64-softmmu/monitor.o
  GEN     arm-softmmu/gdbstub-xml.c
  CC      alpha-softmmu/balloon.o
  CC      arm-softmmu/arch_init.o
  CC      cris-softmmu/gdbstub.o
  CC      alpha-softmmu/ioport.o
  CC      arm-softmmu/cpus.o
  CC      alpha-softmmu/numa.o
  CC      aarch64-softmmu/gdbstub.o
  CC      cris-softmmu/balloon.o
  CC      arm-softmmu/monitor.o
  CC      cris-softmmu/ioport.o
  CC      alpha-softmmu/qtest.o
  CC      aarch64-softmmu/balloon.o
  CC      cris-softmmu/numa.o
  CC      alpha-softmmu/memory.o
  CC      aarch64-softmmu/ioport.o
  CC      cris-softmmu/qtest.o
  CC      aarch64-softmmu/numa.o
  CC      arm-softmmu/gdbstub.o
  CC      cris-softmmu/memory.o
  CC      aarch64-softmmu/qtest.o
  CC      alpha-softmmu/memory_mapping.o
  CC      aarch64-softmmu/memory.o
  CC      arm-softmmu/balloon.o
  CC      alpha-softmmu/dump.o
  CC      arm-softmmu/ioport.o
  CC      cris-softmmu/memory_mapping.o
  CC      alpha-softmmu/migration/ram.o
  CC      arm-softmmu/numa.o
  CC      cris-softmmu/dump.o
  CC      aarch64-softmmu/memory_mapping.o
  CC      arm-softmmu/qtest.o
  CC      aarch64-softmmu/dump.o
  CC      alpha-softmmu/accel/accel.o
  CC      cris-softmmu/migration/ram.o
  CC      arm-softmmu/memory.o
  CC      alpha-softmmu/accel/stubs/hax-stub.o
  CC      aarch64-softmmu/migration/ram.o
  CC      alpha-softmmu/accel/stubs/kvm-stub.o
  CC      cris-softmmu/accel/accel.o
  CC      alpha-softmmu/accel/tcg/tcg-all.o
  CC      arm-softmmu/memory_mapping.o
  CC      cris-softmmu/accel/stubs/hax-stub.o
  CC      aarch64-softmmu/accel/accel.o
  CC      alpha-softmmu/accel/tcg/cputlb.o
  CC      arm-softmmu/dump.o
  CC      cris-softmmu/accel/stubs/kvm-stub.o
  CC      aarch64-softmmu/accel/stubs/hax-stub.o
  CC      cris-softmmu/accel/tcg/tcg-all.o
  CC      aarch64-softmmu/accel/stubs/kvm-stub.o
  CC      cris-softmmu/accel/tcg/cputlb.o
  CC      arm-softmmu/migration/ram.o
  CC      aarch64-softmmu/accel/tcg/tcg-all.o
  CC      alpha-softmmu/accel/tcg/tcg-runtime.o
  CC      aarch64-softmmu/accel/tcg/cputlb.o
  CC      arm-softmmu/accel/accel.o
  CC      alpha-softmmu/accel/tcg/cpu-exec.o
  CC      cris-softmmu/accel/tcg/tcg-runtime.o
  CC      arm-softmmu/accel/stubs/hax-stub.o
  CC      alpha-softmmu/accel/tcg/cpu-exec-common.o
  CC      cris-softmmu/accel/tcg/cpu-exec.o
  CC      arm-softmmu/accel/stubs/kvm-stub.o
  CC      alpha-softmmu/accel/tcg/translate-all.o
  CC      cris-softmmu/accel/tcg/cpu-exec-common.o
  CC      arm-softmmu/accel/tcg/tcg-all.o
  CC      cris-softmmu/accel/tcg/translate-all.o
  CC      arm-softmmu/accel/tcg/cputlb.o
  CC      alpha-softmmu/accel/tcg/translator.o
  CC      aarch64-softmmu/accel/tcg/tcg-runtime.o
  CC      cris-softmmu/accel/tcg/translator.o
  CC      alpha-softmmu/hw/9pfs/virtio-9p-device.o
  CC      aarch64-softmmu/accel/tcg/cpu-exec.o
  CC      cris-softmmu/hw/core/generic-loader.o
  CC      alpha-softmmu/hw/block/virtio-blk.o
  CC      cris-softmmu/hw/core/null-machine.o
  CC      alpha-softmmu/hw/block/dataplane/virtio-blk.o
  CC      aarch64-softmmu/accel/tcg/cpu-exec-common.o
  CC      cris-softmmu/hw/misc/mmio_interface.o
  CC      arm-softmmu/accel/tcg/tcg-runtime.o
  CC      aarch64-softmmu/accel/tcg/translate-all.o
  CC      alpha-softmmu/hw/char/virtio-serial-bus.o
  CC      cris-softmmu/hw/net/etraxfs_eth.o
  CC      arm-softmmu/accel/tcg/cpu-exec.o
  CC      cris-softmmu/hw/net/vhost_net.o
  CC      aarch64-softmmu/accel/tcg/translator.o
  CC      alpha-softmmu/hw/core/generic-loader.o
  CC      cris-softmmu/hw/net/rocker/qmp-norocker.o
  CC      cris-softmmu/hw/vfio/common.o
  CC      aarch64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      alpha-softmmu/hw/core/null-machine.o
  CC      arm-softmmu/accel/tcg/cpu-exec-common.o
  CC      aarch64-softmmu/hw/adc/stm32f2xx_adc.o
  CC      alpha-softmmu/hw/display/vga.o
  CC      arm-softmmu/accel/tcg/translate-all.o
  CC      cris-softmmu/hw/vfio/platform.o
  CC      aarch64-softmmu/hw/block/virtio-blk.o
  CC      arm-softmmu/accel/tcg/translator.o
  CC      cris-softmmu/hw/vfio/spapr.o
  CC      aarch64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      cris-softmmu/hw/cris/boot.o
  CC      alpha-softmmu/hw/display/virtio-gpu.o
  CC      arm-softmmu/hw/9pfs/virtio-9p-device.o
  CC      aarch64-softmmu/hw/char/exynos4210_uart.o
  CC      cris-softmmu/hw/cris/axis_dev88.o
  CC      aarch64-softmmu/hw/char/omap_uart.o
  CC      arm-softmmu/hw/adc/stm32f2xx_adc.o
  CC      cris-softmmu/target/cris/translate.o
  CC      aarch64-softmmu/hw/char/digic-uart.o
  CC      alpha-softmmu/hw/display/virtio-gpu-3d.o
  CC      arm-softmmu/hw/block/virtio-blk.o
  CC      aarch64-softmmu/hw/char/stm32f2xx_usart.o
  CC      alpha-softmmu/hw/display/virtio-gpu-pci.o
  CC      arm-softmmu/hw/block/dataplane/virtio-blk.o
  CC      aarch64-softmmu/hw/char/bcm2835_aux.o
  CC      arm-softmmu/hw/char/exynos4210_uart.o
  CC      alpha-softmmu/hw/misc/ivshmem.o
  CC      aarch64-softmmu/hw/char/virtio-serial-bus.o
  CC      cris-softmmu/target/cris/op_helper.o
  CC      arm-softmmu/hw/char/omap_uart.o
  CC      alpha-softmmu/hw/misc/mmio_interface.o
  CC      aarch64-softmmu/hw/core/generic-loader.o
  CC      cris-softmmu/target/cris/helper.o
  CC      arm-softmmu/hw/char/digic-uart.o
  CC      alpha-softmmu/hw/net/virtio-net.o
  CC      aarch64-softmmu/hw/core/null-machine.o
  CC      arm-softmmu/hw/char/stm32f2xx_usart.o
  CC      cris-softmmu/target/cris/cpu.o
  CC      arm-softmmu/hw/char/bcm2835_aux.o
  CC      aarch64-softmmu/hw/cpu/arm11mpcore.o
  CC      cris-softmmu/target/cris/gdbstub.o
  CC      arm-softmmu/hw/char/virtio-serial-bus.o
  CC      aarch64-softmmu/hw/cpu/realview_mpcore.o
  CC      alpha-softmmu/hw/net/vhost_net.o
  CC      cris-softmmu/target/cris/mmu.o
  CC      aarch64-softmmu/hw/cpu/a9mpcore.o
  CC      cris-softmmu/target/cris/machine.o
  CC      alpha-softmmu/hw/scsi/virtio-scsi.o
  CC      arm-softmmu/hw/core/generic-loader.o
  GEN     trace/generated-helpers.c
  CC      aarch64-softmmu/hw/cpu/a15mpcore.o
  CC      cris-softmmu/trace/control-target.o
  CC      arm-softmmu/hw/core/null-machine.o
  CC      alpha-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      aarch64-softmmu/hw/display/omap_dss.o
  CC      arm-softmmu/hw/cpu/arm11mpcore.o
  CC      cris-softmmu/trace/generated-helpers.o
  CC      alpha-softmmu/hw/scsi/vhost-scsi-common.o
  LINK    cris-softmmu/qemu-system-cris
  CC      aarch64-softmmu/hw/display/omap_lcdc.o
  CC      arm-softmmu/hw/cpu/realview_mpcore.o
  CC      alpha-softmmu/hw/scsi/vhost-scsi.o
  CC      arm-softmmu/hw/cpu/a9mpcore.o
  CC      aarch64-softmmu/hw/display/pxa2xx_lcd.o
  CC      alpha-softmmu/hw/scsi/vhost-user-scsi.o
  CC      arm-softmmu/hw/cpu/a15mpcore.o
  CC      alpha-softmmu/hw/timer/mc146818rtc.o
  CC      arm-softmmu/hw/display/omap_dss.o
  CC      alpha-softmmu/hw/vfio/common.o
  GEN     i386-softmmu/hmp-commands.h
  CC      aarch64-softmmu/hw/display/bcm2835_fb.o
  GEN     i386-softmmu/hmp-commands-info.h
  GEN     i386-softmmu/config-target.h
  CC      i386-softmmu/exec.o
  CC      arm-softmmu/hw/display/omap_lcdc.o
  CC      alpha-softmmu/hw/vfio/pci.o
  CC      arm-softmmu/hw/display/pxa2xx_lcd.o
  CC      aarch64-softmmu/hw/display/vga.o
  CC      arm-softmmu/hw/display/bcm2835_fb.o
  CC      aarch64-softmmu/hw/display/virtio-gpu.o
  CC      alpha-softmmu/hw/vfio/pci-quirks.o
  CC      i386-softmmu/tcg/tcg.o
  CC      arm-softmmu/hw/display/vga.o
  CC      alpha-softmmu/hw/vfio/platform.o
  CC      aarch64-softmmu/hw/display/virtio-gpu-3d.o
  CC      alpha-softmmu/hw/vfio/spapr.o
  CC      arm-softmmu/hw/display/virtio-gpu.o
  CC      aarch64-softmmu/hw/display/virtio-gpu-pci.o
  CC      alpha-softmmu/hw/virtio/virtio.o
  CC      aarch64-softmmu/hw/display/dpcd.o
  CC      i386-softmmu/tcg/tcg-op.o
  CC      arm-softmmu/hw/display/virtio-gpu-3d.o
  CC      aarch64-softmmu/hw/display/xlnx_dp.o
  CC      alpha-softmmu/hw/virtio/virtio-balloon.o
  CC      arm-softmmu/hw/display/virtio-gpu-pci.o
  CC      aarch64-softmmu/hw/dma/xlnx_dpdma.o
  CC      alpha-softmmu/hw/virtio/vhost.o
  CC      arm-softmmu/hw/dma/omap_dma.o
  CC      aarch64-softmmu/hw/dma/omap_dma.o
  CC      i386-softmmu/tcg/optimize.o
  CC      alpha-softmmu/hw/virtio/vhost-backend.o
  CC      arm-softmmu/hw/dma/soc_dma.o
  CC      alpha-softmmu/hw/virtio/vhost-user.o
  CC      aarch64-softmmu/hw/dma/soc_dma.o
  CC      alpha-softmmu/hw/virtio/vhost-vsock.o
  CC      aarch64-softmmu/hw/dma/pxa2xx_dma.o
  CC      arm-softmmu/hw/dma/pxa2xx_dma.o
  CC      i386-softmmu/tcg/tcg-common.o
  CC      aarch64-softmmu/hw/dma/bcm2835_dma.o
  CC      alpha-softmmu/hw/virtio/virtio-crypto.o
  CC      arm-softmmu/hw/dma/bcm2835_dma.o
  CC      aarch64-softmmu/hw/gpio/omap_gpio.o
  CC      i386-softmmu/fpu/softfloat.o
  CC      arm-softmmu/hw/gpio/omap_gpio.o
  CC      alpha-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      aarch64-softmmu/hw/gpio/imx_gpio.o
  CC      arm-softmmu/hw/gpio/imx_gpio.o
  CC      alpha-softmmu/hw/alpha/dp264.o
  CC      aarch64-softmmu/hw/gpio/bcm2835_gpio.o
  CC      arm-softmmu/hw/gpio/bcm2835_gpio.o
  CC      alpha-softmmu/hw/alpha/pci.o
  CC      aarch64-softmmu/hw/i2c/omap_i2c.o
  CC      alpha-softmmu/hw/alpha/typhoon.o
  CC      arm-softmmu/hw/i2c/omap_i2c.o
  CC      aarch64-softmmu/hw/input/pxa2xx_keypad.o
  CC      alpha-softmmu/target/alpha/machine.o
  CC      arm-softmmu/hw/input/pxa2xx_keypad.o
  CC      arm-softmmu/hw/input/tsc210x.o
  CC      alpha-softmmu/target/alpha/translate.o
  CC      aarch64-softmmu/hw/input/tsc210x.o
  CC      i386-softmmu/disas.o
  CC      aarch64-softmmu/hw/intc/armv7m_nvic.o
  CC      arm-softmmu/hw/intc/armv7m_nvic.o
  GEN     i386-softmmu/gdbstub-xml.c
  CC      aarch64-softmmu/hw/intc/exynos4210_gic.o
  CC      arm-softmmu/hw/intc/exynos4210_gic.o
  CC      aarch64-softmmu/hw/intc/exynos4210_combiner.o
  CC      arm-softmmu/hw/intc/exynos4210_combiner.o
  CC      alpha-softmmu/target/alpha/helper.o
  CC      i386-softmmu/arch_init.o
  CC      aarch64-softmmu/hw/intc/omap_intc.o
  CC      arm-softmmu/hw/intc/omap_intc.o
  CC      alpha-softmmu/target/alpha/cpu.o
  CC      i386-softmmu/cpus.o
  CC      alpha-softmmu/target/alpha/int_helper.o
  CC      aarch64-softmmu/hw/intc/bcm2835_ic.o
  CC      arm-softmmu/hw/intc/bcm2835_ic.o
  CC      aarch64-softmmu/hw/intc/bcm2836_control.o
  CC      alpha-softmmu/target/alpha/fpu_helper.o
  CC      aarch64-softmmu/hw/intc/allwinner-a10-pic.o
  CC      arm-softmmu/hw/intc/bcm2836_control.o
  CC      i386-softmmu/monitor.o
  CC      alpha-softmmu/target/alpha/vax_helper.o
  CC      aarch64-softmmu/hw/intc/aspeed_vic.o
  CC      arm-softmmu/hw/intc/allwinner-a10-pic.o
  CC      arm-softmmu/hw/intc/aspeed_vic.o
  CC      alpha-softmmu/target/alpha/sys_helper.o
  CC      aarch64-softmmu/hw/intc/arm_gicv3_cpuif.o
  CC      alpha-softmmu/target/alpha/mem_helper.o
  CC      arm-softmmu/hw/intc/arm_gicv3_cpuif.o
  CC      alpha-softmmu/target/alpha/gdbstub.o
  CC      i386-softmmu/gdbstub.o
  GEN     trace/generated-helpers.c
  CC      alpha-softmmu/trace/control-target.o
  CC      aarch64-softmmu/hw/misc/ivshmem.o
  CC      i386-softmmu/balloon.o
  CC      arm-softmmu/hw/misc/ivshmem.o
  CC      alpha-softmmu/trace/generated-helpers.o
  CC      aarch64-softmmu/hw/misc/arm_sysctl.o
  CC      i386-softmmu/ioport.o
  CC      aarch64-softmmu/hw/misc/cbus.o
  LINK    alpha-softmmu/qemu-system-alpha
  CC      arm-softmmu/hw/misc/arm_sysctl.o
  CC      i386-softmmu/numa.o
  CC      aarch64-softmmu/hw/misc/exynos4210_pmu.o
  CC      aarch64-softmmu/hw/misc/exynos4210_clk.o
  CC      arm-softmmu/hw/misc/cbus.o
  CC      aarch64-softmmu/hw/misc/exynos4210_rng.o
  CC      i386-softmmu/qtest.o
  CC      arm-softmmu/hw/misc/exynos4210_pmu.o
  CC      arm-softmmu/hw/misc/exynos4210_clk.o
  CC      aarch64-softmmu/hw/misc/imx_ccm.o
  CC      arm-softmmu/hw/misc/exynos4210_rng.o
  CC      i386-softmmu/memory.o
  CC      aarch64-softmmu/hw/misc/imx31_ccm.o
  CC      arm-softmmu/hw/misc/imx_ccm.o
  GEN     lm32-softmmu/hmp-commands.h
  CC      arm-softmmu/hw/misc/imx31_ccm.o
  GEN     lm32-softmmu/hmp-commands-info.h
  GEN     lm32-softmmu/config-target.h
  CC      lm32-softmmu/exec.o
  CC      aarch64-softmmu/hw/misc/imx25_ccm.o
  CC      arm-softmmu/hw/misc/imx25_ccm.o
  CC      arm-softmmu/hw/misc/imx6_ccm.o
  CC      aarch64-softmmu/hw/misc/imx6_ccm.o
  CC      i386-softmmu/memory_mapping.o
  CC      arm-softmmu/hw/misc/imx6_src.o
  CC      aarch64-softmmu/hw/misc/imx6_src.o
  CC      i386-softmmu/dump.o
  CC      arm-softmmu/hw/misc/mst_fpga.o
  CC      aarch64-softmmu/hw/misc/mst_fpga.o
  CC      arm-softmmu/hw/misc/omap_clk.o
  CC      i386-softmmu/migration/ram.o
  CC      arm-softmmu/hw/misc/omap_gpmc.o
  CC      aarch64-softmmu/hw/misc/omap_clk.o
  CC      lm32-softmmu/tcg/tcg.o
  CC      aarch64-softmmu/hw/misc/omap_gpmc.o
  CC      arm-softmmu/hw/misc/omap_l4.o
  CC      i386-softmmu/windbgstub.o
  CC      aarch64-softmmu/hw/misc/omap_l4.o
  CC      arm-softmmu/hw/misc/omap_sdrc.o
  CC      aarch64-softmmu/hw/misc/omap_sdrc.o
  CC      i386-softmmu/windbgstub-utils.o
  CC      arm-softmmu/hw/misc/omap_tap.o
  CC      aarch64-softmmu/hw/misc/omap_tap.o
  CC      arm-softmmu/hw/misc/bcm2835_mbox.o
  CC      i386-softmmu/accel/accel.o
  CC      aarch64-softmmu/hw/misc/bcm2835_mbox.o
  CC      i386-softmmu/accel/stubs/hax-stub.o
  CC      arm-softmmu/hw/misc/bcm2835_property.o
  CC      lm32-softmmu/tcg/tcg-op.o
  CC      aarch64-softmmu/hw/misc/bcm2835_property.o
  CC      i386-softmmu/accel/stubs/kvm-stub.o
  CC      aarch64-softmmu/hw/misc/bcm2835_rng.o
  CC      arm-softmmu/hw/misc/bcm2835_rng.o
  CC      i386-softmmu/accel/tcg/tcg-all.o
  CC      aarch64-softmmu/hw/misc/zynq_slcr.o
  CC      i386-softmmu/accel/tcg/cputlb.o
  CC      arm-softmmu/hw/misc/zynq_slcr.o
  CC      aarch64-softmmu/hw/misc/zynq-xadc.o
  CC      arm-softmmu/hw/misc/zynq-xadc.o
  CC      arm-softmmu/hw/misc/stm32f2xx_syscfg.o
  CC      aarch64-softmmu/hw/misc/stm32f2xx_syscfg.o
  CC      lm32-softmmu/tcg/optimize.o
  CC      arm-softmmu/hw/misc/mps2-scc.o
  CC      aarch64-softmmu/hw/misc/mps2-scc.o
  CC      arm-softmmu/hw/misc/aspeed_scu.o
  CC      aarch64-softmmu/hw/misc/auxbus.o
  CC      lm32-softmmu/tcg/tcg-common.o
  CC      aarch64-softmmu/hw/misc/aspeed_scu.o
  CC      arm-softmmu/hw/misc/aspeed_sdmc.o
  CC      i386-softmmu/accel/tcg/tcg-runtime.o
  CC      lm32-softmmu/fpu/softfloat.o
  CC      aarch64-softmmu/hw/misc/aspeed_sdmc.o
  CC      arm-softmmu/hw/misc/mmio_interface.o
  CC      i386-softmmu/accel/tcg/cpu-exec.o
  CC      aarch64-softmmu/hw/misc/mmio_interface.o
  CC      arm-softmmu/hw/misc/msf2-sysreg.o
  CC      i386-softmmu/accel/tcg/cpu-exec-common.o
  CC      aarch64-softmmu/hw/misc/msf2-sysreg.o
  CC      arm-softmmu/hw/net/virtio-net.o
  CC      aarch64-softmmu/hw/net/virtio-net.o
  CC      i386-softmmu/accel/tcg/translate-all.o
  CC      aarch64-softmmu/hw/net/vhost_net.o
  CC      arm-softmmu/hw/net/vhost_net.o
  CC      aarch64-softmmu/hw/pcmcia/pxa2xx.o
  CC      i386-softmmu/accel/tcg/translator.o
  CC      arm-softmmu/hw/pcmcia/pxa2xx.o
  CC      aarch64-softmmu/hw/scsi/virtio-scsi.o
  CC      i386-softmmu/hw/9pfs/virtio-9p-device.o
  CC      lm32-softmmu/disas.o
  CC      aarch64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      i386-softmmu/hw/block/virtio-blk.o
  CC      arm-softmmu/hw/scsi/virtio-scsi.o
  CC      aarch64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      lm32-softmmu/arch_init.o
  CC      i386-softmmu/hw/block/dataplane/virtio-blk.o
  CC      arm-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      lm32-softmmu/cpus.o
  CC      aarch64-softmmu/hw/scsi/vhost-scsi.o
  CC      i386-softmmu/hw/char/virtio-serial-bus.o
  CC      aarch64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      arm-softmmu/hw/scsi/vhost-scsi-common.o
  CC      lm32-softmmu/monitor.o
  CC      arm-softmmu/hw/scsi/vhost-scsi.o
  CC      aarch64-softmmu/hw/sd/omap_mmc.o
  CC      i386-softmmu/hw/core/generic-loader.o
  CC      aarch64-softmmu/hw/sd/pxa2xx_mmci.o
  CC      arm-softmmu/hw/scsi/vhost-user-scsi.o
  CC      i386-softmmu/hw/core/null-machine.o
  CC      aarch64-softmmu/hw/sd/bcm2835_sdhost.o
  CC      arm-softmmu/hw/sd/omap_mmc.o
  CC      aarch64-softmmu/hw/ssi/omap_spi.o
  CC      i386-softmmu/hw/display/vga.o
  CC      arm-softmmu/hw/sd/pxa2xx_mmci.o
  CC      lm32-softmmu/gdbstub.o
  CC      aarch64-softmmu/hw/ssi/imx_spi.o
  CC      arm-softmmu/hw/sd/bcm2835_sdhost.o
  CC      aarch64-softmmu/hw/timer/exynos4210_mct.o
  CC      lm32-softmmu/balloon.o
  CC      arm-softmmu/hw/ssi/omap_spi.o
  CC      i386-softmmu/hw/display/virtio-gpu.o
  CC      lm32-softmmu/ioport.o
  CC      arm-softmmu/hw/ssi/imx_spi.o
  CC      aarch64-softmmu/hw/timer/exynos4210_pwm.o
  CC      lm32-softmmu/numa.o
  CC      aarch64-softmmu/hw/timer/exynos4210_rtc.o
  CC      arm-softmmu/hw/timer/exynos4210_mct.o
  CC      i386-softmmu/hw/display/virtio-gpu-3d.o
  CC      lm32-softmmu/qtest.o
  CC      aarch64-softmmu/hw/timer/omap_gptimer.o
  CC      arm-softmmu/hw/timer/exynos4210_pwm.o
  CC      arm-softmmu/hw/timer/exynos4210_rtc.o
  CC      lm32-softmmu/memory.o
  CC      i386-softmmu/hw/display/virtio-gpu-pci.o
  CC      aarch64-softmmu/hw/timer/omap_synctimer.o
  CC      arm-softmmu/hw/timer/omap_gptimer.o
  CC      i386-softmmu/hw/display/virtio-vga.o
  CC      aarch64-softmmu/hw/timer/pxa2xx_timer.o
  CC      arm-softmmu/hw/timer/omap_synctimer.o
  CC      i386-softmmu/hw/intc/apic.o
  CC      aarch64-softmmu/hw/timer/digic-timer.o
  CC      arm-softmmu/hw/timer/pxa2xx_timer.o
  CC      lm32-softmmu/memory_mapping.o
  CC      aarch64-softmmu/hw/timer/allwinner-a10-pit.o
  CC      arm-softmmu/hw/timer/digic-timer.o
  CC      lm32-softmmu/dump.o
  CC      i386-softmmu/hw/intc/apic_common.o
  CC      arm-softmmu/hw/timer/allwinner-a10-pit.o
  CC      aarch64-softmmu/hw/usb/tusb6010.o
  CC      i386-softmmu/hw/intc/ioapic.o
  CC      arm-softmmu/hw/usb/tusb6010.o
  CC      lm32-softmmu/migration/ram.o
  CC      i386-softmmu/hw/isa/lpc_ich9.o
  CC      aarch64-softmmu/hw/vfio/common.o
  CC      arm-softmmu/hw/vfio/common.o
  CC      i386-softmmu/hw/misc/vmport.o
  CC      aarch64-softmmu/hw/vfio/pci.o
  CC      lm32-softmmu/accel/accel.o
  CC      arm-softmmu/hw/vfio/pci.o
  CC      i386-softmmu/hw/misc/ivshmem.o
  CC      lm32-softmmu/accel/stubs/hax-stub.o
  CC      lm32-softmmu/accel/stubs/kvm-stub.o
  CC      i386-softmmu/hw/misc/pvpanic.o
  CC      aarch64-softmmu/hw/vfio/pci-quirks.o
  CC      arm-softmmu/hw/vfio/pci-quirks.o
  CC      i386-softmmu/hw/misc/mmio_interface.o
  CC      lm32-softmmu/accel/tcg/tcg-all.o
  CC      lm32-softmmu/accel/tcg/cputlb.o
  CC      i386-softmmu/hw/net/virtio-net.o
  CC      aarch64-softmmu/hw/vfio/platform.o
  CC      arm-softmmu/hw/vfio/platform.o
  CC      aarch64-softmmu/hw/vfio/calxeda-xgmac.o
  CC      arm-softmmu/hw/vfio/calxeda-xgmac.o
  CC      i386-softmmu/hw/net/vhost_net.o
  CC      aarch64-softmmu/hw/vfio/amd-xgbe.o
  CC      arm-softmmu/hw/vfio/amd-xgbe.o
  CC      aarch64-softmmu/hw/vfio/spapr.o
  CC      arm-softmmu/hw/vfio/spapr.o
  CC      i386-softmmu/hw/scsi/virtio-scsi.o
  CC      aarch64-softmmu/hw/virtio/virtio.o
  CC      lm32-softmmu/accel/tcg/tcg-runtime.o
  CC      arm-softmmu/hw/virtio/virtio.o
  CC      i386-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      lm32-softmmu/accel/tcg/cpu-exec.o
  CC      aarch64-softmmu/hw/virtio/virtio-balloon.o
  CC      i386-softmmu/hw/scsi/vhost-scsi-common.o
  CC      lm32-softmmu/accel/tcg/cpu-exec-common.o
  CC      arm-softmmu/hw/virtio/virtio-balloon.o
  CC      i386-softmmu/hw/scsi/vhost-scsi.o
  CC      aarch64-softmmu/hw/virtio/vhost.o
  CC      lm32-softmmu/accel/tcg/translate-all.o
  CC      i386-softmmu/hw/scsi/vhost-user-scsi.o
  CC      arm-softmmu/hw/virtio/vhost.o
  CC      i386-softmmu/hw/timer/mc146818rtc.o
  CC      aarch64-softmmu/hw/virtio/vhost-backend.o
  CC      lm32-softmmu/accel/tcg/translator.o
  CC      arm-softmmu/hw/virtio/vhost-backend.o
  CC      i386-softmmu/hw/vfio/common.o
  CC      aarch64-softmmu/hw/virtio/vhost-user.o
  CC      lm32-softmmu/hw/core/generic-loader.o
  CC      arm-softmmu/hw/virtio/vhost-user.o
  CC      lm32-softmmu/hw/core/null-machine.o
  CC      aarch64-softmmu/hw/virtio/vhost-vsock.o
  CC      i386-softmmu/hw/vfio/pci.o
  CC      aarch64-softmmu/hw/virtio/virtio-crypto.o
  CC      arm-softmmu/hw/virtio/vhost-vsock.o
  CC      lm32-softmmu/hw/input/milkymist-softusb.o
  CC      aarch64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      arm-softmmu/hw/virtio/virtio-crypto.o
  CC      lm32-softmmu/hw/misc/milkymist-hpdmc.o
  CC      lm32-softmmu/hw/misc/milkymist-pfpu.o
  CC      i386-softmmu/hw/vfio/pci-quirks.o
  CC      aarch64-softmmu/hw/arm/boot.o
  CC      arm-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      lm32-softmmu/hw/misc/mmio_interface.o
  CC      aarch64-softmmu/hw/arm/collie.o
  CC      i386-softmmu/hw/vfio/platform.o
  CC      arm-softmmu/hw/arm/boot.o
  CC      lm32-softmmu/hw/net/milkymist-minimac2.o
  CC      aarch64-softmmu/hw/arm/exynos4_boards.o
  CC      i386-softmmu/hw/vfio/spapr.o
  CC      arm-softmmu/hw/arm/collie.o
  CC      aarch64-softmmu/hw/arm/gumstix.o
  CC      lm32-softmmu/hw/net/vhost_net.o
  CC      i386-softmmu/hw/virtio/virtio.o
  CC      aarch64-softmmu/hw/arm/highbank.o
  CC      arm-softmmu/hw/arm/exynos4_boards.o
  CC      lm32-softmmu/hw/net/rocker/qmp-norocker.o
  CC      arm-softmmu/hw/arm/gumstix.o
  CC      aarch64-softmmu/hw/arm/digic_boards.o
  CC      lm32-softmmu/hw/sd/milkymist-memcard.o
  CC      lm32-softmmu/hw/vfio/common.o
  CC      arm-softmmu/hw/arm/highbank.o
  CC      aarch64-softmmu/hw/arm/integratorcp.o
  CC      i386-softmmu/hw/virtio/virtio-balloon.o
  CC      arm-softmmu/hw/arm/digic_boards.o
  CC      aarch64-softmmu/hw/arm/mainstone.o
  CC      i386-softmmu/hw/virtio/vhost.o
  CC      lm32-softmmu/hw/vfio/platform.o
  CC      arm-softmmu/hw/arm/integratorcp.o
  CC      aarch64-softmmu/hw/arm/musicpal.o
  CC      lm32-softmmu/hw/vfio/spapr.o
  CC      arm-softmmu/hw/arm/mainstone.o
  CC      i386-softmmu/hw/virtio/vhost-backend.o
  CC      arm-softmmu/hw/arm/musicpal.o
  CC      lm32-softmmu/hw/lm32/lm32_boards.o
  CC      i386-softmmu/hw/virtio/vhost-user.o
  CC      aarch64-softmmu/hw/arm/nseries.o
  CC      lm32-softmmu/hw/lm32/milkymist.o
  CC      arm-softmmu/hw/arm/nseries.o
  CC      i386-softmmu/hw/virtio/vhost-vsock.o
  CC      lm32-softmmu/target/lm32/translate.o
  CC      aarch64-softmmu/hw/arm/omap_sx1.o
  CC      arm-softmmu/hw/arm/omap_sx1.o
  CC      i386-softmmu/hw/virtio/virtio-crypto.o
  CC      aarch64-softmmu/hw/arm/palm.o
  CC      arm-softmmu/hw/arm/palm.o
  CC      i386-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      lm32-softmmu/target/lm32/op_helper.o
  CC      arm-softmmu/hw/arm/realview.o
  CC      aarch64-softmmu/hw/arm/realview.o
  CC      lm32-softmmu/target/lm32/helper.o
  CC      i386-softmmu/hw/i386/multiboot.o
  CC      arm-softmmu/hw/arm/spitz.o
  CC      lm32-softmmu/target/lm32/cpu.o
  CC      aarch64-softmmu/hw/arm/spitz.o
  CC      i386-softmmu/hw/i386/pc.o
  CC      lm32-softmmu/target/lm32/gdbstub.o
  CC      aarch64-softmmu/hw/arm/stellaris.o
  CC      arm-softmmu/hw/arm/stellaris.o
  CC      lm32-softmmu/target/lm32/lm32-semi.o
  CC      lm32-softmmu/target/lm32/machine.o
  CC      aarch64-softmmu/hw/arm/tosa.o
  CC      i386-softmmu/hw/i386/pc_piix.o
  CC      aarch64-softmmu/hw/arm/versatilepb.o
  GEN     trace/generated-helpers.c
  CC      lm32-softmmu/trace/control-target.o
  CC      arm-softmmu/hw/arm/tosa.o
  CC      i386-softmmu/hw/i386/pc_q35.o
  CC      aarch64-softmmu/hw/arm/vexpress.o
  CC      arm-softmmu/hw/arm/versatilepb.o
  CC      lm32-softmmu/trace/generated-helpers.o
  CC      i386-softmmu/hw/i386/pc_sysfw.o
  CC      aarch64-softmmu/hw/arm/virt.o
  CC      arm-softmmu/hw/arm/vexpress.o
  LINK    lm32-softmmu/qemu-system-lm32
  CC      arm-softmmu/hw/arm/virt.o
  CC      i386-softmmu/hw/i386/x86-iommu.o
  CC      aarch64-softmmu/hw/arm/xilinx_zynq.o
  CC      i386-softmmu/hw/i386/intel_iommu.o
  CC      arm-softmmu/hw/arm/xilinx_zynq.o
  CC      aarch64-softmmu/hw/arm/z2.o
  CC      aarch64-softmmu/hw/arm/virt-acpi-build.o
  CC      arm-softmmu/hw/arm/z2.o
  CC      aarch64-softmmu/hw/arm/netduino2.o
  CC      arm-softmmu/hw/arm/virt-acpi-build.o
  CC      i386-softmmu/hw/i386/amd_iommu.o
  CC      aarch64-softmmu/hw/arm/sysbus-fdt.o
  GEN     m68k-softmmu/hmp-commands.h
  GEN     m68k-softmmu/hmp-commands-info.h
  CC      aarch64-softmmu/hw/arm/armv7m.o
  GEN     m68k-softmmu/config-target.h
  CC      m68k-softmmu/exec.o
  CC      arm-softmmu/hw/arm/netduino2.o
  CC      i386-softmmu/hw/i386/kvmvapic.o
  CC      arm-softmmu/hw/arm/sysbus-fdt.o
  CC      aarch64-softmmu/hw/arm/exynos4210.o
  CC      arm-softmmu/hw/arm/armv7m.o
  CC      i386-softmmu/hw/i386/acpi-build.o
  CC      aarch64-softmmu/hw/arm/pxa2xx.o
  CC      arm-softmmu/hw/arm/exynos4210.o
  CC      i386-softmmu/target/i386/helper.o
  CC      arm-softmmu/hw/arm/pxa2xx.o
  CC      aarch64-softmmu/hw/arm/pxa2xx_gpio.o
  CC      m68k-softmmu/tcg/tcg.o
  CC      aarch64-softmmu/hw/arm/pxa2xx_pic.o
  CC      i386-softmmu/target/i386/cpu.o
  CC      aarch64-softmmu/hw/arm/digic.o
  CC      arm-softmmu/hw/arm/pxa2xx_gpio.o
  CC      aarch64-softmmu/hw/arm/omap1.o
  CC      i386-softmmu/target/i386/gdbstub.o
  CC      arm-softmmu/hw/arm/pxa2xx_pic.o
  CC      arm-softmmu/hw/arm/digic.o
  CC      arm-softmmu/hw/arm/omap1.o
  CC      i386-softmmu/target/i386/windbgstub.o
  CC      m68k-softmmu/tcg/tcg-op.o
  CC      aarch64-softmmu/hw/arm/omap2.o
  CC      i386-softmmu/target/i386/xsave_helper.o
  CC      i386-softmmu/target/i386/translate.o
  CC      arm-softmmu/hw/arm/omap2.o
  CC      aarch64-softmmu/hw/arm/strongarm.o
  CC      m68k-softmmu/tcg/optimize.o
  CC      aarch64-softmmu/hw/arm/allwinner-a10.o
  CC      arm-softmmu/hw/arm/strongarm.o
  CC      aarch64-softmmu/hw/arm/cubieboard.o
  CC      arm-softmmu/hw/arm/allwinner-a10.o
  CC      aarch64-softmmu/hw/arm/bcm2835_peripherals.o
  CC      m68k-softmmu/tcg/tcg-common.o
  CC      arm-softmmu/hw/arm/cubieboard.o
  CC      m68k-softmmu/fpu/softfloat.o
  CC      arm-softmmu/hw/arm/bcm2835_peripherals.o
  CC      aarch64-softmmu/hw/arm/bcm2836.o
  CC      arm-softmmu/hw/arm/bcm2836.o
  CC      aarch64-softmmu/hw/arm/raspi.o
  CC      arm-softmmu/hw/arm/raspi.o
  CC      aarch64-softmmu/hw/arm/stm32f205_soc.o
  CC      arm-softmmu/hw/arm/stm32f205_soc.o
  CC      aarch64-softmmu/hw/arm/xlnx-zynqmp.o
  CC      arm-softmmu/hw/arm/fsl-imx25.o
  CC      aarch64-softmmu/hw/arm/xlnx-zcu102.o
  CC      m68k-softmmu/disas.o
  CC      arm-softmmu/hw/arm/imx25_pdk.o
  GEN     m68k-softmmu/gdbstub-xml.c
  CC      arm-softmmu/hw/arm/fsl-imx31.o
  CC      aarch64-softmmu/hw/arm/fsl-imx25.o
  CC      m68k-softmmu/arch_init.o
  CC      aarch64-softmmu/hw/arm/imx25_pdk.o
  CC      arm-softmmu/hw/arm/kzm.o
  CC      m68k-softmmu/cpus.o
  CC      aarch64-softmmu/hw/arm/fsl-imx31.o
  CC      arm-softmmu/hw/arm/fsl-imx6.o
  CC      i386-softmmu/target/i386/bpt_helper.o
  CC      arm-softmmu/hw/arm/sabrelite.o
  CC      m68k-softmmu/monitor.o
  CC      aarch64-softmmu/hw/arm/kzm.o
  CC      i386-softmmu/target/i386/cc_helper.o
  CC      arm-softmmu/hw/arm/aspeed_soc.o
  CC      aarch64-softmmu/hw/arm/fsl-imx6.o
  CC      i386-softmmu/target/i386/excp_helper.o
  CC      arm-softmmu/hw/arm/aspeed.o
  CC      aarch64-softmmu/hw/arm/sabrelite.o
  CC      arm-softmmu/hw/arm/mps2.o
  CC      i386-softmmu/target/i386/fpu_helper.o
  CC      aarch64-softmmu/hw/arm/aspeed_soc.o
  CC      arm-softmmu/hw/arm/msf2-soc.o
  CC      m68k-softmmu/gdbstub.o
  CC      arm-softmmu/hw/arm/msf2-som.o
  CC      aarch64-softmmu/hw/arm/aspeed.o
  CC      arm-softmmu/target/arm/arm-semi.o
  CC      aarch64-softmmu/hw/arm/mps2.o
  CC      m68k-softmmu/balloon.o
  CC      aarch64-softmmu/hw/arm/msf2-soc.o
  CC      arm-softmmu/target/arm/machine.o
  CC      m68k-softmmu/ioport.o
  CC      aarch64-softmmu/hw/arm/msf2-som.o
  CC      arm-softmmu/target/arm/psci.o
  CC      aarch64-softmmu/target/arm/arm-semi.o
  CC      m68k-softmmu/numa.o
  CC      aarch64-softmmu/target/arm/machine.o
  CC      arm-softmmu/target/arm/arch_dump.o
  CC      m68k-softmmu/qtest.o
  CC      i386-softmmu/target/i386/int_helper.o
  CC      arm-softmmu/target/arm/monitor.o
  CC      aarch64-softmmu/target/arm/psci.o
  CC      i386-softmmu/target/i386/mem_helper.o
  CC      m68k-softmmu/memory.o
  CC      aarch64-softmmu/target/arm/arch_dump.o
  CC      arm-softmmu/target/arm/kvm-stub.o
  CC      i386-softmmu/target/i386/misc_helper.o
  CC      arm-softmmu/target/arm/translate.o
  CC      aarch64-softmmu/target/arm/monitor.o
  CC      i386-softmmu/target/i386/mpx_helper.o
  CC      aarch64-softmmu/target/arm/kvm-stub.o
  CC      m68k-softmmu/memory_mapping.o
  CC      i386-softmmu/target/i386/seg_helper.o
  CC      aarch64-softmmu/target/arm/translate.o
  CC      m68k-softmmu/dump.o
  CC      m68k-softmmu/migration/ram.o
  CC      m68k-softmmu/accel/accel.o
  CC      i386-softmmu/target/i386/smm_helper.o
  CC      m68k-softmmu/accel/stubs/hax-stub.o
  CC      i386-softmmu/target/i386/svm_helper.o
  CC      m68k-softmmu/accel/stubs/kvm-stub.o
  CC      i386-softmmu/target/i386/machine.o
  CC      m68k-softmmu/accel/tcg/tcg-all.o
  CC      i386-softmmu/target/i386/arch_memory_mapping.o
  CC      m68k-softmmu/accel/tcg/cputlb.o
  CC      i386-softmmu/target/i386/arch_dump.o
  CC      i386-softmmu/target/i386/monitor.o
  CC      arm-softmmu/target/arm/op_helper.o
  CC      m68k-softmmu/accel/tcg/tcg-runtime.o
  CC      i386-softmmu/target/i386/kvm-stub.o
  CC      m68k-softmmu/accel/tcg/cpu-exec.o
  CC      arm-softmmu/target/arm/helper.o
  GEN     trace/generated-helpers.c
  CC      i386-softmmu/trace/control-target.o
  CC      aarch64-softmmu/target/arm/op_helper.o
  CC      m68k-softmmu/accel/tcg/cpu-exec-common.o
  CC      i386-softmmu/gdbstub-xml.o
  CC      m68k-softmmu/accel/tcg/translate-all.o
  CC      i386-softmmu/trace/generated-helpers.o
  CC      aarch64-softmmu/target/arm/helper.o
  LINK    i386-softmmu/qemu-system-i386
  CC      m68k-softmmu/accel/tcg/translator.o
  CC      m68k-softmmu/hw/char/mcf_uart.o
  CC      m68k-softmmu/hw/core/generic-loader.o
  CC      m68k-softmmu/hw/core/null-machine.o
  CC      arm-softmmu/target/arm/cpu.o
  CC      m68k-softmmu/hw/misc/mmio_interface.o
  CC      arm-softmmu/target/arm/neon_helper.o
  GEN     microblazeel-softmmu/hmp-commands.h
  GEN     microblazeel-softmmu/hmp-commands-info.h
  CC      m68k-softmmu/hw/net/mcf_fec.o
  GEN     microblazeel-softmmu/config-target.h
  CC      microblazeel-softmmu/exec.o
  CC      m68k-softmmu/hw/net/vhost_net.o
  CC      aarch64-softmmu/target/arm/cpu.o
  CC      m68k-softmmu/hw/net/rocker/qmp-norocker.o
  CC      arm-softmmu/target/arm/iwmmxt_helper.o
  CC      m68k-softmmu/hw/vfio/common.o
  CC      aarch64-softmmu/target/arm/neon_helper.o
  CC      microblazeel-softmmu/tcg/tcg.o
  CC      m68k-softmmu/hw/vfio/platform.o
  CC      arm-softmmu/target/arm/gdbstub.o
  CC      m68k-softmmu/hw/vfio/spapr.o
  CC      aarch64-softmmu/target/arm/iwmmxt_helper.o
  CC      arm-softmmu/target/arm/crypto_helper.o
  CC      m68k-softmmu/hw/m68k/an5206.o
  CC      arm-softmmu/target/arm/arm-powerctl.o
  CC      m68k-softmmu/hw/m68k/mcf5208.o
  GEN     trace/generated-helpers.c
  CC      arm-softmmu/trace/control-target.o
  CC      aarch64-softmmu/target/arm/gdbstub.o
  CC      microblazeel-softmmu/tcg/tcg-op.o
  CC      m68k-softmmu/hw/m68k/mcf5206.o
  CC      arm-softmmu/gdbstub-xml.o
  CC      aarch64-softmmu/target/arm/cpu64.o
  CC      arm-softmmu/trace/generated-helpers.o
  CC      m68k-softmmu/hw/m68k/mcf_intc.o
  CC      aarch64-softmmu/target/arm/translate-a64.o
  CC      m68k-softmmu/target/m68k/m68k-semi.o
  LINK    arm-softmmu/qemu-system-arm
  CC      m68k-softmmu/target/m68k/translate.o
  CC      microblazeel-softmmu/tcg/optimize.o
  CC      microblazeel-softmmu/tcg/tcg-common.o
  CC      microblazeel-softmmu/fpu/softfloat.o
  CC      aarch64-softmmu/target/arm/helper-a64.o
  CC      m68k-softmmu/target/m68k/op_helper.o
  CC      aarch64-softmmu/target/arm/gdbstub64.o
  CC      m68k-softmmu/target/m68k/helper.o
  CC      m68k-softmmu/target/m68k/cpu.o
  CC      aarch64-softmmu/target/arm/crypto_helper.o
  CC      m68k-softmmu/target/m68k/fpu_helper.o
  GEN     microblaze-softmmu/hmp-commands.h
  GEN     microblaze-softmmu/hmp-commands-info.h
  GEN     microblaze-softmmu/config-target.h
  CC      microblaze-softmmu/exec.o
  CC      aarch64-softmmu/target/arm/arm-powerctl.o
  CC      microblazeel-softmmu/disas.o
  CC      m68k-softmmu/target/m68k/gdbstub.o
  GEN     trace/generated-helpers.c
  GEN     trace/generated-helpers.c
  CC      aarch64-softmmu/trace/control-target.o
  CC      m68k-softmmu/trace/control-target.o
  CC      microblazeel-softmmu/arch_init.o
  CC      aarch64-softmmu/gdbstub-xml.o
  CC      m68k-softmmu/gdbstub-xml.o
  CC      aarch64-softmmu/trace/generated-helpers.o
  CC      microblazeel-softmmu/cpus.o
  CC      m68k-softmmu/trace/generated-helpers.o
  LINK    m68k-softmmu/qemu-system-m68k
  LINK    aarch64-softmmu/qemu-system-aarch64
  CC      microblazeel-softmmu/monitor.o
  CC      microblaze-softmmu/tcg/tcg.o
  CC      microblaze-softmmu/tcg/tcg-op.o
  CC      microblazeel-softmmu/gdbstub.o
  CC      microblaze-softmmu/tcg/optimize.o
  CC      microblazeel-softmmu/balloon.o
  GEN     mips64el-softmmu/hmp-commands.h
  GEN     mips64el-softmmu/hmp-commands-info.h
  GEN     mips64el-softmmu/config-target.h
  CC      microblaze-softmmu/tcg/tcg-common.o
  CC      microblazeel-softmmu/ioport.o
  CC      mips64el-softmmu/exec.o
  CC      microblaze-softmmu/fpu/softfloat.o
  CC      microblazeel-softmmu/numa.o
  GEN     mips64-softmmu/hmp-commands.h
  GEN     mips64-softmmu/hmp-commands-info.h
  GEN     mips64-softmmu/config-target.h
  CC      microblazeel-softmmu/qtest.o
  CC      mips64-softmmu/exec.o
  CC      microblazeel-softmmu/memory.o
  CC      mips64el-softmmu/tcg/tcg.o
  CC      microblazeel-softmmu/memory_mapping.o
  CC      microblaze-softmmu/disas.o
  CC      mips64-softmmu/tcg/tcg.o
  CC      microblazeel-softmmu/dump.o
  CC      microblaze-softmmu/arch_init.o
  CC      microblaze-softmmu/cpus.o
  CC      microblazeel-softmmu/migration/ram.o
  CC      mips64el-softmmu/tcg/tcg-op.o
  CC      microblaze-softmmu/monitor.o
  CC      microblazeel-softmmu/accel/accel.o
  CC      mips64-softmmu/tcg/tcg-op.o
  CC      microblazeel-softmmu/accel/stubs/hax-stub.o
  CC      microblaze-softmmu/gdbstub.o
  CC      mips64el-softmmu/tcg/optimize.o
  CC      microblazeel-softmmu/accel/stubs/kvm-stub.o
  CC      microblazeel-softmmu/accel/tcg/tcg-all.o
  CC      microblaze-softmmu/balloon.o
  CC      microblazeel-softmmu/accel/tcg/cputlb.o
  CC      mips64-softmmu/tcg/optimize.o
  CC      microblaze-softmmu/ioport.o
  CC      mips64el-softmmu/tcg/tcg-common.o
  CC      microblaze-softmmu/numa.o
  CC      mips64el-softmmu/fpu/softfloat.o
  CC      microblaze-softmmu/qtest.o
  CC      mips64-softmmu/tcg/tcg-common.o
  CC      microblaze-softmmu/memory.o
  CC      microblazeel-softmmu/accel/tcg/tcg-runtime.o
  CC      mips64-softmmu/fpu/softfloat.o
  CC      microblazeel-softmmu/accel/tcg/cpu-exec.o
  CC      microblaze-softmmu/memory_mapping.o
  CC      microblaze-softmmu/dump.o
  CC      microblazeel-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips64el-softmmu/disas.o
  CC      microblazeel-softmmu/accel/tcg/translate-all.o
  CC      microblazeel-softmmu/accel/tcg/translator.o
  CC      mips64el-softmmu/arch_init.o
  CC      microblaze-softmmu/migration/ram.o
  CC      mips64el-softmmu/cpus.o
  CC      microblazeel-softmmu/hw/core/generic-loader.o
  CC      mips64-softmmu/disas.o
  CC      microblazeel-softmmu/hw/core/null-machine.o
  CC      microblazeel-softmmu/hw/misc/mmio_interface.o
  CC      mips64el-softmmu/monitor.o
  CC      mips64-softmmu/arch_init.o
  CC      microblaze-softmmu/accel/accel.o
  CC      microblazeel-softmmu/hw/net/xilinx_ethlite.o
  CC      mips64-softmmu/cpus.o
  CC      microblazeel-softmmu/hw/net/vhost_net.o
  CC      microblaze-softmmu/accel/stubs/hax-stub.o
  CC      microblaze-softmmu/accel/stubs/kvm-stub.o
  CC      microblazeel-softmmu/hw/net/rocker/qmp-norocker.o
  CC      mips64-softmmu/monitor.o
  CC      microblaze-softmmu/accel/tcg/tcg-all.o
  CC      microblazeel-softmmu/hw/vfio/common.o
  CC      microblaze-softmmu/accel/tcg/cputlb.o
  CC      mips64el-softmmu/gdbstub.o
  CC      microblazeel-softmmu/hw/vfio/platform.o
  CC      mips64el-softmmu/balloon.o
  CC      mips64el-softmmu/ioport.o
  CC      mips64-softmmu/gdbstub.o
  CC      microblazeel-softmmu/hw/vfio/spapr.o
  CC      mips64el-softmmu/numa.o
  CC      mips64-softmmu/balloon.o
  CC      microblazeel-softmmu/hw/microblaze/petalogix_s3adsp1800_mmu.o
  CC      mips64el-softmmu/qtest.o
  CC      microblazeel-softmmu/hw/microblaze/petalogix_ml605_mmu.o
  CC      mips64-softmmu/ioport.o
  CC      microblaze-softmmu/accel/tcg/tcg-runtime.o
  CC      microblazeel-softmmu/hw/microblaze/boot.o
  CC      mips64el-softmmu/memory.o
  CC      microblaze-softmmu/accel/tcg/cpu-exec.o
  CC      mips64-softmmu/numa.o
  CC      microblazeel-softmmu/target/microblaze/translate.o
  CC      microblaze-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips64-softmmu/qtest.o
  CC      microblaze-softmmu/accel/tcg/translate-all.o
  CC      mips64-softmmu/memory.o
  CC      mips64el-softmmu/memory_mapping.o
  CC      microblaze-softmmu/accel/tcg/translator.o
  CC      mips64el-softmmu/dump.o
  CC      microblazeel-softmmu/target/microblaze/op_helper.o
  CC      microblaze-softmmu/hw/core/generic-loader.o
  CC      mips64el-softmmu/migration/ram.o
  CC      microblaze-softmmu/hw/core/null-machine.o
  CC      microblazeel-softmmu/target/microblaze/helper.o
  CC      mips64-softmmu/memory_mapping.o
  CC      microblaze-softmmu/hw/misc/mmio_interface.o
  CC      microblazeel-softmmu/target/microblaze/cpu.o
  CC      microblaze-softmmu/hw/net/xilinx_ethlite.o
  CC      mips64-softmmu/dump.o
  CC      microblaze-softmmu/hw/net/vhost_net.o
  CC      microblazeel-softmmu/target/microblaze/gdbstub.o
  CC      mips64el-softmmu/accel/accel.o
  CC      microblaze-softmmu/hw/net/rocker/qmp-norocker.o
  CC      microblaze-softmmu/hw/vfio/common.o
  CC      mips64el-softmmu/accel/stubs/hax-stub.o
  CC      microblazeel-softmmu/target/microblaze/mmu.o
  CC      mips64el-softmmu/accel/stubs/kvm-stub.o
  CC      mips64-softmmu/migration/ram.o
  GEN     trace/generated-helpers.c
  CC      microblazeel-softmmu/trace/control-target.o
  CC      mips64el-softmmu/accel/tcg/tcg-all.o
  CC      mips64el-softmmu/accel/tcg/cputlb.o
  CC      microblaze-softmmu/hw/vfio/platform.o
  CC      microblazeel-softmmu/trace/generated-helpers.o
  CC      microblaze-softmmu/hw/vfio/spapr.o
  CC      mips64-softmmu/accel/accel.o
  CC      microblaze-softmmu/hw/microblaze/petalogix_s3adsp1800_mmu.o
  CC      mips64-softmmu/accel/stubs/hax-stub.o
  LINK    microblazeel-softmmu/qemu-system-microblazeel
  CC      microblaze-softmmu/hw/microblaze/petalogix_ml605_mmu.o
  CC      mips64-softmmu/accel/stubs/kvm-stub.o
  CC      microblaze-softmmu/hw/microblaze/boot.o
  CC      mips64el-softmmu/accel/tcg/tcg-runtime.o
  CC      mips64-softmmu/accel/tcg/tcg-all.o
  CC      microblaze-softmmu/target/microblaze/translate.o
  CC      mips64el-softmmu/accel/tcg/cpu-exec.o
  CC      mips64-softmmu/accel/tcg/cputlb.o
  CC      mips64el-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips64el-softmmu/accel/tcg/translate-all.o
  GEN     mipsel-softmmu/hmp-commands.h
  CC      mips64el-softmmu/accel/tcg/translator.o
  GEN     mipsel-softmmu/hmp-commands-info.h
  GEN     mipsel-softmmu/config-target.h
  CC      microblaze-softmmu/target/microblaze/op_helper.o
  CC      mipsel-softmmu/exec.o
  CC      microblaze-softmmu/target/microblaze/helper.o
  CC      mips64el-softmmu/hw/9pfs/virtio-9p-device.o
  CC      mips64-softmmu/accel/tcg/tcg-runtime.o
  CC      microblaze-softmmu/target/microblaze/cpu.o
  CC      mips64el-softmmu/hw/block/virtio-blk.o
  CC      mips64-softmmu/accel/tcg/cpu-exec.o
  CC      microblaze-softmmu/target/microblaze/gdbstub.o
  CC      mips64el-softmmu/hw/block/dataplane/virtio-blk.o
  CC      microblaze-softmmu/target/microblaze/mmu.o
  CC      mips64-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips64el-softmmu/hw/char/virtio-serial-bus.o
  GEN     trace/generated-helpers.c
  CC      mipsel-softmmu/tcg/tcg.o
  CC      microblaze-softmmu/trace/control-target.o
  CC      mips64-softmmu/accel/tcg/translate-all.o
  CC      mips64el-softmmu/hw/core/generic-loader.o
  CC      microblaze-softmmu/trace/generated-helpers.o
  CC      mips64el-softmmu/hw/core/null-machine.o
  CC      mips64-softmmu/accel/tcg/translator.o
  LINK    microblaze-softmmu/qemu-system-microblaze
  CC      mips64el-softmmu/hw/display/vga.o
  CC      mips64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      mips64-softmmu/hw/block/virtio-blk.o
  CC      mipsel-softmmu/tcg/tcg-op.o
  CC      mips64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mips64el-softmmu/hw/display/virtio-gpu.o
  CC      mips64-softmmu/hw/char/virtio-serial-bus.o
  CC      mips64-softmmu/hw/core/generic-loader.o
  GEN     mips-softmmu/hmp-commands.h
  GEN     mips-softmmu/hmp-commands-info.h
  GEN     mips-softmmu/config-target.h
  CC      mips64el-softmmu/hw/display/virtio-gpu-3d.o
  CC      mips64-softmmu/hw/core/null-machine.o
  CC      mips-softmmu/exec.o
  CC      mips64-softmmu/hw/display/vga.o
  CC      mips64el-softmmu/hw/display/virtio-gpu-pci.o
  CC      mipsel-softmmu/tcg/optimize.o
  CC      mips64el-softmmu/hw/intc/mips_gic.o
  CC      mips64-softmmu/hw/display/virtio-gpu.o
  CC      mips64el-softmmu/hw/misc/ivshmem.o
  CC      mipsel-softmmu/tcg/tcg-common.o
  CC      mips-softmmu/tcg/tcg.o
  CC      mips64-softmmu/hw/display/virtio-gpu-3d.o
  CC      mips64el-softmmu/hw/misc/mips_cmgcr.o
  CC      mipsel-softmmu/fpu/softfloat.o
  CC      mips64el-softmmu/hw/misc/mips_cpc.o
  CC      mips64-softmmu/hw/display/virtio-gpu-pci.o
  CC      mips64el-softmmu/hw/misc/mips_itu.o
  CC      mips64el-softmmu/hw/misc/mmio_interface.o
  CC      mips64-softmmu/hw/intc/mips_gic.o
  CC      mips64el-softmmu/hw/net/virtio-net.o
  CC      mips64-softmmu/hw/misc/ivshmem.o
  CC      mips-softmmu/tcg/tcg-op.o
  CC      mips64-softmmu/hw/misc/mips_cmgcr.o
  CC      mips64el-softmmu/hw/net/vhost_net.o
  CC      mipsel-softmmu/disas.o
  CC      mips64-softmmu/hw/misc/mips_cpc.o
  CC      mips64el-softmmu/hw/scsi/virtio-scsi.o
  CC      mipsel-softmmu/arch_init.o
  CC      mips64-softmmu/hw/misc/mips_itu.o
  CC      mipsel-softmmu/cpus.o
  CC      mips64el-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      mips64-softmmu/hw/misc/mmio_interface.o
  CC      mips64el-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mips-softmmu/tcg/optimize.o
  CC      mips64el-softmmu/hw/scsi/vhost-scsi.o
  CC      mipsel-softmmu/monitor.o
  CC      mips64-softmmu/hw/net/virtio-net.o
  CC      mips64el-softmmu/hw/scsi/vhost-user-scsi.o
  CC      mips64-softmmu/hw/net/vhost_net.o
  CC      mips-softmmu/tcg/tcg-common.o
  CC      mips64el-softmmu/hw/timer/mips_gictimer.o
  CC      mips64-softmmu/hw/scsi/virtio-scsi.o
  CC      mips-softmmu/fpu/softfloat.o
  CC      mipsel-softmmu/gdbstub.o
  CC      mips64el-softmmu/hw/timer/mc146818rtc.o
  CC      mips64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      mipsel-softmmu/balloon.o
  CC      mips64el-softmmu/hw/vfio/common.o
  CC      mips64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mipsel-softmmu/ioport.o
  CC      mips64-softmmu/hw/scsi/vhost-scsi.o
  CC      mipsel-softmmu/numa.o
  CC      mips64el-softmmu/hw/vfio/pci.o
  CC      mips64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      mipsel-softmmu/qtest.o
  CC      mips64-softmmu/hw/timer/mips_gictimer.o
  CC      mips64-softmmu/hw/timer/mc146818rtc.o
  CC      mips64el-softmmu/hw/vfio/pci-quirks.o
  CC      mips-softmmu/disas.o
  CC      mipsel-softmmu/memory.o
  CC      mips-softmmu/arch_init.o
  CC      mips64-softmmu/hw/vfio/common.o
  CC      mips64el-softmmu/hw/vfio/platform.o
  CC      mips-softmmu/cpus.o
  CC      mips64el-softmmu/hw/vfio/spapr.o
  CC      mips64-softmmu/hw/vfio/pci.o
  CC      mipsel-softmmu/memory_mapping.o
  CC      mips-softmmu/monitor.o
  CC      mips64el-softmmu/hw/virtio/virtio.o
  CC      mipsel-softmmu/dump.o
  CC      mips64-softmmu/hw/vfio/pci-quirks.o
  CC      mips64el-softmmu/hw/virtio/virtio-balloon.o
  CC      mipsel-softmmu/migration/ram.o
  CC      mips64el-softmmu/hw/virtio/vhost.o
  CC      mips-softmmu/gdbstub.o
  CC      mips64-softmmu/hw/vfio/platform.o
  CC      mips64el-softmmu/hw/virtio/vhost-backend.o
  CC      mips64-softmmu/hw/vfio/spapr.o
  CC      mipsel-softmmu/accel/accel.o
  CC      mips-softmmu/balloon.o
  CC      mips64el-softmmu/hw/virtio/vhost-user.o
  CC      mips64-softmmu/hw/virtio/virtio.o
  CC      mipsel-softmmu/accel/stubs/hax-stub.o
  CC      mips-softmmu/ioport.o
  CC      mipsel-softmmu/accel/stubs/kvm-stub.o
  CC      mips64el-softmmu/hw/virtio/vhost-vsock.o
  CC      mipsel-softmmu/accel/tcg/tcg-all.o
  CC      mips-softmmu/numa.o
  CC      mips64el-softmmu/hw/virtio/virtio-crypto.o
  CC      mips64-softmmu/hw/virtio/virtio-balloon.o
  CC      mipsel-softmmu/accel/tcg/cputlb.o
  CC      mips-softmmu/qtest.o
  CC      mips64el-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      mips64-softmmu/hw/virtio/vhost.o
  CC      mips-softmmu/memory.o
  CC      mips64el-softmmu/hw/mips/mips_r4k.o
  CC      mips64-softmmu/hw/virtio/vhost-backend.o
  CC      mips64el-softmmu/hw/mips/mips_malta.o
  CC      mipsel-softmmu/accel/tcg/tcg-runtime.o
  CC      mips64-softmmu/hw/virtio/vhost-user.o
  CC      mips-softmmu/memory_mapping.o
  CC      mips64el-softmmu/hw/mips/mips_mipssim.o
  CC      mipsel-softmmu/accel/tcg/cpu-exec.o
  CC      mips-softmmu/dump.o
  CC      mips64-softmmu/hw/virtio/vhost-vsock.o
  CC      mips64el-softmmu/hw/mips/addr.o
  CC      mipsel-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips64-softmmu/hw/virtio/virtio-crypto.o
  CC      mips64el-softmmu/hw/mips/mips_int.o
  CC      mipsel-softmmu/accel/tcg/translate-all.o
  CC      mips-softmmu/migration/ram.o
  CC      mips64el-softmmu/hw/mips/mips_jazz.o
  CC      mips64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      mipsel-softmmu/accel/tcg/translator.o
  CC      mips64el-softmmu/hw/mips/mips_fulong2e.o
  CC      mips64-softmmu/hw/mips/mips_r4k.o
  CC      mips-softmmu/accel/accel.o
  CC      mips64el-softmmu/hw/mips/gt64xxx_pci.o
  CC      mips64-softmmu/hw/mips/mips_malta.o
  CC      mipsel-softmmu/hw/9pfs/virtio-9p-device.o
  CC      mips-softmmu/accel/stubs/hax-stub.o
  CC      mips64el-softmmu/hw/mips/cps.o
  CC      mips-softmmu/accel/stubs/kvm-stub.o
  CC      mipsel-softmmu/hw/block/virtio-blk.o
  CC      mips64-softmmu/hw/mips/mips_mipssim.o
  CC      mips64el-softmmu/hw/mips/boston.o
  CC      mips-softmmu/accel/tcg/tcg-all.o
  CC      mips64-softmmu/hw/mips/addr.o
  CC      mips64el-softmmu/target/mips/translate.o
  CC      mips-softmmu/accel/tcg/cputlb.o
  CC      mipsel-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mips64-softmmu/hw/mips/mips_int.o
  CC      mips64-softmmu/hw/mips/mips_jazz.o
  CC      mipsel-softmmu/hw/char/virtio-serial-bus.o
  CC      mips64-softmmu/hw/mips/gt64xxx_pci.o
  CC      mips64-softmmu/hw/mips/cps.o
  CC      mipsel-softmmu/hw/core/generic-loader.o
  CC      mipsel-softmmu/hw/core/null-machine.o
  CC      mips64-softmmu/target/mips/translate.o
  CC      mips-softmmu/accel/tcg/tcg-runtime.o
  CC      mipsel-softmmu/hw/display/vga.o
  CC      mips-softmmu/accel/tcg/cpu-exec.o
  CC      mips-softmmu/accel/tcg/cpu-exec-common.o
  CC      mipsel-softmmu/hw/display/virtio-gpu.o
  CC      mips-softmmu/accel/tcg/translate-all.o
  CC      mipsel-softmmu/hw/display/virtio-gpu-3d.o
  CC      mips-softmmu/accel/tcg/translator.o
  CC      mipsel-softmmu/hw/display/virtio-gpu-pci.o
  CC      mips-softmmu/hw/9pfs/virtio-9p-device.o
  CC      mips-softmmu/hw/block/virtio-blk.o
  CC      mipsel-softmmu/hw/intc/mips_gic.o
  CC      mips-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mipsel-softmmu/hw/misc/ivshmem.o
  CC      mips-softmmu/hw/char/virtio-serial-bus.o
  CC      mipsel-softmmu/hw/misc/mips_cmgcr.o
  CC      mipsel-softmmu/hw/misc/mips_cpc.o
  CC      mips-softmmu/hw/core/generic-loader.o
  CC      mipsel-softmmu/hw/misc/mips_itu.o
  CC      mips-softmmu/hw/core/null-machine.o
  CC      mips-softmmu/hw/display/vga.o
  CC      mipsel-softmmu/hw/misc/mmio_interface.o
  CC      mipsel-softmmu/hw/net/virtio-net.o
  CC      mips64el-softmmu/target/mips/dsp_helper.o
  CC      mips-softmmu/hw/display/virtio-gpu.o
  CC      mipsel-softmmu/hw/net/vhost_net.o
  CC      mipsel-softmmu/hw/scsi/virtio-scsi.o
  CC      mips-softmmu/hw/display/virtio-gpu-3d.o
  CC      mips64el-softmmu/target/mips/op_helper.o
  CC      mips64-softmmu/target/mips/dsp_helper.o
  CC      mipsel-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      mipsel-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mips-softmmu/hw/display/virtio-gpu-pci.o
  CC      mipsel-softmmu/hw/scsi/vhost-scsi.o
  CC      mips-softmmu/hw/intc/mips_gic.o
  CC      mipsel-softmmu/hw/scsi/vhost-user-scsi.o
  CC      mips-softmmu/hw/misc/ivshmem.o
  CC      mips64-softmmu/target/mips/op_helper.o
  CC      mipsel-softmmu/hw/timer/mips_gictimer.o
  CC      mips-softmmu/hw/misc/mips_cmgcr.o
  CC      mips64el-softmmu/target/mips/lmi_helper.o
  CC      mipsel-softmmu/hw/timer/mc146818rtc.o
  CC      mips-softmmu/hw/misc/mips_cpc.o
  CC      mips-softmmu/hw/misc/mips_itu.o
  CC      mipsel-softmmu/hw/vfio/common.o
  CC      mips64el-softmmu/target/mips/helper.o
  CC      mips-softmmu/hw/misc/mmio_interface.o
  CC      mips-softmmu/hw/net/virtio-net.o
  CC      mipsel-softmmu/hw/vfio/pci.o
  CC      mips64el-softmmu/target/mips/cpu.o
  CC      mips-softmmu/hw/net/vhost_net.o
  CC      mips64el-softmmu/target/mips/gdbstub.o
  CC      mips64-softmmu/target/mips/lmi_helper.o
  CC      mips-softmmu/hw/scsi/virtio-scsi.o
  CC      mips64el-softmmu/target/mips/msa_helper.o
  CC      mipsel-softmmu/hw/vfio/pci-quirks.o
  CC      mips64-softmmu/target/mips/helper.o
  CC      mips-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      mips64-softmmu/target/mips/cpu.o
  CC      mipsel-softmmu/hw/vfio/platform.o
  CC      mips-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mips64-softmmu/target/mips/gdbstub.o
  CC      mips64-softmmu/target/mips/msa_helper.o
  CC      mips-softmmu/hw/scsi/vhost-scsi.o
  CC      mipsel-softmmu/hw/vfio/spapr.o
  CC      mipsel-softmmu/hw/virtio/virtio.o
  CC      mips-softmmu/hw/scsi/vhost-user-scsi.o
  CC      mips-softmmu/hw/timer/mips_gictimer.o
  CC      mipsel-softmmu/hw/virtio/virtio-balloon.o
  CC      mipsel-softmmu/hw/virtio/vhost.o
  CC      mips-softmmu/hw/timer/mc146818rtc.o
  CC      mips64el-softmmu/target/mips/mips-semi.o
  CC      mips-softmmu/hw/vfio/common.o
  CC      mipsel-softmmu/hw/virtio/vhost-backend.o
  CC      mips64el-softmmu/target/mips/machine.o
  CC      mipsel-softmmu/hw/virtio/vhost-user.o
  CC      mips64el-softmmu/target/mips/cp0_timer.o
  GEN     trace/generated-helpers.c
  CC      mips-softmmu/hw/vfio/pci.o
  CC      mips64el-softmmu/trace/control-target.o
  CC      mipsel-softmmu/hw/virtio/vhost-vsock.o
  CC      mips64-softmmu/target/mips/mips-semi.o
  CC      mips64el-softmmu/trace/generated-helpers.o
  CC      mipsel-softmmu/hw/virtio/virtio-crypto.o
  CC      mips64-softmmu/target/mips/machine.o
  CC      mipsel-softmmu/hw/virtio/virtio-crypto-pci.o
  LINK    mips64el-softmmu/qemu-system-mips64el
  CC      mips-softmmu/hw/vfio/pci-quirks.o
  CC      mips64-softmmu/target/mips/cp0_timer.o
  GEN     trace/generated-helpers.c
  CC      mipsel-softmmu/hw/mips/mips_r4k.o
  CC      mips64-softmmu/trace/control-target.o
  CC      mipsel-softmmu/hw/mips/mips_malta.o
  CC      mips-softmmu/hw/vfio/platform.o
  CC      mips64-softmmu/trace/generated-helpers.o
  CC      mipsel-softmmu/hw/mips/mips_mipssim.o
  CC      mips-softmmu/hw/vfio/spapr.o
  CC      mipsel-softmmu/hw/mips/addr.o
  LINK    mips64-softmmu/qemu-system-mips64
  CC      mips-softmmu/hw/virtio/virtio.o
  CC      mipsel-softmmu/hw/mips/mips_int.o
  CC      mipsel-softmmu/hw/mips/gt64xxx_pci.o
  CC      mips-softmmu/hw/virtio/virtio-balloon.o
  CC      mipsel-softmmu/hw/mips/cps.o
  GEN     moxie-softmmu/hmp-commands.h
  GEN     moxie-softmmu/hmp-commands-info.h
  GEN     moxie-softmmu/config-target.h
  CC      moxie-softmmu/exec.o
  CC      mips-softmmu/hw/virtio/vhost.o
  CC      mipsel-softmmu/target/mips/translate.o
  CC      mips-softmmu/hw/virtio/vhost-backend.o
  GEN     nios2-softmmu/hmp-commands.h
  CC      mips-softmmu/hw/virtio/vhost-user.o
  GEN     nios2-softmmu/hmp-commands-info.h
  GEN     nios2-softmmu/config-target.h
  CC      mips-softmmu/hw/virtio/vhost-vsock.o
  CC      nios2-softmmu/exec.o
  CC      mips-softmmu/hw/virtio/virtio-crypto.o
  CC      moxie-softmmu/tcg/tcg.o
  CC      mips-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      mips-softmmu/hw/mips/mips_r4k.o
  CC      mips-softmmu/hw/mips/mips_malta.o
  CC      nios2-softmmu/tcg/tcg.o
  CC      moxie-softmmu/tcg/tcg-op.o
  CC      mips-softmmu/hw/mips/mips_mipssim.o
  CC      mips-softmmu/hw/mips/addr.o
  CC      nios2-softmmu/tcg/tcg-op.o
  CC      mips-softmmu/hw/mips/mips_int.o
  CC      moxie-softmmu/tcg/optimize.o
  CC      mips-softmmu/hw/mips/gt64xxx_pci.o
  CC      moxie-softmmu/tcg/tcg-common.o
  CC      mips-softmmu/hw/mips/cps.o
  CC      mips-softmmu/target/mips/translate.o
  CC      moxie-softmmu/fpu/softfloat.o
  CC      nios2-softmmu/tcg/optimize.o
  CC      mipsel-softmmu/target/mips/dsp_helper.o
  CC      nios2-softmmu/tcg/tcg-common.o
  CC      nios2-softmmu/fpu/softfloat.o
  CC      mipsel-softmmu/target/mips/op_helper.o
  CC      moxie-softmmu/disas.o
  CC      moxie-softmmu/arch_init.o
  CC      nios2-softmmu/disas.o
  CC      moxie-softmmu/cpus.o
  CC      nios2-softmmu/arch_init.o
  CC      mipsel-softmmu/target/mips/lmi_helper.o
  CC      nios2-softmmu/cpus.o
  CC      moxie-softmmu/monitor.o
  CC      mipsel-softmmu/target/mips/helper.o
  CC      nios2-softmmu/monitor.o
  CC      mipsel-softmmu/target/mips/cpu.o
  CC      mipsel-softmmu/target/mips/gdbstub.o
  CC      moxie-softmmu/gdbstub.o
  CC      mipsel-softmmu/target/mips/msa_helper.o
  CC      nios2-softmmu/gdbstub.o
  CC      mips-softmmu/target/mips/dsp_helper.o
  CC      moxie-softmmu/balloon.o
  CC      moxie-softmmu/ioport.o
  CC      nios2-softmmu/balloon.o
  CC      mips-softmmu/target/mips/op_helper.o
  CC      moxie-softmmu/numa.o
  CC      nios2-softmmu/ioport.o
  CC      moxie-softmmu/qtest.o
  CC      nios2-softmmu/numa.o
  CC      moxie-softmmu/memory.o
  CC      nios2-softmmu/qtest.o
  CC      nios2-softmmu/memory.o
  CC      mips-softmmu/target/mips/lmi_helper.o
  CC      mipsel-softmmu/target/mips/mips-semi.o
  CC      moxie-softmmu/memory_mapping.o
  CC      mipsel-softmmu/target/mips/machine.o
  CC      mips-softmmu/target/mips/helper.o
  CC      moxie-softmmu/dump.o
  CC      mipsel-softmmu/target/mips/cp0_timer.o
  GEN     trace/generated-helpers.c
  CC      mipsel-softmmu/trace/control-target.o
  CC      nios2-softmmu/memory_mapping.o
  CC      mips-softmmu/target/mips/cpu.o
  CC      mipsel-softmmu/trace/generated-helpers.o
  CC      moxie-softmmu/migration/ram.o
  CC      mips-softmmu/target/mips/gdbstub.o
  CC      nios2-softmmu/dump.o
  LINK    mipsel-softmmu/qemu-system-mipsel
  CC      mips-softmmu/target/mips/msa_helper.o
  CC      nios2-softmmu/migration/ram.o
  CC      moxie-softmmu/accel/accel.o
  CC      moxie-softmmu/accel/stubs/hax-stub.o
  CC      moxie-softmmu/accel/stubs/kvm-stub.o
  CC      nios2-softmmu/accel/accel.o
  CC      moxie-softmmu/accel/tcg/tcg-all.o
  CC      nios2-softmmu/accel/stubs/hax-stub.o
  CC      moxie-softmmu/accel/tcg/cputlb.o
  CC      nios2-softmmu/accel/stubs/kvm-stub.o
  CC      nios2-softmmu/accel/tcg/tcg-all.o
  CC      nios2-softmmu/accel/tcg/cputlb.o
  CC      moxie-softmmu/accel/tcg/tcg-runtime.o
  CC      nios2-softmmu/accel/tcg/tcg-runtime.o
  CC      moxie-softmmu/accel/tcg/cpu-exec.o
  CC      mips-softmmu/target/mips/mips-semi.o
  CC      moxie-softmmu/accel/tcg/cpu-exec-common.o
  CC      moxie-softmmu/accel/tcg/translate-all.o
  CC      nios2-softmmu/accel/tcg/cpu-exec.o
  CC      nios2-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips-softmmu/target/mips/machine.o
  CC      moxie-softmmu/accel/tcg/translator.o
  CC      nios2-softmmu/accel/tcg/translate-all.o
  CC      mips-softmmu/target/mips/cp0_timer.o
  CC      nios2-softmmu/accel/tcg/translator.o
  CC      moxie-softmmu/hw/core/generic-loader.o
  CC      moxie-softmmu/hw/core/null-machine.o
  GEN     trace/generated-helpers.c
  CC      mips-softmmu/trace/control-target.o
  CC      nios2-softmmu/hw/core/generic-loader.o
  CC      nios2-softmmu/hw/core/null-machine.o
  CC      moxie-softmmu/hw/display/vga.o
  CC      mips-softmmu/trace/generated-helpers.o
  CC      nios2-softmmu/hw/intc/nios2_iic.o
  CC      nios2-softmmu/hw/misc/mmio_interface.o
  LINK    mips-softmmu/qemu-system-mips
  GEN     or1k-softmmu/hmp-commands.h
  GEN     or1k-softmmu/hmp-commands-info.h
  CC      nios2-softmmu/hw/net/vhost_net.o
  GEN     or1k-softmmu/config-target.h
  CC      or1k-softmmu/exec.o
  CC      nios2-softmmu/hw/net/rocker/qmp-norocker.o
  CC      moxie-softmmu/hw/misc/mmio_interface.o
  CC      nios2-softmmu/hw/timer/altera_timer.o
  CC      moxie-softmmu/hw/net/vhost_net.o
  CC      nios2-softmmu/hw/vfio/common.o
  CC      moxie-softmmu/hw/net/rocker/qmp-norocker.o
  CC      or1k-softmmu/tcg/tcg.o
  CC      moxie-softmmu/hw/timer/mc146818rtc.o
  CC      nios2-softmmu/hw/vfio/platform.o
  CC      moxie-softmmu/hw/vfio/common.o
  CC      moxie-softmmu/hw/vfio/platform.o
  CC      nios2-softmmu/hw/vfio/spapr.o
  CC      nios2-softmmu/hw/nios2/boot.o
  CC      moxie-softmmu/hw/vfio/spapr.o
  CC      nios2-softmmu/hw/nios2/cpu_pic.o
  CC      or1k-softmmu/tcg/tcg-op.o
  CC      nios2-softmmu/hw/nios2/10m50_devboard.o
  CC      moxie-softmmu/hw/moxie/moxiesim.o
  CC      nios2-softmmu/target/nios2/translate.o
  CC      moxie-softmmu/target/moxie/translate.o
  GEN     ppc64-softmmu/hmp-commands.h
  GEN     ppc64-softmmu/hmp-commands-info.h
  GEN     ppc64-softmmu/config-target.h
  CC      moxie-softmmu/target/moxie/helper.o
  CC      ppc64-softmmu/exec.o
  CC      nios2-softmmu/target/nios2/op_helper.o
  CC      moxie-softmmu/target/moxie/machine.o
  CC      nios2-softmmu/target/nios2/helper.o
  CC      moxie-softmmu/target/moxie/cpu.o
  CC      or1k-softmmu/tcg/optimize.o
  CC      nios2-softmmu/target/nios2/cpu.o
  CC      moxie-softmmu/target/moxie/mmu.o
  CC      nios2-softmmu/target/nios2/mmu.o
  CC      nios2-softmmu/target/nios2/monitor.o
  GEN     trace/generated-helpers.c
  CC      moxie-softmmu/trace/control-target.o
  CC      or1k-softmmu/tcg/tcg-common.o
  GEN     trace/generated-helpers.c
  CC      nios2-softmmu/trace/control-target.o
  CC      moxie-softmmu/trace/generated-helpers.o
  CC      or1k-softmmu/fpu/softfloat.o
  LINK    moxie-softmmu/qemu-system-moxie
  CC      nios2-softmmu/trace/generated-helpers.o
  CC      ppc64-softmmu/tcg/tcg.o
  LINK    nios2-softmmu/qemu-system-nios2
  CC      or1k-softmmu/disas.o
  CC      or1k-softmmu/arch_init.o
  CC      ppc64-softmmu/tcg/tcg-op.o
  CC      or1k-softmmu/cpus.o
  GEN     ppcemb-softmmu/hmp-commands.h
  GEN     ppcemb-softmmu/hmp-commands-info.h
  GEN     ppcemb-softmmu/config-target.h
  CC      ppcemb-softmmu/exec.o
  CC      ppcemb-softmmu/tcg/tcg.o
  CC      or1k-softmmu/monitor.o
  CC      ppc64-softmmu/tcg/optimize.o
  CC      or1k-softmmu/gdbstub.o
  CC      ppcemb-softmmu/tcg/tcg-op.o
  CC      or1k-softmmu/balloon.o
  CC      ppcemb-softmmu/tcg/optimize.o
  CC      ppc64-softmmu/tcg/tcg-common.o
  CC      or1k-softmmu/ioport.o
  CC      or1k-softmmu/numa.o
  CC      ppc64-softmmu/fpu/softfloat.o
  CC      or1k-softmmu/qtest.o
  CC      ppcemb-softmmu/tcg/tcg-common.o
  CC      or1k-softmmu/memory.o
  CC      ppcemb-softmmu/fpu/softfloat.o
  GEN     ppc-softmmu/hmp-commands.h
  GEN     ppc-softmmu/hmp-commands-info.h
  GEN     ppc-softmmu/config-target.h
  CC      or1k-softmmu/memory_mapping.o
  CC      ppc-softmmu/exec.o
  CC      or1k-softmmu/dump.o
  CC      ppc64-softmmu/disas.o
  CC      or1k-softmmu/migration/ram.o
  GEN     ppc64-softmmu/gdbstub-xml.c
  CC      ppcemb-softmmu/disas.o
  CC      ppc64-softmmu/arch_init.o
  CC      ppc64-softmmu/cpus.o
  CC      or1k-softmmu/accel/accel.o
  GEN     ppcemb-softmmu/gdbstub-xml.c
  CC      or1k-softmmu/accel/stubs/hax-stub.o
  CC      ppc-softmmu/tcg/tcg.o
  CC      or1k-softmmu/accel/stubs/kvm-stub.o
  CC      or1k-softmmu/accel/tcg/tcg-all.o
  CC      ppcemb-softmmu/arch_init.o
  CC      ppc64-softmmu/monitor.o
  CC      or1k-softmmu/accel/tcg/cputlb.o
  CC      ppcemb-softmmu/cpus.o
  CC      ppcemb-softmmu/monitor.o
  CC      ppc64-softmmu/gdbstub.o
  CC      ppc-softmmu/tcg/tcg-op.o
  CC      or1k-softmmu/accel/tcg/tcg-runtime.o
  CC      or1k-softmmu/accel/tcg/cpu-exec.o
  CC      ppc64-softmmu/balloon.o
  CC      ppcemb-softmmu/gdbstub.o
  CC      ppc64-softmmu/ioport.o
  CC      or1k-softmmu/accel/tcg/cpu-exec-common.o
  CC      or1k-softmmu/accel/tcg/translate-all.o
  CC      ppc64-softmmu/numa.o
  CC      ppcemb-softmmu/balloon.o
  CC      ppc-softmmu/tcg/optimize.o
  CC      ppc64-softmmu/qtest.o
  CC      ppcemb-softmmu/ioport.o
  CC      or1k-softmmu/accel/tcg/translator.o
  CC      ppcemb-softmmu/numa.o
  CC      ppc64-softmmu/memory.o
  CC      or1k-softmmu/hw/core/generic-loader.o
  CC      ppc-softmmu/tcg/tcg-common.o
  CC      or1k-softmmu/hw/core/null-machine.o
  CC      ppcemb-softmmu/qtest.o
  CC      or1k-softmmu/hw/intc/ompic.o
  CC      ppc-softmmu/fpu/softfloat.o
  CC      or1k-softmmu/hw/misc/mmio_interface.o
  CC      ppcemb-softmmu/memory.o
  CC      or1k-softmmu/hw/net/vhost_net.o
  CC      ppc64-softmmu/memory_mapping.o
  CC      ppc64-softmmu/dump.o
  CC      or1k-softmmu/hw/net/rocker/qmp-norocker.o
  CC      or1k-softmmu/hw/vfio/common.o
  CC      ppcemb-softmmu/memory_mapping.o
  CC      ppc64-softmmu/migration/ram.o
  CC      ppcemb-softmmu/dump.o
  CC      or1k-softmmu/hw/vfio/platform.o
  CC      ppc-softmmu/disas.o
  CC      or1k-softmmu/hw/vfio/spapr.o
  CC      ppcemb-softmmu/migration/ram.o
  CC      ppc64-softmmu/accel/accel.o
  GEN     ppc-softmmu/gdbstub-xml.c
  CC      or1k-softmmu/hw/openrisc/pic_cpu.o
  CC      ppc-softmmu/arch_init.o
  CC      ppc64-softmmu/accel/stubs/hax-stub.o
  CC      or1k-softmmu/hw/openrisc/cputimer.o
  CC      ppc-softmmu/cpus.o
  CC      ppc64-softmmu/accel/stubs/kvm-stub.o
  CC      or1k-softmmu/hw/openrisc/openrisc_sim.o
  CC      ppcemb-softmmu/accel/accel.o
  CC      or1k-softmmu/target/openrisc/machine.o
  CC      ppc64-softmmu/accel/tcg/tcg-all.o
  CC      ppcemb-softmmu/accel/stubs/hax-stub.o
  CC      ppc-softmmu/monitor.o
  CC      ppc64-softmmu/accel/tcg/cputlb.o
  CC      or1k-softmmu/target/openrisc/cpu.o
  CC      ppcemb-softmmu/accel/stubs/kvm-stub.o
  CC      or1k-softmmu/target/openrisc/exception.o
  CC      ppcemb-softmmu/accel/tcg/tcg-all.o
  CC      or1k-softmmu/target/openrisc/interrupt.o
  CC      ppcemb-softmmu/accel/tcg/cputlb.o
  CC      or1k-softmmu/target/openrisc/mmu.o
  CC      ppc-softmmu/gdbstub.o
  CC      or1k-softmmu/target/openrisc/translate.o
  CC      ppc64-softmmu/accel/tcg/tcg-runtime.o
  CC      ppc64-softmmu/accel/tcg/cpu-exec.o
  CC      ppc-softmmu/balloon.o
  CC      ppc-softmmu/ioport.o
  CC      ppcemb-softmmu/accel/tcg/tcg-runtime.o
  CC      ppc64-softmmu/accel/tcg/cpu-exec-common.o
  CC      or1k-softmmu/target/openrisc/exception_helper.o
  CC      ppc-softmmu/numa.o
  CC      ppc64-softmmu/accel/tcg/translate-all.o
  CC      or1k-softmmu/target/openrisc/fpu_helper.o
  CC      ppcemb-softmmu/accel/tcg/cpu-exec.o
  CC      ppc-softmmu/qtest.o
  CC      ppc64-softmmu/accel/tcg/translator.o
  CC      ppcemb-softmmu/accel/tcg/cpu-exec-common.o
  CC      or1k-softmmu/target/openrisc/interrupt_helper.o
  CC      ppcemb-softmmu/accel/tcg/translate-all.o
  CC      or1k-softmmu/target/openrisc/mmu_helper.o
  CC      ppc-softmmu/memory.o
  CC      or1k-softmmu/target/openrisc/sys_helper.o
  CC      ppc64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      or1k-softmmu/target/openrisc/gdbstub.o
  CC      ppcemb-softmmu/accel/tcg/translator.o
  GEN     trace/generated-helpers.c
  CC      or1k-softmmu/trace/control-target.o
  CC      or1k-softmmu/trace/generated-helpers.o
  CC      ppc64-softmmu/hw/block/virtio-blk.o
  CC      ppc-softmmu/memory_mapping.o
  CC      ppcemb-softmmu/hw/9pfs/virtio-9p-device.o
  LINK    or1k-softmmu/qemu-system-or1k
  CC      ppc-softmmu/dump.o
  CC      ppcemb-softmmu/hw/block/virtio-blk.o
  CC      ppc64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      ppc-softmmu/migration/ram.o
  CC      ppc64-softmmu/hw/char/spapr_vty.o
  CC      ppcemb-softmmu/hw/block/dataplane/virtio-blk.o
  GEN     s390x-softmmu/hmp-commands.h
  CC      ppc64-softmmu/hw/char/virtio-serial-bus.o
  GEN     s390x-softmmu/hmp-commands-info.h
  CC      s390x-softmmu/gen-features
  GEN     s390x-softmmu/config-target.h
  GEN     s390x-softmmu/gen-features.h
  CC      s390x-softmmu/exec.o
  CC      ppcemb-softmmu/hw/char/virtio-serial-bus.o
  CC      ppc-softmmu/accel/accel.o
  CC      ppc-softmmu/accel/stubs/hax-stub.o
  CC      ppc64-softmmu/hw/core/generic-loader.o
  CC      ppc64-softmmu/hw/core/null-machine.o
  CC      ppcemb-softmmu/hw/core/generic-loader.o
  CC      ppc-softmmu/accel/stubs/kvm-stub.o
  CC      ppc64-softmmu/hw/display/sm501.o
  CC      ppc-softmmu/accel/tcg/tcg-all.o
  CC      ppcemb-softmmu/hw/core/null-machine.o
  CC      ppc-softmmu/accel/tcg/cputlb.o
  CC      ppcemb-softmmu/hw/display/sm501.o
  CC      ppc64-softmmu/hw/display/vga.o
  CC      s390x-softmmu/tcg/tcg.o
  CC      ppcemb-softmmu/hw/display/vga.o
  CC      ppc64-softmmu/hw/display/virtio-gpu.o
  CC      ppc-softmmu/accel/tcg/tcg-runtime.o
  CC      ppc64-softmmu/hw/display/virtio-gpu-3d.o
  CC      ppc-softmmu/accel/tcg/cpu-exec.o
  CC      ppcemb-softmmu/hw/display/virtio-gpu.o
  CC      s390x-softmmu/tcg/tcg-op.o
  CC      ppc64-softmmu/hw/display/virtio-gpu-pci.o
  CC      ppc-softmmu/accel/tcg/cpu-exec-common.o
  CC      ppc-softmmu/accel/tcg/translate-all.o
  CC      ppc64-softmmu/hw/display/virtio-vga.o
  CC      ppcemb-softmmu/hw/display/virtio-gpu-3d.o
  CC      ppc-softmmu/accel/tcg/translator.o
  CC      ppc64-softmmu/hw/i2c/ppc4xx_i2c.o
  CC      ppcemb-softmmu/hw/display/virtio-gpu-pci.o
  CC      s390x-softmmu/tcg/optimize.o
  CC      ppc64-softmmu/hw/intc/xics.o
  CC      ppc-softmmu/hw/9pfs/virtio-9p-device.o
  CC      ppc-softmmu/hw/block/virtio-blk.o
  CC      ppc64-softmmu/hw/intc/xics_spapr.o
  CC      ppcemb-softmmu/hw/i2c/ppc4xx_i2c.o
  CC      ppc64-softmmu/hw/intc/xics_pnv.o
  CC      ppc-softmmu/hw/block/dataplane/virtio-blk.o
  CC      s390x-softmmu/tcg/tcg-common.o
  CC      ppcemb-softmmu/hw/misc/ivshmem.o
  CC      s390x-softmmu/fpu/softfloat.o
  CC      ppc64-softmmu/hw/misc/ivshmem.o
  CC      ppc-softmmu/hw/char/virtio-serial-bus.o
  CC      ppcemb-softmmu/hw/misc/mmio_interface.o
  CC      ppc64-softmmu/hw/misc/mmio_interface.o
  CC      ppc-softmmu/hw/core/generic-loader.o
  CC      ppcemb-softmmu/hw/net/xilinx_ethlite.o
  CC      ppc64-softmmu/hw/net/spapr_llan.o
  CC      ppcemb-softmmu/hw/net/virtio-net.o
  CC      ppc-softmmu/hw/core/null-machine.o
  CC      ppc64-softmmu/hw/net/xilinx_ethlite.o
  CC      ppc-softmmu/hw/display/sm501.o
  CC      ppc64-softmmu/hw/net/virtio-net.o
  CC      ppcemb-softmmu/hw/net/vhost_net.o
  CC      ppc-softmmu/hw/display/vga.o
  CC      ppcemb-softmmu/hw/scsi/virtio-scsi.o
  CC      s390x-softmmu/disas.o
  CC      ppc64-softmmu/hw/net/vhost_net.o
  CC      ppcemb-softmmu/hw/scsi/virtio-scsi-dataplane.o
  GEN     s390x-softmmu/gdbstub-xml.c
  CC      ppc64-softmmu/hw/net/fsl_etsec/etsec.o
  CC      ppc-softmmu/hw/display/virtio-gpu.o
  CC      ppcemb-softmmu/hw/scsi/vhost-scsi-common.o
  CC      ppc64-softmmu/hw/net/fsl_etsec/registers.o
  CC      ppc64-softmmu/hw/net/fsl_etsec/rings.o
  CC      ppcemb-softmmu/hw/scsi/vhost-scsi.o
  CC      ppcemb-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc64-softmmu/hw/net/fsl_etsec/miim.o
  CC      ppc-softmmu/hw/display/virtio-gpu-3d.o
  CC      s390x-softmmu/arch_init.o
  CC      ppc64-softmmu/hw/nvram/spapr_nvram.o
  CC      ppcemb-softmmu/hw/vfio/common.o
  CC      s390x-softmmu/cpus.o
  CC      ppc64-softmmu/hw/scsi/spapr_vscsi.o
  CC      ppc-softmmu/hw/display/virtio-gpu-pci.o
  CC      ppcemb-softmmu/hw/vfio/pci.o
  CC      ppc-softmmu/hw/i2c/ppc4xx_i2c.o
  CC      s390x-softmmu/monitor.o
  CC      ppc64-softmmu/hw/scsi/virtio-scsi.o
  CC      ppc-softmmu/hw/misc/ivshmem.o
  CC      ppc64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      ppc64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      ppcemb-softmmu/hw/vfio/pci-quirks.o
  CC      ppc64-softmmu/hw/scsi/vhost-scsi.o
  CC      ppc-softmmu/hw/misc/mmio_interface.o
  CC      s390x-softmmu/gdbstub.o
  CC      ppc64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc-softmmu/hw/net/xilinx_ethlite.o
  CC      ppc64-softmmu/hw/timer/mc146818rtc.o
  CC      ppcemb-softmmu/hw/vfio/platform.o
  CC      ppc-softmmu/hw/net/virtio-net.o
  CC      s390x-softmmu/balloon.o
  CC      ppcemb-softmmu/hw/vfio/spapr.o
  CC      s390x-softmmu/ioport.o
  CC      ppc64-softmmu/hw/vfio/common.o
  CC      ppcemb-softmmu/hw/virtio/virtio.o
  CC      ppc-softmmu/hw/net/vhost_net.o
  CC      s390x-softmmu/numa.o
  CC      ppc-softmmu/hw/net/fsl_etsec/etsec.o
  CC      ppc64-softmmu/hw/vfio/pci.o
  CC      s390x-softmmu/qtest.o
  CC      ppc-softmmu/hw/net/fsl_etsec/registers.o
  CC      ppcemb-softmmu/hw/virtio/virtio-balloon.o
  CC      ppc-softmmu/hw/net/fsl_etsec/rings.o
  CC      s390x-softmmu/memory.o
  CC      ppc64-softmmu/hw/vfio/pci-quirks.o
  CC      ppcemb-softmmu/hw/virtio/vhost.o
  CC      ppc-softmmu/hw/net/fsl_etsec/miim.o
  CC      ppc64-softmmu/hw/vfio/platform.o
  CC      ppcemb-softmmu/hw/virtio/vhost-backend.o
  CC      ppc-softmmu/hw/scsi/virtio-scsi.o
  CC      s390x-softmmu/memory_mapping.o
  CC      ppc64-softmmu/hw/vfio/spapr.o
  CC      ppc-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      ppcemb-softmmu/hw/virtio/vhost-user.o
  CC      s390x-softmmu/dump.o
  CC      ppc64-softmmu/hw/virtio/virtio.o
  CC      ppc-softmmu/hw/scsi/vhost-scsi-common.o
  CC      ppcemb-softmmu/hw/virtio/vhost-vsock.o
  CC      ppc-softmmu/hw/scsi/vhost-scsi.o
  CC      s390x-softmmu/migration/ram.o
  CC      ppc-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc-softmmu/hw/timer/mc146818rtc.o
  CC      ppcemb-softmmu/hw/virtio/virtio-crypto.o
  CC      ppc64-softmmu/hw/virtio/virtio-balloon.o
  CC      ppc-softmmu/hw/vfio/common.o
  CC      ppcemb-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      s390x-softmmu/accel/accel.o
  CC      ppc64-softmmu/hw/virtio/vhost.o
  CC      s390x-softmmu/accel/kvm/kvm-all.o
  CC      ppcemb-softmmu/hw/ppc/ppc.o
  CC      ppc-softmmu/hw/vfio/pci.o
  CC      ppc64-softmmu/hw/virtio/vhost-backend.o
  CC      ppcemb-softmmu/hw/ppc/ppc_booke.o
  CC      s390x-softmmu/accel/stubs/hax-stub.o
  CC      ppc64-softmmu/hw/virtio/vhost-user.o
  CC      s390x-softmmu/accel/tcg/tcg-all.o
  CC      s390x-softmmu/accel/tcg/cputlb.o
  CC      ppc-softmmu/hw/vfio/pci-quirks.o
  CC      ppcemb-softmmu/hw/ppc/fdt.o
  CC      ppc64-softmmu/hw/virtio/vhost-vsock.o
  CC      ppcemb-softmmu/hw/ppc/ppc405_boards.o
  CC      ppc64-softmmu/hw/virtio/virtio-crypto.o
  CC      ppc-softmmu/hw/vfio/platform.o
  CC      ppcemb-softmmu/hw/ppc/ppc4xx_devs.o
  CC      ppc64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      ppc-softmmu/hw/vfio/spapr.o
  CC      ppcemb-softmmu/hw/ppc/ppc405_uc.o
  CC      ppc64-softmmu/hw/ppc/ppc.o
  CC      s390x-softmmu/accel/tcg/tcg-runtime.o
  CC      ppc-softmmu/hw/virtio/virtio.o
  CC      s390x-softmmu/accel/tcg/cpu-exec.o
  CC      ppcemb-softmmu/hw/ppc/ppc440_bamboo.o
  CC      ppc64-softmmu/hw/ppc/ppc_booke.o
  CC      ppcemb-softmmu/hw/ppc/ppc4xx_pci.o
  CC      s390x-softmmu/accel/tcg/cpu-exec-common.o
  CC      ppc-softmmu/hw/virtio/virtio-balloon.o
  CC      s390x-softmmu/accel/tcg/translate-all.o
  CC      ppc64-softmmu/hw/ppc/fdt.o
  CC      ppcemb-softmmu/hw/ppc/virtex_ml507.o
  CC      ppc64-softmmu/hw/ppc/spapr.o
  CC      ppc-softmmu/hw/virtio/vhost.o
  CC      ppcemb-softmmu/target/ppc/cpu-models.o
  CC      s390x-softmmu/accel/tcg/translator.o
  CC      ppc-softmmu/hw/virtio/vhost-backend.o
  CC      s390x-softmmu/hw/9pfs/virtio-9p-device.o
  CC      ppc64-softmmu/hw/ppc/spapr_vio.o
  CC      s390x-softmmu/hw/block/virtio-blk.o
  CC      ppcemb-softmmu/target/ppc/cpu.o
  CC      ppc-softmmu/hw/virtio/vhost-user.o
  CC      ppcemb-softmmu/target/ppc/translate.o
  CC      ppc64-softmmu/hw/ppc/spapr_events.o
  CC      s390x-softmmu/hw/block/dataplane/virtio-blk.o
  CC      ppc-softmmu/hw/virtio/vhost-vsock.o
  CC      ppc64-softmmu/hw/ppc/spapr_hcall.o
  CC      ppc-softmmu/hw/virtio/virtio-crypto.o
  CC      s390x-softmmu/hw/char/virtio-serial-bus.o
  CC      ppc64-softmmu/hw/ppc/spapr_iommu.o
  CC      ppc-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      s390x-softmmu/hw/char/terminal3270.o
  CC      ppc64-softmmu/hw/ppc/spapr_rtas.o
  CC      ppc64-softmmu/hw/ppc/spapr_pci.o
  CC      ppc-softmmu/hw/ppc/ppc.o
  CC      s390x-softmmu/hw/core/generic-loader.o
  CC      s390x-softmmu/hw/core/null-machine.o
  CC      ppc-softmmu/hw/ppc/ppc_booke.o
  CC      ppc-softmmu/hw/ppc/fdt.o
  CC      s390x-softmmu/hw/display/virtio-gpu.o
  CC      ppc64-softmmu/hw/ppc/spapr_rtc.o
  CC      ppc-softmmu/hw/ppc/ppc405_boards.o
  CC      ppc-softmmu/hw/ppc/ppc4xx_devs.o
  CC      ppc64-softmmu/hw/ppc/spapr_drc.o
  CC      s390x-softmmu/hw/display/virtio-gpu-3d.o
  CC      ppc-softmmu/hw/ppc/ppc405_uc.o
  CC      ppc64-softmmu/hw/ppc/spapr_rng.o
  CC      s390x-softmmu/hw/display/virtio-gpu-pci.o
  CC      ppc-softmmu/hw/ppc/ppc440_bamboo.o
  CC      s390x-softmmu/hw/intc/s390_flic.o
  CC      ppc64-softmmu/hw/ppc/spapr_cpu_core.o
  CC      ppc64-softmmu/hw/ppc/spapr_ovec.o
  CC      ppc-softmmu/hw/ppc/ppc4xx_pci.o
  CC      s390x-softmmu/hw/intc/s390_flic_kvm.o
  CC      ppc64-softmmu/hw/ppc/pnv.o
  CC      s390x-softmmu/hw/misc/mmio_interface.o
  CC      ppc-softmmu/hw/ppc/prep.o
  CC      s390x-softmmu/hw/net/virtio-net.o
  CC      ppc-softmmu/hw/ppc/prep_systemio.o
  CC      ppc64-softmmu/hw/ppc/pnv_xscom.o
  CC      ppc-softmmu/hw/ppc/rs6000_mc.o
  CC      s390x-softmmu/hw/net/vhost_net.o
  CC      ppc-softmmu/hw/ppc/mac_oldworld.o
  CC      ppc64-softmmu/hw/ppc/pnv_core.o
  CC      s390x-softmmu/hw/net/rocker/qmp-norocker.o
  CC      ppc-softmmu/hw/ppc/mac_newworld.o
  CC      ppc64-softmmu/hw/ppc/pnv_lpc.o
  CC      s390x-softmmu/hw/scsi/virtio-scsi.o
  CC      ppc-softmmu/hw/ppc/e500.o
  CC      ppc64-softmmu/hw/ppc/pnv_psi.o
  CC      ppc64-softmmu/hw/ppc/pnv_occ.o
  CC      ppc-softmmu/hw/ppc/mpc8544ds.o
  CC      s390x-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      ppc64-softmmu/hw/ppc/pnv_bmc.o
  CC      ppc-softmmu/hw/ppc/e500plat.o
  CC      s390x-softmmu/hw/scsi/vhost-scsi-common.o
  CC      ppc64-softmmu/hw/ppc/spapr_pci_vfio.o
  CC      s390x-softmmu/hw/scsi/vhost-scsi.o
  CC      ppc-softmmu/hw/ppc/mpc8544_guts.o
  CC      ppc64-softmmu/hw/ppc/spapr_rtas_ddw.o
  CC      s390x-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc-softmmu/hw/ppc/ppce500_spin.o
  CC      s390x-softmmu/hw/vfio/common.o
  CC      ppc64-softmmu/hw/ppc/ppc405_boards.o
  CC      ppc-softmmu/hw/ppc/virtex_ml507.o
  CC      ppc-softmmu/target/ppc/cpu-models.o
  CC      s390x-softmmu/hw/vfio/pci.o
  CC      ppc64-softmmu/hw/ppc/ppc4xx_devs.o
  CC      ppc64-softmmu/hw/ppc/ppc405_uc.o
  CC      ppc-softmmu/target/ppc/cpu.o
  CC      s390x-softmmu/hw/vfio/pci-quirks.o
  CC      ppc-softmmu/target/ppc/translate.o
  CC      ppc64-softmmu/hw/ppc/ppc440_bamboo.o
  CC      ppc64-softmmu/hw/ppc/ppc4xx_pci.o
  CC      s390x-softmmu/hw/vfio/ccw.o
  CC      ppc64-softmmu/hw/ppc/prep.o
  CC      s390x-softmmu/hw/vfio/platform.o
  CC      ppcemb-softmmu/target/ppc/machine.o
  CC      ppc64-softmmu/hw/ppc/prep_systemio.o
  CC      s390x-softmmu/hw/vfio/spapr.o
  CC      ppcemb-softmmu/target/ppc/mmu_helper.o
  CC      ppc64-softmmu/hw/ppc/rs6000_mc.o
  CC      s390x-softmmu/hw/virtio/virtio.o
  CC      ppc64-softmmu/hw/ppc/mac_oldworld.o
  CC      ppc64-softmmu/hw/ppc/mac_newworld.o
  CC      ppcemb-softmmu/target/ppc/mmu-hash32.o
  CC      s390x-softmmu/hw/virtio/virtio-balloon.o
  CC      ppc64-softmmu/hw/ppc/e500.o
  CC      ppcemb-softmmu/target/ppc/monitor.o
  CC      s390x-softmmu/hw/virtio/vhost.o
  CC      ppc64-softmmu/hw/ppc/mpc8544ds.o
  CC      ppcemb-softmmu/target/ppc/arch_dump.o
  CC      ppc64-softmmu/hw/ppc/e500plat.o
  CC      ppcemb-softmmu/target/ppc/kvm-stub.o
  CC      s390x-softmmu/hw/virtio/vhost-backend.o
  CC      ppcemb-softmmu/target/ppc/dfp_helper.o
  CC      ppc64-softmmu/hw/ppc/mpc8544_guts.o
  CC      s390x-softmmu/hw/virtio/vhost-user.o
  CC      ppc64-softmmu/hw/ppc/ppce500_spin.o
  CC      ppcemb-softmmu/target/ppc/excp_helper.o
  CC      ppc64-softmmu/hw/ppc/virtex_ml507.o
  CC      s390x-softmmu/hw/virtio/vhost-vsock.o
  CC      ppc64-softmmu/target/ppc/cpu-models.o
  CC      ppcemb-softmmu/target/ppc/fpu_helper.o
  CC      s390x-softmmu/hw/virtio/virtio-crypto.o
  CC      s390x-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      ppc64-softmmu/target/ppc/cpu.o
  CC      s390x-softmmu/hw/s390x/s390-virtio-hcall.o
  CC      ppc64-softmmu/target/ppc/translate.o
  CC      s390x-softmmu/hw/s390x/sclp.o
  CC      s390x-softmmu/hw/s390x/event-facility.o
  CC      ppcemb-softmmu/target/ppc/int_helper.o
  CC      s390x-softmmu/hw/s390x/sclpquiesce.o
  CC      s390x-softmmu/hw/s390x/sclpcpu.o
  CC      s390x-softmmu/hw/s390x/ipl.o
  CC      ppcemb-softmmu/target/ppc/timebase_helper.o
  CC      ppcemb-softmmu/target/ppc/misc_helper.o
  CC      s390x-softmmu/hw/s390x/css.o
  CC      ppcemb-softmmu/target/ppc/mem_helper.o
  CC      ppc-softmmu/target/ppc/machine.o
  CC      ppcemb-softmmu/target/ppc/gdbstub.o
  CC      s390x-softmmu/hw/s390x/s390-virtio-ccw.o
  CC      ppc-softmmu/target/ppc/mmu_helper.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/decContext.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/decNumber.o
  CC      s390x-softmmu/hw/s390x/3270-ccw.o
  CC      ppc-softmmu/target/ppc/mmu-hash32.o
  CC      s390x-softmmu/hw/s390x/virtio-ccw.o
  CC      ppc-softmmu/target/ppc/monitor.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      ppc-softmmu/target/ppc/arch_dump.o
  CC      s390x-softmmu/hw/s390x/css-bridge.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      ppc-softmmu/target/ppc/kvm-stub.o
  CC      s390x-softmmu/hw/s390x/ccw-device.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      s390x-softmmu/hw/s390x/s390-pci-bus.o
  CC      ppc-softmmu/target/ppc/dfp_helper.o
  GEN     trace/generated-helpers.c
  CC      ppcemb-softmmu/trace/control-target.o
  CC      s390x-softmmu/hw/s390x/s390-pci-inst.o
  CC      ppcemb-softmmu/gdbstub-xml.o
  CC      ppc-softmmu/target/ppc/excp_helper.o
  CC      ppcemb-softmmu/trace/generated-helpers.o
  CC      s390x-softmmu/hw/s390x/s390-skeys.o
  LINK    ppcemb-softmmu/qemu-system-ppcemb
  CC      ppc-softmmu/target/ppc/fpu_helper.o
  CC      s390x-softmmu/hw/s390x/s390-stattrib.o
  CC      s390x-softmmu/hw/s390x/s390-skeys-kvm.o
  CC      ppc-softmmu/target/ppc/int_helper.o
  CC      s390x-softmmu/hw/s390x/s390-stattrib-kvm.o
  CC      s390x-softmmu/hw/s390x/s390-ccw.o
  CC      s390x-softmmu/target/s390x/cpu.o
  CC      s390x-softmmu/target/s390x/cpu_models.o
  CC      ppc-softmmu/target/ppc/timebase_helper.o
  CC      s390x-softmmu/target/s390x/cpu_features.o
  CC      ppc64-softmmu/target/ppc/machine.o
  CC      ppc-softmmu/target/ppc/misc_helper.o
  CC      s390x-softmmu/target/s390x/gdbstub.o
  CC      ppc-softmmu/target/ppc/mem_helper.o
  CC      s390x-softmmu/target/s390x/interrupt.o
  CC      ppc64-softmmu/target/ppc/mmu_helper.o
  GEN     sh4eb-softmmu/hmp-commands.h
  GEN     sh4eb-softmmu/hmp-commands-info.h
  GEN     sh4eb-softmmu/config-target.h
  CC      s390x-softmmu/target/s390x/helper.o
  CC      sh4eb-softmmu/exec.o
  CC      ppc-softmmu/target/ppc/gdbstub.o
  CC      s390x-softmmu/target/s390x/translate.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/decContext.o
  CC      ppc64-softmmu/target/ppc/mmu-hash32.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/decNumber.o
  CC      ppc64-softmmu/target/ppc/monitor.o
  CC      sh4eb-softmmu/tcg/tcg.o
  CC      ppc64-softmmu/target/ppc/arch_dump.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      ppc64-softmmu/target/ppc/mmu-hash64.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      ppc64-softmmu/target/ppc/mmu-book3s-v3.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      ppc64-softmmu/target/ppc/compat.o
  CC      sh4eb-softmmu/tcg/tcg-op.o
  GEN     trace/generated-helpers.c
  CC      ppc-softmmu/trace/control-target.o
  CC      ppc64-softmmu/target/ppc/mmu-radix64.o
  CC      s390x-softmmu/target/s390x/cc_helper.o
  CC      ppc-softmmu/gdbstub-xml.o
  CC      ppc64-softmmu/target/ppc/kvm-stub.o
  CC      s390x-softmmu/target/s390x/excp_helper.o
  CC      ppc64-softmmu/target/ppc/dfp_helper.o
  CC      ppc-softmmu/trace/generated-helpers.o
  CC      s390x-softmmu/target/s390x/fpu_helper.o
  LINK    ppc-softmmu/qemu-system-ppc
  CC      ppc64-softmmu/target/ppc/excp_helper.o
  CC      sh4eb-softmmu/tcg/optimize.o
  CC      s390x-softmmu/target/s390x/int_helper.o
  CC      s390x-softmmu/target/s390x/mem_helper.o
  CC      ppc64-softmmu/target/ppc/fpu_helper.o
  CC      sh4eb-softmmu/tcg/tcg-common.o
  CC      ppc64-softmmu/target/ppc/int_helper.o
  CC      sh4eb-softmmu/fpu/softfloat.o
  CC      s390x-softmmu/target/s390x/misc_helper.o
  CC      s390x-softmmu/target/s390x/crypto_helper.o
  CC      s390x-softmmu/target/s390x/machine.o
  CC      ppc64-softmmu/target/ppc/timebase_helper.o
  CC      s390x-softmmu/target/s390x/ioinst.o
  CC      ppc64-softmmu/target/ppc/misc_helper.o
  CC      s390x-softmmu/target/s390x/arch_dump.o
  CC      s390x-softmmu/target/s390x/mmu_helper.o
  CC      ppc64-softmmu/target/ppc/mem_helper.o
  CC      sh4eb-softmmu/disas.o
  CC      s390x-softmmu/target/s390x/diag.o
  CC      s390x-softmmu/target/s390x/sigp.o
  CC      sh4eb-softmmu/arch_init.o
  CC      ppc64-softmmu/target/ppc/gdbstub.o
  CC      s390x-softmmu/target/s390x/kvm.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/decContext.o
  CC      sh4eb-softmmu/cpus.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/decNumber.o
  CC      sh4eb-softmmu/monitor.o
  GEN     sh4-softmmu/hmp-commands.h
  GEN     trace/generated-helpers.c
  GEN     sh4-softmmu/hmp-commands-info.h
  CC      s390x-softmmu/trace/control-target.o
  GEN     sh4-softmmu/config-target.h
  CC      s390x-softmmu/gdbstub-xml.o
  CC      sh4-softmmu/exec.o
  CC      s390x-softmmu/trace/generated-helpers.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      sh4eb-softmmu/gdbstub.o
  LINK    s390x-softmmu/qemu-system-s390x
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      sh4eb-softmmu/balloon.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      sh4eb-softmmu/ioport.o
  CC      sh4-softmmu/tcg/tcg.o
  CC      sh4eb-softmmu/numa.o
  GEN     trace/generated-helpers.c
  CC      ppc64-softmmu/trace/control-target.o
  CC      sh4-softmmu/tcg/tcg-op.o
  CC      ppc64-softmmu/gdbstub-xml.o
  CC      ppc64-softmmu/trace/generated-helpers.o
  CC      sh4eb-softmmu/qtest.o
  LINK    ppc64-softmmu/qemu-system-ppc64
  CC      sh4eb-softmmu/memory.o
  CC      sh4-softmmu/tcg/optimize.o
  GEN     sparc64-softmmu/hmp-commands.h
  GEN     sparc64-softmmu/hmp-commands-info.h
  GEN     sparc64-softmmu/config-target.h
  CC      sparc64-softmmu/exec.o
  CC      sh4eb-softmmu/memory_mapping.o
  CC      sh4-softmmu/tcg/tcg-common.o
  CC      sh4-softmmu/fpu/softfloat.o
  CC      sh4eb-softmmu/dump.o
  CC      sh4eb-softmmu/migration/ram.o
  GEN     sparc-softmmu/hmp-commands.h
  GEN     sparc-softmmu/hmp-commands-info.h
  GEN     sparc-softmmu/config-target.h
  CC      sparc-softmmu/exec.o
  CC      sparc64-softmmu/tcg/tcg.o
  CC      sh4eb-softmmu/accel/accel.o
  CC      sparc-softmmu/tcg/tcg.o
  CC      sh4eb-softmmu/accel/stubs/hax-stub.o
  CC      sh4-softmmu/disas.o
  CC      sh4eb-softmmu/accel/stubs/kvm-stub.o
  CC      sparc64-softmmu/tcg/tcg-op.o
  CC      sh4-softmmu/arch_init.o
  CC      sh4-softmmu/cpus.o
  CC      sh4eb-softmmu/accel/tcg/tcg-all.o
  CC      sh4eb-softmmu/accel/tcg/cputlb.o
  CC      sh4-softmmu/monitor.o
  CC      sparc-softmmu/tcg/tcg-op.o
  CC      sparc64-softmmu/tcg/optimize.o
  CC      sh4-softmmu/gdbstub.o
  CC      sh4eb-softmmu/accel/tcg/tcg-runtime.o
  CC      sparc64-softmmu/tcg/tcg-common.o
  CC      sh4eb-softmmu/accel/tcg/cpu-exec.o
  CC      sparc-softmmu/tcg/optimize.o
  CC      sparc64-softmmu/fpu/softfloat.o
  CC      sh4-softmmu/balloon.o
  CC      sh4eb-softmmu/accel/tcg/cpu-exec-common.o
  CC      sh4-softmmu/ioport.o
  CC      sh4eb-softmmu/accel/tcg/translate-all.o
  CC      sparc-softmmu/tcg/tcg-common.o
  CC      sh4-softmmu/numa.o
  CC      sparc-softmmu/fpu/softfloat.o
  CC      sh4-softmmu/qtest.o
  CC      sh4eb-softmmu/accel/tcg/translator.o
  CC      sh4-softmmu/memory.o
  CC      sh4eb-softmmu/hw/9pfs/virtio-9p-device.o
  CC      sparc64-softmmu/disas.o
  CC      sh4eb-softmmu/hw/block/tc58128.o
  CC      sparc64-softmmu/arch_init.o
  CC      sh4eb-softmmu/hw/block/virtio-blk.o
  CC      sh4-softmmu/memory_mapping.o
  CC      sparc-softmmu/disas.o
  CC      sparc64-softmmu/cpus.o
  CC      sh4-softmmu/dump.o
  CC      sparc-softmmu/arch_init.o
  CC      sh4eb-softmmu/hw/block/dataplane/virtio-blk.o
  CC      sh4eb-softmmu/hw/char/sh_serial.o
  CC      sparc-softmmu/cpus.o
  CC      sparc64-softmmu/monitor.o
  CC      sh4eb-softmmu/hw/char/virtio-serial-bus.o
  CC      sh4-softmmu/migration/ram.o
  CC      sparc-softmmu/monitor.o
  CC      sh4eb-softmmu/hw/core/generic-loader.o
  CC      sh4eb-softmmu/hw/core/null-machine.o
  CC      sh4-softmmu/accel/accel.o
  CC      sparc64-softmmu/gdbstub.o
  CC      sh4eb-softmmu/hw/display/sm501.o
  CC      sh4-softmmu/accel/stubs/hax-stub.o
  CC      sparc-softmmu/gdbstub.o
  CC      sparc64-softmmu/balloon.o
  CC      sh4-softmmu/accel/stubs/kvm-stub.o
  CC      sh4eb-softmmu/hw/display/vga.o
  CC      sparc64-softmmu/ioport.o
  CC      sh4-softmmu/accel/tcg/tcg-all.o
  CC      sparc64-softmmu/numa.o
  CC      sparc-softmmu/balloon.o
  CC      sh4-softmmu/accel/tcg/cputlb.o
  CC      sparc-softmmu/ioport.o
  CC      sparc64-softmmu/qtest.o
  CC      sh4eb-softmmu/hw/display/virtio-gpu.o
  CC      sparc-softmmu/numa.o
  CC      sparc64-softmmu/memory.o
  CC      sh4eb-softmmu/hw/display/virtio-gpu-3d.o
  CC      sparc-softmmu/qtest.o
  CC      sh4-softmmu/accel/tcg/tcg-runtime.o
  CC      sparc-softmmu/memory.o
  CC      sh4eb-softmmu/hw/display/virtio-gpu-pci.o
  CC      sh4-softmmu/accel/tcg/cpu-exec.o
  CC      sparc64-softmmu/memory_mapping.o
  CC      sh4eb-softmmu/hw/intc/sh_intc.o
  CC      sh4-softmmu/accel/tcg/cpu-exec-common.o
  CC      sparc64-softmmu/dump.o
  CC      sh4eb-softmmu/hw/misc/ivshmem.o
  CC      sh4-softmmu/accel/tcg/translate-all.o
  CC      sh4eb-softmmu/hw/misc/mmio_interface.o
  CC      sparc-softmmu/memory_mapping.o
  CC      sparc64-softmmu/migration/ram.o
  CC      sparc-softmmu/dump.o
  CC      sh4-softmmu/accel/tcg/translator.o
  CC      sh4eb-softmmu/hw/net/virtio-net.o
  CC      sparc-softmmu/migration/ram.o
  CC      sh4eb-softmmu/hw/net/vhost_net.o
  CC      sh4-softmmu/hw/9pfs/virtio-9p-device.o
  CC      sparc64-softmmu/accel/accel.o
  CC      sh4-softmmu/hw/block/tc58128.o
  CC      sparc64-softmmu/accel/stubs/hax-stub.o
  CC      sh4eb-softmmu/hw/scsi/virtio-scsi.o
  CC      sh4-softmmu/hw/block/virtio-blk.o
  CC      sparc64-softmmu/accel/stubs/kvm-stub.o
  CC      sparc-softmmu/accel/accel.o
  CC      sh4eb-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      sparc64-softmmu/accel/tcg/tcg-all.o
  CC      sh4-softmmu/hw/block/dataplane/virtio-blk.o
  CC      sparc64-softmmu/accel/tcg/cputlb.o
  CC      sparc-softmmu/accel/stubs/hax-stub.o
  CC      sh4eb-softmmu/hw/scsi/vhost-scsi-common.o
  CC      sh4-softmmu/hw/char/sh_serial.o
  CC      sparc-softmmu/accel/stubs/kvm-stub.o
  CC      sh4eb-softmmu/hw/scsi/vhost-scsi.o
  CC      sh4-softmmu/hw/char/virtio-serial-bus.o
  CC      sh4eb-softmmu/hw/scsi/vhost-user-scsi.o
  CC      sparc-softmmu/accel/tcg/tcg-all.o
  CC      sh4eb-softmmu/hw/timer/sh_timer.o
  CC      sh4-softmmu/hw/core/generic-loader.o
  CC      sh4eb-softmmu/hw/timer/mc146818rtc.o
  CC      sparc-softmmu/accel/tcg/cputlb.o
  CC      sh4-softmmu/hw/core/null-machine.o
  CC      sparc64-softmmu/accel/tcg/tcg-runtime.o
  CC      sh4-softmmu/hw/display/sm501.o
  CC      sh4eb-softmmu/hw/vfio/common.o
  CC      sparc64-softmmu/accel/tcg/cpu-exec.o
  CC      sh4-softmmu/hw/display/vga.o
  CC      sh4eb-softmmu/hw/vfio/pci.o
  CC      sparc64-softmmu/accel/tcg/cpu-exec-common.o
  CC      sparc-softmmu/accel/tcg/tcg-runtime.o
  CC      sparc64-softmmu/accel/tcg/translate-all.o
  CC      sparc64-softmmu/accel/tcg/translator.o
  CC      sh4eb-softmmu/hw/vfio/pci-quirks.o
  CC      sparc-softmmu/accel/tcg/cpu-exec.o
  CC      sh4-softmmu/hw/display/virtio-gpu.o
  CC      sparc-softmmu/accel/tcg/cpu-exec-common.o
  CC      sparc64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      sh4eb-softmmu/hw/vfio/platform.o
  CC      sparc-softmmu/accel/tcg/translate-all.o
  CC      sparc64-softmmu/hw/block/virtio-blk.o
  CC      sparc64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      sh4-softmmu/hw/display/virtio-gpu-3d.o
  CC      sh4eb-softmmu/hw/vfio/spapr.o
  CC      sparc-softmmu/accel/tcg/translator.o
  CC      sparc64-softmmu/hw/char/virtio-serial-bus.o
  CC      sh4eb-softmmu/hw/virtio/virtio.o
  CC      sparc-softmmu/hw/core/generic-loader.o
  CC      sh4-softmmu/hw/display/virtio-gpu-pci.o
  CC      sparc64-softmmu/hw/core/generic-loader.o
  CC      sparc-softmmu/hw/core/null-machine.o
  CC      sh4-softmmu/hw/intc/sh_intc.o
  CC      sparc64-softmmu/hw/core/null-machine.o
  CC      sparc64-softmmu/hw/display/vga.o
  CC      sparc-softmmu/hw/display/tcx.o
  CC      sh4eb-softmmu/hw/virtio/virtio-balloon.o
  CC      sh4-softmmu/hw/misc/ivshmem.o
  CC      sh4eb-softmmu/hw/virtio/vhost.o
  CC      sparc-softmmu/hw/display/cg3.o
  CC      sparc-softmmu/hw/intc/grlib_irqmp.o
  CC      sh4-softmmu/hw/misc/mmio_interface.o
  CC      sh4eb-softmmu/hw/virtio/vhost-backend.o
  CC      sh4-softmmu/hw/net/virtio-net.o
  CC      sparc64-softmmu/hw/display/virtio-gpu.o
  CC      sparc-softmmu/hw/misc/eccmemctl.o
  CC      sh4eb-softmmu/hw/virtio/vhost-user.o
  CC      sparc-softmmu/hw/misc/slavio_misc.o
  CC      sh4-softmmu/hw/net/vhost_net.o
  CC      sh4-softmmu/hw/scsi/virtio-scsi.o
  CC      sparc64-softmmu/hw/display/virtio-gpu-3d.o
  CC      sparc-softmmu/hw/misc/mmio_interface.o
  CC      sh4eb-softmmu/hw/virtio/vhost-vsock.o
  CC      sparc-softmmu/hw/net/vhost_net.o
  CC      sh4-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      sh4eb-softmmu/hw/virtio/virtio-crypto.o
  CC      sparc64-softmmu/hw/display/virtio-gpu-pci.o
  CC      sparc-softmmu/hw/net/rocker/qmp-norocker.o
  CC      sh4-softmmu/hw/scsi/vhost-scsi-common.o
  CC      sparc-softmmu/hw/vfio/common.o
  CC      sh4eb-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      sparc64-softmmu/hw/misc/ivshmem.o
  CC      sh4-softmmu/hw/scsi/vhost-scsi.o
  CC      sh4eb-softmmu/hw/sh4/shix.o
  CC      sparc64-softmmu/hw/misc/mmio_interface.o
  CC      sparc-softmmu/hw/vfio/platform.o
  CC      sh4eb-softmmu/hw/sh4/r2d.o
  CC      sh4-softmmu/hw/scsi/vhost-user-scsi.o
  CC      sparc64-softmmu/hw/net/virtio-net.o
  CC      sparc-softmmu/hw/vfio/spapr.o
  CC      sh4eb-softmmu/hw/sh4/sh7750.o
  CC      sh4-softmmu/hw/timer/sh_timer.o
  CC      sparc-softmmu/hw/sparc/sun4m.o
  CC      sh4eb-softmmu/hw/sh4/sh7750_regnames.o
  CC      sh4-softmmu/hw/timer/mc146818rtc.o
  CC      sh4eb-softmmu/hw/sh4/sh_pci.o
  CC      sparc64-softmmu/hw/net/vhost_net.o
  CC      sparc-softmmu/hw/sparc/leon3.o
  CC      sparc64-softmmu/hw/scsi/virtio-scsi.o
  CC      sh4eb-softmmu/target/sh4/translate.o
  CC      sh4-softmmu/hw/vfio/common.o
  CC      sparc-softmmu/target/sparc/machine.o
  CC      sparc64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      sparc-softmmu/target/sparc/monitor.o
  CC      sparc64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      sh4-softmmu/hw/vfio/pci.o
  CC      sparc-softmmu/target/sparc/translate.o
  CC      sparc64-softmmu/hw/scsi/vhost-scsi.o
  CC      sparc64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      sh4eb-softmmu/target/sh4/op_helper.o
  CC      sh4-softmmu/hw/vfio/pci-quirks.o
  CC      sparc64-softmmu/hw/timer/mc146818rtc.o
  CC      sh4eb-softmmu/target/sh4/helper.o
  CC      sparc64-softmmu/hw/vfio/common.o
  CC      sh4-softmmu/hw/vfio/platform.o
  CC      sh4eb-softmmu/target/sh4/cpu.o
  CC      sparc-softmmu/target/sparc/helper.o
  CC      sh4-softmmu/hw/vfio/spapr.o
  CC      sh4eb-softmmu/target/sh4/monitor.o
  CC      sparc-softmmu/target/sparc/cpu.o
  CC      sh4-softmmu/hw/virtio/virtio.o
  CC      sparc64-softmmu/hw/vfio/pci.o
  CC      sh4eb-softmmu/target/sh4/gdbstub.o
  CC      sparc-softmmu/target/sparc/fop_helper.o
  GEN     trace/generated-helpers.c
  CC      sh4eb-softmmu/trace/control-target.o
  CC      sparc-softmmu/target/sparc/cc_helper.o
  CC      sh4-softmmu/hw/virtio/virtio-balloon.o
  CC      sparc64-softmmu/hw/vfio/pci-quirks.o
  CC      sparc-softmmu/target/sparc/win_helper.o
  CC      sh4eb-softmmu/trace/generated-helpers.o
  CC      sh4-softmmu/hw/virtio/vhost.o
  LINK    sh4eb-softmmu/qemu-system-sh4eb
  CC      sparc-softmmu/target/sparc/mmu_helper.o
  CC      sparc64-softmmu/hw/vfio/platform.o
  CC      sparc-softmmu/target/sparc/ldst_helper.o
  CC      sh4-softmmu/hw/virtio/vhost-backend.o
  CC      sparc64-softmmu/hw/vfio/spapr.o
  CC      sh4-softmmu/hw/virtio/vhost-user.o
  CC      sparc64-softmmu/hw/virtio/virtio.o
  CC      sparc-softmmu/target/sparc/int32_helper.o
  CC      sh4-softmmu/hw/virtio/vhost-vsock.o
  CC      sparc64-softmmu/hw/virtio/virtio-balloon.o
  CC      sparc-softmmu/target/sparc/gdbstub.o
  CC      sparc64-softmmu/hw/virtio/vhost.o
  CC      sh4-softmmu/hw/virtio/virtio-crypto.o
  GEN     trace/generated-helpers.c
  CC      sparc-softmmu/trace/control-target.o
  CC      sh4-softmmu/hw/virtio/virtio-crypto-pci.o
  GEN     tricore-softmmu/hmp-commands.h
  GEN     tricore-softmmu/hmp-commands-info.h
  CC      sparc-softmmu/trace/generated-helpers.o
  GEN     tricore-softmmu/config-target.h
  CC      sparc64-softmmu/hw/virtio/vhost-backend.o
  CC      tricore-softmmu/exec.o
  LINK    sparc-softmmu/qemu-system-sparc
  CC      sh4-softmmu/hw/sh4/shix.o
  CC      sparc64-softmmu/hw/virtio/vhost-user.o
  CC      sh4-softmmu/hw/sh4/r2d.o
  CC      sparc64-softmmu/hw/virtio/vhost-vsock.o
  CC      sh4-softmmu/hw/sh4/sh7750.o
  CC      sparc64-softmmu/hw/virtio/virtio-crypto.o
  CC      sh4-softmmu/hw/sh4/sh7750_regnames.o
  CC      sparc64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      tricore-softmmu/tcg/tcg.o
  CC      sh4-softmmu/hw/sh4/sh_pci.o
  CC      sh4-softmmu/target/sh4/translate.o
  CC      sh4-softmmu/target/sh4/op_helper.o
  CC      sparc64-softmmu/hw/sparc64/sparc64.o
  CC      tricore-softmmu/tcg/tcg-op.o
  CC      sparc64-softmmu/hw/sparc64/sun4u.o
  CC      sparc64-softmmu/hw/sparc64/niagara.o
  CC      tricore-softmmu/tcg/optimize.o
  CC      sh4-softmmu/target/sh4/helper.o
  CC      sparc64-softmmu/target/sparc/machine.o
  CC      sh4-softmmu/target/sh4/cpu.o
  CC      tricore-softmmu/tcg/tcg-common.o
  CC      sparc64-softmmu/target/sparc/monitor.o
  CC      sh4-softmmu/target/sh4/monitor.o
  CC      tricore-softmmu/fpu/softfloat.o
  CC      sh4-softmmu/target/sh4/gdbstub.o
  CC      sparc64-softmmu/target/sparc/translate.o
  GEN     trace/generated-helpers.c
  GEN     unicore32-softmmu/hmp-commands.h
  CC      sh4-softmmu/trace/control-target.o
  GEN     unicore32-softmmu/hmp-commands-info.h
  GEN     unicore32-softmmu/config-target.h
  CC      unicore32-softmmu/exec.o
  CC      sh4-softmmu/trace/generated-helpers.o
  LINK    sh4-softmmu/qemu-system-sh4
  CC      tricore-softmmu/disas.o
  CC      unicore32-softmmu/tcg/tcg.o
  CC      sparc64-softmmu/target/sparc/helper.o
  CC      tricore-softmmu/arch_init.o
  CC      tricore-softmmu/cpus.o
  CC      sparc64-softmmu/target/sparc/cpu.o
  CC      unicore32-softmmu/tcg/tcg-op.o
  CC      tricore-softmmu/monitor.o
  CC      sparc64-softmmu/target/sparc/fop_helper.o
  CC      tricore-softmmu/gdbstub.o
  CC      sparc64-softmmu/target/sparc/cc_helper.o
  CC      unicore32-softmmu/tcg/optimize.o
  CC      tricore-softmmu/balloon.o
  CC      unicore32-softmmu/tcg/tcg-common.o
  CC      sparc64-softmmu/target/sparc/win_helper.o
  CC      tricore-softmmu/ioport.o
  CC      sparc64-softmmu/target/sparc/mmu_helper.o
  CC      tricore-softmmu/numa.o
  CC      unicore32-softmmu/fpu/softfloat.o
  CC      sparc64-softmmu/target/sparc/ldst_helper.o
  CC      sparc64-softmmu/target/sparc/int64_helper.o
  CC      tricore-softmmu/qtest.o
  CC      tricore-softmmu/memory.o
  CC      sparc64-softmmu/target/sparc/vis_helper.o
  CC      unicore32-softmmu/disas.o
  CC      sparc64-softmmu/target/sparc/gdbstub.o
  GEN     trace/generated-helpers.c
  CC      sparc64-softmmu/trace/control-target.o
  CC      unicore32-softmmu/arch_init.o
  CC      tricore-softmmu/memory_mapping.o
  CC      unicore32-softmmu/cpus.o
  CC      sparc64-softmmu/trace/generated-helpers.o
  CC      tricore-softmmu/dump.o
  LINK    sparc64-softmmu/qemu-system-sparc64
  CC      unicore32-softmmu/monitor.o
  CC      tricore-softmmu/migration/ram.o
  GEN     x86_64-softmmu/hmp-commands.h
  GEN     x86_64-softmmu/hmp-commands-info.h
  GEN     x86_64-softmmu/config-target.h
  CC      x86_64-softmmu/exec.o
  CC      unicore32-softmmu/gdbstub.o
  CC      tricore-softmmu/accel/accel.o
  CC      tricore-softmmu/accel/stubs/hax-stub.o
  CC      tricore-softmmu/accel/stubs/kvm-stub.o
  CC      tricore-softmmu/accel/tcg/tcg-all.o
  GEN     xtensaeb-softmmu/hmp-commands.h
  GEN     xtensaeb-softmmu/hmp-commands-info.h
  GEN     xtensaeb-softmmu/config-target.h
  CC      unicore32-softmmu/balloon.o
  CC      tricore-softmmu/accel/tcg/cputlb.o
  CC      xtensaeb-softmmu/exec.o
  CC      unicore32-softmmu/ioport.o
  CC      unicore32-softmmu/numa.o
  CC      x86_64-softmmu/tcg/tcg.o
  CC      unicore32-softmmu/qtest.o
  CC      tricore-softmmu/accel/tcg/tcg-runtime.o
  CC      unicore32-softmmu/memory.o
  CC      xtensaeb-softmmu/tcg/tcg.o
  CC      tricore-softmmu/accel/tcg/cpu-exec.o
  CC      tricore-softmmu/accel/tcg/cpu-exec-common.o
  CC      x86_64-softmmu/tcg/tcg-op.o
  CC      unicore32-softmmu/memory_mapping.o
  CC      tricore-softmmu/accel/tcg/translate-all.o
  CC      unicore32-softmmu/dump.o
  CC      tricore-softmmu/accel/tcg/translator.o
  CC      xtensaeb-softmmu/tcg/tcg-op.o
  CC      tricore-softmmu/hw/core/generic-loader.o
  CC      tricore-softmmu/hw/core/null-machine.o
  CC      unicore32-softmmu/migration/ram.o
  CC      x86_64-softmmu/tcg/optimize.o
  CC      tricore-softmmu/hw/misc/mmio_interface.o
  CC      tricore-softmmu/hw/net/vhost_net.o
  CC      unicore32-softmmu/accel/accel.o
  CC      x86_64-softmmu/tcg/tcg-common.o
  CC      tricore-softmmu/hw/net/rocker/qmp-norocker.o
  CC      xtensaeb-softmmu/tcg/optimize.o
  CC      tricore-softmmu/hw/vfio/common.o
  CC      x86_64-softmmu/fpu/softfloat.o
  CC      unicore32-softmmu/accel/stubs/hax-stub.o
  CC      tricore-softmmu/hw/vfio/platform.o
  CC      unicore32-softmmu/accel/stubs/kvm-stub.o
  CC      xtensaeb-softmmu/tcg/tcg-common.o
  CC      tricore-softmmu/hw/vfio/spapr.o
  CC      unicore32-softmmu/accel/tcg/tcg-all.o
  CC      xtensaeb-softmmu/fpu/softfloat.o
  CC      tricore-softmmu/hw/tricore/tricore_testboard.o
  CC      unicore32-softmmu/accel/tcg/cputlb.o
  CC      tricore-softmmu/target/tricore/translate.o
  CC      x86_64-softmmu/disas.o
  GEN     x86_64-softmmu/gdbstub-xml.c
  CC      unicore32-softmmu/accel/tcg/tcg-runtime.o
  CC      xtensaeb-softmmu/disas.o
  CC      unicore32-softmmu/accel/tcg/cpu-exec.o
  CC      x86_64-softmmu/arch_init.o
  CC      x86_64-softmmu/cpus.o
  CC      unicore32-softmmu/accel/tcg/cpu-exec-common.o
  CC      xtensaeb-softmmu/arch_init.o
  CC      unicore32-softmmu/accel/tcg/translate-all.o
  CC      xtensaeb-softmmu/cpus.o
  CC      x86_64-softmmu/monitor.o
  CC      unicore32-softmmu/accel/tcg/translator.o
  CC      xtensaeb-softmmu/monitor.o
  CC      unicore32-softmmu/hw/core/generic-loader.o
  CC      tricore-softmmu/target/tricore/helper.o
  CC      unicore32-softmmu/hw/core/null-machine.o
  CC      x86_64-softmmu/gdbstub.o
  CC      unicore32-softmmu/hw/misc/mmio_interface.o
  CC      tricore-softmmu/target/tricore/cpu.o
  CC      tricore-softmmu/target/tricore/op_helper.o
  CC      unicore32-softmmu/hw/net/vhost_net.o
  CC      x86_64-softmmu/balloon.o
  CC      unicore32-softmmu/hw/net/rocker/qmp-norocker.o
  CC      xtensaeb-softmmu/gdbstub.o
  CC      x86_64-softmmu/ioport.o
  CC      unicore32-softmmu/hw/vfio/common.o
  CC      xtensaeb-softmmu/balloon.o
  CC      x86_64-softmmu/numa.o
  CC      xtensaeb-softmmu/ioport.o
  CC      tricore-softmmu/target/tricore/fpu_helper.o
  CC      unicore32-softmmu/hw/vfio/platform.o
  CC      x86_64-softmmu/qtest.o
  GEN     trace/generated-helpers.c
  CC      xtensaeb-softmmu/numa.o
  CC      tricore-softmmu/trace/control-target.o
  CC      unicore32-softmmu/hw/vfio/spapr.o
  CC      x86_64-softmmu/memory.o
  CC      xtensaeb-softmmu/qtest.o
  CC      unicore32-softmmu/hw/unicore32/puv3.o
  CC      tricore-softmmu/trace/generated-helpers.o
  CC      unicore32-softmmu/target/unicore32/translate.o
  CC      xtensaeb-softmmu/memory.o
  LINK    tricore-softmmu/qemu-system-tricore
  CC      x86_64-softmmu/memory_mapping.o
  CC      xtensaeb-softmmu/memory_mapping.o
  CC      x86_64-softmmu/dump.o
  CC      xtensaeb-softmmu/dump.o
  CC      unicore32-softmmu/target/unicore32/op_helper.o
  CC      unicore32-softmmu/target/unicore32/helper.o
  CC      xtensaeb-softmmu/migration/ram.o
  CC      unicore32-softmmu/target/unicore32/cpu.o
  CC      x86_64-softmmu/migration/ram.o
  CC      x86_64-softmmu/accel/accel.o
  CC      unicore32-softmmu/target/unicore32/ucf64_helper.o
  CC      unicore32-softmmu/target/unicore32/softmmu.o
  GEN     trace/generated-helpers.c
  CC      unicore32-softmmu/trace/control-target.o
  CC      xtensaeb-softmmu/accel/accel.o
  CC      unicore32-softmmu/trace/generated-helpers.o
  CC      xtensaeb-softmmu/accel/stubs/hax-stub.o
  CC      x86_64-softmmu/accel/stubs/hax-stub.o
  CC      xtensaeb-softmmu/accel/stubs/kvm-stub.o
  LINK    unicore32-softmmu/qemu-system-unicore32
  GEN     xtensa-softmmu/hmp-commands.h
  CC      x86_64-softmmu/accel/stubs/kvm-stub.o
  GEN     xtensa-softmmu/hmp-commands-info.h
  GEN     xtensa-softmmu/config-target.h
  CC      xtensa-softmmu/exec.o
  CC      xtensaeb-softmmu/accel/tcg/tcg-all.o
  CC      x86_64-softmmu/accel/tcg/tcg-all.o
  CC      xtensaeb-softmmu/accel/tcg/cputlb.o
  CC      x86_64-softmmu/accel/tcg/cputlb.o
  CC      xtensa-softmmu/tcg/tcg.o
  CC      x86_64-softmmu/accel/tcg/tcg-runtime.o
  GEN     aarch64-linux-user/config-target.h
  CC      xtensaeb-softmmu/accel/tcg/tcg-runtime.o
  CC      aarch64-linux-user/exec.o
  CC      x86_64-softmmu/accel/tcg/cpu-exec.o
  CC      xtensaeb-softmmu/accel/tcg/cpu-exec.o
  CC      aarch64-linux-user/tcg/tcg.o
  CC      xtensa-softmmu/tcg/tcg-op.o
  CC      x86_64-softmmu/accel/tcg/cpu-exec-common.o
  CC      xtensaeb-softmmu/accel/tcg/cpu-exec-common.o
  CC      x86_64-softmmu/accel/tcg/translate-all.o
  CC      xtensaeb-softmmu/accel/tcg/translate-all.o
  CC      x86_64-softmmu/accel/tcg/translator.o
  CC      xtensa-softmmu/tcg/optimize.o
  CC      xtensaeb-softmmu/accel/tcg/translator.o
  CC      x86_64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      aarch64-linux-user/tcg/tcg-op.o
  CC      xtensaeb-softmmu/hw/core/generic-loader.o
  CC      x86_64-softmmu/hw/block/virtio-blk.o
  CC      xtensa-softmmu/tcg/tcg-common.o
  CC      xtensaeb-softmmu/hw/core/null-machine.o
  CC      x86_64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      xtensa-softmmu/fpu/softfloat.o
  CC      x86_64-softmmu/hw/char/virtio-serial-bus.o
  CC      xtensaeb-softmmu/hw/misc/mmio_interface.o
  CC      x86_64-softmmu/hw/core/generic-loader.o
  CC      xtensaeb-softmmu/hw/net/vhost_net.o
  CC      aarch64-linux-user/tcg/optimize.o
  CC      x86_64-softmmu/hw/core/null-machine.o
  CC      xtensaeb-softmmu/hw/net/rocker/qmp-norocker.o
  CC      x86_64-softmmu/hw/display/vga.o
  CC      xtensaeb-softmmu/hw/vfio/common.o
  CC      aarch64-linux-user/tcg/tcg-common.o
  CC      xtensaeb-softmmu/hw/vfio/platform.o
  CC      aarch64-linux-user/fpu/softfloat.o
  CC      xtensa-softmmu/disas.o
  CC      xtensaeb-softmmu/hw/vfio/spapr.o
  CC      x86_64-softmmu/hw/display/virtio-gpu.o
  CC      xtensa-softmmu/arch_init.o
  CC      xtensaeb-softmmu/hw/xtensa/pic_cpu.o
  CC      xtensa-softmmu/cpus.o
  CC      x86_64-softmmu/hw/display/virtio-gpu-3d.o
  CC      xtensaeb-softmmu/hw/xtensa/sim.o
  CC      xtensaeb-softmmu/hw/xtensa/xtfpga.o
  CC      xtensa-softmmu/monitor.o
  CC      x86_64-softmmu/hw/display/virtio-gpu-pci.o
  CC      xtensaeb-softmmu/target/xtensa/xtensa-semi.o
  CC      aarch64-linux-user/disas.o
  CC      x86_64-softmmu/hw/display/virtio-vga.o
  CC      xtensaeb-softmmu/target/xtensa/core-dc232b.o
  CC      xtensaeb-softmmu/target/xtensa/core-dc233c.o
  GEN     aarch64-linux-user/gdbstub-xml.c
  CC      x86_64-softmmu/hw/intc/apic.o
  CC      xtensaeb-softmmu/target/xtensa/core-fsf.o
  CC      xtensa-softmmu/gdbstub.o
  CC      xtensaeb-softmmu/target/xtensa/monitor.o
  CC      xtensaeb-softmmu/target/xtensa/translate.o
  CC      x86_64-softmmu/hw/intc/apic_common.o
  CC      aarch64-linux-user/gdbstub.o
  CC      xtensa-softmmu/balloon.o
  CC      xtensa-softmmu/ioport.o
  CC      x86_64-softmmu/hw/intc/ioapic.o
  CC      aarch64-linux-user/thunk.o
  CC      x86_64-softmmu/hw/isa/lpc_ich9.o
  CC      xtensa-softmmu/numa.o
  CC      aarch64-linux-user/accel/stubs/hax-stub.o
  CC      aarch64-linux-user/accel/stubs/kvm-stub.o
  CC      x86_64-softmmu/hw/misc/vmport.o
  CC      aarch64-linux-user/accel/tcg/tcg-runtime.o
  CC      xtensa-softmmu/qtest.o
  CC      x86_64-softmmu/hw/misc/ivshmem.o
  CC      xtensaeb-softmmu/target/xtensa/op_helper.o
  CC      xtensa-softmmu/memory.o
  CC      aarch64-linux-user/accel/tcg/cpu-exec.o
  CC      x86_64-softmmu/hw/misc/pvpanic.o
  CC      xtensaeb-softmmu/target/xtensa/helper.o
  CC      aarch64-linux-user/accel/tcg/cpu-exec-common.o
  CC      x86_64-softmmu/hw/misc/mmio_interface.o
  CC      aarch64-linux-user/accel/tcg/translate-all.o
  CC      x86_64-softmmu/hw/net/virtio-net.o
  CC      xtensaeb-softmmu/target/xtensa/cpu.o
  CC      xtensa-softmmu/memory_mapping.o
  CC      xtensaeb-softmmu/target/xtensa/gdbstub.o
  CC      aarch64-linux-user/accel/tcg/translator.o
  CC      xtensa-softmmu/dump.o
  GEN     trace/generated-helpers.c
  CC      xtensaeb-softmmu/trace/control-target.o
  CC      x86_64-softmmu/hw/net/vhost_net.o
  CC      aarch64-linux-user/accel/tcg/user-exec.o
  CC      xtensaeb-softmmu/trace/generated-helpers.o
  CC      x86_64-softmmu/hw/scsi/virtio-scsi.o
  CC      xtensa-softmmu/migration/ram.o
  LINK    xtensaeb-softmmu/qemu-system-xtensaeb
  CC      x86_64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      aarch64-linux-user/accel/tcg/user-exec-stub.o
  CC      x86_64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      xtensa-softmmu/accel/accel.o
  CC      aarch64-linux-user/linux-user/main.o
  CC      x86_64-softmmu/hw/scsi/vhost-scsi.o
  CC      xtensa-softmmu/accel/stubs/hax-stub.o
  CC      x86_64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      xtensa-softmmu/accel/stubs/kvm-stub.o
  CC      x86_64-softmmu/hw/timer/mc146818rtc.o
  GEN     alpha-linux-user/config-target.h
  CC      alpha-linux-user/exec.o
  CC      aarch64-linux-user/linux-user/syscall.o
  CC      xtensa-softmmu/accel/tcg/tcg-all.o
  CC      alpha-linux-user/tcg/tcg.o
  CC      xtensa-softmmu/accel/tcg/cputlb.o
  CC      x86_64-softmmu/hw/vfio/common.o
  CC      x86_64-softmmu/hw/vfio/pci.o
  CC      xtensa-softmmu/accel/tcg/tcg-runtime.o
  CC      xtensa-softmmu/accel/tcg/cpu-exec.o
  CC      alpha-linux-user/tcg/tcg-op.o
  CC      xtensa-softmmu/accel/tcg/cpu-exec-common.o
  CC      x86_64-softmmu/hw/vfio/pci-quirks.o
  CC      aarch64-linux-user/linux-user/strace.o
  CC      xtensa-softmmu/accel/tcg/translate-all.o
  CC      x86_64-softmmu/hw/vfio/platform.o
  CC      xtensa-softmmu/accel/tcg/translator.o
  CC      aarch64-linux-user/linux-user/mmap.o
  CC      x86_64-softmmu/hw/vfio/spapr.o
  CC      xtensa-softmmu/hw/core/generic-loader.o
  CC      alpha-linux-user/tcg/optimize.o
  CC      x86_64-softmmu/hw/virtio/virtio.o
  CC      xtensa-softmmu/hw/core/null-machine.o
  CC      aarch64-linux-user/linux-user/signal.o
  CC      xtensa-softmmu/hw/misc/mmio_interface.o
  CC      alpha-linux-user/tcg/tcg-common.o
  CC      aarch64-linux-user/linux-user/elfload.o
  CC      x86_64-softmmu/hw/virtio/virtio-balloon.o
  CC      xtensa-softmmu/hw/net/vhost_net.o
  CC      alpha-linux-user/fpu/softfloat.o
  CC      xtensa-softmmu/hw/net/rocker/qmp-norocker.o
  CC      x86_64-softmmu/hw/virtio/vhost.o
  CC      xtensa-softmmu/hw/vfio/common.o
  CC      aarch64-linux-user/linux-user/linuxload.o
  CC      aarch64-linux-user/linux-user/uaccess.o
  CC      xtensa-softmmu/hw/vfio/platform.o
  CC      aarch64-linux-user/linux-user/uname.o
  CC      x86_64-softmmu/hw/virtio/vhost-backend.o
  CC      xtensa-softmmu/hw/vfio/spapr.o
  CC      x86_64-softmmu/hw/virtio/vhost-user.o
  CCAS    aarch64-linux-user/linux-user/safe-syscall.o
  CC      aarch64-linux-user/linux-user/flatload.o
  CC      xtensa-softmmu/hw/xtensa/pic_cpu.o
  CC      x86_64-softmmu/hw/virtio/vhost-vsock.o
  CC      aarch64-linux-user/target/arm/arm-semi.o
  CC      xtensa-softmmu/hw/xtensa/sim.o
  CC      x86_64-softmmu/hw/virtio/virtio-crypto.o
  CC      alpha-linux-user/disas.o
  CC      xtensa-softmmu/hw/xtensa/xtfpga.o
  CC      aarch64-linux-user/target/arm/kvm-stub.o
  CC      x86_64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      alpha-linux-user/gdbstub.o
  CC      aarch64-linux-user/target/arm/translate.o
  CC      xtensa-softmmu/target/xtensa/xtensa-semi.o
  CC      x86_64-softmmu/hw/i386/multiboot.o
  CC      alpha-linux-user/thunk.o
  CC      xtensa-softmmu/target/xtensa/core-dc232b.o
  CC      x86_64-softmmu/hw/i386/pc.o
  CC      alpha-linux-user/accel/stubs/hax-stub.o
  CC      xtensa-softmmu/target/xtensa/core-dc233c.o
  CC      xtensa-softmmu/target/xtensa/core-fsf.o
  CC      x86_64-softmmu/hw/i386/pc_piix.o
  CC      alpha-linux-user/accel/stubs/kvm-stub.o
  CC      xtensa-softmmu/target/xtensa/monitor.o
  CC      alpha-linux-user/accel/tcg/tcg-runtime.o
  CC      xtensa-softmmu/target/xtensa/translate.o
  CC      x86_64-softmmu/hw/i386/pc_q35.o
  CC      alpha-linux-user/accel/tcg/cpu-exec.o
  CC      x86_64-softmmu/hw/i386/pc_sysfw.o
  CC      alpha-linux-user/accel/tcg/cpu-exec-common.o
  CC      x86_64-softmmu/hw/i386/x86-iommu.o
  CC      x86_64-softmmu/hw/i386/intel_iommu.o
  CC      alpha-linux-user/accel/tcg/translate-all.o
  CC      xtensa-softmmu/target/xtensa/op_helper.o
  CC      alpha-linux-user/accel/tcg/translator.o
  CC      x86_64-softmmu/hw/i386/amd_iommu.o
  CC      alpha-linux-user/accel/tcg/user-exec.o
  CC      xtensa-softmmu/target/xtensa/helper.o
  CC      x86_64-softmmu/hw/i386/kvmvapic.o
  CC      xtensa-softmmu/target/xtensa/cpu.o
  CC      alpha-linux-user/accel/tcg/user-exec-stub.o
  CC      xtensa-softmmu/target/xtensa/gdbstub.o
  CC      x86_64-softmmu/hw/i386/acpi-build.o
  CC      alpha-linux-user/linux-user/main.o
  GEN     trace/generated-helpers.c
  CC      xtensa-softmmu/trace/control-target.o
  CC      alpha-linux-user/linux-user/syscall.o
  CC      aarch64-linux-user/target/arm/op_helper.o
  CC      xtensa-softmmu/trace/generated-helpers.o
  CC      x86_64-softmmu/target/i386/helper.o
  LINK    xtensa-softmmu/qemu-system-xtensa
  CC      aarch64-linux-user/target/arm/helper.o
  CC      x86_64-softmmu/target/i386/cpu.o
  CC      alpha-linux-user/linux-user/strace.o
  CC      x86_64-softmmu/target/i386/gdbstub.o
  CC      x86_64-softmmu/target/i386/windbgstub.o
  CC      aarch64-linux-user/target/arm/cpu.o
  CC      x86_64-softmmu/target/i386/xsave_helper.o
  CC      alpha-linux-user/linux-user/mmap.o
  CC      x86_64-softmmu/target/i386/translate.o
  CC      aarch64-linux-user/target/arm/neon_helper.o
  CC      alpha-linux-user/linux-user/signal.o
  GEN     armeb-linux-user/config-target.h
  CC      armeb-linux-user/exec.o
  CC      alpha-linux-user/linux-user/elfload.o
  CC      armeb-linux-user/tcg/tcg.o
  CC      aarch64-linux-user/target/arm/iwmmxt_helper.o
  CC      alpha-linux-user/linux-user/linuxload.o
  CC      alpha-linux-user/linux-user/uaccess.o
  CC      aarch64-linux-user/target/arm/gdbstub.o
  CC      alpha-linux-user/linux-user/uname.o
  CC      armeb-linux-user/tcg/tcg-op.o
  CC      aarch64-linux-user/target/arm/cpu64.o
  CCAS    alpha-linux-user/linux-user/safe-syscall.o
  CC      alpha-linux-user/target/alpha/translate.o
  CC      aarch64-linux-user/target/arm/translate-a64.o
  CC      alpha-linux-user/target/alpha/helper.o
  CC      armeb-linux-user/tcg/optimize.o
  CC      alpha-linux-user/target/alpha/cpu.o
  CC      alpha-linux-user/target/alpha/int_helper.o
  CC      armeb-linux-user/tcg/tcg-common.o
  CC      x86_64-softmmu/target/i386/bpt_helper.o
  CC      alpha-linux-user/target/alpha/fpu_helper.o
  CC      armeb-linux-user/fpu/softfloat.o
  CC      x86_64-softmmu/target/i386/cc_helper.o
  CC      alpha-linux-user/target/alpha/vax_helper.o
  CC      x86_64-softmmu/target/i386/excp_helper.o
  CC      alpha-linux-user/target/alpha/sys_helper.o
  CC      x86_64-softmmu/target/i386/fpu_helper.o
  CC      alpha-linux-user/target/alpha/mem_helper.o
  CC      aarch64-linux-user/target/arm/helper-a64.o
  CC      alpha-linux-user/target/alpha/gdbstub.o
  GEN     trace/generated-helpers.c
  CC      alpha-linux-user/trace/control-target.o
  CC      aarch64-linux-user/target/arm/gdbstub64.o
  CC      aarch64-linux-user/target/arm/crypto_helper.o
  CC      alpha-linux-user/trace/generated-helpers.o
  CC      armeb-linux-user/disas.o
  GEN     trace/generated-helpers.c
  CC      aarch64-linux-user/trace/control-target.o
  LINK    alpha-linux-user/qemu-alpha
  GEN     armeb-linux-user/gdbstub-xml.c
  CC      aarch64-linux-user/gdbstub-xml.o
  CC      armeb-linux-user/gdbstub.o
  CC      aarch64-linux-user/trace/generated-helpers.o
  CC      armeb-linux-user/thunk.o
  CC      x86_64-softmmu/target/i386/int_helper.o
  LINK    aarch64-linux-user/qemu-aarch64
  CC      x86_64-softmmu/target/i386/mem_helper.o
  CC      armeb-linux-user/accel/stubs/hax-stub.o
  CC      armeb-linux-user/accel/stubs/kvm-stub.o
  CC      x86_64-softmmu/target/i386/misc_helper.o
  CC      x86_64-softmmu/target/i386/mpx_helper.o
  GEN     arm-linux-user/config-target.h
  CC      arm-linux-user/exec.o
  CC      armeb-linux-user/accel/tcg/tcg-runtime.o
  CC      arm-linux-user/tcg/tcg.o
  GEN     cris-linux-user/config-target.h
  CC      x86_64-softmmu/target/i386/seg_helper.o
  CC      cris-linux-user/exec.o
  CC      armeb-linux-user/accel/tcg/cpu-exec.o
  CC      cris-linux-user/tcg/tcg.o
  CC      armeb-linux-user/accel/tcg/cpu-exec-common.o
  CC      armeb-linux-user/accel/tcg/translate-all.o
  CC      arm-linux-user/tcg/tcg-op.o
  CC      x86_64-softmmu/target/i386/smm_helper.o
  CC      armeb-linux-user/accel/tcg/translator.o
  CC      cris-linux-user/tcg/tcg-op.o
  CC      x86_64-softmmu/target/i386/svm_helper.o
  CC      armeb-linux-user/accel/tcg/user-exec.o
  CC      x86_64-softmmu/target/i386/machine.o
  CC      arm-linux-user/tcg/optimize.o
  CC      armeb-linux-user/accel/tcg/user-exec-stub.o
  CC      x86_64-softmmu/target/i386/arch_memory_mapping.o
  CC      cris-linux-user/tcg/optimize.o
  CC      x86_64-softmmu/target/i386/arch_dump.o
  CC      armeb-linux-user/linux-user/main.o
  CC      x86_64-softmmu/target/i386/monitor.o
  CC      cris-linux-user/tcg/tcg-common.o
  CC      arm-linux-user/tcg/tcg-common.o
  CC      armeb-linux-user/linux-user/syscall.o
  CC      cris-linux-user/fpu/softfloat.o
  CC      x86_64-softmmu/target/i386/kvm-stub.o
  CC      arm-linux-user/fpu/softfloat.o
  GEN     trace/generated-helpers.c
  CC      x86_64-softmmu/trace/control-target.o
  CC      x86_64-softmmu/gdbstub-xml.o
  CC      x86_64-softmmu/trace/generated-helpers.o
  CC      cris-linux-user/disas.o
  LINK    x86_64-softmmu/qemu-system-x86_64
  CC      arm-linux-user/disas.o
  CC      cris-linux-user/gdbstub.o
  GEN     arm-linux-user/gdbstub-xml.c
  CC      cris-linux-user/thunk.o
  CC      arm-linux-user/gdbstub.o
  CC      armeb-linux-user/linux-user/strace.o
  CC      cris-linux-user/accel/stubs/hax-stub.o
  CC      arm-linux-user/thunk.o
  CC      cris-linux-user/accel/stubs/kvm-stub.o
  CC      arm-linux-user/accel/stubs/hax-stub.o
  CC      arm-linux-user/accel/stubs/kvm-stub.o
  CC      cris-linux-user/accel/tcg/tcg-runtime.o
  CC      armeb-linux-user/linux-user/mmap.o
  CC      cris-linux-user/accel/tcg/cpu-exec.o
  CC      arm-linux-user/accel/tcg/tcg-runtime.o
  CC      arm-linux-user/accel/tcg/cpu-exec.o
  CC      cris-linux-user/accel/tcg/cpu-exec-common.o
  CC      armeb-linux-user/linux-user/signal.o
  CC      cris-linux-user/accel/tcg/translate-all.o
  CC      cris-linux-user/accel/tcg/translator.o
  CC      arm-linux-user/accel/tcg/cpu-exec-common.o
  CC      armeb-linux-user/linux-user/elfload.o
  CC      arm-linux-user/accel/tcg/translate-all.o
  CC      armeb-linux-user/linux-user/linuxload.o
  CC      cris-linux-user/accel/tcg/user-exec.o
  CC      cris-linux-user/accel/tcg/user-exec-stub.o
  CC      armeb-linux-user/linux-user/uaccess.o
  CC      arm-linux-user/accel/tcg/translator.o
  CC      armeb-linux-user/linux-user/uname.o
  CC      cris-linux-user/linux-user/main.o
  CC      cris-linux-user/linux-user/syscall.o
  CCAS    armeb-linux-user/linux-user/safe-syscall.o
  CC      armeb-linux-user/linux-user/flatload.o
  CC      arm-linux-user/accel/tcg/user-exec.o
  CC      arm-linux-user/accel/tcg/user-exec-stub.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11.o
  CC      cris-linux-user/linux-user/strace.o
  CC      arm-linux-user/linux-user/main.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11_cpdo.o
  CC      arm-linux-user/linux-user/syscall.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11_cpdt.o
  GEN     hppa-linux-user/config-target.h
  CC      hppa-linux-user/exec.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11_cprt.o
  CC      hppa-linux-user/tcg/tcg.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpopcode.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/single_cpdo.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/double_cpdo.o
  CC      cris-linux-user/linux-user/mmap.o
  CC      hppa-linux-user/tcg/tcg-op.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/extended_cpdo.o
  CC      cris-linux-user/linux-user/signal.o
  CC      armeb-linux-user/target/arm/arm-semi.o
  CC      cris-linux-user/linux-user/elfload.o
  CC      arm-linux-user/linux-user/strace.o
  CC      armeb-linux-user/target/arm/kvm-stub.o
  CC      armeb-linux-user/target/arm/translate.o
  CC      hppa-linux-user/tcg/optimize.o
  CC      cris-linux-user/linux-user/linuxload.o
  CC      arm-linux-user/linux-user/mmap.o
  CC      cris-linux-user/linux-user/uaccess.o
  CC      arm-linux-user/linux-user/signal.o
  CC      hppa-linux-user/tcg/tcg-common.o
  CC      cris-linux-user/linux-user/uname.o
  CC      hppa-linux-user/fpu/softfloat.o
  CC      arm-linux-user/linux-user/elfload.o
  CCAS    cris-linux-user/linux-user/safe-syscall.o
  CC      cris-linux-user/target/cris/translate.o
  CC      arm-linux-user/linux-user/linuxload.o
  CC      arm-linux-user/linux-user/uaccess.o
  CC      hppa-linux-user/disas.o
  CC      arm-linux-user/linux-user/uname.o
  CC      hppa-linux-user/gdbstub.o
  CC      cris-linux-user/target/cris/op_helper.o
  CCAS    arm-linux-user/linux-user/safe-syscall.o
  CC      arm-linux-user/linux-user/flatload.o
  CC      cris-linux-user/target/cris/helper.o
  CC      hppa-linux-user/thunk.o
  CC      cris-linux-user/target/cris/cpu.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11.o
  CC      cris-linux-user/target/cris/gdbstub.o
  CC      hppa-linux-user/accel/stubs/hax-stub.o
  CC      hppa-linux-user/accel/stubs/kvm-stub.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11_cpdo.o
  GEN     trace/generated-helpers.c
  CC      cris-linux-user/trace/control-target.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11_cpdt.o
  CC      hppa-linux-user/accel/tcg/tcg-runtime.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11_cprt.o
  CC      hppa-linux-user/accel/tcg/cpu-exec.o
  CC      cris-linux-user/trace/generated-helpers.o
  CC      armeb-linux-user/target/arm/op_helper.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpopcode.o
  CC      hppa-linux-user/accel/tcg/cpu-exec-common.o
  LINK    cris-linux-user/qemu-cris
  CC      hppa-linux-user/accel/tcg/translate-all.o
  CC      arm-linux-user/linux-user/arm/nwfpe/single_cpdo.o
  CC      arm-linux-user/linux-user/arm/nwfpe/double_cpdo.o
  CC      armeb-linux-user/target/arm/helper.o
  CC      hppa-linux-user/accel/tcg/translator.o
  CC      arm-linux-user/linux-user/arm/nwfpe/extended_cpdo.o
  CC      armeb-linux-user/target/arm/cpu.o
  CC      hppa-linux-user/accel/tcg/user-exec.o
  CC      arm-linux-user/target/arm/arm-semi.o
  CC      arm-linux-user/target/arm/kvm-stub.o
  CC      hppa-linux-user/accel/tcg/user-exec-stub.o
  CC      hppa-linux-user/linux-user/main.o
  CC      arm-linux-user/target/arm/translate.o
  GEN     i386-linux-user/config-target.h
  CC      hppa-linux-user/linux-user/syscall.o
  CC      i386-linux-user/exec.o
  CC      armeb-linux-user/target/arm/neon_helper.o
  CC      i386-linux-user/tcg/tcg.o
  CC      armeb-linux-user/target/arm/iwmmxt_helper.o
  CC      armeb-linux-user/target/arm/gdbstub.o
  CC      i386-linux-user/tcg/tcg-op.o
  CC      armeb-linux-user/target/arm/crypto_helper.o
  CC      hppa-linux-user/linux-user/strace.o
  GEN     trace/generated-helpers.c
  CC      armeb-linux-user/trace/control-target.o
  CC      hppa-linux-user/linux-user/mmap.o
  CC      armeb-linux-user/gdbstub-xml.o
  CC      i386-linux-user/tcg/optimize.o
  CC      armeb-linux-user/trace/generated-helpers.o
  CC      hppa-linux-user/linux-user/signal.o
  CC      arm-linux-user/target/arm/op_helper.o
  LINK    armeb-linux-user/qemu-armeb
  CC      hppa-linux-user/linux-user/elfload.o
  CC      i386-linux-user/tcg/tcg-common.o
  CC      hppa-linux-user/linux-user/linuxload.o
  CC      arm-linux-user/target/arm/helper.o
  CC      hppa-linux-user/linux-user/uaccess.o
  CC      i386-linux-user/fpu/softfloat.o
  GEN     m68k-linux-user/config-target.h
  CC      m68k-linux-user/exec.o
  CC      hppa-linux-user/linux-user/uname.o
  CCAS    hppa-linux-user/linux-user/safe-syscall.o
  CC      m68k-linux-user/tcg/tcg.o
  CC      hppa-linux-user/target/hppa/translate.o
  CC      arm-linux-user/target/arm/cpu.o
  CC      m68k-linux-user/tcg/tcg-op.o
  CC      i386-linux-user/disas.o
  CC      arm-linux-user/target/arm/neon_helper.o
  GEN     i386-linux-user/gdbstub-xml.c
  CC      hppa-linux-user/target/hppa/helper.o
  CC      hppa-linux-user/target/hppa/cpu.o
  CC      hppa-linux-user/target/hppa/op_helper.o
  CC      i386-linux-user/gdbstub.o
  CC      hppa-linux-user/target/hppa/gdbstub.o
  CC      arm-linux-user/target/arm/iwmmxt_helper.o
  CC      m68k-linux-user/tcg/optimize.o
  GEN     trace/generated-helpers.c
  CC      hppa-linux-user/trace/control-target.o
  CC      i386-linux-user/thunk.o
  CC      i386-linux-user/accel/stubs/hax-stub.o
  CC      m68k-linux-user/tcg/tcg-common.o
  CC      hppa-linux-user/trace/generated-helpers.o
  CC      m68k-linux-user/fpu/softfloat.o
  CC      i386-linux-user/accel/stubs/kvm-stub.o
  CC      arm-linux-user/target/arm/gdbstub.o
  LINK    hppa-linux-user/qemu-hppa
  CC      i386-linux-user/accel/tcg/tcg-runtime.o
  CC      arm-linux-user/target/arm/crypto_helper.o
  GEN     trace/generated-helpers.c
  CC      i386-linux-user/accel/tcg/cpu-exec.o
  CC      arm-linux-user/trace/control-target.o
  CC      arm-linux-user/gdbstub-xml.o
  CC      i386-linux-user/accel/tcg/cpu-exec-common.o
  CC      arm-linux-user/trace/generated-helpers.o
  GEN     microblazeel-linux-user/config-target.h
  CC      i386-linux-user/accel/tcg/translate-all.o
  CC      microblazeel-linux-user/exec.o
  LINK    arm-linux-user/qemu-arm
  CC      microblazeel-linux-user/tcg/tcg.o
  CC      i386-linux-user/accel/tcg/translator.o
  CC      microblazeel-linux-user/tcg/tcg-op.o
  CC      m68k-linux-user/disas.o
  CC      i386-linux-user/accel/tcg/user-exec.o
  GEN     m68k-linux-user/gdbstub-xml.c
  GEN     microblaze-linux-user/config-target.h
  CC      microblaze-linux-user/exec.o
  CC      m68k-linux-user/gdbstub.o
  CC      i386-linux-user/accel/tcg/user-exec-stub.o
  CC      microblaze-linux-user/tcg/tcg.o
  CC      i386-linux-user/linux-user/main.o
  CC      microblazeel-linux-user/tcg/optimize.o
  CC      m68k-linux-user/thunk.o
  CC      i386-linux-user/linux-user/syscall.o
  CC      m68k-linux-user/accel/stubs/hax-stub.o
  CC      microblazeel-linux-user/tcg/tcg-common.o
  CC      m68k-linux-user/accel/stubs/kvm-stub.o
  CC      microblazeel-linux-user/fpu/softfloat.o
  CC      m68k-linux-user/accel/tcg/tcg-runtime.o
  CC      microblaze-linux-user/tcg/tcg-op.o
  CC      m68k-linux-user/accel/tcg/cpu-exec.o
  CC      m68k-linux-user/accel/tcg/cpu-exec-common.o
  CC      m68k-linux-user/accel/tcg/translate-all.o
  CC      microblaze-linux-user/tcg/optimize.o
  CC      microblazeel-linux-user/disas.o
  CC      m68k-linux-user/accel/tcg/translator.o
  CC      microblazeel-linux-user/gdbstub.o
  CC      i386-linux-user/linux-user/strace.o
  CC      microblaze-linux-user/tcg/tcg-common.o
  CC      m68k-linux-user/accel/tcg/user-exec.o
  CC      microblaze-linux-user/fpu/softfloat.o
  CC      microblazeel-linux-user/thunk.o
  CC      m68k-linux-user/accel/tcg/user-exec-stub.o
  CC      i386-linux-user/linux-user/mmap.o
  CC      m68k-linux-user/linux-user/main.o
  CC      microblazeel-linux-user/accel/stubs/hax-stub.o
  CC      i386-linux-user/linux-user/signal.o
  CC      microblazeel-linux-user/accel/stubs/kvm-stub.o
  CC      m68k-linux-user/linux-user/syscall.o
  CC      microblazeel-linux-user/accel/tcg/tcg-runtime.o
  CC      i386-linux-user/linux-user/elfload.o
  CC      microblazeel-linux-user/accel/tcg/cpu-exec.o
  CC      microblazeel-linux-user/accel/tcg/cpu-exec-common.o
  CC      i386-linux-user/linux-user/linuxload.o
  CC      microblazeel-linux-user/accel/tcg/translate-all.o
  CC      microblaze-linux-user/disas.o
  CC      i386-linux-user/linux-user/uaccess.o
  CC      microblaze-linux-user/gdbstub.o
  CC      i386-linux-user/linux-user/uname.o
  CC      microblazeel-linux-user/accel/tcg/translator.o
  CCAS    i386-linux-user/linux-user/safe-syscall.o
  CC      microblazeel-linux-user/accel/tcg/user-exec.o
  CC      i386-linux-user/linux-user/vm86.o
  CC      microblaze-linux-user/thunk.o
  CC      i386-linux-user/target/i386/helper.o
  CC      microblazeel-linux-user/accel/tcg/user-exec-stub.o
  CC      microblaze-linux-user/accel/stubs/hax-stub.o
  CC      i386-linux-user/target/i386/cpu.o
  CC      microblazeel-linux-user/linux-user/main.o
  CC      microblaze-linux-user/accel/stubs/kvm-stub.o
  CC      microblaze-linux-user/accel/tcg/tcg-runtime.o
  CC      m68k-linux-user/linux-user/strace.o
  CC      microblazeel-linux-user/linux-user/syscall.o
  CC      microblaze-linux-user/accel/tcg/cpu-exec.o
  CC      i386-linux-user/target/i386/gdbstub.o
  CC      microblaze-linux-user/accel/tcg/cpu-exec-common.o
  CC      i386-linux-user/target/i386/windbgstub.o
  CC      microblaze-linux-user/accel/tcg/translate-all.o
  CC      m68k-linux-user/linux-user/mmap.o
  CC      microblaze-linux-user/accel/tcg/translator.o
  CC      m68k-linux-user/linux-user/signal.o
/var/tmp/patchew-tester-tmp-j1ms6ngb/src/target/i386/windbgstub.c: In function ‘kd_api_read_msr’:
/var/tmp/patchew-tester-tmp-j1ms6ngb/src/target/i386/windbgstub.c:1081:15: error: implicit declaration of function ‘cpu_get_apic_base’ [-Werror=implicit-function-declaration]
         val = cpu_get_apic_base(x86_env_get_cpu(env)->apic_state);
               ^~~~~~~~~~~~~~~~~
/var/tmp/patchew-tester-tmp-j1ms6ngb/src/target/i386/windbgstub.c:1081:9: error: nested extern declaration of ‘cpu_get_apic_base’ [-Werror=nested-externs]
         val = cpu_get_apic_base(x86_env_get_cpu(env)->apic_state);
         ^~~
/var/tmp/patchew-tester-tmp-j1ms6ngb/src/target/i386/windbgstub.c: In function ‘kd_api_write_msr’:
/var/tmp/patchew-tester-tmp-j1ms6ngb/src/target/i386/windbgstub.c:1238:9: error: implicit declaration of function ‘cpu_set_apic_base’ [-Werror=implicit-function-declaration]
         cpu_set_apic_base(x86_env_get_cpu(env)->apic_state, val);
         ^~~~~~~~~~~~~~~~~
/var/tmp/patchew-tester-tmp-j1ms6ngb/src/target/i386/windbgstub.c:1238:9: error: nested extern declaration of ‘cpu_set_apic_base’ [-Werror=nested-externs]
cc1: all warnings being treated as errors
/var/tmp/patchew-tester-tmp-j1ms6ngb/src/rules.mak:66: recipe for target 'target/i386/windbgstub.o' failed
make[1]: *** [target/i386/windbgstub.o] Error 1
Makefile:383: recipe for target 'subdir-i386-linux-user' failed
make: *** [subdir-i386-linux-user] Error 2
make: *** Waiting for unfinished jobs....
  CC      microblaze-linux-user/accel/tcg/user-exec.o
  CC      microblaze-linux-user/accel/tcg/user-exec-stub.o
  CC      m68k-linux-user/linux-user/elfload.o
  CC      microblaze-linux-user/linux-user/main.o
  CC      microblaze-linux-user/linux-user/syscall.o
  CC      microblaze-linux-user/linux-user/strace.o
  CC      m68k-linux-user/linux-user/linuxload.o
  CC      microblaze-linux-user/linux-user/mmap.o
  CC      m68k-linux-user/linux-user/uaccess.o
  CC      m68k-linux-user/linux-user/uname.o
  CC      microblazeel-linux-user/linux-user/strace.o
  CC      microblaze-linux-user/linux-user/signal.o
  CCAS    m68k-linux-user/linux-user/safe-syscall.o
  CC      m68k-linux-user/linux-user/flatload.o
  CC      microblaze-linux-user/linux-user/elfload.o
  CC      microblazeel-linux-user/linux-user/mmap.o
  CC      m68k-linux-user/linux-user/m68k-sim.o
  CC      microblaze-linux-user/linux-user/linuxload.o
  CC      microblazeel-linux-user/linux-user/signal.o
  CC      m68k-linux-user/target/m68k/m68k-semi.o
  CC      microblaze-linux-user/linux-user/uaccess.o
  CC      microblazeel-linux-user/linux-user/elfload.o
  CC      microblaze-linux-user/linux-user/uname.o
  CC      m68k-linux-user/target/m68k/translate.o
  CCAS    microblaze-linux-user/linux-user/safe-syscall.o
  CC      microblaze-linux-user/linux-user/flatload.o
  CC      microblaze-linux-user/target/microblaze/translate.o
  CC      microblazeel-linux-user/linux-user/linuxload.o
  CC      microblaze-linux-user/target/microblaze/op_helper.o
  CC      microblazeel-linux-user/linux-user/uaccess.o
  CC      microblaze-linux-user/target/microblaze/helper.o
  CC      microblazeel-linux-user/linux-user/uname.o
  CC      microblaze-linux-user/target/microblaze/cpu.o
  CCAS    microblazeel-linux-user/linux-user/safe-syscall.o
  CC      microblaze-linux-user/target/microblaze/gdbstub.o
  CC      microblazeel-linux-user/linux-user/flatload.o
  GEN     trace/generated-helpers.c
  CC      microblaze-linux-user/trace/control-target.o
  CC      microblaze-linux-user/trace/generated-helpers.o
  CC      m68k-linux-user/target/m68k/op_helper.o
  CC      microblazeel-linux-user/target/microblaze/translate.o
  CC      m68k-linux-user/target/m68k/helper.o
  CC      m68k-linux-user/target/m68k/cpu.o
  LINK    microblaze-linux-user/qemu-microblaze
  CC      m68k-linux-user/target/m68k/fpu_helper.o
  CC      m68k-linux-user/target/m68k/gdbstub.o
  GEN     trace/generated-helpers.c
  CC      m68k-linux-user/trace/control-target.o
  CC      microblazeel-linux-user/target/microblaze/op_helper.o
  CC      m68k-linux-user/gdbstub-xml.o
  CC      microblazeel-linux-user/target/microblaze/helper.o
  CC      microblazeel-linux-user/target/microblaze/cpu.o
  CC      m68k-linux-user/trace/generated-helpers.o
  CC      microblazeel-linux-user/target/microblaze/gdbstub.o
  GEN     trace/generated-helpers.c
  LINK    m68k-linux-user/qemu-m68k
  CC      microblazeel-linux-user/trace/control-target.o
  CC      microblazeel-linux-user/trace/generated-helpers.o
  LINK    microblazeel-linux-user/qemu-microblazeel
=== OUTPUT END ===

Test command exited with code: 2


---
Email generated automatically by Patchew [http://patchew.org/].
Please send your feedback to patchew-devel@freelists.org

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 00/45] Windbg supporting
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (45 preceding siblings ...)
  2017-11-21 15:00 ` [Qemu-devel] [PATCH v3 00/45] Windbg supporting no-reply
@ 2017-11-21 15:05 ` no-reply
  2017-11-21 16:23 ` no-reply
  47 siblings, 0 replies; 70+ messages in thread
From: no-reply @ 2017-11-21 15:05 UTC (permalink / raw)
  To: mikhail.abakumov
  Cc: famz, qemu-devel, sw, lprosek, dovgaluk, rkagan, pbonzini, den

Hi,

This series seems to have some coding style problems. See output below for
more information:

Subject: [Qemu-devel] [PATCH v3 00/45] Windbg supporting
Type: series
Message-id: 151127322955.6888.16198535123422076171.stgit@Misha-PC.lan02.inno

=== TEST SCRIPT BEGIN ===
#!/bin/bash

BASE=base
n=1
total=$(git log --oneline $BASE.. | wc -l)
failed=0

git config --local diff.renamelimit 0
git config --local diff.renames True

commits="$(git log --format=%H --reverse $BASE..)"
for c in $commits; do
    echo "Checking PATCH $n/$total: $(git log -n 1 --format=%s $c)..."
    if ! git show $c --format=email | ./scripts/checkpatch.pl --mailback -; then
        failed=1
        echo
    fi
    n=$((n+1))
done

exit $failed
=== TEST SCRIPT END ===

Updating 3c8cf5a9c21ff8782164d1def7f44bd888713384
From https://github.com/patchew-project/qemu
 * [new tag]               patchew/151127322955.6888.16198535123422076171.stgit@Misha-PC.lan02.inno -> patchew/151127322955.6888.16198535123422076171.stgit@Misha-PC.lan02.inno
 * [new tag]               patchew/20171121142538.22072-1-berrange@redhat.com -> patchew/20171121142538.22072-1-berrange@redhat.com
Switched to a new branch 'test'
d362b89cac windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex
18aff3dc37 windbg: added new api functions
2bcb5c3e4a windbg: implemented kd_api_query_memory
5ec1f614fe windbg: implemented kd_api_fill_memory
62f31d70ce windbg: implemented kd_api_search_memory
271fa73151 windbg: implemented kd_api_read_msr and kd_api_write_msr
3acac8e660 windbg: implemented kd_api_get_version
9de41ff4f4 windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
6b29ad10e5 windbg: implemented kd_api_read_io_space and kd_api_write_io_space
c5b8c6d44a windbg: implemented kd_api_continue
dd48382a4d windbg: debug exception subscribing
f39bcbc62e windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
09dca429d2 windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
623796d1f2 windbg: implemented windbg_set_dr7
736fc3dd85 windbg: implemented windbg_set_dr
7fdef2c475 windbg: implemented windbg_set_sr
1a4d2aecdb windbg: implemented windbg_write_ks_regs
811bd2ada7 windbg: implemented windbg_read_ks_regs
65fbd065d8 windbg: implemented windbg_write_context
58e16be427 windbg: implemented windbg_read_context
d537b5a79b windbg: implemented kd_api_read_control_space and kd_api_write_control_space
e97babd70b windbg: implemented kd_api_get_context and kd_api_set_context
9dbe11adbd windbg: kernel's structures
77b3eba622 windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
7aecc04a58 windbg: implemented windbg_process_manipulate_packet
2aa0acc7d1 windbg: implemented windbg_process_data_packet
2bf0bd91ec windbg: implemented windbg_process_control_packet
75c0091cb6 windbg: windbg_vm_stop
a8181bff22 windbg: generate LoadSymbolsStateChange
05f4ef3358 windbg: generate ExceptionStateChange
bd46bf1699 windbg: sized data buffer
2032fcb9f0 windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
eee56f5887 windbg: handler of parsing context
a906b8b0d9 windbg: send data and control packets
7ba62b6241 windbg: parsing data stream
dfc08cb26c windbg: structures for parsing data stream
7d750760fb windbg: handler of fs/gs register
4ccf74e383 windbg: hook to wrmsr operation
696a5b890e windbg: added chardev
3dd2e38059 windbg: added WindbgState
71cde42e04 windbg: added helper features
8802776fb8 windbg: added '-windbg' option
65edc4e965 windbg: modified windbgkd.h
d2114acd58 windbg: added windbg's KD header file
8b0599de68 windbg: added empty windbgstub files

=== OUTPUT BEGIN ===
Checking PATCH 1/45: windbg: added empty windbgstub files...
ERROR: do not set execute permissions for source files
#30: FILE: include/exec/windbgstub-utils.h

ERROR: do not set execute permissions for source files
#54: FILE: include/exec/windbgstub.h

ERROR: do not set execute permissions for source files
#89: FILE: stubs/windbgstub.c

ERROR: do not set execute permissions for source files
#123: FILE: target/i386/windbgstub.c

ERROR: do not set execute permissions for source files
#141: FILE: windbgstub-utils.c

ERROR: do not set execute permissions for source files
#159: FILE: windbgstub.c

total: 6 errors, 0 warnings, 121 lines checked

Your patch has style problems, please review.  If any of these errors
are false positives report them to the maintainer, see
CHECKPATCH in MAINTAINERS.

Checking PATCH 2/45: windbg: added windbg's KD header file...
ERROR: do not set execute permissions for source files
#14: FILE: include/exec/windbgkd.h

total: 1 errors, 0 warnings, 879 lines checked

Your patch has style problems, please review.  If any of these errors
are false positives report them to the maintainer, see
CHECKPATCH in MAINTAINERS.

Checking PATCH 3/45: windbg: modified windbgkd.h...
Checking PATCH 4/45: windbg: added '-windbg' option...
Checking PATCH 5/45: windbg: added helper features...
Checking PATCH 6/45: windbg: added WindbgState...
Checking PATCH 7/45: windbg: added chardev...
Checking PATCH 8/45: windbg: hook to wrmsr operation...
Checking PATCH 9/45: windbg: handler of fs/gs register...
Checking PATCH 10/45: windbg: structures for parsing data stream...
Checking PATCH 11/45: windbg: parsing data stream...
Checking PATCH 12/45: windbg: send data and control packets...
Checking PATCH 13/45: windbg: handler of parsing context...
Checking PATCH 14/45: windbg: init DBGKD_ANY_WAIT_STATE_CHANGE...
Checking PATCH 15/45: windbg: sized data buffer...
Checking PATCH 16/45: windbg: generate ExceptionStateChange...
Checking PATCH 17/45: windbg: generate LoadSymbolsStateChange...
Checking PATCH 18/45: windbg: windbg_vm_stop...
Checking PATCH 19/45: windbg: implemented windbg_process_control_packet...
Checking PATCH 20/45: windbg: implemented windbg_process_data_packet...
Checking PATCH 21/45: windbg: implemented windbg_process_manipulate_packet...
Checking PATCH 22/45: windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory...
Checking PATCH 23/45: windbg: kernel's structures...
Checking PATCH 24/45: windbg: implemented kd_api_get_context and kd_api_set_context...
Checking PATCH 25/45: windbg: implemented kd_api_read_control_space and kd_api_write_control_space...
Checking PATCH 26/45: windbg: implemented windbg_read_context...
Checking PATCH 27/45: windbg: implemented windbg_write_context...
Checking PATCH 28/45: windbg: implemented windbg_read_ks_regs...
Checking PATCH 29/45: windbg: implemented windbg_write_ks_regs...
Checking PATCH 30/45: windbg: implemented windbg_set_sr...
Checking PATCH 31/45: windbg: implemented windbg_set_dr...
Checking PATCH 32/45: windbg: implemented windbg_set_dr7...
Checking PATCH 33/45: windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove...
Checking PATCH 34/45: windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint...
Checking PATCH 35/45: windbg: debug exception subscribing...
Checking PATCH 36/45: windbg: implemented kd_api_continue...
Checking PATCH 37/45: windbg: implemented kd_api_read_io_space and kd_api_write_io_space...
Checking PATCH 38/45: windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory...
Checking PATCH 39/45: windbg: implemented kd_api_get_version...
Checking PATCH 40/45: windbg: implemented kd_api_read_msr and kd_api_write_msr...
Checking PATCH 41/45: windbg: implemented kd_api_search_memory...
Checking PATCH 42/45: windbg: implemented kd_api_fill_memory...
Checking PATCH 43/45: windbg: implemented kd_api_query_memory...
Checking PATCH 44/45: windbg: added new api functions...
Checking PATCH 45/45: windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex...
=== OUTPUT END ===

Test command exited with code: 1


---
Email generated automatically by Patchew [http://patchew.org/].
Please send your feedback to patchew-devel@freelists.org

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 00/45] Windbg supporting
  2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
                   ` (46 preceding siblings ...)
  2017-11-21 15:05 ` no-reply
@ 2017-11-21 16:23 ` no-reply
  2017-11-29  8:23   ` Ladi Prosek
  47 siblings, 1 reply; 70+ messages in thread
From: no-reply @ 2017-11-21 16:23 UTC (permalink / raw)
  To: mikhail.abakumov
  Cc: famz, qemu-devel, sw, lprosek, dovgaluk, rkagan, pbonzini, den

Hi,

This series failed build test on ppc host. Please find the details below.

Message-id: 151127322955.6888.16198535123422076171.stgit@Misha-PC.lan02.inno
Type: series
Subject: [Qemu-devel] [PATCH v3 00/45] Windbg supporting

=== TEST SCRIPT BEGIN ===
#!/bin/bash
# Testing script will be invoked under the git checkout with
# HEAD pointing to a commit that has the patches applied on top of "base"
# branch
set -e
echo "=== ENV ==="
env
echo "=== PACKAGES ==="
rpm -qa
echo "=== TEST BEGIN ==="
INSTALL=$PWD/install
BUILD=$PWD/build
mkdir -p $BUILD $INSTALL
SRC=$PWD
cd $BUILD
$SRC/configure --prefix=$INSTALL
make -j100
# XXX: we need reliable clean up
# make check -j100 V=1
make install
=== TEST SCRIPT END ===

Updating 3c8cf5a9c21ff8782164d1def7f44bd888713384
From https://github.com/patchew-project/qemu
 - [tag update]      patchew/1511276888-17834-1-git-send-email-peter.maydell@linaro.org -> patchew/1511276888-17834-1-git-send-email-peter.maydell@linaro.org
 - [tag update]      patchew/20171121142538.22072-1-berrange@redhat.com -> patchew/20171121142538.22072-1-berrange@redhat.com
 * [new tag]         patchew/20171121151017.28158-1-kwolf@redhat.com -> patchew/20171121151017.28158-1-kwolf@redhat.com
Submodule 'dtc' (git://git.qemu-project.org/dtc.git) registered for path 'dtc'
Submodule 'pixman' (git://anongit.freedesktop.org/pixman) registered for path 'pixman'
Submodule 'roms/SLOF' (git://git.qemu-project.org/SLOF.git) registered for path 'roms/SLOF'
Submodule 'roms/ipxe' (git://git.qemu-project.org/ipxe.git) registered for path 'roms/ipxe'
Submodule 'roms/openbios' (git://git.qemu-project.org/openbios.git) registered for path 'roms/openbios'
Submodule 'roms/openhackware' (git://git.qemu-project.org/openhackware.git) registered for path 'roms/openhackware'
Submodule 'roms/qemu-palcode' (git://github.com/rth7680/qemu-palcode.git) registered for path 'roms/qemu-palcode'
Submodule 'roms/seabios' (git://git.qemu-project.org/seabios.git/) registered for path 'roms/seabios'
Submodule 'roms/sgabios' (git://git.qemu-project.org/sgabios.git) registered for path 'roms/sgabios'
Submodule 'roms/u-boot' (git://git.qemu-project.org/u-boot.git) registered for path 'roms/u-boot'
Submodule 'roms/vgabios' (git://git.qemu-project.org/vgabios.git/) registered for path 'roms/vgabios'
Cloning into 'dtc'...
Submodule path 'dtc': checked out '65cc4d2748a2c2e6f27f1cf39e07a5dbabd80ebf'
Cloning into 'pixman'...
Submodule path 'pixman': checked out '87eea99e443b389c978cf37efc52788bf03a0ee0'
Cloning into 'roms/SLOF'...
Submodule path 'roms/SLOF': checked out 'e3d05727a074619fc12d0a67f05cf2c42c875cce'
Cloning into 'roms/ipxe'...
Submodule path 'roms/ipxe': checked out '04186319181298083ef28695a8309028b26fe83c'
Cloning into 'roms/openbios'...
Submodule path 'roms/openbios': checked out 'e79bca64838c96ec44fd7acd508879c5284233dd'
Cloning into 'roms/openhackware'...
Submodule path 'roms/openhackware': checked out 'c559da7c8eec5e45ef1f67978827af6f0b9546f5'
Cloning into 'roms/qemu-palcode'...
Submodule path 'roms/qemu-palcode': checked out 'c87a92639b28ac42bc8f6c67443543b405dc479b'
Cloning into 'roms/seabios'...
Submodule path 'roms/seabios': checked out 'e2fc41e24ee0ada60fc511d60b15a41b294538be'
Cloning into 'roms/sgabios'...
Submodule path 'roms/sgabios': checked out '23d474943dcd55d0550a3d20b3d30e9040a4f15b'
Cloning into 'roms/u-boot'...
Submodule path 'roms/u-boot': checked out '2072e7262965bb48d7fffb1e283101e6ed8b21a8'
Cloning into 'roms/vgabios'...
Submodule path 'roms/vgabios': checked out '19ea12c230ded95928ecaef0db47a82231c2e485'
warning: unable to rmdir pixman: Directory not empty
Switched to a new branch 'test'
M	dtc
M	roms/SLOF
M	roms/ipxe
M	roms/openbios
M	roms/qemu-palcode
M	roms/seabios
M	roms/sgabios
M	roms/u-boot
d362b89 windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex
18aff3d windbg: added new api functions
2bcb5c3 windbg: implemented kd_api_query_memory
5ec1f61 windbg: implemented kd_api_fill_memory
62f31d7 windbg: implemented kd_api_search_memory
271fa73 windbg: implemented kd_api_read_msr and kd_api_write_msr
3acac8e windbg: implemented kd_api_get_version
9de41ff windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
6b29ad1 windbg: implemented kd_api_read_io_space and kd_api_write_io_space
c5b8c6d windbg: implemented kd_api_continue
dd48382 windbg: debug exception subscribing
f39bcbc windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
09dca42 windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
623796d windbg: implemented windbg_set_dr7
736fc3d windbg: implemented windbg_set_dr
7fdef2c windbg: implemented windbg_set_sr
1a4d2ae windbg: implemented windbg_write_ks_regs
811bd2a windbg: implemented windbg_read_ks_regs
65fbd06 windbg: implemented windbg_write_context
58e16be windbg: implemented windbg_read_context
d537b5a windbg: implemented kd_api_read_control_space and kd_api_write_control_space
e97babd windbg: implemented kd_api_get_context and kd_api_set_context
9dbe11a windbg: kernel's structures
77b3eba windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
7aecc04 windbg: implemented windbg_process_manipulate_packet
2aa0acc windbg: implemented windbg_process_data_packet
2bf0bd9 windbg: implemented windbg_process_control_packet
75c0091 windbg: windbg_vm_stop
a8181bf windbg: generate LoadSymbolsStateChange
05f4ef3 windbg: generate ExceptionStateChange
bd46bf1 windbg: sized data buffer
2032fcb windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
eee56f5 windbg: handler of parsing context
a906b8b windbg: send data and control packets
7ba62b6 windbg: parsing data stream
dfc08cb windbg: structures for parsing data stream
7d75076 windbg: handler of fs/gs register
4ccf74e windbg: hook to wrmsr operation
696a5b8 windbg: added chardev
3dd2e38 windbg: added WindbgState
71cde42 windbg: added helper features
8802776 windbg: added '-windbg' option
65edc4e windbg: modified windbgkd.h
d2114ac windbg: added windbg's KD header file
8b0599d windbg: added empty windbgstub files

=== OUTPUT BEGIN ===
=== ENV ===
XDG_SESSION_ID=43713
SHELL=/bin/sh
USER=patchew
PATCHEW=/home/patchew/patchew/patchew-cli -s http://patchew.org --nodebug
PATH=/usr/bin:/bin
PWD=/var/tmp/patchew-tester-tmp-yk6niwxj/src
LANG=en_US.UTF-8
HOME=/home/patchew
SHLVL=2
LOGNAME=patchew
XDG_RUNTIME_DIR=/run/user/1000
_=/usr/bin/env
=== PACKAGES ===
plymouth-core-libs-0.8.9-0.28.20140113.el7.centos.ppc64le
vim-common-7.4.160-2.el7.ppc64le
perl-Test-Simple-0.98-243.el7.noarch
hplip-common-3.15.9-3.el7.ppc64le
valgrind-3.12.0-8.el7.ppc64le
gamin-0.1.10-16.el7.ppc64le
libpeas-loader-python-1.20.0-1.el7.ppc64le
telepathy-filesystem-0.0.2-6.el7.noarch
colord-libs-1.3.4-1.el7.ppc64le
kbd-legacy-1.15.5-13.el7.noarch
perl-CPAN-Meta-YAML-0.008-14.el7.noarch
libvirt-daemon-driver-nwfilter-3.2.0-14.el7.ppc64le
ntsysv-1.7.4-1.el7.ppc64le
kernel-bootwrapper-3.10.0-693.el7.ppc64le
telepathy-farstream-0.6.0-5.el7.ppc64le
kdenetwork-common-4.10.5-8.el7_0.noarch
elfutils-devel-0.168-8.el7.ppc64le
pm-utils-1.4.1-27.el7.ppc64le
perl-Error-0.17020-2.el7.noarch
usbmuxd-1.1.0-1.el7.ppc64le
bzip2-devel-1.0.6-13.el7.ppc64le
blktrace-1.0.5-8.el7.ppc64le
gnome-keyring-pam-3.20.0-3.el7.ppc64le
tzdata-java-2017b-1.el7.noarch
perl-devel-5.16.3-292.el7.ppc64le
gnome-getting-started-docs-3.22.0-1.el7.noarch
perl-Log-Message-Simple-0.10-2.el7.noarch
totem-pl-parser-3.10.7-1.el7.ppc64le
lohit-oriya-fonts-2.5.4.1-3.el7.noarch
python-coverage-3.6-0.5.b3.el7.ppc64le
java-1.7.0-openjdk-1.7.0.141-2.6.10.5.el7.ppc64le
mailcap-2.1.41-2.el7.noarch
perl-CPANPLUS-0.91.38-4.el7.noarch
fprintd-pam-0.5.0-4.0.el7_0.ppc64le
less-458-9.el7.ppc64le
gupnp-igd-0.2.4-1.el7.ppc64le
thai-scalable-waree-fonts-0.5.0-7.el7.noarch
python-di-0.3-2.el7.noarch
yelp-libs-3.22.0-1.el7.ppc64le
vte-profile-0.46.2-1.el7.ppc64le
gpm-libs-1.20.7-5.el7.ppc64le
gnome-clocks-3.22.1-1.el7.ppc64le
p11-kit-trust-0.23.5-3.el7.ppc64le
gssproxy-0.7.0-4.el7.ppc64le
gnu-free-mono-fonts-20120503-8.el7.noarch
python-dateutil-1.5-7.el7.noarch
gucharmap-libs-3.18.2-1.el7.ppc64le
glibc-common-2.17-196.el7.ppc64le
libreport-plugin-mantisbt-2.1.11-38.el7.centos.ppc64le
motif-devel-2.3.4-8.1.el7_3.ppc64le
celt051-0.5.1.3-8.el7.ppc64le
radvd-1.9.2-9.el7.ppc64le
lohit-tamil-fonts-2.5.3-2.el7.noarch
python-ipaddress-1.0.16-2.el7.noarch
anaconda-widgets-21.48.22.121-1.el7.centos.ppc64le
zlib-1.2.7-17.el7.ppc64le
libstdc++-devel-4.8.5-16.el7.ppc64le
system-config-printer-1.4.1-19.el7.ppc64le
mozjs24-24.2.0-7.el7.ppc64le
device-mapper-multipath-libs-0.4.9-111.el7.ppc64le
wqy-microhei-fonts-0.2.0-0.12.beta.el7.noarch
python-schedutils-0.4-6.el7.ppc64le
gnome-bluetooth-3.20.1-1.el7.ppc64le
nss-util-3.28.4-3.el7.ppc64le
dotconf-1.3-8.el7.ppc64le
ibus-rawcode-1.3.2-3.el7.ppc64le
abattis-cantarell-fonts-0.0.25-1.el7.noarch
sssd-common-1.15.2-50.el7.ppc64le
sil-padauk-fonts-2.8-5.el7.noarch
bind-utils-9.9.4-50.el7.ppc64le
sox-14.4.1-6.el7.ppc64le
libSM-1.2.2-2.el7.ppc64le
libtiff-devel-4.0.3-27.el7_3.ppc64le
plymouth-system-theme-0.8.9-0.28.20140113.el7.centos.ppc64le
python-libs-2.7.5-58.el7.ppc64le
sssd-1.15.2-50.el7.ppc64le
rfkill-0.4-9.el7.ppc64le
cyrus-sasl-md5-2.1.26-21.el7.ppc64le
libXtst-devel-1.2.3-1.el7.ppc64le
avahi-libs-0.6.31-17.el7.ppc64le
ruby-2.0.0.648-30.el7.ppc64le
seahorse-3.20.0-1.el7.ppc64le
python-six-1.9.0-2.el7.noarch
gpgme-1.3.2-5.el7.ppc64le
iwl7260-firmware-22.0.7.0-56.el7.noarch
libsss_certmap-1.15.2-50.el7.ppc64le
xorg-x11-drv-wacom-0.34.2-2.el7.ppc64le
libXau-1.0.8-2.1.el7.ppc64le
shadow-utils-4.1.5.1-24.el7.ppc64le
evolution-ews-3.22.6-6.el7.ppc64le
libsecret-0.18.5-2.el7.ppc64le
perl-Module-Signature-0.73-2.el7.noarch
rootfiles-8.1-11.el7.noarch
trace-cmd-2.6.0-8.el7.ppc64le
hamcrest-1.3-6.el7.noarch
gawk-4.0.2-4.el7_3.1.ppc64le
usermode-1.111-5.el7.ppc64le
gnome-terminal-nautilus-3.22.1-2.el7.ppc64le
gvfs-client-1.30.4-3.el7.ppc64le
yum-utils-1.1.31-42.el7.noarch
iwl3945-firmware-15.32.2.9-56.el7.noarch
perl-Archive-Zip-1.30-11.el7.noarch
spice-glib-0.33-6.el7.ppc64le
augeas-libs-1.4.0-2.el7.ppc64le
openlmi-providers-0.5.0-4.el7.ppc64le
gnome-color-manager-3.22.2-1.el7.ppc64le
imsettings-libs-1.6.3-9.el7.ppc64le
nss-softokn-devel-3.28.3-6.el7.ppc64le
python34-3.4.5-4.el7.ppc64le
perl-DBI-1.627-4.el7.ppc64le
plymouth-plugin-label-0.8.9-0.28.20140113.el7.centos.ppc64le
binutils-2.25.1-31.base.el7.ppc64le
libsss_nss_idmap-1.15.2-50.el7.ppc64le
gvfs-smb-1.30.4-3.el7.ppc64le
freetype-devel-2.4.11-15.el7.ppc64le
libXi-1.7.9-1.el7.ppc64le
perl-Text-Diff-1.41-5.el7.noarch
gcr-devel-3.20.0-1.el7.ppc64le
numactl-libs-2.0.9-6.el7_2.ppc64le
hardlink-1.0-19.el7.ppc64le
gnome-disk-utility-3.22.1-1.el7.ppc64le
mariadb-libs-5.5.56-2.el7.ppc64le
libnotify-0.7.7-1.el7.ppc64le
perl-TimeDate-2.30-2.el7.noarch
soprano-devel-2.9.2-3.el7.ppc64le
pixman-0.34.0-1.el7.ppc64le
kmod-20-15.el7.ppc64le
qt3-PostgreSQL-3.3.8b-51.el7.ppc64le
python2-pyasn1-0.1.9-7.el7.noarch
libXt-1.1.5-3.el7.ppc64le
perl-Font-AFM-1.20-13.el7.noarch
ibus-1.5.3-13.el7.ppc64le
findutils-4.5.11-5.el7.ppc64le
ibus-libs-1.5.3-13.el7.ppc64le
iprutils-2.4.14.1-1.el7.ppc64le
libpwquality-1.2.3-4.el7.ppc64le
libXrender-devel-0.9.10-1.el7.ppc64le
perl-IO-stringy-2.110-22.el7.noarch
kdelibs-4.14.8-6.el7_3.ppc64le
flac-libs-1.3.0-5.el7_1.ppc64le
device-mapper-event-libs-1.02.140-8.el7.ppc64le
gnutls-devel-3.3.26-9.el7.ppc64le
libXau-devel-1.0.8-2.1.el7.ppc64le
gstreamer1-plugins-base-1.10.4-1.el7.ppc64le
perl-HTML-Tree-5.03-2.el7.noarch
kdenetwork-kopete-4.10.5-8.el7_0.ppc64le
libepoxy-1.3.1-1.el7.ppc64le
mesa-libGLES-17.0.1-6.20170307.el7.ppc64le
qt-postgresql-4.8.5-13.el7.ppc64le
fontconfig-devel-2.10.95-11.el7.ppc64le
java-1.8.0-openjdk-headless-1.8.0.131-11.b12.el7.ppc64le
libXfont-1.5.2-1.el7.ppc64le
libkexiv2-4.10.5-3.el7.ppc64le
openjpeg-libs-1.5.1-17.el7.ppc64le
iscsi-initiator-utils-6.2.0.874-4.el7.ppc64le
NetworkManager-adsl-1.8.0-9.el7.ppc64le
libgtop2-2.34.2-1.el7.ppc64le
libXdamage-devel-1.1.4-4.1.el7.ppc64le
ipset-libs-6.29-1.el7.ppc64le
kde-runtime-drkonqi-4.10.5-8.el7.ppc64le
e2fsprogs-libs-1.42.9-10.el7.ppc64le
dhclient-4.2.5-58.el7.centos.ppc64le
usbutils-007-5.el7.ppc64le
python-ethtool-0.8-5.el7.ppc64le
gstreamer1-plugins-bad-free-1.10.4-2.el7.ppc64le
fftw-libs-double-3.3.3-8.el7.ppc64le
kdenetwork-krdc-4.10.5-8.el7_0.ppc64le
fuse-libs-2.9.2-8.el7.ppc64le
pciutils-3.5.1-2.el7.ppc64le
at-3.1.13-22.el7.ppc64le
python-IPy-0.75-6.el7.noarch
libXp-1.0.2-2.1.el7.ppc64le
vim-minimal-7.4.160-2.el7.ppc64le
kdesdk-kmtrace-4.10.5-6.el7.ppc64le
libraw1394-2.1.0-2.el7.ppc64le
libdrm-devel-2.4.74-1.el7.ppc64le
irqbalance-1.0.7-10.el7.ppc64le
fipscheck-lib-1.4.1-6.el7.ppc64le
gvfs-1.30.4-3.el7.ppc64le
libiscsi-1.9.0-7.el7.ppc64le
motif-2.3.4-8.1.el7_3.ppc64le
keyutils-1.5.8-3.el7.ppc64le
NetworkManager-ppp-1.8.0-9.el7.ppc64le
systemtap-3.1-3.el7.ppc64le
boost-serialization-1.53.0-27.el7.ppc64le
grilo-0.3.3-1.el7.ppc64le
rpm-4.11.3-25.el7.ppc64le
kdegraphics-libs-4.10.5-3.el7.noarch
libfontenc-1.1.3-3.el7.ppc64le
perl-Git-1.8.3.1-11.el7.noarch
rubygem-abrt-0.3.0-1.el7.noarch
tcl-8.5.13-8.el7.ppc64le
gtksourceview3-3.22.2-1.el7.ppc64le
cmake-2.8.12.2-2.el7.ppc64le
pulseaudio-utils-10.0-3.el7.ppc64le
libusal-1.1.11-23.el7.ppc64le
grub2-ppc64le-2.02-0.64.el7.centos.ppc64le
libreport-plugin-mailx-2.1.11-38.el7.centos.ppc64le
libvisual-0.4.0-16.el7.ppc64le
metacity-2.34.13-7.el7.ppc64le
redland-virtuoso-1.0.16-6.el7.ppc64le
nautilus-3.22.3-3.el7.ppc64le
pciutils-libs-3.5.1-2.el7.ppc64le
soprano-2.9.2-3.el7.ppc64le
mariadb-devel-5.5.56-2.el7.ppc64le
libxkbcommon-x11-0.7.1-1.el7.ppc64le
farstream02-0.2.3-3.el7.ppc64le
redhat-rpm-config-9.1.0-76.el7.centos.noarch
skkdic-20130104-6.T1435.el7.noarch
perl-HTTP-Tiny-0.033-3.el7.noarch
lvm2-libs-2.02.171-8.el7.ppc64le
perl-XML-Grove-0.46alpha-52.el7.noarch
boost-devel-1.53.0-27.el7.ppc64le
pycairo-1.8.10-8.el7.ppc64le
popt-devel-1.13-16.el7.ppc64le
gnome-settings-daemon-3.22.2-5.el7.ppc64le
perl-Socket-2.010-4.el7.ppc64le
numad-0.5-17.20150602git.el7.ppc64le
e2fsprogs-devel-1.42.9-10.el7.ppc64le
libsecret-devel-0.18.5-2.el7.ppc64le
libXv-devel-1.0.11-1.el7.ppc64le
libchewing-0.3.4-6.el7.ppc64le
gnome-shell-extension-places-menu-3.22.2-10.el7.noarch
perl-Time-HiRes-1.9725-3.el7.ppc64le
openchange-2.3-2.el7.ppc64le
audit-libs-devel-2.7.6-3.el7.ppc64le
python-dmidecode-3.12.2-1.el7.ppc64le
libmediaart-1.9.1-1.el7.ppc64le
elfutils-default-yama-scope-0.168-8.el7.noarch
quota-4.01-14.el7.ppc64le
perl-threads-1.87-4.el7.ppc64le
realmd-0.16.1-9.el7.ppc64le
nautilus-sendto-3.8.4-1.el7.ppc64le
gstreamer-0.10.36-7.el7.ppc64le
cairo-gobject-devel-1.14.8-2.el7.ppc64le
abrt-libs-2.1.11-48.el7.centos.ppc64le
libvirt-daemon-driver-storage-iscsi-3.2.0-14.el7.ppc64le
perl-Pod-Parser-1.61-2.el7.noarch
python-devel-2.7.5-58.el7.ppc64le
mpfr-devel-3.1.1-4.el7.ppc64le
kernel-headers-3.10.0-693.el7.ppc64le
powerpc-utils-python-1.2.1-9.el7.noarch
linux-firmware-20170606-56.gitc990aae.el7.noarch
libqmi-1.16.0-1.el7.ppc64le
libvirt-libs-3.2.0-14.el7.ppc64le
perl-Digest-1.17-245.el7.noarch
libgcab1-0.7-3.el7.ppc64le
flex-2.5.37-3.el7.ppc64le
tzdata-2017b-1.el7.noarch
phonon-4.6.0-10.el7.ppc64le
anaconda-tui-21.48.22.121-1.el7.centos.ppc64le
libmbim-utils-1.14.0-2.el7.ppc64le
gnutls-utils-3.3.26-9.el7.ppc64le
perl-Parse-CPAN-Meta-1.4404-5.el7.noarch
flite-1.3-22.el7.ppc64le
nfs4-acl-tools-0.3.3-15.el7.ppc64le
poppler-data-0.4.6-3.el7.noarch
gvfs-fuse-1.30.4-3.el7.ppc64le
gnome-software-3.22.7-1.el7.ppc64le
perl-ExtUtils-ParseXS-3.18-3.el7.noarch
libvirt-python-3.2.0-3.el7.ppc64le
perl-Module-Load-Conditional-0.54-3.el7.noarch
python-netifaces-0.10.4-3.el7.ppc64le
swig-2.0.10-5.el7.ppc64le
ipa-client-common-4.5.0-20.el7.centos.noarch
cheese-libs-3.22.1-1.el7.ppc64le
gnome-tweak-tool-3.22.0-1.el7.noarch
perl-ExtUtils-CBuilder-0.28.2.6-292.el7.noarch
libsoup-devel-2.56.0-3.el7.ppc64le
perl-IO-Zlib-1.10-292.el7.noarch
fros-1.0-2.el7.noarch
lohit-devanagari-fonts-2.5.3-4.el7.noarch
grub2-ppc64le-modules-2.02-0.64.el7.centos.noarch
libgdata-0.17.8-1.el7.ppc64le
evince-nautilus-3.22.1-5.el7.ppc64le
perl-ExtUtils-Embed-1.30-292.el7.noarch
dleyna-connector-dbus-0.2.0-2.el7.ppc64le
libiec61883-1.2.0-10.el7.ppc64le
python-lxml-3.2.1-4.el7.ppc64le
liberation-serif-fonts-1.07.2-15.el7.noarch
tigervnc-license-1.8.0-1.el7.noarch
gnome-packagekit-3.22.1-2.el7.ppc64le
hpijs-3.15.9-3.el7.ppc64le
libmodman-2.0.1-8.el7.ppc64le
ntp-4.2.6p5-25.el7.centos.2.ppc64le
gmp-devel-6.0.0-15.el7.ppc64le
pyxattr-0.5.1-5.el7.ppc64le
sil-abyssinica-fonts-1.200-6.el7.noarch
ncurses-libs-5.9-13.20130511.el7.ppc64le
gnome-dictionary-libs-3.20.0-1.el7.ppc64le
kdesdk-devel-4.10.5-6.el7.ppc64le
libreport-rhel-anaconda-bugzilla-2.1.11-38.el7.centos.ppc64le
libvirt-daemon-config-network-3.2.0-14.el7.ppc64le
boost-iostreams-1.53.0-27.el7.ppc64le
python-ply-3.4-11.el7.noarch
ucs-miscfixed-fonts-0.3-11.el7.noarch
info-5.1-4.el7.ppc64le
libXxf86misc-devel-1.0.3-7.1.el7.ppc64le
ibus-qt-1.3.2-4.el7.ppc64le
gnome-video-effects-0.4.3-1.el7.noarch
bridge-utils-1.5-9.el7.ppc64le
make-3.82-23.el7.ppc64le
pywbem-0.7.0-25.20130827svn625.el7.noarch
pnm2ppa-1.04-28.el7.ppc64le
chkconfig-1.7.4-1.el7.ppc64le
at-spi2-atk-devel-2.22.0-2.el7.ppc64le
freeglut-devel-2.8.1-3.el7.ppc64le
jbigkit-libs-2.0-11.el7.ppc64le
sssd-ipa-1.15.2-50.el7.ppc64le
openssl-libs-1.0.2k-8.el7.ppc64le
ldns-1.6.16-10.el7.ppc64le
rdate-1.4-25.el7.ppc64le
libdb-5.3.21-20.el7.ppc64le
evince-libs-3.22.1-5.el7.ppc64le
empathy-3.12.12-4.el7.ppc64le
rubygem-json-1.7.7-30.el7.ppc64le
dmraid-1.0.0.rc16-28.el7.ppc64le
libblkid-2.23.2-43.el7.ppc64le
logrotate-3.8.6-14.el7.ppc64le
iwl105-firmware-18.168.6.1-56.el7.noarch
grep-2.20-3.el7.ppc64le
xorg-x11-drv-synaptics-1.9.0-1.el7.ppc64le
iowatcher-1.0-6.el7.ppc64le
rubygem-net-http-persistent-2.8-5.el7.noarch
setroubleshoot-plugins-3.0.65-1.el7.noarch
atk-2.22.0-3.el7.ppc64le
libcacard-2.5.2-2.el7.ppc64le
iwl6050-firmware-41.28.5.1-56.el7.noarch
lcms2-2.6-3.el7.ppc64le
tigervnc-server-minimal-1.8.0-1.el7.ppc64le
gvfs-goa-1.30.4-3.el7.ppc64le
authconfig-6.2.8-30.el7.ppc64le
yum-plugin-fastestmirror-1.1.31-42.el7.noarch
dbus-python-1.1.1-9.el7.ppc64le
perl-Archive-Tar-1.92-2.el7.noarch
iwl5000-firmware-8.83.5.1_1-56.el7.noarch
libacl-2.2.51-12.el7.ppc64le
farstream-0.1.2-8.el7.ppc64le
ppc64-utils-0.14-16.el7.ppc64le
servicelog-1.1.14-3.el7.ppc64le
python2-ipaclient-4.5.0-20.el7.centos.noarch
libpeas-1.20.0-1.el7.ppc64le
perl-TermReadKey-2.30-20.el7.ppc64le
hdparm-9.43-5.el7.ppc64le
libicu-50.1.2-15.el7.ppc64le
polkit-qt-0.103.0-10.el7_0.ppc64le
gnome-weather-3.20.2-1.el7.noarch
libmspack-0.5-0.5.alpha.el7.ppc64le
libkkc-data-0.3.1-9.el7.ppc64le
hicolor-icon-theme-0.12-7.el7.noarch
perl-Newt-1.08-36.el7.ppc64le
libexif-0.6.21-6.el7.ppc64le
gtk3-devel-3.22.10-4.el7.ppc64le
gvfs-mtp-1.30.4-3.el7.ppc64le
ncompress-4.2.4.4-3.el7.ppc64le
libXcomposite-0.4.4-4.1.el7.ppc64le
python-decorator-3.4.0-3.el7.noarch
perl-Business-ISBN-Data-20120719.001-2.el7.noarch
cpio-2.11-24.el7.ppc64le
mesa-libGLU-9.0.0-4.el7.ppc64le
baobab-3.22.1-1.el7.ppc64le
device-mapper-libs-1.02.140-8.el7.ppc64le
libXtst-1.2.3-1.el7.ppc64le
ModemManager-glib-1.6.0-2.el7.ppc64le
perl-HTML-Parser-3.71-4.el7.ppc64le
libical-1.0.1-1.el7.ppc64le
xorg-x11-xinit-1.3.4-1.el7.ppc64le
gstreamer1-plugins-base-devel-1.10.4-1.el7.ppc64le
libdrm-2.4.74-1.el7.ppc64le
libXfixes-devel-5.0.3-1.el7.ppc64le
python-gssapi-1.2.0-3.el7.ppc64le
perl-Text-Unidecode-0.04-20.el7.noarch
hunspell-1.3.2-15.el7.ppc64le
kde-settings-19-23.5.el7.centos.noarch
perl-App-cpanminus-1.6922-2.el7.noarch
parted-3.1-28.el7.ppc64le
mesa-libGL-17.0.1-6.20170307.el7.ppc64le
elfutils-libelf-devel-0.168-8.el7.ppc64le
perl-Net-LibIDN-0.12-15.el7.ppc64le
apr-1.4.8-3.el7.ppc64le
kdepimlibs-4.10.5-4.el7.ppc64le
virt-top-1.0.8-23.el7.ppc64le
samba-client-libs-4.6.2-8.el7.ppc64le
gstreamer-plugins-base-0.10.36-10.el7.ppc64le
json-glib-devel-1.2.6-1.el7.ppc64le
perl-autodie-2.16-2.el7.noarch
tar-1.26-32.el7.ppc64le
ksysguard-libs-4.11.19-8.el7.ppc64le
rdma-core-devel-13-7.el7.ppc64le
accountsservice-0.6.45-2.el7.ppc64le
libxklavier-5.4-7.el7.ppc64le
libxml2-devel-2.9.1-6.el7_2.3.ppc64le
ghostscript-fonts-5.50-32.el7.noarch
libassuan-2.1.0-3.el7.ppc64le
libkipi-devel-4.10.5-3.el7.ppc64le
python-smbc-1.0.13-7.el7.ppc64le
initscripts-9.49.39-1.el7.ppc64le
qt3-3.3.8b-51.el7.ppc64le
yum-metadata-parser-1.1.4-10.el7.ppc64le
device-mapper-persistent-data-0.7.0-0.1.rc6.el7.ppc64le
adwaita-icon-theme-3.22.0-1.el7.noarch
kdepim-4.10.5-6.el7.ppc64le
postfix-2.10.1-6.el7.ppc64le
abrt-addon-pstoreoops-2.1.11-48.el7.centos.ppc64le
freerdp-libs-1.0.2-10.el7.ppc64le
langtable-python-0.0.31-3.el7.noarch
tcp_wrappers-7.6-77.el7.ppc64le
lm_sensors-libs-3.4.0-4.20160601gitf9185e5.el7.ppc64le
kde-style-oxygen-4.11.19-8.el7.ppc64le
powertop-2.3-12.el7.ppc64le
wpa_supplicant-2.6-5.el7.ppc64le
gtk3-3.22.10-4.el7.ppc64le
boost-python-1.53.0-27.el7.ppc64le
keyutils-libs-devel-1.5.8-3.el7.ppc64le
libdvdread-5.0.3-3.el7.ppc64le
im-chooser-common-1.6.4-4.el7.ppc64le
aic94xx-firmware-30-6.el7.noarch
media-player-info-17-4.el7.noarch
compat-gnome-desktop314-3.14.2-1.el7.ppc64le
harfbuzz-1.3.2-1.el7.ppc64le
libgcrypt-devel-1.5.3-14.el7.ppc64le
groff-base-1.22.2-8.el7.ppc64le
sane-backends-1.0.24-9.el7.ppc64le
setuptool-1.19.11-8.el7.ppc64le
ebtables-2.0.10-15.el7.ppc64le
libchamplain-0.12.15-1.el7.ppc64le
boost-math-1.53.0-27.el7.ppc64le
libuser-0.60-7.el7_1.ppc64le
boost-date-time-1.53.0-27.el7.ppc64le
espeak-1.47.11-4.el7.ppc64le
tbb-devel-4.1-9.20130314.el7.ppc64le
grub2-tools-minimal-2.02-0.64.el7.centos.ppc64le
gjs-1.46.0-1.el7.ppc64le
libsss_autofs-1.15.2-50.el7.ppc64le
deltarpm-3.6-3.el7.ppc64le
libnl-1.1.4-3.el7.ppc64le
libgpod-0.8.2-12.el7.ppc64le
postgresql-devel-9.2.21-1.el7.ppc64le
libibcm-13-7.el7.ppc64le
abrt-gui-libs-2.1.11-48.el7.centos.ppc64le
libxkbcommon-0.7.1-1.el7.ppc64le
passwd-0.79-4.el7.ppc64le
lsvpd-1.7.8-1.el7.ppc64le
fprintd-0.5.0-4.0.el7_0.ppc64le
hunspell-en-0.20121024-6.el7.noarch
qca-ossl-2.0.0-0.19.beta3.el7.ppc64le
libdmapsharing-2.9.37-1.el7.ppc64le
ortp-0.20.0-10.el7.ppc64le
python-pycurl-7.19.0-19.el7.ppc64le
perl-Pod-Escapes-1.04-292.el7.noarch
pcp-3.11.8-7.el7.ppc64le
libblkid-devel-2.23.2-43.el7.ppc64le
dracut-network-033-502.el7.ppc64le
pyatspi-2.20.3-1.el7.noarch
systemtap-sdt-devel-3.1-3.el7.ppc64le
check-0.9.9-5.el7.ppc64le
perl-threads-shared-1.43-6.el7.ppc64le
gnome-shell-extension-common-3.22.2-10.el7.noarch
gnome-icon-theme-symbolic-3.12.0-2.el7.noarch
abrt-cli-2.1.11-48.el7.centos.ppc64le
festival-speechtools-libs-1.2.96-28.el7.ppc64le
python-slip-dbus-0.4.0-2.el7.noarch
mesa-private-llvm-3.9.1-3.el7.ppc64le
perl-Time-Local-1.2300-2.el7.noarch
yelp-3.22.0-1.el7.ppc64le
fuse-devel-2.9.2-8.el7.ppc64le
dnsmasq-2.76-2.el7.ppc64le
festvox-slt-arctic-hts-0.20061229-28.el7.noarch
libtasn1-devel-4.10-1.el7.ppc64le
libgudev1-219-42.el7.ppc64le
perl-version-0.99.07-2.el7.ppc64le
libvirt-daemon-driver-qemu-3.2.0-14.el7.ppc64le
ps_mem-3.1-7.el7.noarch
rtkit-0.11-10.el7.ppc64le
abrt-gui-2.1.11-48.el7.centos.ppc64le
nettle-devel-2.7.1-8.el7.ppc64le
perl-ExtUtils-Manifest-1.61-244.el7.noarch
libreswan-3.20-3.el7.ppc64le
python-pyudev-0.15-9.el7.noarch
appstream-data-7-20170301.el7.noarch
powerpc-utils-1.3.3-4.el7.ppc64le
setup-2.8.71-7.el7.noarch
enscript-1.6.6-6.el7.ppc64le
libgexiv2-0.10.4-2.el7.ppc64le
perl-Digest-SHA-5.85-4.el7.ppc64le
upower-0.99.4-2.el7.ppc64le
dhcp-libs-4.2.5-58.el7.centos.ppc64le
kbd-1.15.5-13.el7.ppc64le
phonon-backend-gstreamer-4.6.3-3.el7.ppc64le
dejavu-fonts-common-2.33-6.el7.noarch
libaio-devel-0.3.109-13.el7.ppc64le
grubby-8.28-23.el7.ppc64le
perl-CPAN-Meta-2.120921-5.el7.noarch
libmusicbrainz5-5.0.1-9.el7.ppc64le
liberation-mono-fonts-1.07.2-15.el7.noarch
fcoe-utils-1.0.32-1.el7.ppc64le
gvfs-afc-1.30.4-3.el7.ppc64le
m17n-db-1.6.4-3.el7.noarch
time-1.7-45.el7.ppc64le
python-configobj-4.7.2-7.el7.noarch
perl-Log-Message-0.08-3.el7.noarch
glib-networking-2.50.0-1.el7.ppc64le
gcc-4.8.5-16.el7.ppc64le
gnome-classic-session-3.22.2-10.el7.noarch
libglade2-2.6.4-11.el7.ppc64le
langtable-data-0.0.31-3.el7.noarch
dejavu-serif-fonts-2.33-6.el7.noarch
python-requests-2.6.0-1.el7_1.noarch
perl-HTML-Tagset-3.20-15.el7.noarch
gssdp-1.0.1-1.el7.ppc64le
perl-CPANPLUS-Dist-Build-0.70-3.el7.noarch
brasero-nautilus-3.12.1-2.el7.ppc64le
evolution-data-server-3.22.7-6.el7.ppc64le
khmeros-fonts-common-5.0-17.el7.noarch
dejavu-sans-fonts-2.33-6.el7.noarch
python-kmod-0.9-4.el7.ppc64le
lzop-1.03-10.el7.ppc64le
telepathy-salut-0.8.1-6.el7.ppc64le
tbb-4.1-9.20130314.el7.ppc64le
kdegraphics-devel-4.10.5-3.el7.noarch
libcryptui-3.12.2-1.el7.ppc64le
ncurses-base-5.9-13.20130511.el7.noarch
lohit-nepali-fonts-2.5.3-2.el7.noarch
python-configshell-1.1.fb23-3.el7.noarch
acl-2.2.51-12.el7.ppc64le
python-rtslib-2.1.fb63-2.el7.noarch
libreport-plugin-rhtsupport-2.1.11-38.el7.centos.ppc64le
imsettings-qt-1.6.3-9.el7.ppc64le
webkitgtk3-2.4.11-2.el7.ppc64le
libsepol-2.5-6.el7.ppc64le
smc-meera-fonts-6.0-7.el7.noarch
python-mako-0.8.1-2.el7.noarch
pinentry-0.8.1-17.el7.ppc64le
alsa-tools-firmware-1.1.0-1.el7.ppc64le
libgdither-0.6-8.el7.ppc64le
ibus-libpinyin-1.6.91-4.el7.ppc64le
libXp-devel-1.0.2-2.1.el7.ppc64le
nspr-4.13.1-1.0.el7_3.ppc64le
cscope-15.8-10.el7.ppc64le
m2crypto-0.21.1-17.el7.ppc64le
libatomic-4.8.5-16.el7.ppc64le
opencc-0.4.3-3.el7.ppc64le
sbc-1.0-5.el7.ppc64le
SDL-devel-1.2.15-14.el7.ppc64le
vorbis-tools-1.4.0-12.el7.ppc64le
bzip2-libs-1.0.6-13.el7.ppc64le
google-crosextra-carlito-fonts-1.103-0.2.20130920.el7.noarch
nmap-ncat-6.40-7.el7.ppc64le
krb5-libs-1.15.1-8.el7.ppc64le
sssd-krb5-1.15.2-50.el7.ppc64le
cups-filters-libs-1.0.35-22.el7.ppc64le
virt-manager-1.4.1-7.el7.noarch
evince-3.22.1-5.el7.ppc64le
readline-6.2-10.el7.ppc64le
ctags-5.8-13.el7.ppc64le
sound-theme-freedesktop-0.8-3.el7.noarch
ruby-libs-2.0.0.648-30.el7.ppc64le
pth-2.0.7-23.el7.ppc64le
rubygems-2.0.14.1-30.el7.noarch
gnome-dictionary-3.20.0-1.el7.ppc64le
xorg-x11-drv-evdev-2.10.5-2.1.el7.ppc64le
audit-libs-2.7.6-3.el7.ppc64le
iwl135-firmware-18.168.6.1-56.el7.noarch
python-nss-0.16.0-3.el7.ppc64le
json-glib-1.2.6-1.el7.ppc64le
flatpak-libs-0.8.7-1.el7.ppc64le
libutempter-1.1.6-4.el7.ppc64le
ekiga-4.0.1-7.el7.ppc64le
easymock2-2.5.2-12.el7.noarch
keyutils-libs-1.5.8-3.el7.ppc64le
iwl1000-firmware-39.31.5.1-56.el7.noarch
teamd-1.25-5.el7.ppc64le
telepathy-glib-0.24.0-1.el7.ppc64le
PackageKit-yum-1.1.5-1.el7.centos.ppc64le
virt-what-1.13-10.el7.ppc64le
ppc64-diag-2.7.3-3.el7.ppc64le
libpurple-2.10.11-5.el7.ppc64le
libffi-3.0.13-18.el7.ppc64le
iwl2000-firmware-18.168.6.1-56.el7.noarch
perl-YAML-0.84-5.el7.noarch
libxml2-python-2.9.1-6.el7_2.3.ppc64le
lsscsi-0.27-6.el7.ppc64le
systemtap-client-3.1-3.el7.ppc64le
virt-viewer-5.0-7.el7.ppc64le
dbusmenu-qt-0.9.2-7.el7.ppc64le
libtar-1.2.11-29.el7.ppc64le
ccache-3.3.4-1.el7.ppc64le
perl-DBD-SQLite-1.39-3.el7.ppc64le
gnome-icon-theme-3.12.0-1.el7.noarch
gdk-pixbuf2-2.36.5-1.el7.ppc64le
libpath_utils-0.2.1-27.el7.ppc64le
gvfs-archive-1.30.4-3.el7.ppc64le
gnome-online-accounts-devel-3.22.5-1.el7.ppc64le
yajl-2.0.4-4.el7.ppc64le
perl-Pod-Coverage-0.23-3.el7.noarch
libselinux-python-2.5-11.el7.ppc64le
libX11-devel-1.6.5-1.el7.ppc64le
qrencode-libs-3.4.1-3.el7.ppc64le
gnome-system-log-3.9.90-3.el7.ppc64le
mesa-libGLU-devel-9.0.0-4.el7.ppc64le
boost-system-1.53.0-27.el7.ppc64le
perl-HTTP-Message-6.06-6.el7.noarch
cracklib-2.9.0-11.el7.ppc64le
libXcursor-1.1.14-8.el7.ppc64le
dbus-1.6.12-17.el7.ppc64le
libnotify-devel-0.7.7-1.el7.ppc64le
ibus-gtk3-1.5.3-13.el7.ppc64le
libv4l-0.9.5-4.el7.ppc64le
perl-Time-Piece-1.20.1-292.el7.ppc64le
cracklib-dicts-2.9.0-11.el7.ppc64le
startup-notification-0.12-8.el7.ppc64le
dconf-0.26.0-2.el7.ppc64le
net-snmp-devel-5.7.2-28.el7.ppc64le
kate-part-4.10.5-4.el7.ppc64le
orc-0.4.26-1.el7.ppc64le
kernel-devel-3.10.0-693.el7.ppc64le
avahi-gobject-0.6.31-17.el7.ppc64le
cairo-gobject-1.14.8-2.el7.ppc64le
httpd-2.4.6-67.el7.centos.ppc64le
subversion-1.7.14-10.el7.ppc64le
kdepimlibs-akonadi-4.10.5-4.el7.ppc64le
gdbm-1.10-8.el7.ppc64le
perl-File-CheckTree-4.42-3.el7.noarch
atk-devel-2.22.0-3.el7.ppc64le
java-1.8.0-openjdk-devel-1.8.0.131-11.b12.el7.ppc64le
abrt-dbus-2.1.11-48.el7.centos.ppc64le
qt-mysql-4.8.5-13.el7.ppc64le
libkdcraw-4.10.5-4.el7.ppc64le
libaio-0.3.109-13.el7.ppc64le
urw-fonts-2.4-16.el7.noarch
libgee06-0.6.8-3.el7.ppc64le
libXrandr-devel-1.5.1-2.el7.ppc64le
cronie-anacron-1.4.11-17.el7.ppc64le
mlocate-0.26-6.el7.ppc64le
kdesdk-okteta-devel-4.10.5-6.el7.ppc64le
iso-codes-3.46-2.el7.noarch
cpp-4.8.5-16.el7.ppc64le
e2fsprogs-1.42.9-10.el7.ppc64le
at-spi2-atk-2.22.0-2.el7.ppc64le
libstoragemgmt-python-clibs-1.4.0-3.el7.ppc64le
PackageKit-command-not-found-1.1.5-1.el7.centos.ppc64le
kdenetwork-kopete-devel-4.10.5-8.el7_0.ppc64le
libmnl-1.0.3-7.el7.ppc64le
tcp_wrappers-devel-7.6-77.el7.ppc64le
python-dns-1.12.0-4.20150617git465785f.el7.noarch
libXinerama-devel-1.1.3-2.1.el7.ppc64le
libibverbs-13-7.el7.ppc64le
net-tools-2.0-0.22.20131004git.el7.ppc64le
kde-workspace-libs-4.11.19-8.el7.ppc64le
libwebp-0.3.0-7.el7.ppc64le
libattr-devel-2.4.46-12.el7.ppc64le
libkadm5-1.15.1-8.el7.ppc64le
gcr-3.20.0-1.el7.ppc64le
colord-1.3.4-1.el7.ppc64le
rsyslog-8.24.0-12.el7.ppc64le
im-chooser-1.6.4-4.el7.ppc64le
boost-filesystem-1.53.0-27.el7.ppc64le
libgpg-error-devel-1.12-3.el7.ppc64le
harfbuzz-icu-1.3.2-1.el7.ppc64le
libpeas-gtk-1.20.0-1.el7.ppc64le
abrt-addon-python-2.1.11-48.el7.centos.ppc64le
selinux-policy-targeted-3.13.1-166.el7.noarch
libksane-4.10.5-4.el7.ppc64le
m4-1.4.16-10.el7.ppc64le
xmlrpc-c-client-1.32.5-1905.svn2451.el7.ppc64le
sysvinit-tools-2.88-14.dsf.el7.ppc64le
libnma-1.8.0-3.el7.ppc64le
os-prober-1.58-9.el7.ppc64le
libproxy-mozjs-0.4.11-10.el7.ppc64le
speech-dispatcher-0.7.1-15.el7.ppc64le
boost-signals-1.53.0-27.el7.ppc64le
python-ldap-2.4.15-2.el7.ppc64le
libvpx-1.3.0-5.el7_0.ppc64le
nm-connection-editor-1.8.0-3.el7.ppc64le
NetworkManager-team-1.8.0-9.el7.ppc64le
perf-3.10.0-693.el7.ppc64le
libgsf-1.14.26-7.el7.ppc64le
libpfm-4.7.0-4.el7.ppc64le
postgresql-9.2.21-1.el7.ppc64le
ethtool-4.8-1.el7.ppc64le
xorg-x11-server-utils-7.7-20.el7.ppc64le
attica-0.4.2-1.el7.ppc64le
xfsdump-3.1.4-1.el7.ppc64le
firewalld-filesystem-0.4.4.4-6.el7.noarch
libXfont2-2.0.1-2.el7.ppc64le
net-snmp-agent-libs-5.7.2-28.el7.ppc64le
tcl-devel-8.5.13-8.el7.ppc64le
libgxps-0.2.5-1.el7.ppc64le
cyrus-sasl-devel-2.1.26-21.el7.ppc64le
hmaccalc-0.9.13-4.el7.ppc64le
libwacom-data-0.24-1.el7.noarch
perl-Pod-Usage-1.63-3.el7.noarch
libitm-4.8.5-16.el7.ppc64le
python-yubico-1.2.3-1.el7.noarch
libXxf86vm-devel-1.1.4-1.el7.ppc64le
abrt-tui-2.1.11-48.el7.centos.ppc64le
pinfo-0.6.10-9.el7.ppc64le
gnome-shell-extension-user-theme-3.22.2-10.el7.noarch
perl-File-Path-2.09-2.el7.noarch
xorg-x11-fonts-Type1-7.5-9.el7.noarch
python-firewall-0.4.4.4-6.el7.noarch
libXres-1.0.7-2.1.el7.ppc64le
libcgroup-tools-0.41-13.el7.ppc64le
libnl-devel-1.1.4-3.el7.ppc64le
gnome-user-docs-3.22.0-1.el7.noarch
perl-Pod-Simple-3.28-4.el7.noarch
systemd-libs-219-42.el7.ppc64le
ncurses-devel-5.9-13.20130511.el7.ppc64le
mesa-libEGL-devel-17.0.1-6.20170307.el7.ppc64le
audit-2.7.6-3.el7.ppc64le
iotop-0.6-2.el7.noarch
libvirt-daemon-driver-storage-logical-3.2.0-14.el7.ppc64le
perl-Module-CoreList-2.76.02-292.el7.noarch
libmbim-1.14.0-2.el7.ppc64le
libgcc-4.8.5-16.el7.ppc64le
xdg-desktop-portal-0.5-2.el7.ppc64le
perl-Module-Load-0.24-3.el7.noarch
caribou-gtk3-module-0.4.21-1.el7.ppc64le
sqlite-devel-3.7.17-8.el7.ppc64le
centos-indexhtml-7-9.el7.centos.noarch
elfutils-0.168-8.el7.ppc64le
centos-release-7-4.1708.el7.centos.ppc64le
trousers-0.3.14-2.el7.ppc64le
perl-Thread-Queue-3.02-2.el7.noarch
python-meh-gui-0.25.2-1.el7.noarch
gom-0.3.2-1.el7.ppc64le
lldpad-1.0.1-3.git036e314.el7.ppc64le
libgusb-0.2.9-1.el7.ppc64le
liberation-fonts-common-1.07.2-15.el7.noarch
libimobiledevice-1.2.0-1.el7.ppc64le
perl-Module-Pluggable-4.8-3.el7.noarch
ghostscript-cups-9.07-28.el7.ppc64le
osinfo-db-tools-1.1.0-1.el7.ppc64le
kbd-misc-1.15.5-13.el7.noarch
dhcp-common-4.2.5-58.el7.centos.ppc64le
control-center-filesystem-3.22.2-5.el7.ppc64le
libvirt-glib-1.0.0-1.el7.ppc64le
perl-CPAN-Meta-Requirements-2.122-7.el7.noarch
PyQt4-4.10.1-13.el7.ppc64le
btrfs-progs-4.9.1-1.el7.ppc64le
anaconda-gui-21.48.22.121-1.el7.centos.ppc64le
libatasmart-0.19-6.el7.ppc64le
shared-desktop-ontologies-0.11.0-2.el7.noarch
libvirt-daemon-config-nwfilter-3.2.0-14.el7.ppc64le
autoconf-2.69-11.el7.noarch
gnome-terminal-3.22.1-2.el7.ppc64le
python-cups-1.9.63-6.el7.ppc64le
intltool-0.50.2-7.el7.noarch
glibc-headers-2.17-196.el7.ppc64le
kdesdk-common-4.10.5-6.el7.noarch
libvirt-daemon-driver-secret-3.2.0-14.el7.ppc64le
perl-Locale-Maketext-Simple-0.21-292.el7.noarch
gnome-keyring-3.20.0-3.el7.ppc64le
python-sss-murmur-1.15.2-50.el7.ppc64le
vim-enhanced-7.4.160-2.el7.ppc64le
perl-ExtUtils-MakeMaker-6.68-3.el7.noarch
emacs-filesystem-24.3-19.el7_3.noarch
libvncserver-0.9.9-9.el7_0.1.ppc64le
perl-Object-Accessor-0.42-292.el7.noarch
gnome-desktop3-3.22.2-2.el7.ppc64le
python-backports-1.0-8.el7.ppc64le
evolution-help-3.22.6-10.el7.noarch
systemtap-devel-3.1-3.el7.ppc64le
langtable-0.0.31-3.el7.noarch
geocode-glib-3.20.1-1.el7.ppc64le
perl-Compress-Raw-Bzip2-2.061-3.el7.ppc64le
pygtk2-libglade-2.24.0-9.el7.ppc64le
python-urllib3-1.10.2-3.el7.noarch
orca-3.6.3-4.el7.ppc64le
perl-File-Fetch-0.42-2.el7.noarch
latencytop-common-0.5-13.el7.ppc64le
geoclue2-libs-2.4.5-1.el7.ppc64le
perl-Module-Loaded-0.08-292.el7.noarch
webkitgtk4-2.14.7-2.el7.ppc64le
python-paste-1.7.5.1-9.20111221hg1498.el7.noarch
totem-nautilus-3.22.1-1.el7.ppc64le
libtool-2.4.2-22.el7_3.ppc64le
smc-fonts-common-6.0-7.el7.noarch
libnice-0.1.3-4.el7.ppc64le
libdvdnav-5.0.3-1.el7.ppc64le
folks-0.11.3-1.el7.ppc64le
python-ipaddr-2.1.11-1.el7.noarch
xorg-x11-utils-7.5-22.el7.ppc64le
oxygen-icon-theme-4.10.5-2.el7.noarch
libkkc-common-0.3.1-9.el7.noarch
libgovirt-0.3.3-5.el7.ppc64le
boost-timer-1.53.0-27.el7.ppc64le
gnome-packagekit-common-3.22.1-2.el7.ppc64le
javapackages-tools-3.4.1-11.el7.noarch
sane-backends-devel-1.0.24-9.el7.ppc64le
konkretcmpi-0.9.1-5.el7.ppc64le
perl-srpm-macros-1-8.el7.noarch
chrony-3.1-2.el7.centos.ppc64le
fuse-2.9.2-8.el7.ppc64le
evolution-3.22.6-10.el7.ppc64le
python-urwid-1.1.1-3.el7.ppc64le
shotwell-0.24.5-1.el7.ppc64le
libreport-web-2.1.11-38.el7.centos.ppc64le
glibc-2.17-196.el7.ppc64le
usb_modeswitch-data-20160612-2.el7.noarch
patch-2.7.1-8.el7.ppc64le
file-roller-3.22.3-1.el7.ppc64le
python-netaddr-0.7.5-7.el7.noarch
ibus-table-chinese-1.4.6-3.el7.noarch
libreport-plugin-reportuploader-2.1.11-38.el7.centos.ppc64le
pcre-8.32-17.el7.ppc64le
libvirt-daemon-driver-network-3.2.0-14.el7.ppc64le
cyrus-sasl-plain-2.1.26-21.el7.ppc64le
glade-libs-3.20.0-1.el7.ppc64le
python-markupsafe-0.11-10.el7.ppc64le
kdenetwork-devel-4.10.5-8.el7_0.noarch
libreport-plugin-ureport-2.1.11-38.el7.centos.ppc64le
dbus-libs-1.6.12-17.el7.ppc64le
alsa-firmware-1.0.28-2.el7.noarch
mozjs17-17.0.0-19.el7.ppc64le
avahi-ui-gtk3-0.6.31-17.el7.ppc64le
python-cffi-1.6.0-5.el7.ppc64le
xdg-user-dirs-gtk-0.10-4.el7.ppc64le
gavl-1.4.0-4.el7.ppc64le
libjpeg-turbo-1.2.90-5.el7.ppc64le
device-mapper-multipath-0.4.9-111.el7.ppc64le
libcdio-0.92-1.el7.ppc64le
pulseaudio-module-bluetooth-10.0-3.el7.ppc64le
pytalloc-2.1.9-1.el7.ppc64le
ibus-sayura-1.3.2-3.el7.ppc64le
checkpolicy-2.5-4.el7.ppc64le
libICE-1.0.9-9.el7.ppc64le
libvirt-daemon-driver-interface-3.2.0-14.el7.ppc64le
libunistring-0.9.3-9.el7.ppc64le
libXScrnSaver-devel-1.2.2-6.1.el7.ppc64le
openlmi-python-base-0.5.0-4.el7.noarch
PyQt4-devel-4.10.1-13.el7.ppc64le
libndp-1.2-7.el7.ppc64le
libxml2-2.9.1-6.el7_2.3.ppc64le
sssd-krb5-common-1.15.2-50.el7.ppc64le
ncurses-5.9-13.20130511.el7.ppc64le
icedax-1.1.11-23.el7.ppc64le
libmsn-4.2.1-7.el7.ppc64le
evolution-data-server-devel-3.22.7-6.el7.ppc64le
poppler-0.26.5-16.el7.ppc64le
sed-4.2.2-5.el7.ppc64le
sssd-ldap-1.15.2-50.el7.ppc64le
fontconfig-2.10.95-11.el7.ppc64le
pinentry-qt-0.8.1-17.el7.ppc64le
cyrus-sasl-scram-2.1.26-21.el7.ppc64le
paps-0.6.8-28.el7.1.ppc64le
libyaml-0.1.4-11.el7_0.ppc64le
libgpg-error-1.12-3.el7.ppc64le
sgpio-1.2.0.10-13.el7.ppc64le
alsa-lib-1.1.3-3.el7.ppc64le
gutenprint-5.2.9-18.el7.ppc64le
openslp-2.0.0-6.el7.ppc64le
ruby-irb-2.0.0.648-30.el7.noarch
libgcrypt-1.5.3-14.el7.ppc64le
python-blivet-0.61.15.65-1.el7.noarch
gzip-1.5-9.el7.ppc64le
xorg-x11-drv-void-1.4.1-2.el7.ppc64le
nss-pem-1.0.3-4.el7.ppc64le
rubygem-rdoc-4.0.0-30.el7.noarch
libcap-ng-0.7.5-4.el7.ppc64le
rpm-build-libs-4.11.3-25.el7.ppc64le
shared-mime-info-1.8-3.el7.ppc64le
xorg-x11-drv-v4l-0.2.0-47.el7.ppc64le
nss-tools-3.28.4-8.el7.ppc64le
libsemanage-2.5-8.el7.ppc64le
libxcb-1.12-1.el7.ppc64le
flatpak-0.8.7-1.el7.ppc64le
gstreamer1-1.10.4-2.el7.ppc64le
xorg-x11-drv-nouveau-1.0.13-3.el7.ppc64le
sgml-common-0.6.3-39.el7.noarch
util-linux-2.23.2-43.el7.ppc64le
libtdb-1.3.12-2.el7.ppc64le
rpm-devel-4.11.3-25.el7.ppc64le
gobject-introspection-1.50.0-1.el7.ppc64le
qdox-1.12.1-10.el7.noarch
libteam-1.25-5.el7.ppc64le
openssh-clients-7.4p1-11.el7.ppc64le
libattr-2.4.46-12.el7.ppc64le
python-meh-0.25.2-1.el7.noarch
avahi-glib-0.6.31-17.el7.ppc64le
rhino-1.7R5-1.el7.noarch
perl-Pod-Checker-1.60-2.el7.noarch
rarian-0.8.1-11.el7.ppc64le
gmp-6.0.0-15.el7.ppc64le
createrepo-0.9.9-28.el7.noarch
python-gobject-base-3.22.0-1.el7.ppc64le
telepathy-haze-0.8.0-1.el7.ppc64le
perl-Version-Requirements-0.101022-244.el7.noarch
tog-pegasus-2.14.1-5.el7.ppc64le
lua-5.1.4-15.el7.ppc64le
libburn-1.2.8-4.el7.ppc64le
openssl-1.0.2k-8.el7.ppc64le
dleyna-server-0.5.0-1.el7.ppc64le
perl-IO-HTML-1.00-2.el7.noarch
libsemanage-python-2.5-8.el7.ppc64le
libidn-1.28-4.el7.ppc64le
nss-devel-3.28.4-8.el7.ppc64le
net-snmp-libs-5.7.2-28.el7.ppc64le
paps-libs-0.6.8-28.el7.1.ppc64le
perl-DBIx-Simple-1.35-7.el7.noarch
lzo-minilzo-2.06-8.el7.ppc64le
libref_array-0.1.5-27.el7.ppc64le
libX11-1.6.5-1.el7.ppc64le
xdg-utils-1.1.0-0.17.20120809git.el7.noarch
harfbuzz-devel-1.3.2-1.el7.ppc64le
perl-CGI-3.63-4.el7.noarch
libini_config-1.3.0-27.el7.ppc64le
xmlrpc-c-1.32.5-1905.svn2451.el7.ppc64le
libXfixes-5.0.3-1.el7.ppc64le
glibmm24-2.50.0-1.el7.ppc64le
webkitgtk4-devel-2.14.7-2.el7.ppc64le
perl-Devel-Symdump-2.10-2.el7.noarch
libpipeline-1.2.3-3.el7.ppc64le
mpfr-3.1.1-4.el7.ppc64le
libXrandr-1.5.1-2.el7.ppc64le
cyrus-sasl-gssapi-2.1.26-21.el7.ppc64le
gtk2-devel-2.24.31-1.el7.ppc64le
perl-URI-1.60-9.el7.noarch
kpartx-0.4.9-111.el7.ppc64le
file-libs-5.11-33.el7.ppc64le
libXext-devel-1.3.3-3.el7.ppc64le
libSM-devel-1.2.2-2.el7.ppc64le
qt-devel-4.8.5-13.el7.ppc64le
perl-HTTP-Date-6.02-8.el7.noarch
dracut-033-502.el7.ppc64le
libtool-ltdl-2.4.2-22.el7_3.ppc64le
libcanberra-0.30-5.el7.ppc64le
python-enum34-1.0.4-1.el7.noarch
libxkbfile-devel-1.0.9-3.el7.ppc64le
perl-HTTP-Cookies-6.01-5.el7.noarch
polkit-0.112-12.el7_3.ppc64le
libtheora-1.1.1-8.el7.ppc64le
libXpm-3.5.12-1.el7.ppc64le
libevent-2.0.21-4.el7.ppc64le
ibus-gtk2-1.5.3-13.el7.ppc64le
kdelibs-common-4.14.8-6.el7_3.ppc64le
systemd-sysv-219-42.el7.ppc64le
diffutils-3.3-4.el7.ppc64le
libXv-1.0.11-1.el7.ppc64le
pam-1.1.8-18.el7.ppc64le
imsettings-gsettings-1.6.3-9.el7.ppc64le
perl-YAML-Tiny-1.51-6.el7.noarch
GConf2-3.2.6-8.el7.ppc64le
libtasn1-4.10-1.el7.ppc64le
libxkbfile-1.0.9-3.el7.ppc64le
gettext-libs-0.19.8.1-2.el7.ppc64le
kdelibs-ktexteditor-4.14.8-6.el7_3.ppc64le
perl-Env-1.04-2.el7.noarch
libpciaccess-0.13.4-3.el7_3.ppc64le
nss-softokn-3.28.3-6.el7.ppc64le
pango-1.40.4-1.el7.ppc64le
telepathy-logger-0.8.0-5.el7.ppc64le
nepomuk-core-4.10.5-5.el7.ppc64le
perl-Net-HTTP-6.06-2.el7.noarch
samba-common-4.6.2-8.el7.noarch
libsigc++20-2.10.0-1.el7.ppc64le
cogl-1.22.2-1.el7.ppc64le
pcre-devel-8.32-17.el7.ppc64le
kdenetwork-kopete-libs-4.10.5-8.el7_0.ppc64le
icoutils-0.31.3-1.el7_3.ppc64le
pyparted-3.9-13.el7.ppc64le
apr-util-1.5.2-6.el7.ppc64le
giflib-4.1.6-9.el7.ppc64le
expat-devel-2.1.0-10.el7_3.ppc64le
kdesdk-okteta-4.10.5-6.el7.ppc64le
papi-5.2.0-23.el7.ppc64le
abrt-python-2.1.11-48.el7.centos.ppc64le
lzo-2.06-8.el7.ppc64le
java-1.8.0-openjdk-1.8.0.131-11.b12.el7.ppc64le
libffi-devel-3.0.13-18.el7.ppc64le
kwin-libs-4.11.19-8.el7.ppc64le
xorg-x11-font-utils-7.5-20.el7.ppc64le
iscsi-initiator-utils-iscsiuio-6.2.0.874-4.el7.ppc64le
file-5.11-33.el7.ppc64le
libXft-devel-2.3.2-2.el7.ppc64le
libipa_hbac-1.15.2-50.el7.ppc64le
kwin-gles-libs-4.11.19-8.el7.ppc64le
libsamplerate-0.1.8-6.el7.ppc64le
cronie-1.4.11-17.el7.ppc64le
xml-common-0.6.3-39.el7.noarch
ghostscript-9.07-28.el7.ppc64le
libpinyin-data-0.9.93-4.el7.ppc64le
kde-runtime-libs-4.10.5-8.el7.ppc64le
ipset-6.29-1.el7.ppc64le
plymouth-0.8.9-0.28.20140113.el7.centos.ppc64le
taglib-1.8-7.20130218git.el7.ppc64le
at-spi2-core-2.22.0-1.el7.ppc64le
xfsprogs-4.5.0-12.el7.ppc64le
kdepim-runtime-4.10.5-3.el7.ppc64le
libusbmuxd-1.0.10-5.el7.ppc64le
libstoragemgmt-python-1.4.0-3.el7.noarch
libseccomp-2.3.1-3.el7.ppc64le
gstreamer1-plugins-good-1.10.4-2.el7.ppc64le
pyusb-1.0.0-0.11.b1.el7.noarch
nepomuk-core-devel-4.10.5-5.el7.ppc64le
libofa-0.9.3-24.el7.ppc64le
device-mapper-event-1.02.140-8.el7.ppc64le
librtas-2.0.1-1.el7.ppc64le
libXcomposite-devel-0.4.4-4.1.el7.ppc64le
audit-libs-python-2.7.6-3.el7.ppc64le
okular-libs-4.10.5-4.el7.ppc64le
gdisk-0.8.6-5.el7.ppc64le
libibumad-13-7.el7.ppc64le
libsndfile-1.0.25-10.el7.ppc64le
libXxf86misc-1.0.3-7.1.el7.ppc64le
pyparsing-1.5.6-9.el7.noarch
kdesdk-kmtrace-libs-4.10.5-6.el7.ppc64le
attr-2.4.46-12.el7.ppc64le
rpcbind-0.2.0-42.el7.ppc64le
slang-2.2.4-11.el7.ppc64le
gtk2-2.24.31-1.el7.ppc64le
libssh2-1.4.3-10.el7_2.1.ppc64le
kdesdk-kompare-4.10.5-6.el7.ppc64le
openssl-devel-1.0.2k-8.el7.ppc64le
bluez-5.44-2.el7.ppc64le
boost-thread-1.53.0-27.el7.ppc64le
clutter-gtk-1.8.2-1.el7.ppc64le
soundtouch-1.4.0-9.el7.ppc64le
ibus-table-1.5.0-5.el7.noarch
setools-libs-3.3.8-1.1.el7.ppc64le
ppp-2.4.5-33.el7.ppc64le
libvpd-2.2.5-1.el7.ppc64le
clutter-gst3-3.0.22-1.el7.ppc64le
boost-test-1.53.0-27.el7.ppc64le
libgphoto2-2.5.2-5.el7.ppc64le
libcurl-7.29.0-42.el7.ppc64le
libmtp-1.1.6-5.el7.ppc64le
unzip-6.0-16.el7.ppc64le
vte291-0.46.2-1.el7.ppc64le
boost-random-1.53.0-27.el7.ppc64le
hplip-libs-3.15.9-3.el7.ppc64le
openldap-2.4.44-5.el7.ppc64le
rsync-3.0.9-18.el7.ppc64le
psmisc-22.20-15.el7.ppc64le
compat-cheese314-3.14.2-1.el7.ppc64le
dosfstools-3.0.20-9.el7.ppc64le
sane-backends-drivers-cameras-1.0.24-9.el7.ppc64le
kde-filesystem-4-47.el7.ppc64le
cryptsetup-1.7.4-3.el7.ppc64le
boost-program-options-1.53.0-27.el7.ppc64le
libgnomekbd-3.22.0.1-1.el7.ppc64le
libsrtp-1.4.4-10.20101004cvs.el7.ppc64le
speech-dispatcher-python-0.7.1-15.el7.ppc64le
raptor2-2.0.9-3.el7.ppc64le
grub2-tools-2.02-0.64.el7.centos.ppc64le
libiodbc-3.52.7-7.el7.ppc64le
gtk-vnc2-0.7.0-2.el7.ppc64le
libdv-1.0.0-17.el7.ppc64le
libXxf86dga-1.1.4-2.1.el7.ppc64le
python-deltarpm-3.6-3.el7.ppc64le
ibacm-13-7.el7.ppc64le
opus-1.0.2-6.el7.ppc64le
system-config-printer-libs-1.4.1-19.el7.noarch
libthai-0.1.14-9.el7.ppc64le
tracker-1.10.5-4.el7.ppc64le
shared-desktop-ontologies-devel-0.11.0-2.el7.noarch
qt-4.8.5-13.el7.ppc64le
pcre2-10.23-2.el7.ppc64le
gtkspell3-3.0.3-4.el7.ppc64le
libevdev-1.5.6-1.el7.ppc64le
totem-3.22.1-1.el7.ppc64le
virtuoso-opensource-6.1.6-6.el7.ppc64le
strigi-libs-0.7.7-12.20120626.el7.ppc64le
boost-wave-1.53.0-27.el7.ppc64le
libXmu-devel-1.1.2-2.el7.ppc64le
iproute-3.10.0-87.el7.ppc64le
firewalld-0.4.4.4-6.el7.noarch
color-filesystem-1-13.el7.noarch
automoc-1.0-0.20.rc3.el7.ppc64le
perl-Pod-Perldoc-3.20-4.el7.noarch
poppler-utils-0.26.5-16.el7.ppc64le
boost-1.53.0-27.el7.ppc64le
pcp-libs-3.11.8-7.el7.ppc64le
pykickstart-1.99.66.12-1.el7.noarch
openldap-devel-2.4.44-5.el7.ppc64le
perl-Encode-2.51-7.el7.ppc64le
python-gobject-3.22.0-1.el7.ppc64le
krb5-workstation-1.15.1-8.el7.ppc64le
libwacom-0.24-1.el7.ppc64le
isomd5sum-1.0.10-5.el7.ppc64le
abrt-addon-vmcore-2.1.11-48.el7.centos.ppc64le
perl-constant-1.27-2.el7.noarch
compat-libcogl12-1.14.0-3.el7.ppc64le
python-libipa_hbac-1.15.2-50.el7.ppc64le
gdm-3.22.3-11.el7.ppc64le
gstreamer1-devel-1.10.4-2.el7.ppc64le
abrt-retrace-client-2.1.11-48.el7.centos.ppc64le
perl-Exporter-5.68-3.el7.noarch
libXpm-devel-3.5.12-1.el7.ppc64le
python2-pyasn1-modules-0.1.9-7.el7.noarch
gnome-shell-extension-alternate-tab-3.22.2-10.el7.noarch
ttmkfdir-3.0.9-42.el7.ppc64le
samba-libs-4.6.2-8.el7.ppc64le
perl-File-Temp-0.23.01-3.el7.noarch
brltty-4.5-15.el7.ppc64le
sos-3.4-6.el7.centos.noarch
gnome-shell-extension-window-list-3.22.2-10.el7.noarch
clucene-core-2.3.3.4-11.el7.ppc64le
osinfo-db-20170423-2.el7.noarch
perl-macros-5.16.3-292.el7.ppc64le
python-brlapi-0.6.0-15.el7.ppc64le
libselinux-devel-2.5-11.el7.ppc64le
quota-nls-4.01-14.el7.noarch
elfutils-libs-0.168-8.el7.ppc64le
oddjob-mkhomedir-0.31.5-4.el7.ppc64le
perl-5.16.3-292.el7.ppc64le
opal-3.10.10-4.el7.ppc64le
gstreamer-tools-0.10.36-7.el7.ppc64le
libvirt-daemon-driver-storage-scsi-3.2.0-14.el7.ppc64le
satyr-0.13-14.el7.ppc64le
polkit-docs-0.112-12.el7_3.noarch
perl-Compress-Raw-Zlib-2.061-4.el7.ppc64le
compat-libcogl-pango12-1.14.0-3.el7.ppc64le
alsa-lib-devel-1.1.3-3.el7.ppc64le
libvirt-daemon-driver-storage-mpath-3.2.0-14.el7.ppc64le
NetworkManager-libnm-1.8.0-9.el7.ppc64le
tcsh-6.18.01-15.el7.ppc64le
perl-XML-Dumper-0.81-17.el7.noarch
libpfm-devel-4.7.0-4.el7.ppc64le
unixODBC-devel-2.3.1-11.el7.ppc64le
rcs-5.9.0-5.el7.ppc64le
ltrace-0.7.91-14.el7.ppc64le
ed-1.9-4.el7.ppc64le
wqy-zenhei-fonts-0.9.46-11.el7.noarch
lohit-bengali-fonts-2.5.3-4.el7.noarch
paratype-pt-sans-fonts-20101909-3.el7.noarch
paktype-naskh-basic-fonts-4.1-3.el7.noarch
lklug-fonts-0.6-10.20090803cvs.el7.noarch
lohit-kannada-fonts-2.5.3-3.el7.noarch
cjkuni-uming-fonts-0.2.20080216.1-53.el7.noarch
vlgothic-fonts-20130607-2.el7.noarch
lohit-telugu-fonts-2.5.3-3.el7.noarch
gnu-free-serif-fonts-20120503-8.el7.noarch
jomolhari-fonts-0.003-17.el7.noarch
scl-utils-20130529-17.el7_1.ppc64le
diffstat-1.57-4.el7.ppc64le
xorg-x11-drivers-7.7-6.el7.ppc64le
setserial-2.17-33.el7.ppc64le
vinagre-3.22.0-8.el7.ppc64le
man-pages-overrides-7.4.3-1.el7.ppc64le
gedit-3.22.0-3.el7.ppc64le
iwl5150-firmware-8.24.2.2-56.el7.noarch
gnome-contacts-3.22.1-1.el7.ppc64le
words-3.0-22.el7.noarch
setroubleshoot-3.2.28-3.el7.ppc64le
iwl7265-firmware-22.0.7.0-56.el7.noarch
gnome-system-monitor-3.22.2-2.el7.ppc64le
man-pages-3.53-5.el7.noarch
librsvg2-devel-2.40.16-1.el7.ppc64le
gpg-pubkey-f4a80eb5-53a7ff4b
system-config-printer-udev-1.4.1-19.el7.ppc64le
gnome-calculator-3.22.3-1.el7.ppc64le
gvfs-afp-1.30.4-3.el7.ppc64le
latencytop-0.5-13.el7.ppc64le
gtk3-immodule-xim-3.22.10-4.el7.ppc64le
mousetweaks-3.12.0-1.el7.ppc64le
qt3-MySQL-3.3.8b-51.el7.ppc64le
xvattr-1.3-27.el7.ppc64le
yum-langpacks-0.4.2-7.el7.noarch
rpm-build-4.11.3-25.el7.ppc64le
virt-install-1.4.1-7.el7.noarch
samba-client-4.6.2-8.el7.ppc64le
qt-odbc-4.8.5-13.el7.ppc64le
NetworkManager-tui-1.8.0-9.el7.ppc64le
avahi-0.6.31-17.el7.ppc64le
httpd-manual-2.4.6-67.el7.centos.noarch
PackageKit-gstreamer-plugin-1.1.5-1.el7.centos.ppc64le
tuned-2.8.0-5.el7.noarch
qemu-guest-agent-2.8.0-2.el7.ppc64le
smartmontools-6.2-8.el7.ppc64le
openssh-server-7.4p1-11.el7.ppc64le
dracut-config-rescue-033-502.el7.ppc64le
openlmi-providers-devel-0.5.0-4.el7.ppc64le
oprofile-0.9.9-22.el7.ppc64le
gcc-c++-4.8.5-16.el7.ppc64le
perl-homedir-1.008010-4.el7.noarch
libgudev1-devel-219-42.el7.ppc64le
sudo-1.8.19p2-10.el7.ppc64le
libacl-devel-2.2.51-12.el7.ppc64le
perl-XML-Twig-3.44-2.el7.noarch
crash-trace-command-2.0-12.el7.ppc64le
crash-gcore-command-1.3.1-0.el7.ppc64le
libgnome-keyring-devel-3.12.0-1.el7.ppc64le
binutils-devel-2.25.1-31.base.el7.ppc64le
libcap-ng-devel-0.7.5-4.el7.ppc64le
bash-completion-2.1-6.el7.noarch
dstat-0.7.2-12.el7.noarch
wget-1.14-15.el7.ppc64le
gpg-pubkey-352c64e5-52ae6884
certmonger-0.78.4-3.el7.ppc64le
libatomic-static-4.8.5-16.el7.ppc64le
libicu-devel-50.1.2-15.el7.ppc64le
caribou-0.4.21-1.el7.ppc64le
grub2-common-2.02-0.64.el7.centos.noarch
plymouth-graphics-libs-0.8.9-0.28.20140113.el7.centos.ppc64le
kernel-3.10.0-693.el7.ppc64le
perl-Perl-OSType-1.003-3.el7.noarch
libvirt-daemon-3.2.0-14.el7.ppc64le
ledmon-0.80-2.el7.ppc64le
gupnp-av-0.12.10-1.el7.ppc64le
cups-1.6.3-29.el7.ppc64le
mozilla-filesystem-1.9-11.el7.ppc64le
libqmi-utils-1.16.0-1.el7.ppc64le
anaconda-core-21.48.22.121-1.el7.centos.ppc64le
perl-JSON-PP-2.27202-2.el7.noarch
libvirt-client-3.2.0-14.el7.ppc64le
numactl-devel-2.0.9-6.el7_2.ppc64le
cups-client-1.6.3-29.el7.ppc64le
mutter-3.22.3-11.el7.ppc64le
ipa-common-4.5.0-20.el7.centos.noarch
glibc-devel-2.17-196.el7.ppc64le
firefox-52.2.0-2.el7.centos.ppc64le
perl-Params-Check-0.38-2.el7.noarch
virt-manager-common-1.4.1-7.el7.noarch
indent-2.2.11-13.el7.ppc64le
python-linux-procfs-0.4.9-3.el7.noarch
gnome-session-3.22.3-4.el7.ppc64le
adwaita-cursor-theme-3.22.0-1.el7.noarch
perl-Archive-Extract-0.68-3.el7.noarch
gnome-initial-setup-3.22.1-4.el7.ppc64le
perl-IO-Compress-2.061-2.el7.noarch
geoclue2-2.4.5-1.el7.ppc64le
khmeros-base-fonts-5.0-17.el7.noarch
python-tempita-0.5.1-6.el7.noarch
gnome-online-accounts-3.22.5-1.el7.ppc64le
nhn-nanum-fonts-common-3.020-9.el7.noarch
gobject-introspection-devel-1.50.0-1.el7.ppc64le
rhythmbox-3.4.1-1.el7.ppc64le
libavc1394-0.5.3-14.el7.ppc64le
telepathy-gabble-0.18.1-4.el7.ppc64le
stix-fonts-1.1.0-5.el7.noarch
python-javapackages-3.4.1-11.el7.noarch
gnome-packagekit-installer-3.22.1-2.el7.ppc64le
mesa-filesystem-17.0.1-6.20170307.el7.ppc64le
konkretcmpi-python-0.9.1-5.el7.ppc64le
libsane-hpaio-3.15.9-3.el7.ppc64le
copy-jdk-configs-2.2-3.el7.noarch
usb_modeswitch-2.4.0-5.el7.ppc64le
nhn-nanum-gothic-fonts-3.020-9.el7.noarch
pytz-2016.10-2.el7.noarch
librsvg2-tools-2.40.16-1.el7.ppc64le
bash-4.2.46-28.el7.ppc64le
libreport-plugin-bugzilla-2.1.11-38.el7.centos.ppc64le
kde-workspace-devel-4.11.19-8.el7.ppc64le
libdb-devel-5.3.21-20.el7.ppc64le
fxload-2002_04_11-16.el7.ppc64le
google-crosextra-caladea-fonts-1.002-0.4.20130214.el7.noarch
python-pycparser-2.14-1.el7.noarch
libtimezonemap-0.4.4-1.el7.ppc64le
libcom_err-1.42.9-10.el7.ppc64le
frei0r-plugins-1.3-13.el7.ppc64le
ibus-m17n-1.3.4-13.el7.ppc64le
libcdio-paranoia-10.2+0.90-11.el7.ppc64le
netcf-libs-0.2.8-4.el7.ppc64le
lohit-punjabi-fonts-2.5.3-2.el7.noarch
cmpi-bindings-pywbem-0.9.5-6.el7.ppc64le
at-spi2-core-devel-2.22.0-1.el7.ppc64le
xz-libs-5.2.2-1.el7.ppc64le
libasyncns-0.8-7.el7.ppc64le
libcanberra-devel-0.30-5.el7.ppc64le
coreutils-8.22-18.el7.ppc64le
sssd-ad-1.15.2-50.el7.ppc64le
doxygen-1.8.5-3.el7.ppc64le
httpd-tools-2.4.6-67.el7.centos.ppc64le
libspectre-0.2.8-1.el7.ppc64le
cyrus-sasl-lib-2.1.26-21.el7.ppc64le
rubygem-bigdecimal-1.2.0-30.el7.ppc64le
icedtea-web-1.6.2-4.el7.ppc64le
libarchive-3.1.2-10.el7_2.ppc64le
python-pyblock-0.53-6.el7.ppc64le
byacc-1.9.20130304-3.el7.ppc64le
wodim-1.1.11-23.el7.ppc64le
xorg-x11-drv-qxl-0.1.5-3.el7.ppc64le
elfutils-libelf-0.168-8.el7.ppc64le
rubygem-thor-0.19.1-1.el7.noarch
file-roller-nautilus-3.22.3-1.el7.ppc64le
pkgconfig-0.27.1-4.el7.ppc64le
setroubleshoot-server-3.2.28-3.el7.ppc64le
iwl2030-firmware-18.168.6.1-56.el7.noarch
mailx-12.5-16.el7.ppc64le
xorg-x11-drv-fbdev-0.4.3-25.el7.ppc64le
libtevent-0.9.31-1.el7.ppc64le
policycoreutils-2.5-17.1.el7.ppc64le
java-1.7.0-openjdk-devel-1.7.0.141-2.6.10.5.el7.ppc64le
gsettings-desktop-schemas-3.22.0-1.el7.ppc64le
yum-3.4.3-154.el7.centos.noarch
iwl6000g2a-firmware-17.168.5.3-56.el7.noarch
perl-B-Lint-1.17-3.el7.noarch
gstreamer-plugins-bad-free-0.10.23-23.el7.ppc64le
libvorbis-1.3.3-8.el7.ppc64le
rarian-compat-0.8.1-11.el7.ppc64le
abrt-desktop-2.1.11-48.el7.centos.ppc64le
desktop-file-utils-0.23-1.el7.ppc64le
libiptcdata-1.0.4-11.el7.ppc64le
gpg-pubkey-f533f4fa-56585169
perl-DB_File-1.830-6.el7.ppc64le
compat-poppler022-qt-0.22.5-4.el7.ppc64le
libldb-1.1.29-1.el7.ppc64le
http-parser-2.7.1-1.el7.ppc64le
NetworkManager-libreswan-gnome-1.2.4-2.el7.ppc64le
centos-logos-70.0.6-3.el7.centos.noarch
libX11-common-1.6.5-1.el7.noarch
perl-FCGI-0.74-8.el7.ppc64le
pango-devel-1.40.4-1.el7.ppc64le
libbasicobjects-0.1.1-27.el7.ppc64le
libgfortran-4.8.5-16.el7.ppc64le
gtk2-immodule-xim-2.24.31-1.el7.ppc64le
libgnome-keyring-3.12.0-1.el7.ppc64le
libXrender-0.9.10-1.el7.ppc64le
perl-Business-ISBN-2.06-2.el7.noarch
freeglut-2.8.1-3.el7.ppc64le
libgomp-4.8.5-16.el7.ppc64le
device-mapper-1.02.140-8.el7.ppc64le
xdg-desktop-portal-gtk-0.5-1.el7.ppc64le
libudisks2-2.1.2-6.el7.ppc64le
pulseaudio-libs-10.0-3.el7.ppc64le
perl-HTTP-Daemon-6.01-5.el7.noarch
xorg-x11-xauth-1.0.9-1.el7.ppc64le
nettle-2.7.1-8.el7.ppc64le
polkit-pkla-compat-0.1-4.el7.ppc64le
startup-notification-devel-0.12-8.el7.ppc64le
genisoimage-1.1.11-23.el7.ppc64le
dbus-x11-1.6.12-17.el7.ppc64le
perl-Text-Soundex-3.04-4.el7.ppc64le
xdg-user-dirs-0.15-4.el7.ppc64le
jansson-2.10-1.el7.ppc64le
NetworkManager-glib-1.8.0-9.el7.ppc64le
rpm-sign-4.11.3-25.el7.ppc64le
gettext-0.19.8.1-2.el7.ppc64le
cairo-1.14.8-2.el7.ppc64le
perl-IO-Socket-SSL-1.94-6.el7.noarch
kdepimlibs-kxmlrpcclient-4.10.5-4.el7.ppc64le
libplist-1.12-3.el7.ppc64le
libwbclient-4.6.2-8.el7.ppc64le
cgdcbxd-1.0.2-7.el7.ppc64le
glib2-devel-2.50.3-3.el7.ppc64le
gdk-pixbuf2-devel-2.36.5-1.el7.ppc64le
theora-tools-1.1.1-8.el7.ppc64le
libkipi-4.10.5-3.el7.ppc64le
libmng-1.0.10-14.el7.ppc64le
abrt-addon-kerneloops-2.1.11-48.el7.centos.ppc64le
grub2-2.02-0.64.el7.centos.ppc64le
xz-devel-5.2.2-1.el7.ppc64le
xorg-x11-xkb-utils-7.7-12.el7.ppc64le
libverto-tevent-0.2.5-4.el7.ppc64le
libkdcraw-devel-4.10.5-4.el7.ppc64le
bzip2-1.0.6-13.el7.ppc64le
iputils-20160308-10.el7.ppc64le
cifs-utils-6.2-10.el7.ppc64le
libpinyin-0.9.93-4.el7.ppc64le
libao-1.1.0-8.el7.ppc64le
gdbm-devel-1.10-8.el7.ppc64le
kdepim-libs-4.10.5-6.el7.ppc64le
libxshmfence-1.2-1.el7.ppc64le
libstoragemgmt-1.4.0-3.el7.ppc64le
psacct-6.6.1-13.el7.ppc64le
pyliblzma-0.5.3-11.el7.ppc64le
libXcursor-devel-1.1.14-8.el7.ppc64le
hesiod-3.2.1-3.el7.ppc64le
okular-devel-4.10.5-4.el7.ppc64le
gsm-1.0.13-11.el7.ppc64le
telepathy-mission-control-5.16.3-3.el7.ppc64le
rng-tools-5-11.el7.ppc64le
python-chardet-2.2.1-1.el7_1.noarch
libcanberra-gtk3-0.30-5.el7.ppc64le
krb5-devel-1.15.1-8.el7.ppc64le
kdesdk-kompare-devel-4.10.5-6.el7.ppc64le
unixODBC-2.3.1-11.el7.ppc64le
dbus-devel-1.6.12-17.el7.ppc64le
kpatch-0.4.0-1.el7.noarch
graphite2-1.3.6-1.el7_2.ppc64le
nautilus-extensions-3.22.3-3.el7.ppc64le
libdb-utils-5.3.21-20.el7.ppc64le
sane-backends-libs-1.0.24-9.el7.ppc64le
zip-3.0-11.el7.ppc64le
mdadm-4.0-5.el7.ppc64le
memstomp-0.1.4-11.el7.ppc64le
libconfig-1.4.9-5.el7.ppc64le
clutter-gst2-2.0.18-1.el7.ppc64le
postgresql-libs-9.2.21-1.el7.ppc64le
gsound-1.0.2-2.el7.ppc64le
ilmbase-1.0.3-7.el7.ppc64le
udisks2-2.1.2-6.el7.ppc64le
perl-core-5.16.3-292.el7.ppc64le
pcsc-lite-libs-1.8.8-6.el7.ppc64le
gvnc-0.7.0-2.el7.ppc64le
qemu-img-1.5.3-141.el7.ppc64le
libappstream-glib-0.6.10-1.el7.ppc64le
sg3_utils-libs-1.37-12.el7.ppc64le
librdmacm-13-7.el7.ppc64le
adcli-0.8.1-3.el7.ppc64le
libnfnetlink-1.0.1-4.el7.ppc64le
colord-gtk-0.1.25-4.el7.ppc64le
libuser-python-0.60-7.el7_1.ppc64le
libfprint-0.5.0-4.el7.ppc64le
OpenEXR-libs-1.7.1-7.el7.ppc64le
attica-devel-0.4.2-1.el7.ppc64le
papi-devel-5.2.0-23.el7.ppc64le
m17n-lib-1.6.4-14.el7.ppc64le
qimageblitz-0.0.6-7.el7.ppc64le
python-urlgrabber-3.10-8.el7.noarch
pcp-selinux-3.11.8-7.el7.ppc64le
perl-Text-ParseWords-3.29-4.el7.noarch
apr-util-devel-1.5.2-6.el7.ppc64le
readline-devel-6.2-10.el7.ppc64le
python-kitchen-1.1.1-5.el7.noarch
gnome-abrt-0.3.4-8.el7.ppc64le
check-devel-0.9.9-5.el7.ppc64le
pulseaudio-gdm-hooks-10.0-3.el7.ppc64le
perl-Scalar-List-Utils-1.27-248.el7.ppc64le
abrt-addon-ccpp-2.1.11-48.el7.centos.ppc64le
gnome-icon-theme-extras-3.12.0-1.el7.noarch
python-slip-0.4.0-2.el7.noarch
brlapi-0.6.0-15.el7.ppc64le
qpdf-libs-5.0.1-3.el7.ppc64le
yelp-xsl-3.20.1-1.el7.noarch
perl-Storable-2.45-3.el7.ppc64le
libosinfo-1.0.0-1.el7.ppc64le
libcap-devel-2.22-9.el7.ppc64le
libepoxy-devel-1.3.1-1.el7.ppc64le
festival-1.96-28.el7.ppc64le
libusbx-1.0.20-1.el7.ppc64le
libvirt-daemon-driver-storage-disk-3.2.0-14.el7.ppc64le
perl-Test-Harness-3.28-3.el7.noarch
polkit-devel-0.112-12.el7_3.ppc64le
perl-Crypt-SSLeay-0.64-5.el7.ppc64le
libverto-devel-0.2.5-4.el7.ppc64le
caribou-gtk2-module-0.4.21-1.el7.ppc64le
vim-filesystem-7.4.160-2.el7.ppc64le
procps-ng-3.3.10-16.el7.ppc64le
NetworkManager-libreswan-1.2.4-2.el7.ppc64le
perl-Module-Metadata-1.000018-2.el7.noarch
pixman-devel-0.34.0-1.el7.ppc64le
patchutils-0.3.3-4.el7.ppc64le
filesystem-3.2-21.el7.ppc64le
cups-filesystem-1.6.3-29.el7.noarch
gettext-devel-0.19.8.1-2.el7.ppc64le
usbredir-0.7.1-2.el7.ppc64le
neon-0.30.0-3.el7.ppc64le
perl-LWP-MediaTypes-6.02-2.el7.noarch
python-qrcode-core-5.0.1-1.el7.noarch
hyphen-en-2.8.6-5.el7.noarch
gnu-free-fonts-common-20120503-8.el7.noarch
gtkmm30-3.22.0-1.el7.ppc64le
initial-setup-gui-0.3.9.40-1.el7.centos.ppc64le
libhugetlbfs-2.16-12.el7.ppc64le
subversion-libs-1.7.14-10.el7.ppc64le
perl-Encode-Locale-1.03-5.el7.noarch
python-inotify-0.9.4-4.el7.noarch
nano-2.3.1-10.el7.ppc64le
mobile-broadband-provider-info-1.20170310-1.el7.noarch
adwaita-gtk2-theme-3.22.2-1.el7.ppc64le
ipa-client-4.5.0-20.el7.centos.ppc64le
perl-IPC-Cmd-0.80-4.el7.noarch
libsoup-2.56.0-3.el7.ppc64le
perl-Term-UI-0.36-2.el7.noarch
python-setuptools-0.9.8-7.el7.noarch
dejavu-sans-mono-fonts-2.33-6.el7.noarch
bind-license-9.9.4-50.el7.noarch
webkitgtk4-jsc-2.14.7-2.el7.ppc64le
firewall-config-0.4.4.4-6.el7.noarch
perl-CPAN-1.9800-292.el7.noarch
gupnp-1.0.1-1.el7.ppc64le
boost-graph-1.53.0-27.el7.ppc64le
python-perf-3.10.0-693.el7.ppc64le
overpass-fonts-2.1-1.el7.noarch
thai-scalable-fonts-common-0.5.0-7.el7.noarch
webkitgtk4-jsc-devel-2.14.7-2.el7.ppc64le
pulseaudio-module-x11-10.0-3.el7.ppc64le
marisa-0.2.4-4.el7.ppc64le
gnutls-c++-3.3.26-9.el7.ppc64le
ca-certificates-2017.2.14-71.el7.noarch
python-idna-2.4-1.el7.noarch
strace-4.12-4.el7.ppc64le
nss-softokn-freebl-3.28.3-6.el7.ppc64le
vino-3.22.0-3.el7.ppc64le
libXaw-devel-1.0.13-4.el7.ppc64le
libreport-centos-2.1.11-38.el7.centos.ppc64le
alsa-utils-1.1.3-2.el7.ppc64le
libnl3-cli-3.2.28-4.el7.ppc64le
python-iniparse-0.4-9.el7.noarch
traceroute-2.0.22-2.el7.ppc64le
libselinux-2.5-11.el7.ppc64le
keybinder3-0.3.0-1.el7.ppc64le
kdepim-devel-4.10.5-6.el7.ppc64le
pakchois-0.4-10.el7.ppc64le
cryptsetup-python-1.7.4-3.el7.ppc64le
libjpeg-turbo-devel-1.2.90-5.el7.ppc64le
python-jwcrypto-0.2.1-1.el7.noarch
lohit-malayalam-fonts-2.5.3-2.el7.noarch
libpng-1.5.13-7.el7_2.ppc64le
freerdp-plugins-1.0.2-10.el7.ppc64le
ibus-chewing-1.4.4-14.el7.ppc64le
libfastjson-0.99.4-2.el7.ppc64le
libsss_sudo-1.15.2-50.el7.ppc64le
redhat-menus-12.0.2-8.el7.noarch
bind-libs-9.9.4-50.el7.ppc64le
gnu-free-sans-fonts-20120503-8.el7.noarch
libuuid-2.23.2-43.el7.ppc64le
festival-freebsoft-utils-0.10-7.el7.noarch
unique3-devel-3.0.2-8.el7.ppc64le
compat-poppler022-0.22.5-4.el7.ppc64le
sssd-proxy-1.15.2-50.el7.ppc64le
python-2.7.5-58.el7.ppc64le
libwvstreams-4.6.1-11.el7.ppc64le
lrzsz-0.12.20-36.el7.ppc64le
sqlite-3.7.17-8.el7.ppc64le
xorg-x11-server-common-1.19.3-11.el7.ppc64le
sushi-3.21.91-1.el7.ppc64le
rubygem-psych-2.0.0-30.el7.ppc64le
gnupg2-2.0.22-4.el7.ppc64le
libmount-2.23.2-43.el7.ppc64le
nss-3.28.4-8.el7.ppc64le
iwl3160-firmware-22.0.7.0-56.el7.noarch
libnl3-3.2.28-4.el7.ppc64le
xorg-x11-drv-ati-7.7.1-3.20160928git3fc839ff.el7.ppc64le
evolution-mapi-3.22.6-1.el7.ppc64le
libservicelog-1.1.17-2.el7.ppc64le
perl-PAR-Dist-0.49-2.el7.noarch
dbus-glib-0.100-7.el7.ppc64le
docbook-style-xsl-1.78.1-3.el7.noarch
iwl100-firmware-39.31.5.1-56.el7.noarch
libxslt-1.1.28-5.el7.ppc64le
junit-4.11-8.el7.noarch
gnome-session-xsession-3.22.3-4.el7.ppc64le
selinux-policy-3.13.1-166.el7.noarch
PackageKit-1.1.5-1.el7.centos.ppc64le
zlib-devel-1.2.7-17.el7.ppc64le
perl-libxml-perl-0.08-19.el7.noarch
iwl4965-firmware-228.61.2.24-56.el7.noarch
p11-kit-0.23.5-3.el7.ppc64le
spice-gtk3-0.33-6.el7.ppc64le
pygobject3-devel-3.22.0-1.el7.ppc64le
systemtap-runtime-3.1-3.el7.ppc64le
nss-softokn-freebl-devel-3.28.3-6.el7.ppc64le
libgee-0.18.1-1.el7.ppc64le
perl-PlRPC-0.2020-14.el7.noarch
python34-libs-3.4.5-4.el7.ppc64le
json-c-0.11-4.el7_0.ppc64le
plymouth-plugin-two-step-0.8.9-0.28.20140113.el7.centos.ppc64le
gnome-font-viewer-3.22.0-1.el7.ppc64le
sssd-client-1.15.2-50.el7.ppc64le
libXext-1.3.3-3.el7.ppc64le
nspr-devel-4.13.1-1.0.el7_3.ppc64le
perl-Algorithm-Diff-1.1902-17.el7.noarch
tcp_wrappers-libs-7.6-77.el7.ppc64le
libgdata-devel-0.17.8-1.el7.ppc64le
gnome-screenshot-3.22.0-1.el7.ppc64le
mtdev-1.1.5-5.el7.ppc64le
mesa-libEGL-17.0.1-6.20170307.el7.ppc64le
libpng-devel-1.5.13-7.el7_2.ppc64le
perl-Digest-SHA1-2.13-9.el7.ppc64le
libdhash-0.4.3-27.el7.ppc64le
phonon-devel-4.6.0-10.el7.ppc64le
qt3-ODBC-3.3.8b-51.el7.ppc64le
systemd-219-42.el7.ppc64le
libXinerama-1.1.3-2.1.el7.ppc64le
gdb-7.6.1-100.el7.ppc64le
perl-File-Listing-6.04-7.el7.noarch
jasper-libs-1.900.1-31.el7.ppc64le
ibus-setup-1.5.3-13.el7.noarch
spice-vdagent-0.14.0-14.el7.ppc64le
PackageKit-glib-1.1.5-1.el7.centos.ppc64le
libXmu-1.1.2-2.el7.ppc64le
atkmm-2.24.2-1.el7.ppc64le
perl-Sys-Syslog-0.33-3.el7.ppc64le
libXdmcp-1.1.2-6.el7.ppc64le
kdelibs-devel-4.14.8-6.el7_3.ppc64le
targetcli-2.1.fb46-1.el7.noarch
libcgroup-0.41-13.el7.ppc64le
qt-x11-4.8.5-13.el7.ppc64le
libxcb-devel-1.12-1.el7.ppc64le
perl-HTML-Format-2.10-7.el7.noarch
libsss_idmap-1.15.2-50.el7.ppc64le
kactivities-4.10.5-3.el7.ppc64le
httpd-devel-2.4.6-67.el7.centos.ppc64le
abrt-2.1.11-48.el7.centos.ppc64le
java-1.7.0-openjdk-headless-1.7.0.141-2.6.10.5.el7.ppc64le
apr-devel-1.4.8-3.el7.ppc64le
cdparanoia-10.2-17.el7.ppc64le
libpcap-1.5.3-9.el7.ppc64le
libkworkspace-4.11.19-8.el7.ppc64le
dbus-glib-devel-0.100-7.el7.ppc64le
crontabs-1.11-6.20121102git.el7.noarch
libXi-devel-1.7.9-1.el7.ppc64le
gnome-menus-3.13.3-3.el7.ppc64le
libieee1284-devel-0.2.11-15.el7.ppc64le
kmod-libs-20-15.el7.ppc64le
kde-runtime-4.10.5-8.el7.ppc64le
mod_ssl-2.4.6-67.el7.centos.ppc64le
cyrus-sasl-2.1.26-21.el7.ppc64le
libXScrnSaver-1.2.2-6.1.el7.ppc64le
python-augeas-0.5.0-2.el7.noarch
LibRaw-0.14.8-5.el7.20120830git98d925.ppc64le
hyphen-2.8.6-5.el7.ppc64le
kdenetwork-krdc-libs-4.10.5-8.el7_0.ppc64le
opal-prd-5.5.0-1.el7.ppc64le
rdma-core-13-7.el7.ppc64le
pulseaudio-10.0-3.el7.ppc64le
python-sssdconfig-1.15.2-50.el7.noarch
libisofs-1.2.8-4.el7.ppc64le
libverto-0.2.5-4.el7.ppc64le
kdesdk-kmtrace-devel-4.10.5-6.el7.ppc64le
systemd-devel-219-42.el7.ppc64le
mesa-dri-drivers-17.0.1-6.20170307.el7.ppc64le
clutter-1.26.0-1.el7.ppc64le
fipscheck-1.4.1-6.el7.ppc64le
dwz-0.11-3.el7.ppc64le
boost-regex-1.53.0-27.el7.ppc64le
libXaw-1.0.13-4.el7.ppc64le
gcc-gfortran-4.8.5-16.el7.ppc64le
systemd-python-219-42.el7.ppc64le
zenity-3.22.0-1.el7.ppc64le
boost-atomic-1.53.0-27.el7.ppc64le
rpm-libs-4.11.3-25.el7.ppc64le
GeoIP-1.5.0-11.el7.ppc64le
libksane-devel-4.10.5-4.el7.ppc64le
rubygem-bundler-1.7.8-3.el7.noarch
git-1.8.3.1-11.el7.ppc64le
brasero-libs-3.12.1-2.el7.ppc64le
c-ares-1.10.0-3.el7.ppc64le
libnfsidmap-0.25-17.el7.ppc64le
cdparanoia-libs-10.2-17.el7.ppc64le
tk-8.5.13-6.el7.ppc64le
libhugetlbfs-devel-2.16-12.el7.ppc64le
NetworkManager-wifi-1.8.0-9.el7.ppc64le
libcanberra-gtk2-0.30-5.el7.ppc64le
hostname-3.13-3.el7.ppc64le
redland-1.0.16-6.el7.ppc64le
libdaemon-0.14-7.el7.ppc64le
brasero-3.12.1-2.el7.ppc64le
cups-devel-1.6.3-29.el7.ppc64le
qca2-2.0.3-7.el7.ppc64le
pangomm-2.40.1-1.el7.ppc64le
libnetfilter_conntrack-1.0.6-1.el7_3.ppc64le
sip-devel-4.14.6-4.el7.ppc64le
perl-parent-0.225-244.el7.noarch
libkkc-0.3.1-9.el7.ppc64le
crypto-utils-2.4.1-42.el7.ppc64le
lvm2-2.02.171-8.el7.ppc64le
poppler-glib-0.26.5-16.el7.ppc64le
crash-7.1.9-2.el7.ppc64le
libbluray-0.2.3-5.el7.ppc64le
perl-Filter-1.49-3.el7.ppc64le
control-center-3.22.2-5.el7.ppc64le
c-ares-devel-1.10.0-3.el7.ppc64le
sysstat-10.1.5-12.el7.ppc64le
mesa-libGL-devel-17.0.1-6.20170307.el7.ppc64le
python-pwquality-1.2.3-4.el7.ppc64le
liblouis-python-2.5.2-10.el7.noarch
perl-PathTools-3.40-5.el7.ppc64le
gnome-shell-extension-apps-menu-3.22.2-10.el7.noarch
hunspell-devel-1.3.2-15.el7.ppc64le
policycoreutils-python-2.5-17.1.el7.ppc64le
libwnck3-3.20.1-1.el7.ppc64le
gsettings-desktop-schemas-devel-3.22.0-1.el7.ppc64le
lsof-4.87-4.el7.ppc64le
perl-Getopt-Long-2.40-2.el7.noarch
nfs-utils-1.3.0-0.48.el7.ppc64le
mtr-0.85-7.el7.ppc64le
autofs-5.0.7-69.el7.ppc64le
cairo-devel-1.14.8-2.el7.ppc64le
xorg-x11-xbitmaps-1.1.1-6.el7.noarch
libreport-2.1.11-38.el7.centos.ppc64le
perl-XML-Parser-2.41-10.el7.ppc64le
libvirt-daemon-driver-storage-3.2.0-14.el7.ppc64le
python2-caribou-0.4.21-1.el7.noarch
fontpackages-filesystem-1.44-8.el7.noarch
perl-Test-Pod-1.48-3.el7.noarch
libuuid-devel-2.23.2-43.el7.ppc64le
perl-Package-Constants-0.02-292.el7.noarch
gnutls-3.3.26-9.el7.ppc64le
libreport-cli-2.1.11-38.el7.centos.ppc64le
gettext-common-devel-0.19.8.1-2.el7.noarch
cups-filters-1.0.35-22.el7.ppc64le
xkeyboard-config-2.20-1.el7.noarch
bison-3.0.4-1.el7.ppc64le
compat-libcolord1-1.0.4-1.el7.ppc64le
perl-Digest-MD5-2.52-3.el7.ppc64le
gnutls-dane-3.3.26-9.el7.ppc64le
libusbx-devel-1.0.20-1.el7.ppc64le
initial-setup-0.3.9.40-1.el7.centos.ppc64le
libchamplain-gtk-0.12.15-1.el7.ppc64le
libreport-filesystem-2.1.11-38.el7.centos.ppc64le
m17n-contrib-1.1.14-3.el7.noarch
newt-python-0.52.15-4.el7.ppc64le
perl-Locale-Maketext-1.23-3.el7.noarch
libvirt-daemon-driver-nodedev-3.2.0-14.el7.ppc64le
perl-ExtUtils-Install-1.58-292.el7.noarch
libvirt-3.2.0-14.el7.ppc64le
gnome-themes-standard-3.22.2-1.el7.ppc64le
gl-manpages-1.1-7.20130122.el7.noarch
lohit-gujarati-fonts-2.5.3-2.el7.noarch
python-backports-ssl_match_hostname-3.4.0.2-4.el7.noarch
perl-local-lib-1.008010-4.el7.noarch
rest-0.8.0-1.el7.ppc64le
perl-Module-Build-0.40.05-2.el7.noarch
ibus-kkc-1.5.18-7.el7.ppc64le
webkitgtk4-plugin-process-gtk2-2.14.7-2.el7.ppc64le
basesystem-10.0-7.el7.centos.noarch
madan-fonts-2.000-11.el7.noarch
python-beaker-1.5.4-10.el7.noarch
boost-locale-1.53.0-27.el7.ppc64le
dleyna-core-0.5.0-1.el7.ppc64le
liberation-sans-fonts-1.07.2-15.el7.noarch
tk-devel-8.5.13-6.el7.ppc64le
gnome-packagekit-updater-3.22.1-2.el7.ppc64le
cim-schema-2.33.0-6.el7.noarch
lohit-assamese-fonts-2.5.3-2.el7.noarch
tagsoup-1.2.1-8.el7.noarch
libshout-2.2.2-11.el7.ppc64le
ntpdate-4.2.6p5-25.el7.centos.2.ppc64le
libproxy-0.4.11-10.el7.ppc64le
gvfs-gphoto2-1.30.4-3.el7.ppc64le
gspell-1.2.3-1.el7.ppc64le
libstdc++-4.8.5-16.el7.ppc64le
sil-nuosu-fonts-2.1.1-5.el7.noarch
python-ntplib-0.3.2-1.el7.noarch
bc-1.06.95-13.el7.ppc64le
libvirt-daemon-driver-lxc-3.2.0-14.el7.ppc64le
libreport-anaconda-2.1.11-38.el7.centos.ppc64le
kdepimlibs-devel-4.10.5-4.el7.ppc64le
unique3-3.0.2-8.el7.ppc64le
freetype-2.4.11-15.el7.ppc64le
lohit-marathi-fonts-2.5.3-2.el7.noarch
python2-cryptography-1.7.2-1.el7.ppc64le
libss-1.42.9-10.el7.ppc64le
kernel-tools-libs-3.10.0-693.el7.ppc64le
libsysfs-2.1.0-16.el7.ppc64le
ibus-hangul-1.4.2-10.el7.ppc64le
freerdp-1.0.2-10.el7.ppc64le
popt-1.13-16.el7.ppc64le
open-sans-fonts-1.10-1.el7.noarch
bind-libs-lite-9.9.4-50.el7.ppc64le
lksctp-tools-1.0.17-2.el7.ppc64le
sssd-common-pac-1.15.2-50.el7.ppc64le
libtiff-4.0.3-27.el7_3.ppc64le
gnome-desktop3-devel-3.22.2-2.el7.ppc64le
cdrdao-1.2.3-20.el7.ppc64le
expat-2.1.0-10.el7_3.ppc64le
latrace-0.5.11-6.1.el7.ppc64le
perl-Net-SSLeay-1.55-6.el7.ppc64le
cups-libs-1.6.3-29.el7.ppc64le
dmraid-events-1.0.0.rc16-28.el7.ppc64le
rubygem-io-console-0.4.2-30.el7.ppc64le
gutenprint-cups-5.2.9-18.el7.ppc64le
xorg-x11-server-Xorg-1.19.3-11.el7.ppc64le
libtalloc-2.1.9-1.el7.ppc64le
iwl6000g2b-firmware-17.168.5.2-56.el7.noarch
nss-sysinit-3.28.4-8.el7.ppc64le
glib2-2.50.3-3.el7.ppc64le
rpm-python-4.11.3-25.el7.ppc64le
ustr-1.0.4-16.el7.ppc64le
gucharmap-3.18.2-1.el7.ppc64le
xorg-x11-drv-dummy-0.3.7-1.el7.ppc64le
libogg-1.3.0-7.el7.ppc64le
iwl6000-firmware-9.221.4.1-56.el7.noarch
docbook-dtds-1.0-60.el7.noarch
xorg-x11-proto-devel-7.7-20.el7.noarch
pygpgme-0.3-9.el7.ppc64le
openssh-7.4p1-11.el7.ppc64le
cheese-3.22.1-1.el7.ppc64le
jline-1.0-8.el7.noarch
libcap-2.22-9.el7.ppc64le
ivtv-firmware-20080701-26.el7.noarch
perl-Pod-LaTeX-0.61-2.el7.noarch
enchant-1.6.0-8.el7.ppc64le
python2-ipalib-4.5.0-20.el7.centos.noarch
tog-pegasus-libs-2.14.1-5.el7.ppc64le
firstboot-19.12-1.el7.ppc64le
gupnp-dlna-0.10.5-1.el7.ppc64le
which-2.20-7.el7.ppc64le
epel-release-7-9.noarch
perl-Net-Daemon-0.48-5.el7.noarch
libcroco-0.6.11-1.el7.ppc64le
liboauth-devel-0.9.7-4.el7.ppc64le
libhangul-0.1.0-8.el7.ppc64le
eog-3.20.5-2.el7.ppc64le
plymouth-theme-charge-0.8.9-0.28.20140113.el7.centos.ppc64le
libcollection-0.6.2-27.el7.ppc64le
perl-Locale-Codes-3.26-2.el7.noarch
pygobject2-2.28.6-11.el7.ppc64le
libXdamage-1.1.4-4.1.el7.ppc64le
libestr-0.1.9-2.el7.ppc64le
PackageKit-gtk3-module-1.1.5-1.el7.centos.ppc64le
libgweather-devel-3.20.4-1.el7.ppc64le
xz-5.2.2-1.el7.ppc64le
perl-WWW-RobotRules-6.02-5.el7.noarch
libICE-devel-1.0.9-9.el7.ppc64le
libXft-2.3.2-2.el7.ppc64le
cryptsetup-libs-1.7.4-3.el7.ppc64le
alsa-plugins-pulseaudio-1.1.1-1.el7.ppc64le
glx-utils-8.2.0-3.el7.ppc64le
speex-1.2-0.19.rc1.el7.ppc64le
perl-HTTP-Negotiate-6.01-5.el7.noarch
libtirpc-0.2.4-0.10.el7.ppc64le
pulseaudio-libs-glib2-10.0-3.el7.ppc64le
mesa-libgbm-17.0.1-6.20170307.el7.ppc64le
pulseaudio-libs-devel-10.0-3.el7.ppc64le
imsettings-1.6.3-9.el7.ppc64le
hunspell-en-US-0.20121024-6.el7.noarch
perl-IO-Socket-IP-0.21-4.el7.noarch
nss-util-devel-3.28.4-3.el7.ppc64le
libXxf86vm-1.1.4-1.el7.ppc64le
hwdata-0.252-8.6.el7.ppc64le
kernel-tools-3.10.0-693.el7.ppc64le
nepomuk-core-libs-4.10.5-5.el7.ppc64le
exiv2-libs-0.23-6.el7.ppc64le
perl-libwww-perl-6.05-2.el7.noarch
p11-kit-devel-0.23.5-3.el7.ppc64le
librsvg2-2.40.16-1.el7.ppc64le
libsmbclient-4.6.2-8.el7.ppc64le
abrt-console-notification-2.1.11-48.el7.centos.ppc64le
kdesdk-okteta-libs-4.10.5-6.el7.ppc64le
boost-chrono-1.53.0-27.el7.ppc64le
iw-4.3-1.el7.ppc64le
libcom_err-devel-1.42.9-10.el7.ppc64le
akonadi-1.9.2-4.el7.ppc64le
accountsservice-libs-0.6.45-2.el7.ppc64le
wvdial-1.61-9.el7.ppc64le
libkexiv2-devel-4.10.5-3.el7.ppc64le
libmpc-1.0.1-3.el7.ppc64le
lm_sensors-devel-3.4.0-4.20160601gitf9185e5.el7.ppc64le
meanwhile-1.1.0-12.el7.ppc64le
libXt-devel-1.1.5-3.el7.ppc64le
plymouth-scripts-0.8.9-0.28.20140113.el7.centos.ppc64le
mod_fcgid-2.3.9-4.el7.ppc64le
kdepim-runtime-libs-4.10.5-3.el7.ppc64le
mesa-libglapi-17.0.1-6.20170307.el7.ppc64le
hunspell-en-GB-0.20121024-6.el7.noarch
sip-4.14.6-4.el7.ppc64le
cairomm-1.12.0-1.el7.ppc64le
abrt-addon-xorg-2.1.11-48.el7.centos.ppc64le
ModemManager-1.6.0-2.el7.ppc64le
kdenetwork-krdc-devel-4.10.5-8.el7_0.ppc64le
libieee1284-0.2.11-15.el7.ppc64le
highlight-3.13-3.el7.ppc64le
pyOpenSSL-0.13.1-3.el7.ppc64le
gtk-update-icon-cache-3.22.10-4.el7.ppc64le
NetworkManager-1.8.0-9.el7.ppc64le
crda-3.13_2016.02.08-1.el7.ppc64le
kdesdk-kompare-libs-4.10.5-6.el7.ppc64le
newt-0.52.15-4.el7.ppc64le
xcb-util-0.4.0-2.el7.ppc64le
automake-1.13.4-3.el7.noarch
libgweather-3.20.4-1.el7.ppc64le
lockdev-1.0.4-0.13.20111007git.el7.ppc64le
man-db-2.6.3-9.el7.ppc64le
gd-2.0.35-26.el7.ppc64le
exempi-2.2.0-8.el7.ppc64le
curl-7.29.0-42.el7.ppc64le
snappy-1.1.0-3.el7.ppc64le
libreport-gtk-2.1.11-38.el7.centos.ppc64le
unbound-libs-1.4.20-34.el7.ppc64le
tcpdump-4.9.0-5.el7.ppc64le
sane-backends-drivers-scanners-1.0.24-9.el7.ppc64le
libedit-3.0-12.20121213cvs.el7.ppc64le
liboauth-0.9.7-4.el7.ppc64le
libmpcdec-1.2.6-12.el7.ppc64le
libnm-gtk-1.8.0-3.el7.ppc64le
grub2-tools-extra-2.02-0.64.el7.centos.ppc64le
libitm-devel-4.8.5-16.el7.ppc64le
libdmx-1.1.3-3.el7.ppc64le
wavpack-4.60.1-9.el7.ppc64le
rasqal-0.9.30-4.el7.ppc64le
autogen-libopts-5.18-5.el7.ppc64le
gnome-bluetooth-libs-3.20.1-1.el7.ppc64le
qt-settings-19-23.5.el7.centos.noarch
libxslt-devel-1.1.28-5.el7.ppc64le
grilo-plugins-0.3.4-1.el7.ppc64le
SDL-1.2.15-14.el7.ppc64le
sip-macros-4.14.6-4.el7.ppc64le
iptables-1.4.21-18.0.1.el7.centos.ppc64le
gstreamer-plugins-good-0.10.31-13.el7.ppc64le
qjson-0.8.1-4.el7.ppc64le
perl-Test-Pod-Coverage-1.08-21.el7.noarch
pcp-conf-3.11.8-7.el7.ppc64le
perl-podlators-2.5.1-3.el7.noarch
libcurl-devel-7.29.0-42.el7.ppc64le
graphite2-devel-1.3.6-1.el7_2.ppc64le
pygtk2-2.24.0-9.el7.ppc64le
kexec-tools-2.0.14-17.el7.ppc64le
iptables-devel-1.4.21-18.0.1.el7.centos.ppc64le
gnome-shell-3.22.3-17.el7.ppc64le
perl-Carp-1.26-244.el7.noarch
liblouis-2.5.2-10.el7.ppc64le
dvd+rw-tools-7.1-15.el7.ppc64le
ptlib-2.10.10-6.el7.ppc64le
samba-common-libs-4.6.2-8.el7.ppc64le
gvfs-devel-1.30.4-3.el7.ppc64le
gnome-shell-extension-launch-new-instance-3.22.2-10.el7.noarch
perl-libs-5.16.3-292.el7.ppc64le
libselinux-utils-2.5-11.el7.ppc64le
libsepol-devel-2.5-6.el7.ppc64le
festival-lib-1.96-28.el7.ppc64le
oddjob-0.31.5-4.el7.ppc64le
latencytop-tui-0.5-13.el7.ppc64le
libvirt-daemon-driver-storage-core-3.2.0-14.el7.ppc64le
perl-Data-Dumper-2.145-3.el7.ppc64le
libreport-python-2.1.11-38.el7.centos.ppc64le
libical-devel-1.0.1-1.el7.ppc64le
libmx-1.4.7-10.el7.ppc64le
cups-pk-helper-0.2.6-2.el7.ppc64le
=== TEST BEGIN ===
Install prefix    /var/tmp/patchew-tester-tmp-yk6niwxj/src/install
BIOS directory    /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/share/qemu
firmware path     /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/share/qemu-firmware
binary directory  /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/bin
library directory /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/lib
module directory  /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/lib/qemu
libexec directory /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/libexec
include directory /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/include
config directory  /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/etc
local state directory   /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/var
Manual directory  /var/tmp/patchew-tester-tmp-yk6niwxj/src/install/share/man
ELF interp prefix /usr/gnemul/qemu-%M
Source path       /var/tmp/patchew-tester-tmp-yk6niwxj/src
GIT binary        git
GIT submodules    ui/keycodemapdb dtc capstone
C compiler        cc
Host C compiler   cc
C++ compiler      c++
Objective-C compiler cc
ARFLAGS           rv
CFLAGS            -O2 -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 -g 
QEMU_CFLAGS       -I/usr/include/pixman-1   -I$(SRC_PATH)/dtc/libfdt -Werror -pthread -I/usr/include/glib-2.0 -I/usr/lib64/glib-2.0/include   -DNCURSES_WIDECHAR   -m64 -D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -Wstrict-prototypes -Wredundant-decls -Wall -Wundef -Wwrite-strings -Wmissing-prototypes -fno-strict-aliasing -fno-common -fwrapv  -Wendif-labels -Wno-missing-include-dirs -Wempty-body -Wnested-externs -Wformat-security -Wformat-y2k -Winit-self -Wignored-qualifiers -Wold-style-declaration -Wold-style-definition -Wtype-limits -fstack-protector-strong -Wno-missing-braces -I/usr/include/p11-kit-1       -I/usr/include/libpng15   -I$(SRC_PATH)/capstone/include
LDFLAGS           -Wl,--warn-common -m64 -g 
make              make
install           install
python            python -B
smbd              /usr/sbin/smbd
module support    no
host CPU          ppc64
host big endian   no
target list       aarch64-softmmu alpha-softmmu arm-softmmu cris-softmmu i386-softmmu lm32-softmmu m68k-softmmu microblazeel-softmmu microblaze-softmmu mips64el-softmmu mips64-softmmu mipsel-softmmu mips-softmmu moxie-softmmu nios2-softmmu or1k-softmmu ppc64-softmmu ppcemb-softmmu ppc-softmmu s390x-softmmu sh4eb-softmmu sh4-softmmu sparc64-softmmu sparc-softmmu tricore-softmmu unicore32-softmmu x86_64-softmmu xtensaeb-softmmu xtensa-softmmu aarch64-linux-user alpha-linux-user armeb-linux-user arm-linux-user cris-linux-user hppa-linux-user i386-linux-user m68k-linux-user microblazeel-linux-user microblaze-linux-user mips64el-linux-user mips64-linux-user mipsel-linux-user mips-linux-user mipsn32el-linux-user mipsn32-linux-user nios2-linux-user or1k-linux-user ppc64abi32-linux-user ppc64le-linux-user ppc64-linux-user ppc-linux-user s390x-linux-user sh4eb-linux-user sh4-linux-user sparc32plus-linux-user sparc64-linux-user sparc-linux-user tilegx-linux-user x86_64-linux-user
gprof enabled     no
sparse enabled    no
strip binaries    yes
profiler          no
static build      no
SDL support       yes (1.2.15)
GTK support       yes (3.22.10)
GTK GL support    no
VTE support       no 
TLS priority      NORMAL
GNUTLS support    yes
GNUTLS rnd        yes
libgcrypt         no
libgcrypt kdf     no
nettle            yes (2.7.1)
nettle kdf        yes
libtasn1          yes
curses support    yes
virgl support     no
curl support      yes
mingw32 support   no
Audio drivers     oss
Block whitelist (rw) 
Block whitelist (ro) 
VirtFS support    yes
Multipath support no
VNC support       yes
VNC SASL support  yes
VNC JPEG support  yes
VNC PNG support   yes
xen support       no
brlapi support    no
bluez  support    no
Documentation     no
PIE               no
vde support       no
netmap support    no
Linux AIO support yes
ATTR/XATTR support yes
Install blobs     yes
KVM support       yes
HAX support       no
TCG support       yes
TCG debug enabled no
TCG interpreter   no
RDMA support      yes
fdt support       yes
preadv support    yes
fdatasync         yes
madvise           yes
posix_madvise     yes
libcap-ng support yes
vhost-net support yes
vhost-scsi support yes
vhost-vsock support yes
vhost-user support yes
Trace backends    log
spice support     no 
rbd support       no
xfsctl support    no
smartcard support no
libusb            yes
usb net redir     no
OpenGL support    no
OpenGL dmabufs    no
libiscsi support  no
libnfs support    no
build guest agent yes
QGA VSS support   no
QGA w32 disk info no
QGA MSI support   no
seccomp support   no
coroutine backend ucontext
coroutine pool    yes
debug stack usage no
crypto afalg      no
GlusterFS support no
gcov              gcov
gcov enabled      no
TPM support       yes
libssh2 support   no
TPM passthrough   no
TPM emulator      yes
QOM debugging     yes
Live block migration yes
lzo support       no
snappy support    no
bzip2 support     yes
NUMA host support yes
tcmalloc support  no
jemalloc support  no
avx2 optimization no
replication support yes
VxHS block device no
capstone          git
  GEN     aarch64-softmmu/config-devices.mak.tmp
  GEN     alpha-softmmu/config-devices.mak.tmp
  GEN     arm-softmmu/config-devices.mak.tmp
  GEN     cris-softmmu/config-devices.mak.tmp
  GEN     i386-softmmu/config-devices.mak.tmp
  GEN     lm32-softmmu/config-devices.mak.tmp
  GEN     microblazeel-softmmu/config-devices.mak.tmp
  GEN     microblaze-softmmu/config-devices.mak.tmp
  GEN     mips64el-softmmu/config-devices.mak.tmp
  GEN     m68k-softmmu/config-devices.mak.tmp
  GEN     mips64-softmmu/config-devices.mak.tmp
  GEN     mipsel-softmmu/config-devices.mak.tmp
  GEN     mips-softmmu/config-devices.mak.tmp
  GEN     nios2-softmmu/config-devices.mak.tmp
  GEN     or1k-softmmu/config-devices.mak.tmp
  GEN     ppc64-softmmu/config-devices.mak.tmp
  GEN     moxie-softmmu/config-devices.mak.tmp
  GEN     ppcemb-softmmu/config-devices.mak.tmp
  GEN     s390x-softmmu/config-devices.mak.tmp
  GEN     ppc-softmmu/config-devices.mak.tmp
  GEN     sh4-softmmu/config-devices.mak.tmp
  GEN     sh4eb-softmmu/config-devices.mak.tmp
  GEN     lm32-softmmu/config-devices.mak
  GEN     sparc64-softmmu/config-devices.mak.tmp
  GEN     sparc-softmmu/config-devices.mak.tmp
  GEN     tricore-softmmu/config-devices.mak.tmp
  GEN     unicore32-softmmu/config-devices.mak.tmp
  GEN     arm-softmmu/config-devices.mak
  GEN     x86_64-softmmu/config-devices.mak.tmp
  GEN     xtensaeb-softmmu/config-devices.mak.tmp
  GEN     s390x-softmmu/config-devices.mak
  GEN     xtensa-softmmu/config-devices.mak.tmp
  GEN     i386-softmmu/config-devices.mak
  GEN     or1k-softmmu/config-devices.mak
  GEN     alpha-linux-user/config-devices.mak.tmp
  GEN     armeb-linux-user/config-devices.mak.tmp
  GEN     m68k-softmmu/config-devices.mak
  GEN     arm-linux-user/config-devices.mak.tmp
  GEN     aarch64-linux-user/config-devices.mak.tmp
  GEN     cris-linux-user/config-devices.mak.tmp
  GEN     hppa-linux-user/config-devices.mak.tmp
  GEN     alpha-softmmu/config-devices.mak
  GEN     mipsel-softmmu/config-devices.mak
  GEN     moxie-softmmu/config-devices.mak
  GEN     mips64el-softmmu/config-devices.mak
  GEN     microblazeel-softmmu/config-devices.mak
  GEN     microblaze-softmmu/config-devices.mak
  GEN     m68k-linux-user/config-devices.mak.tmp
  GEN     i386-linux-user/config-devices.mak.tmp
  GEN     microblazeel-linux-user/config-devices.mak.tmp
  GEN     cris-softmmu/config-devices.mak
  GEN     cris-linux-user/config-devices.mak
  GEN     mips64el-linux-user/config-devices.mak.tmp
  GEN     microblaze-linux-user/config-devices.mak.tmp
  GEN     mips64-linux-user/config-devices.mak.tmp
  GEN     mipsel-linux-user/config-devices.mak.tmp
  GEN     ppcemb-softmmu/config-devices.mak
  GEN     mips-linux-user/config-devices.mak.tmp
  GEN     unicore32-softmmu/config-devices.mak
  GEN     mipsn32el-linux-user/config-devices.mak.tmp
  GEN     nios2-softmmu/config-devices.mak
  GEN     sparc64-softmmu/config-devices.mak
  GEN     mipsn32-linux-user/config-devices.mak.tmp
  GEN     sparc-softmmu/config-devices.mak
  GEN     arm-linux-user/config-devices.mak
  GEN     or1k-linux-user/config-devices.mak.tmp
  GEN     ppc64abi32-linux-user/config-devices.mak.tmp
  GEN     ppc64le-linux-user/config-devices.mak.tmp
  GEN     ppc64-softmmu/config-devices.mak
  GEN     nios2-linux-user/config-devices.mak.tmp
  GEN     ppc64-linux-user/config-devices.mak.tmp
  GEN     sparc64-linux-user/config-devices.mak.tmp
  GEN     s390x-linux-user/config-devices.mak.tmp
  GEN     sparc-linux-user/config-devices.mak.tmp
  GEN     mips64-softmmu/config-devices.mak
  GEN     tilegx-linux-user/config-devices.mak.tmp
  GEN     sh4eb-linux-user/config-devices.mak.tmp
  GEN     sh4-linux-user/config-devices.mak.tmp
  GEN     armeb-linux-user/config-devices.mak
  GEN     or1k-linux-user/config-devices.mak
  GEN     hppa-linux-user/config-devices.mak
  GEN     ppc-linux-user/config-devices.mak.tmp
  GEN     tricore-softmmu/config-devices.mak
  GEN     mips64-linux-user/config-devices.mak
  GEN     microblaze-linux-user/config-devices.mak
  GEN     mipsn32el-linux-user/config-devices.mak
  GEN     config-host.h
  GEN     sparc32plus-linux-user/config-devices.mak.tmp
  GIT     ui/keycodemapdb dtc capstone
  GEN     mipsel-linux-user/config-devices.mak
  GEN     x86_64-linux-user/config-devices.mak.tmp
  GEN     sh4eb-softmmu/config-devices.mak
  GEN     xtensaeb-softmmu/config-devices.mak
  GEN     aarch64-softmmu/config-devices.mak
  GEN     aarch64-linux-user/config-devices.mak
  GEN     sh4-softmmu/config-devices.mak
  GEN     alpha-linux-user/config-devices.mak
  GEN     mips64el-linux-user/config-devices.mak
  GEN     qemu-options.def
  GEN     m68k-linux-user/config-devices.mak
  GEN     microblazeel-linux-user/config-devices.mak
  GEN     ppc64le-linux-user/config-devices.mak
  GEN     mipsn32-linux-user/config-devices.mak
  GEN     sparc-linux-user/config-devices.mak
  GEN     tilegx-linux-user/config-devices.mak
  GEN     i386-linux-user/config-devices.mak
  GEN     x86_64-softmmu/config-devices.mak
  GEN     mips-linux-user/config-devices.mak
  GEN     mips-softmmu/config-devices.mak
  GEN     qapi-types.h
  GEN     qmp-commands.h
  GEN     qapi-visit.h
  GEN     sparc64-linux-user/config-devices.mak
  GEN     s390x-linux-user/config-devices.mak
  GEN     qapi-event.h
  GEN     xtensa-softmmu/config-devices.mak
  GEN     nios2-linux-user/config-devices.mak
  GEN     ppc64abi32-linux-user/config-devices.mak
  GEN     ppc64-linux-user/config-devices.mak
  GEN     ppc-softmmu/config-devices.mak
  GEN     ppc-linux-user/config-devices.mak
  GEN     sh4eb-linux-user/config-devices.mak
  GEN     sh4-linux-user/config-devices.mak
  GEN     sparc32plus-linux-user/config-devices.mak
  GEN     x86_64-linux-user/config-devices.mak
  GEN     qmp-marshal.c
  GEN     qapi-types.c
  GEN     qapi-visit.c
  GEN     qmp-introspect.h
  GEN     qapi-event.c
  GEN     qmp-introspect.c
  GEN     trace/generated-tcg-tracers.h
  GEN     trace/generated-helpers.c
  GEN     trace/generated-helpers.h
  GEN     module_block.h
  GEN     trace/generated-helpers-wrappers.h
  GEN     tests/test-qapi-types.h
  GEN     tests/test-qapi-visit.h
  GEN     tests/test-qmp-commands.h
  GEN     tests/test-qapi-event.h
  GEN     tests/test-qmp-introspect.h
  GEN     trace-root.h
  GEN     util/trace.h
  GEN     crypto/trace.h
  GEN     io/trace.h
  GEN     migration/trace.h
  GEN     block/trace.h
  GEN     chardev/trace.h
  GEN     hw/block/trace.h
  GEN     hw/block/dataplane/trace.h
  GEN     hw/char/trace.h
  GEN     hw/intc/trace.h
  GEN     hw/net/trace.h
  GEN     hw/virtio/trace.h
  GEN     hw/audio/trace.h
  GEN     hw/misc/trace.h
  GEN     hw/usb/trace.h
  GEN     hw/scsi/trace.h
  GEN     hw/nvram/trace.h
  GEN     hw/display/trace.h
  GEN     hw/input/trace.h
  GEN     hw/timer/trace.h
  GEN     hw/dma/trace.h
  GEN     hw/sparc/trace.h
  GEN     hw/sd/trace.h
  GEN     hw/isa/trace.h
  GEN     hw/mem/trace.h
  GEN     hw/i386/trace.h
  GEN     hw/i386/xen/trace.h
  GEN     hw/9pfs/trace.h
  GEN     hw/ppc/trace.h
  GEN     hw/pci/trace.h
  GEN     hw/s390x/trace.h
  GEN     hw/vfio/trace.h
  GEN     hw/acpi/trace.h
  GEN     hw/arm/trace.h
  GEN     hw/alpha/trace.h
  GEN     hw/xen/trace.h
  GEN     hw/ide/trace.h
  GEN     ui/trace.h
  GEN     audio/trace.h
  GEN     net/trace.h
  GEN     target/arm/trace.h
  GEN     target/i386/trace.h
  GEN     target/mips/trace.h
  GEN     target/sparc/trace.h
  GEN     target/s390x/trace.h
  GEN     target/ppc/trace.h
  GEN     qom/trace.h
  GEN     linux-user/trace.h
  GEN     qapi/trace.h
  GEN     accel/tcg/trace.h
  GEN     accel/kvm/trace.h
  GEN     nbd/trace.h
  GEN     scsi/trace.h
  GEN     trace-root.c
  GEN     util/trace.c
  GEN     crypto/trace.c
  GEN     io/trace.c
  GEN     migration/trace.c
  GEN     block/trace.c
  GEN     chardev/trace.c
  GEN     hw/block/trace.c
  GEN     hw/block/dataplane/trace.c
  GEN     hw/char/trace.c
  GEN     hw/intc/trace.c
  GEN     hw/net/trace.c
  GEN     hw/virtio/trace.c
  GEN     hw/audio/trace.c
  GEN     hw/misc/trace.c
  GEN     hw/usb/trace.c
  GEN     hw/scsi/trace.c
  GEN     hw/nvram/trace.c
  GEN     hw/display/trace.c
  GEN     hw/input/trace.c
  GEN     hw/timer/trace.c
  GEN     hw/dma/trace.c
  GEN     hw/sparc/trace.c
  GEN     hw/sd/trace.c
  GEN     hw/isa/trace.c
  GEN     hw/mem/trace.c
  GEN     hw/i386/trace.c
  GEN     hw/i386/xen/trace.c
  GEN     hw/9pfs/trace.c
  GEN     hw/ppc/trace.c
  GEN     hw/pci/trace.c
  GEN     hw/s390x/trace.c
  GEN     hw/vfio/trace.c
  GEN     hw/acpi/trace.c
  GEN     hw/arm/trace.c
  GEN     hw/alpha/trace.c
  GEN     hw/xen/trace.c
  GEN     hw/ide/trace.c
  GEN     ui/trace.c
  GEN     audio/trace.c
  GEN     net/trace.c
  GEN     target/arm/trace.c
  GEN     target/i386/trace.c
  GEN     target/mips/trace.c
  GEN     target/sparc/trace.c
  GEN     target/s390x/trace.c
  GEN     target/ppc/trace.c
  GEN     qom/trace.c
  GEN     linux-user/trace.c
  GEN     qapi/trace.c
  GEN     accel/tcg/trace.c
  GEN     accel/kvm/trace.c
  GEN     nbd/trace.c
  GEN     scsi/trace.c
  GEN     config-all-devices.mak
mkdir -p dtc/libfdt
mkdir -p dtc/tests
  GEN     ui/input-keymap-linux-to-qcode.c
  GEN     ui/input-keymap-qcode-to-qnum.c
  GEN     ui/input-keymap-qnum-to-qcode.c
  CC      cs.o
  CC      utils.o
  CC      SStream.o
  CC      MCInstrDesc.o
  CC      arch/ARM/ARMDisassembler.o
  CC      MCRegisterInfo.o
  CC      arch/ARM/ARMInstPrinter.o
  CC      arch/ARM/ARMMapping.o
  CC      arch/ARM/ARMModule.o
  CC      arch/AArch64/AArch64BaseInfo.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/dumptrees.c
  CC      arch/AArch64/AArch64Disassembler.o
  CC      arch/AArch64/AArch64InstPrinter.o
  CC      arch/AArch64/AArch64Mapping.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/trees.S
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/testutils.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/value-labels.c
  CC      arch/AArch64/AArch64Module.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/asm_tree_dump.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/truncated_property.c
  CC      arch/Mips/MipsDisassembler.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/check_path.c
  CC      arch/Mips/MipsInstPrinter.o
  CC      arch/Mips/MipsMapping.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/overlay_bad_fixup.c
  CC      arch/PowerPC/PPCDisassembler.o
  CC      arch/Mips/MipsModule.o
  CC      arch/PowerPC/PPCInstPrinter.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/subnode_iterate.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/overlay.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/property_iterate.c
  CC      arch/PowerPC/PPCMapping.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/integer-expressions.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/utilfdt_test.c
  CC      arch/Sparc/SparcDisassembler.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/path_offset_aliases.c
  CC      arch/PowerPC/PPCModule.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/add_subnode_with_nops.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/dtbs_equal_unordered.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/dtb_reverse.c
  CC      arch/Sparc/SparcInstPrinter.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/dtbs_equal_ordered.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/extra-terminating-null.c
  CC      arch/Sparc/SparcMapping.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/incbin.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/boot-cpuid.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/phandle_format.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/path-references.c
  CC      arch/Sparc/SparcModule.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/references.c
  CC      arch/SystemZ/SystemZDisassembler.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/string_escapes.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/appendprop2.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/propname_escapes.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/appendprop1.c
  CC      arch/SystemZ/SystemZInstPrinter.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/del_node.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/del_property.c
  CC      arch/SystemZ/SystemZModule.o
  CC      arch/X86/X86DisassemblerDecoder.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/setprop.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/set_name.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/rw_tree1.c
  CC      arch/SystemZ/SystemZMCTargetDesc.o
  CC      arch/SystemZ/SystemZMapping.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/open_pack.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/nopulate.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/mangle-layout.c
  CC      arch/X86/X86Disassembler.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/sw_tree1.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/nop_node.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/move_and_save.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/nop_property.c
  CC      arch/X86/X86IntelInstPrinter.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/stringlist.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/setprop_inplace.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/addr_size_cells.c
  CC      arch/X86/X86ATTInstPrinter.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/notfound.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/sized_cells.c
  CC      arch/X86/X86Mapping.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/char_literal.c
  CC      arch/X86/X86Module.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/get_alias.c
  CC      arch/XCore/XCoreDisassembler.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/node_offset_by_compatible.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/node_check_compatible.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/node_offset_by_phandle.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/node_offset_by_prop_value.c
  CC      arch/XCore/XCoreInstPrinter.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/parent_offset.c
  CC      arch/XCore/XCoreMapping.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/supernode_atdepth_offset.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/get_path.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/getprop.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/get_phandle.c
  CC      arch/XCore/XCoreModule.o
  CC      MCInst.o
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/get_name.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/path_offset.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/subnode_offset.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/find_property.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/root_node.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/tests/get_mem_rsv.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_overlay.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_addresses.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_empty_tree.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_strerror.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_rw.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_sw.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_wip.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt_ro.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/libfdt/fdt.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/fdtput.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/util.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/fdtget.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/fdtdump.c
	 LEX convert-dtsv0-lexer.lex.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/srcpos.c
	 BISON dtc-parser.tab.c
	 LEX dtc-lexer.lex.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/treesource.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/livetree.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/fstree.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/flattree.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/dtc.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/data.c
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/checks.c
	 DEP convert-dtsv0-lexer.lex.c
	 DEP dtc-parser.tab.c
	 DEP dtc-lexer.lex.c
	CHK version_gen.h
	UPD version_gen.h
	 DEP /var/tmp/patchew-tester-tmp-yk6niwxj/src/dtc/util.c
	 CC libfdt/fdt.o
	 CC libfdt/fdt_ro.o
	 CC libfdt/fdt_wip.o
	 CC libfdt/fdt_sw.o
	 CC libfdt/fdt_rw.o
	 CC libfdt/fdt_empty_tree.o
	 CC libfdt/fdt_strerror.o
	 CC libfdt/fdt_addresses.o
	 CC libfdt/fdt_overlay.o
	 AR libfdt/libfdt.a
ar: creating libfdt/libfdt.a
a - libfdt/fdt.o
a - libfdt/fdt_ro.o
a - libfdt/fdt_wip.o
a - libfdt/fdt_sw.o
a - libfdt/fdt_rw.o
a - libfdt/fdt_strerror.o
a - libfdt/fdt_empty_tree.o
a - libfdt/fdt_addresses.o
a - libfdt/fdt_overlay.o
  AR      libcapstone.a
ar: creating /var/tmp/patchew-tester-tmp-yk6niwxj/src/build/capstone/libcapstone.a
mkdir -p dtc/libfdt
mkdir -p dtc/tests
make[1]: `/var/tmp/patchew-tester-tmp-yk6niwxj/src/build/capstone/libcapstone.a' is up to date.
  CC      tests/qemu-iotests/socket_scm_helper.o
  GEN     qga/qapi-generated/qga-qapi-types.h
  GEN     qga/qapi-generated/qga-qapi-visit.h
  GEN     qga/qapi-generated/qga-qmp-commands.h
  GEN     qga/qapi-generated/qga-qapi-types.c
  GEN     qga/qapi-generated/qga-qapi-visit.c
  GEN     qga/qapi-generated/qga-qmp-marshal.c
  CC      qmp-introspect.o
  CC      qapi-types.o
  CC      qapi-visit.o
  CC      qapi-event.o
  CC      qapi/qapi-visit-core.o
  CC      qapi/qapi-dealloc-visitor.o
  CC      qapi/qobject-output-visitor.o
  CC      qapi/qobject-input-visitor.o
  CC      qapi/qmp-registry.o
  CC      qapi/qmp-dispatch.o
  CC      qapi/string-input-visitor.o
  CC      qapi/string-output-visitor.o
  CC      qapi/opts-visitor.o
  CC      qapi/qapi-clone-visitor.o
  CC      qapi/qmp-event.o
  CC      qapi/qapi-util.o
  CC      qobject/qnum.o
  CC      qobject/qstring.o
  CC      qobject/qnull.o
  CC      qobject/qlist.o
  CC      qobject/qdict.o
  CC      qobject/qbool.o
  CC      qobject/qjson.o
  CC      qobject/qobject.o
  CC      qobject/json-streamer.o
  CC      qobject/json-lexer.o
  CC      qobject/qlit.o
  CC      qobject/json-parser.o
  CC      util/cutils.o
  CC      util/qemu-timer-common.o
  CC      util/bufferiszero.o
  CC      trace/control.o
  CC      util/unicode.o
  CC      trace/qmp.o
  CC      util/lockcnt.o
  CC      util/aiocb.o
  CC      util/osdep.o
  CC      util/thread-pool.o
  CC      util/async.o
  CC      util/qemu-timer.o
  CC      util/main-loop.o
  CC      util/iohandler.o
  CC      util/aio-posix.o
  CC      util/compatfd.o
  CC      util/event_notifier-posix.o
  CC      util/oslib-posix.o
  CC      util/mmap-alloc.o
  CC      util/qemu-openpty.o
  CC      util/qemu-thread-posix.o
  CC      util/memfd.o
  CC      util/envlist.o
  CC      util/path.o
  CC      util/host-utils.o
  CC      util/bitmap.o
  CC      util/module.o
  CC      util/bitops.o
  CC      util/fifo8.o
  CC      util/hbitmap.o
  CC      util/acl.o
  CC      util/cacheinfo.o
  CC      util/error.o
  CC      util/qemu-error.o
  CC      util/id.o
  CC      util/iov.o
  CC      util/qemu-config.o
  CC      util/qemu-sockets.o
  CC      util/uri.o
  CC      util/notify.o
  CC      util/qemu-option.o
  CC      util/qemu-progress.o
  CC      util/keyval.o
  CC      util/crc32c.o
  CC      util/hexdump.o
  CC      util/uuid.o
  CC      util/throttle.o
  CC      util/getauxval.o
  CC      util/readline.o
  CC      util/rcu.o
  CC      util/qemu-coroutine.o
  CC      util/qemu-coroutine-lock.o
  CC      util/qemu-coroutine-io.o
  CC      util/qemu-coroutine-sleep.o
  CC      util/coroutine-ucontext.o
  CC      util/buffer.o
  CC      util/base64.o
  CC      util/timed-average.o
  CC      util/log.o
  CC      util/pagesize.o
  CC      util/qdist.o
  CC      util/qht.o
  CC      util/range.o
  CC      util/stats64.o
  CC      util/systemd.o
  CC      trace-root.o
  CC      util/trace.o
  CC      crypto/trace.o
  CC      io/trace.o
  CC      migration/trace.o
  CC      block/trace.o
  CC      chardev/trace.o
  CC      hw/block/trace.o
  CC      hw/block/dataplane/trace.o
  CC      hw/char/trace.o
  CC      hw/intc/trace.o
  CC      hw/virtio/trace.o
  CC      hw/net/trace.o
  CC      hw/audio/trace.o
  CC      hw/misc/trace.o
  CC      hw/usb/trace.o
  CC      hw/scsi/trace.o
  CC      hw/nvram/trace.o
  CC      hw/display/trace.o
  CC      hw/input/trace.o
  CC      hw/timer/trace.o
  CC      hw/dma/trace.o
  CC      hw/sparc/trace.o
  CC      hw/sd/trace.o
  CC      hw/isa/trace.o
  CC      hw/mem/trace.o
  CC      hw/i386/trace.o
  CC      hw/i386/xen/trace.o
  CC      hw/9pfs/trace.o
  CC      hw/ppc/trace.o
  CC      hw/pci/trace.o
  CC      hw/s390x/trace.o
  CC      hw/vfio/trace.o
  CC      hw/acpi/trace.o
  CC      hw/arm/trace.o
  CC      hw/xen/trace.o
  CC      hw/alpha/trace.o
  CC      hw/ide/trace.o
  CC      audio/trace.o
  CC      ui/trace.o
  CC      target/arm/trace.o
  CC      target/i386/trace.o
  CC      net/trace.o
  CC      target/mips/trace.o
  CC      target/sparc/trace.o
  CC      target/s390x/trace.o
  CC      target/ppc/trace.o
  CC      qom/trace.o
  CC      qapi/trace.o
  CC      linux-user/trace.o
  CC      accel/tcg/trace.o
  CC      accel/kvm/trace.o
  CC      nbd/trace.o
  CC      stubs/arch-query-cpu-def.o
  CC      scsi/trace.o
  CC      crypto/pbkdf-stub.o
  CC      stubs/arch-query-cpu-model-expansion.o
  CC      stubs/arch-query-cpu-model-comparison.o
  CC      stubs/arch-query-cpu-model-baseline.o
  CC      stubs/bdrv-next-monitor-owned.o
  CC      stubs/blk-commit-all.o
  CC      stubs/blockdev-close-all-bdrv-states.o
  CC      stubs/clock-warp.o
  CC      stubs/cpu-get-icount.o
  CC      stubs/cpu-get-clock.o
  CC      stubs/dump.o
  CC      stubs/fdset.o
  CC      stubs/error-printf.o
  CC      stubs/gdbstub.o
  CC      stubs/windbgstub.o
  CC      stubs/get-vm-name.o
  CC      stubs/iothread.o
  CC      stubs/iothread-lock.o
  CC      stubs/is-daemonized.o
  CC      stubs/linux-aio.o
  CC      stubs/machine-init-done.o
  CC      stubs/migr-blocker.o
  CC      stubs/change-state-handler.o
  CC      stubs/monitor.o
  CC      stubs/notify-event.o
  CC      stubs/qtest.o
  CC      stubs/replay.o
  CC      stubs/runstate-check.o
  CC      stubs/set-fd-handler.o
  CC      stubs/slirp.o
  CC      stubs/sysbus.o
  CC      stubs/tpm.o
  CC      stubs/trace-control.o
  CC      stubs/uuid.o
  CC      stubs/vmstate.o
  CC      stubs/vm-stop.o
  CC      stubs/qmp_pc_dimm.o
  CC      stubs/target-monitor-defs.o
  CC      stubs/vmgenid.o
  CC      stubs/pc_madt_cpu_entry.o
  CC      stubs/xen-common.o
  CC      stubs/target-get-monitor-def.o
  CC      stubs/xen-hvm.o
  CC      stubs/pci-host-piix.o
  CC      contrib/ivshmem-client/ivshmem-client.o
  CC      contrib/ivshmem-client/main.o
  CC      contrib/ivshmem-server/ivshmem-server.o
  CC      contrib/ivshmem-server/main.o
  CC      qemu-nbd.o
  CC      block.o
  CC      qemu-io-cmds.o
  CC      blockjob.o
  CC      replication.o
  CC      block/raw-format.o
  CC      block/qcow.o
  CC      block/vdi.o
  CC      block/vmdk.o
  CC      block/cloop.o
  CC      block/bochs.o
  CC      block/vpc.o
  CC      block/vvfat.o
  CC      block/dmg.o
  CC      block/qcow2.o
  CC      block/qcow2-refcount.o
  CC      block/qcow2-cluster.o
  CC      block/qcow2-cache.o
  CC      block/qcow2-bitmap.o
  CC      block/qcow2-snapshot.o
  CC      block/qed.o
  CC      block/qed-l2-cache.o
  CC      block/qed-table.o
  CC      block/qed-check.o
  CC      block/qed-cluster.o
  CC      block/vhdx.o
  CC      block/vhdx-endian.o
  CC      block/vhdx-log.o
  CC      block/quorum.o
  CC      block/parallels.o
  CC      block/blkdebug.o
  CC      block/blkverify.o
  CC      block/blkreplay.o
  CC      block/snapshot.o
  CC      block/qapi.o
  CC      block/block-backend.o
  CC      block/file-posix.o
  CC      block/linux-aio.o
  CC      block/null.o
  CC      block/mirror.o
  CC      block/commit.o
  CC      block/throttle-groups.o
  CC      block/io.o
  CC      block/nbd.o
  CC      block/nbd-client.o
  CC      block/sheepdog.o
  CC      block/accounting.o
  CC      block/dirty-bitmap.o
  CC      block/write-threshold.o
  CC      block/backup.o
  CC      block/replication.o
  CC      block/throttle.o
  CC      block/crypto.o
  CC      nbd/server.o
  CC      nbd/client.o
  CC      nbd/common.o
  CC      scsi/utils.o
  CC      scsi/pr-manager.o
  CC      scsi/pr-manager-helper.o
  CC      block/curl.o
  CC      block/dmg-bz2.o
  CC      crypto/init.o
  CC      crypto/hash.o
  CC      crypto/hash-nettle.o
  CC      crypto/hmac.o
  CC      crypto/hmac-nettle.o
  CC      crypto/aes.o
  CC      crypto/desrfb.o
  CC      crypto/cipher.o
  CC      crypto/tlscreds.o
  CC      crypto/tlscredsanon.o
  CC      crypto/tlscredsx509.o
  CC      crypto/tlssession.o
  CC      crypto/secret.o
  CC      crypto/random-gnutls.o
  CC      crypto/pbkdf.o
  CC      crypto/pbkdf-nettle.o
  CC      crypto/ivgen.o
  CC      crypto/ivgen-essiv.o
  CC      crypto/ivgen-plain.o
  CC      crypto/ivgen-plain64.o
  CC      crypto/afsplit.o
  CC      crypto/xts.o
  CC      crypto/block.o
  CC      crypto/block-qcow.o
  CC      crypto/block-luks.o
  CC      io/channel-buffer.o
  CC      io/channel.o
  CC      io/channel-command.o
  CC      io/channel-file.o
  CC      io/channel-socket.o
  CC      io/channel-watch.o
  CC      io/channel-tls.o
  CC      io/channel-websock.o
  CC      io/channel-util.o
  CC      io/dns-resolver.o
  CC      io/task.o
  CC      qom/object.o
  CC      qom/container.o
  CC      qom/qom-qobject.o
  CC      qom/object_interfaces.o
  GEN     qemu-img-cmds.h
  CC      qemu-io.o
  CC      fsdev/virtfs-proxy-helper.o
  CC      fsdev/9p-marshal.o
  CC      fsdev/9p-iov-marshal.o
  CC      scsi/qemu-pr-helper.o
  CC      qemu-bridge-helper.o
  CC      blockdev.o
  CC      blockdev-nbd.o
  CC      bootdevice.o
  CC      iothread.o
  CC      qdev-monitor.o
  CC      device-hotplug.o
  CC      os-posix.o
  CC      bt-host.o
  CC      bt-vhci.o
  CC      dma-helpers.o
  CC      vl.o
  CC      tpm.o
  CC      device_tree.o
  CC      qmp-marshal.o
  CC      qmp.o
  CC      hmp.o
  CC      cpus-common.o
  CC      audio/audio.o
  CC      audio/noaudio.o
  CC      audio/wavaudio.o
  CC      audio/mixeng.o
  CC      audio/sdlaudio.o
  CC      audio/ossaudio.o
  CC      audio/wavcapture.o
  CC      backends/rng.o
  CC      backends/rng-egd.o
  CC      backends/rng-random.o
  CC      backends/tpm.o
  CC      backends/hostmem.o
  CC      backends/hostmem-ram.o
  CC      backends/hostmem-file.o
  CC      backends/cryptodev.o
  CC      backends/cryptodev-builtin.o
  CC      block/stream.o
  CC      chardev/wctablet.o
  CC      chardev/msmouse.o
  CC      chardev/testdev.o
  CC      disas/alpha.o
  CC      disas/arm.o
  CXX     disas/arm-a64.o
  CC      disas/cris.o
  CC      disas/hppa.o
  CC      disas/i386.o
  CC      disas/m68k.o
  CC      disas/microblaze.o
  CC      disas/mips.o
  CC      disas/nios2.o
  CC      disas/moxie.o
  CC      disas/s390.o
  CC      disas/ppc.o
  CC      disas/sh4.o
  CC      disas/sparc.o
  CC      disas/lm32.o
  CXX     disas/libvixl/vixl/utils.o
  CXX     disas/libvixl/vixl/compiler-intrinsics.o
  CXX     disas/libvixl/vixl/a64/instructions-a64.o
  CXX     disas/libvixl/vixl/a64/decoder-a64.o
  CC      fsdev/qemu-fsdev.o
  CXX     disas/libvixl/vixl/a64/disasm-a64.o
  CC      fsdev/qemu-fsdev-opts.o
  CC      fsdev/qemu-fsdev-throttle.o
  CC      fsdev/qemu-fsdev-dummy.o
  CC      hw/9pfs/9p.o
  CC      hw/9pfs/9p-util.o
  CC      hw/9pfs/9p-local.o
  CC      hw/9pfs/9p-xattr.o
  CC      hw/9pfs/9p-xattr-user.o
  CC      hw/9pfs/9p-posix-acl.o
  CC      hw/9pfs/coth.o
  CC      hw/9pfs/cofs.o
  CC      hw/9pfs/codir.o
  CC      hw/9pfs/cofile.o
  CC      hw/9pfs/9p-synth.o
  CC      hw/9pfs/coxattr.o
  CC      hw/9pfs/9p-handle.o
  CC      hw/9pfs/9p-proxy.o
  CC      hw/acpi/core.o
  CC      hw/acpi/piix4.o
  CC      hw/acpi/ich9.o
  CC      hw/acpi/pcihp.o
  CC      hw/acpi/tco.o
  CC      hw/acpi/cpu_hotplug.o
  CC      hw/acpi/memory_hotplug.o
  CC      hw/acpi/cpu.o
  CC      hw/acpi/nvdimm.o
  CC      hw/acpi/vmgenid.o
  CC      hw/acpi/acpi_interface.o
  CC      hw/acpi/bios-linker-loader.o
  CC      hw/acpi/aml-build.o
  CC      hw/acpi/ipmi.o
  CC      hw/acpi/acpi-stub.o
  CC      hw/acpi/ipmi-stub.o
  CC      hw/audio/sb16.o
  CC      hw/audio/es1370.o
  CC      hw/audio/ac97.o
  CC      hw/audio/adlib.o
  CC      hw/audio/fmopl.o
  CC      hw/audio/gus.o
  CC      hw/audio/gusemu_hal.o
  CC      hw/audio/gusemu_mixer.o
  CC      hw/audio/cs4231a.o
  CC      hw/audio/intel-hda.o
  CC      hw/audio/hda-codec.o
  CC      hw/audio/pcspk.o
  CC      hw/audio/wm8750.o
  CC      hw/audio/pl041.o
  CC      hw/audio/lm4549.o
  CC      hw/audio/cs4231.o
  CC      hw/audio/marvell_88w8618.o
  CC      hw/audio/milkymist-ac97.o
  CC      hw/audio/soundhw.o
  CC      hw/block/block.o
  CC      hw/block/cdrom.o
  CC      hw/block/hd-geometry.o
  CC      hw/block/fdc.o
  CC      hw/block/m25p80.o
  CC      hw/block/nand.o
  CC      hw/block/pflash_cfi01.o
  CC      hw/block/pflash_cfi02.o
  CC      hw/block/ecc.o
  CC      hw/block/onenand.o
  CC      hw/block/nvme.o
  CC      hw/bt/core.o
  CC      hw/bt/l2cap.o
  CC      hw/bt/sdp.o
  CC      hw/bt/hci.o
  CC      hw/bt/hid.o
  CC      hw/bt/hci-csr.o
  CC      hw/char/ipoctal232.o
  CC      hw/char/parallel.o
  CC      hw/char/escc.o
  CC      hw/char/pl011.o
  CC      hw/char/serial.o
  CC      hw/char/serial-isa.o
  CC      hw/char/virtio-console.o
  CC      hw/char/serial-pci.o
  CC      hw/char/xilinx_uartlite.o
  CC      hw/char/cadence_uart.o
  CC      hw/char/cmsdk-apb-uart.o
  CC      hw/char/etraxfs_ser.o
  CC      hw/char/debugcon.o
  CC      hw/char/grlib_apbuart.o
  CC      hw/char/imx_serial.o
  CC      hw/char/lm32_juart.o
  CC      hw/char/milkymist-uart.o
  CC      hw/char/lm32_uart.o
  CC      hw/char/sclpconsole.o
  CC      hw/char/sclpconsole-lm.o
  CC      hw/core/qdev.o
  CC      hw/core/bus.o
  CC      hw/core/qdev-properties.o
  CC      hw/core/reset.o
  CC      hw/core/fw-path-provider.o
  CC      hw/core/irq.o
  CC      hw/core/hotplug.o
  CC      hw/core/empty_slot.o
  CC      hw/core/nmi.o
  CC      hw/core/stream.o
  CC      hw/core/ptimer.o
  CC      hw/core/sysbus.o
  CC      hw/core/machine.o
  CC      hw/core/loader.o
  CC      hw/core/loader-fit.o
  CC      hw/core/qdev-properties-system.o
  CC      hw/core/register.o
  CC      hw/core/or-irq.o
  CC      hw/core/platform-bus.o
  CC      hw/cpu/core.o
  CC      hw/display/ads7846.o
  CC      hw/display/g364fb.o
  CC      hw/display/cirrus_vga.o
  CC      hw/display/jazz_led.o
  CC      hw/display/pl110.o
  CC      hw/display/ssd0303.o
  CC      hw/display/ssd0323.o
  CC      hw/display/vga-pci.o
  CC      hw/display/vga-isa.o
  CC      hw/display/vga-isa-mm.o
  CC      hw/display/vmware_vga.o
  CC      hw/display/blizzard.o
  CC      hw/display/exynos4210_fimd.o
  CC      hw/display/framebuffer.o
  CC      hw/display/milkymist-vgafb.o
  CC      hw/display/tc6393xb.o
  CC      hw/dma/puv3_dma.o
  CC      hw/dma/rc4030.o
  CC      hw/dma/pl080.o
  CC      hw/dma/pl330.o
  CC      hw/dma/i82374.o
  CC      hw/dma/i8257.o
  CC      hw/dma/xilinx_axidma.o
  CC      hw/dma/xlnx-zynq-devcfg.o
  CC      hw/dma/etraxfs_dma.o
  CC      hw/dma/sparc32_dma.o
  CC      hw/dma/sun4m_iommu.o
  CC      hw/gpio/max7310.o
  CC      hw/gpio/pl061.o
  CC      hw/gpio/puv3_gpio.o
  CC      hw/gpio/mpc8xxx.o
  CC      hw/gpio/zaurus.o
  CC      hw/gpio/gpio_key.o
  CC      hw/i2c/core.o
  CC      hw/i2c/smbus.o
  CC      hw/i2c/smbus_eeprom.o
  CC      hw/i2c/i2c-ddc.o
  CC      hw/i2c/smbus_ich9.o
  CC      hw/i2c/versatile_i2c.o
  CC      hw/i2c/pm_smbus.o
  CC      hw/i2c/bitbang_i2c.o
  CC      hw/i2c/exynos4210_i2c.o
  CC      hw/i2c/imx_i2c.o
  CC      hw/i2c/aspeed_i2c.o
  CC      hw/ide/core.o
  CC      hw/ide/atapi.o
  CC      hw/ide/qdev.o
  CC      hw/ide/pci.o
  CC      hw/ide/isa.o
  CC      hw/ide/piix.o
  CC      hw/ide/cmd646.o
  CC      hw/ide/macio.o
  CC      hw/ide/mmio.o
  CC      hw/ide/microdrive.o
  CC      hw/ide/via.o
  CC      hw/ide/ahci.o
  CC      hw/ide/ich.o
  CC      hw/ide/ahci-allwinner.o
  CC      hw/input/adb.o
  CC      hw/input/hid.o
  CC      hw/input/lm832x.o
  CC      hw/input/pckbd.o
  CC      hw/input/pl050.o
  CC      hw/input/ps2.o
  CC      hw/input/stellaris_input.o
  CC      hw/input/tsc2005.o
  CC      hw/input/vmmouse.o
  CC      hw/input/virtio-input.o
  CC      hw/input/virtio-input-hid.o
  CC      hw/intc/heathrow_pic.o
  CC      hw/intc/i8259_common.o
  CC      hw/input/virtio-input-host.o
  CC      hw/intc/i8259.o
  CC      hw/intc/pl190.o
  CC      hw/intc/puv3_intc.o
  CC      hw/intc/xilinx_intc.o
  CC      hw/intc/etraxfs_pic.o
  CC      hw/intc/imx_avic.o
  CC      hw/intc/lm32_pic.o
  CC      hw/intc/realview_gic.o
  CC      hw/intc/slavio_intctl.o
  CC      hw/intc/ioapic_common.o
  CC      hw/intc/arm_gic_common.o
  CC      hw/intc/arm_gic.o
  CC      hw/intc/arm_gicv2m.o
  CC      hw/intc/arm_gicv3_common.o
  CC      hw/intc/arm_gicv3.o
  CC      hw/intc/arm_gicv3_dist.o
  CC      hw/intc/arm_gicv3_redist.o
  CC      hw/intc/arm_gicv3_its_common.o
  CC      hw/intc/openpic.o
  CC      hw/intc/intc.o
  CC      hw/ipack/ipack.o
  CC      hw/ipack/tpci200.o
  CC      hw/ipmi/ipmi.o
  CC      hw/ipmi/ipmi_bmc_sim.o
  CC      hw/ipmi/ipmi_bmc_extern.o
  CC      hw/ipmi/isa_ipmi_kcs.o
  CC      hw/ipmi/isa_ipmi_bt.o
  CC      hw/isa/isa-bus.o
  CC      hw/isa/apm.o
  CC      hw/isa/i82378.o
  CC      hw/isa/pc87312.o
  CC      hw/isa/piix4.o
  CC      hw/isa/vt82c686.o
  CC      hw/mem/pc-dimm.o
  CC      hw/mem/nvdimm.o
  CC      hw/misc/applesmc.o
  CC      hw/misc/tmp105.o
  CC      hw/misc/max111x.o
  CC      hw/misc/tmp421.o
  CC      hw/misc/debugexit.o
  CC      hw/misc/sga.o
  CC      hw/misc/pc-testdev.o
  CC      hw/misc/pci-testdev.o
  CC      hw/misc/edu.o
  CC      hw/misc/unimp.o
  CC      hw/misc/vmcoreinfo.o
  CC      hw/misc/arm_l2x0.o
  CC      hw/misc/arm_integrator_debug.o
  CC      hw/misc/a9scu.o
  CC      hw/misc/arm11scu.o
  CC      hw/misc/puv3_pm.o
  CC      hw/misc/macio/cuda.o
  CC      hw/misc/macio/mac_dbdma.o
  CC      hw/misc/macio/macio.o
  CC      hw/net/ne2000.o
  CC      hw/net/dp8393x.o
  CC      hw/net/eepro100.o
  CC      hw/net/pcnet-pci.o
  CC      hw/net/pcnet.o
  CC      hw/net/e1000.o
  CC      hw/net/e1000x_common.o
  CC      hw/net/net_tx_pkt.o
  CC      hw/net/net_rx_pkt.o
  CC      hw/net/e1000e.o
  CC      hw/net/e1000e_core.o
  CC      hw/net/rtl8139.o
  CC      hw/net/vmxnet3.o
  CC      hw/net/smc91c111.o
  CC      hw/net/lan9118.o
  CC      hw/net/ne2000-isa.o
  CC      hw/net/opencores_eth.o
  CC      hw/net/xgmac.o
  CC      hw/net/mipsnet.o
  CC      hw/net/xilinx_axienet.o
  CC      hw/net/allwinner_emac.o
  CC      hw/net/imx_fec.o
  CC      hw/net/cadence_gem.o
  CC      hw/net/stellaris_enet.o
  CC      hw/net/lance.o
  CC      hw/net/sunhme.o
  CC      hw/net/ftgmac100.o
  CC      hw/net/rocker/rocker_desc.o
  CC      hw/net/rocker/rocker_world.o
  CC      hw/net/sungem.o
  CC      hw/net/rocker/rocker.o
  CC      hw/net/rocker/rocker_of_dpa.o
  CC      hw/net/rocker/rocker_fp.o
  CC      hw/nvram/ds1225y.o
  CC      hw/nvram/eeprom93xx.o
  CC      hw/nvram/fw_cfg.o
  CC      hw/nvram/chrp_nvram.o
  CC      hw/nvram/mac_nvram.o
  CC      hw/pci-bridge/pci_bridge_dev.o
  CC      hw/pci-bridge/pcie_root_port.o
  CC      hw/pci-bridge/gen_pcie_root_port.o
  CC      hw/pci-bridge/pcie_pci_bridge.o
  CC      hw/pci-bridge/pci_expander_bridge.o
  CC      hw/pci-bridge/xio3130_upstream.o
  CC      hw/pci-bridge/xio3130_downstream.o
  CC      hw/pci-bridge/ioh3420.o
  CC      hw/pci-bridge/i82801b11.o
  CC      hw/pci-bridge/dec.o
  CC      hw/pci-host/pam.o
  CC      hw/pci-host/prep.o
  CC      hw/pci-host/grackle.o
  CC      hw/pci-host/uninorth.o
  CC      hw/pci-host/ppce500.o
  CC      hw/pci-host/versatile.o
  CC      hw/pci-host/apb.o
  CC      hw/pci-host/piix.o
  CC      hw/pci-host/bonito.o
  CC      hw/pci-host/q35.o
  CC      hw/pci-host/gpex.o
  CC      hw/pci-host/xilinx-pcie.o
  CC      hw/pci/pci_bridge.o
  CC      hw/pci/pci.o
  CC      hw/pci/msix.o
  CC      hw/pci/msi.o
  CC      hw/pci/shpc.o
  CC      hw/pci/slotid_cap.o
  CC      hw/pci/pci_host.o
  CC      hw/pci/pcie_host.o
  CC      hw/pci/pci-stub.o
  CC      hw/pci/pcie.o
  CC      hw/pci/pcie_aer.o
  CC      hw/pci/pcie_port.o
  CC      hw/pcmcia/pcmcia.o
  CC      hw/scsi/scsi-disk.o
  CC      hw/scsi/scsi-generic.o
  CC      hw/scsi/scsi-bus.o
  CC      hw/scsi/lsi53c895a.o
  CC      hw/scsi/mptsas.o
  CC      hw/scsi/mptendian.o
  CC      hw/scsi/mptconfig.o
  CC      hw/scsi/megasas.o
  CC      hw/scsi/esp.o
  CC      hw/scsi/vmw_pvscsi.o
  CC      hw/scsi/esp-pci.o
  CC      hw/sd/pl181.o
  CC      hw/sd/ssi-sd.o
  CC      hw/sd/sd.o
  CC      hw/sd/core.o
  CC      hw/sd/sdhci.o
  CC      hw/smbios/smbios_type_38.o
  CC      hw/smbios/smbios.o
  CC      hw/smbios/smbios-stub.o
  CC      hw/ssi/pl022.o
  CC      hw/smbios/smbios_type_38-stub.o
  CC      hw/ssi/ssi.o
  CC      hw/ssi/xilinx_spi.o
  CC      hw/ssi/xilinx_spips.o
  CC      hw/ssi/aspeed_smc.o
  CC      hw/ssi/stm32f2xx_spi.o
  CC      hw/ssi/mss-spi.o
  CC      hw/timer/arm_timer.o
  CC      hw/timer/arm_mptimer.o
  CC      hw/timer/armv7m_systick.o
  CC      hw/timer/a9gtimer.o
  CC      hw/timer/cadence_ttc.o
  CC      hw/timer/ds1338.o
  CC      hw/timer/hpet.o
  CC      hw/timer/i8254_common.o
  CC      hw/timer/i8254.o
  CC      hw/timer/m48t59.o
  CC      hw/timer/m48t59-isa.o
  CC      hw/timer/pl031.o
  CC      hw/timer/puv3_ost.o
  CC      hw/timer/twl92230.o
  CC      hw/timer/xilinx_timer.o
  CC      hw/timer/slavio_timer.o
  CC      hw/timer/etraxfs_timer.o
  CC      hw/timer/imx_epit.o
  CC      hw/timer/grlib_gptimer.o
  CC      hw/timer/imx_gpt.o
  CC      hw/timer/lm32_timer.o
  CC      hw/timer/milkymist-sysctl.o
  CC      hw/timer/stm32f2xx_timer.o
  CC      hw/timer/aspeed_timer.o
  CC      hw/timer/sun4v-rtc.o
  CC      hw/timer/cmsdk-apb-timer.o
  CC      hw/timer/mss-timer.o
  CC      hw/tpm/tpm_tis.o
  CC      hw/tpm/tpm_emulator.o
  CC      hw/tpm/tpm_util.o
  CC      hw/usb/core.o
  CC      hw/usb/combined-packet.o
  CC      hw/usb/bus.o
  CC      hw/usb/libhw.o
  CC      hw/usb/desc.o
  CC      hw/usb/desc-msos.o
  CC      hw/usb/hcd-uhci.o
  CC      hw/usb/hcd-ohci.o
  CC      hw/usb/hcd-ehci.o
  CC      hw/usb/hcd-ehci-pci.o
  CC      hw/usb/hcd-ehci-sysbus.o
  CC      hw/usb/hcd-xhci.o
  CC      hw/usb/hcd-xhci-nec.o
  CC      hw/usb/hcd-musb.o
  CC      hw/usb/dev-hub.o
  CC      hw/usb/dev-hid.o
  CC      hw/usb/dev-storage.o
  CC      hw/usb/dev-wacom.o
  CC      hw/usb/dev-uas.o
  CC      hw/usb/dev-audio.o
  CC      hw/usb/dev-serial.o
  CC      hw/usb/dev-network.o
  CC      hw/usb/dev-bluetooth.o
  CC      hw/usb/dev-smartcard-reader.o
  CC      hw/usb/dev-mtp.o
  CC      hw/usb/host-libusb.o
  CC      hw/usb/host-legacy.o
  CC      hw/usb/host-stub.o
  CC      hw/virtio/virtio-rng.o
  CC      hw/virtio/virtio-pci.o
  CC      hw/virtio/virtio-bus.o
  CC      hw/virtio/virtio-mmio.o
  CC      hw/virtio/vhost-stub.o
  CC      hw/watchdog/watchdog.o
  CC      hw/watchdog/wdt_i6300esb.o
  CC      hw/watchdog/wdt_ib700.o
  CC      hw/watchdog/wdt_diag288.o
  CC      hw/watchdog/wdt_aspeed.o
  CC      migration/migration.o
  CC      migration/socket.o
  CC      migration/fd.o
  CC      migration/exec.o
  CC      migration/tls.o
  CC      migration/channel.o
  CC      migration/savevm.o
  CC      migration/colo-comm.o
  CC      migration/colo.o
  CC      migration/colo-failover.o
  CC      migration/vmstate.o
  CC      migration/vmstate-types.o
  CC      migration/page_cache.o
  CC      migration/qemu-file.o
  CC      migration/global_state.o
  CC      migration/qemu-file-channel.o
  CC      migration/xbzrle.o
  CC      migration/postcopy-ram.o
  CC      migration/qjson.o
  CC      migration/rdma.o
  CC      migration/block.o
  CC      net/net.o
  CC      net/queue.o
  CC      net/checksum.o
  CC      net/util.o
  CC      net/hub.o
  CC      net/socket.o
  CC      net/dump.o
  CC      net/eth.o
  CC      net/l2tpv3.o
  CC      net/vhost-user.o
  CC      net/slirp.o
  CC      net/filter.o
  CC      net/filter-buffer.o
  CC      net/filter-mirror.o
  CC      net/colo-compare.o
  CC      net/colo.o
  CC      net/filter-rewriter.o
  CC      net/filter-replay.o
  CC      net/tap.o
  CC      net/tap-linux.o
  CC      qom/cpu.o
  CC      replay/replay.o
  CC      replay/replay-internal.o
  CC      replay/replay-events.o
  CC      replay/replay-time.o
  CC      replay/replay-input.o
  CC      replay/replay-snapshot.o
  CC      replay/replay-char.o
  CC      replay/replay-net.o
  CC      replay/replay-audio.o
  CC      slirp/cksum.o
  CC      slirp/if.o
  CC      slirp/ip_icmp.o
  CC      slirp/ip6_icmp.o
  CC      slirp/ip6_input.o
  CC      slirp/ip6_output.o
  CC      slirp/ip_input.o
  CC      slirp/ip_output.o
  CC      slirp/dnssearch.o
  CC      slirp/dhcpv6.o
  CC      slirp/slirp.o
  CC      slirp/mbuf.o
  CC      slirp/misc.o
  CC      slirp/sbuf.o
  CC      slirp/socket.o
  CC      slirp/tcp_input.o
  CC      slirp/tcp_output.o
  CC      slirp/tcp_subr.o
  CC      slirp/tcp_timer.o
  CC      slirp/udp.o
  CC      slirp/udp6.o
  CC      slirp/bootp.o
  CC      slirp/tftp.o
  CC      slirp/arp_table.o
  CC      slirp/ndp_table.o
  CC      slirp/ncsi.o
  CC      ui/keymaps.o
  CC      ui/console.o
  CC      ui/cursor.o
  CC      ui/qemu-pixman.o
  CC      ui/input.o
  CC      ui/input-keymap.o
  CC      ui/input-legacy.o
  CC      ui/input-linux.o
  CC      ui/sdl.o
  CC      ui/sdl_zoom.o
  CC      ui/x_keymap.o
  CC      ui/curses.o
  CC      ui/vnc.o
  CC      ui/vnc-enc-zlib.o
  CC      ui/vnc-enc-hextile.o
  CC      ui/vnc-enc-tight.o
  CC      ui/vnc-palette.o
  CC      ui/vnc-enc-zrle.o
  CC      ui/vnc-auth-vencrypt.o
  CC      ui/vnc-auth-sasl.o
  CC      ui/vnc-jobs.o
  CC      ui/gtk.o
  CC      ui/vnc-ws.o
  CC      chardev/char-fd.o
  CC      chardev/char.o
  CC      chardev/char-fe.o
  CC      chardev/char-file.o
  CC      chardev/char-io.o
  CC      chardev/char-mux.o
  CC      chardev/char-null.o
  CC      chardev/char-parallel.o
  CC      chardev/char-pipe.o
  CC      chardev/char-pty.o
  CC      chardev/char-ringbuf.o
  CC      chardev/char-serial.o
  CC      chardev/char-socket.o
  CC      chardev/char-stdio.o
  CC      chardev/char-udp.o
  CCAS    spapr-rtas/spapr-rtas.o
  LINK    tests/qemu-iotests/socket_scm_helper
  CC      qga/commands.o
  CC      qga/guest-agent-command-state.o
  Building spapr-rtas/spapr-rtas.img
  CC      qga/main.o
  Building spapr-rtas/spapr-rtas.bin
  CC      qga/commands-posix.o
rm spapr-rtas.img spapr-rtas.o
  CC      qga/channel-posix.o
  CC      qga/qapi-generated/qga-qapi-types.o
  CC      qga/qapi-generated/qga-qapi-visit.o
  CC      qga/qapi-generated/qga-qmp-marshal.o
  CC      qemu-img.o
  AR      libqemuutil.a
  LINK    qemu-ga
  LINK    ivshmem-client
  LINK    ivshmem-server
  LINK    qemu-nbd
  LINK    qemu-img
  LINK    qemu-io
  LINK    fsdev/virtfs-proxy-helper
  LINK    scsi/qemu-pr-helper
  LINK    qemu-bridge-helper
  GEN     mipsn32el-linux-user/config-target.h
  CC      mipsn32el-linux-user/tcg/tcg.o
  CC      mipsn32el-linux-user/exec.o
  CC      mipsn32el-linux-user/tcg/tcg-op.o
  CC      mipsn32el-linux-user/tcg/optimize.o
  CC      mipsn32el-linux-user/tcg/tcg-common.o
  CC      mipsn32el-linux-user/fpu/softfloat.o
  CC      mipsn32el-linux-user/disas.o
  CC      mipsn32el-linux-user/gdbstub.o
  CC      mipsn32el-linux-user/thunk.o
  CC      mipsn32el-linux-user/accel/stubs/hax-stub.o
  CC      mipsn32el-linux-user/accel/stubs/kvm-stub.o
  CC      mipsn32el-linux-user/accel/tcg/tcg-runtime.o
  CC      mipsn32el-linux-user/accel/tcg/cpu-exec.o
  CC      mipsn32el-linux-user/accel/tcg/cpu-exec-common.o
  CC      mipsn32el-linux-user/accel/tcg/translate-all.o
  GEN     mips64-linux-user/config-target.h
  CC      mipsn32el-linux-user/accel/tcg/translator.o
  CC      mipsn32el-linux-user/accel/tcg/user-exec.o
  CC      mipsn32el-linux-user/linux-user/main.o
  CC      mipsn32el-linux-user/linux-user/syscall.o
  CC      mipsn32el-linux-user/accel/tcg/user-exec-stub.o
  CC      mipsn32el-linux-user/linux-user/mmap.o
  GEN     arm-linux-user/config-target.h
  CC      mipsn32el-linux-user/linux-user/strace.o
  CC      mipsn32el-linux-user/linux-user/uname.o
  CC      mipsn32el-linux-user/linux-user/signal.o
  GEN     microblazeel-linux-user/config-target.h
  CC      mipsn32el-linux-user/linux-user/linuxload.o
  CC      mipsn32el-linux-user/target/mips/dsp_helper.o
  CCAS    mipsn32el-linux-user/linux-user/safe-syscall.o
  CC      mipsn32el-linux-user/target/mips/translate.o
  CC      mips64-linux-user/exec.o
  CC      arm-linux-user/exec.o
  CC      mipsn32el-linux-user/linux-user/uaccess.o
  CC      mipsn32el-linux-user/target/mips/op_helper.o
  CC      mipsn32el-linux-user/linux-user/elfload.o
  CC      mipsn32el-linux-user/target/mips/lmi_helper.o
  CC      mipsn32el-linux-user/target/mips/helper.o
  CC      mipsn32el-linux-user/target/mips/cpu.o
  CC      arm-linux-user/tcg/tcg.o
  CC      mips64-linux-user/tcg/tcg.o
  GEN     i386-linux-user/config-target.h
  GEN     mips64el-linux-user/config-target.h
  CC      arm-linux-user/tcg/tcg-op.o
  CC      mips64-linux-user/tcg/tcg-op.o
  GEN     mipsn32-linux-user/config-target.h
  CC      mipsn32el-linux-user/target/mips/gdbstub.o
  CC      arm-linux-user/tcg/tcg-common.o
  CC      arm-linux-user/fpu/softfloat.o
  CC      arm-linux-user/tcg/optimize.o
  CC      microblazeel-linux-user/exec.o
  GEN     alpha-linux-user/config-target.h
  GEN     cris-linux-user/config-target.h
  GEN     microblaze-linux-user/config-target.h
  GEN     aarch64-linux-user/config-target.h
  GEN     m68k-linux-user/config-target.h
  CC      i386-linux-user/exec.o
  GEN     hppa-linux-user/config-target.h
  CC      mipsn32el-linux-user/target/mips/msa_helper.o
  GEN     tilegx-linux-user/config-target.h
  GEN     sh4-linux-user/config-target.h
  GEN     mipsel-linux-user/config-target.h
  CC      mipsn32-linux-user/exec.o
  CC      mips64el-linux-user/exec.o
  CC      alpha-linux-user/exec.o
  GEN     mips-linux-user/config-target.h
  GEN     x86_64-linux-user/config-target.h
  GEN     armeb-linux-user/config-target.h
  CC      aarch64-linux-user/exec.o
  CC      microblaze-linux-user/exec.o
  GEN     sparc32plus-linux-user/config-target.h
  CC      cris-linux-user/exec.o
  GEN     or1k-linux-user/config-target.h
  GEN     nios2-linux-user/config-target.h
  CC      tilegx-linux-user/exec.o
  GEN     ppc-linux-user/config-target.h
  GEN     sparc-linux-user/config-target.h
  CC      sh4-linux-user/exec.o
  CC      hppa-linux-user/exec.o
  CC      m68k-linux-user/exec.o
  GEN     ppc64le-linux-user/config-target.h
  GEN     sh4eb-linux-user/config-target.h
  CC      x86_64-linux-user/exec.o
  CC      sparc32plus-linux-user/exec.o
  CC      mipsel-linux-user/exec.o
  CC      mips-linux-user/exec.o
  CC      ppc-linux-user/exec.o
  GEN     ppc64abi32-linux-user/config-target.h
  GEN     sparc64-linux-user/config-target.h
  GEN     ppc64-linux-user/config-target.h
  CC      or1k-linux-user/exec.o
  CC      armeb-linux-user/exec.o
  CC      nios2-linux-user/exec.o
  CC      sh4eb-linux-user/exec.o
  CC      sparc-linux-user/exec.o
  CC      s390x-linux-user/gen-features
  CC      ppc64abi32-linux-user/exec.o
  CC      sparc64-linux-user/exec.o
  CC      ppc64le-linux-user/exec.o
  CC      ppc64-linux-user/exec.o
  CC      mipsn32el-linux-user/target/mips/mips-semi.o
  CC      sparc32plus-linux-user/tcg/tcg.o
  CC      mips64-linux-user/tcg/optimize.o
  CC      sh4-linux-user/tcg/tcg.o
  GEN     s390x-linux-user/config-target.h
  CC      ppc-linux-user/tcg/tcg.o
  GEN     s390x-linux-user/gen-features.h
  CC      ppc64-linux-user/tcg/tcg.o
  GEN     cris-softmmu/hmp-commands.h
  GEN     cris-softmmu/hmp-commands-info.h
  CC      s390x-linux-user/exec.o
  GEN     trace/generated-helpers.c
  GEN     tricore-softmmu/hmp-commands.h
  GEN     tricore-softmmu/hmp-commands-info.h
  CC      mips64el-linux-user/tcg/tcg.o
  CC      cris-linux-user/tcg/tcg.o
  CC      tilegx-linux-user/tcg/tcg.o
  CC      mips64-linux-user/tcg/tcg-common.o
  CC      s390x-linux-user/tcg/tcg.o
  GEN     moxie-softmmu/hmp-commands.h
  GEN     xtensaeb-softmmu/hmp-commands.h
  GEN     cris-softmmu/config-target.h
  CC      arm-linux-user/disas.o
  CC      hppa-linux-user/tcg/tcg.o
  GEN     s390x-softmmu/hmp-commands.h
  CC      cris-softmmu/exec.o
  GEN     microblazeel-softmmu/hmp-commands.h
  CC      microblazeel-linux-user/tcg/tcg.o
  CC      mips64-linux-user/fpu/softfloat.o
  GEN     unicore32-softmmu/hmp-commands.h
  GEN     m68k-softmmu/hmp-commands.h
  CC      sparc-linux-user/tcg/tcg.o
  CC      alpha-linux-user/tcg/tcg.o
  GEN     lm32-softmmu/hmp-commands.h
  CC      s390x-linux-user/tcg/tcg-op.o
  GEN     xtensa-softmmu/hmp-commands.h
  GEN     nios2-softmmu/hmp-commands.h
  GEN     tricore-softmmu/config-target.h
  CC      aarch64-linux-user/tcg/tcg.o
  GEN     microblaze-softmmu/hmp-commands.h
  GEN     ppcemb-softmmu/hmp-commands.h
  GEN     xtensa-softmmu/hmp-commands-info.h
  CC      i386-linux-user/tcg/tcg.o
  GEN     xtensaeb-softmmu/hmp-commands-info.h
  CC      or1k-linux-user/tcg/tcg.o
  CC      mipsn32-linux-user/tcg/tcg.o
  CC      sparc64-linux-user/tcg/tcg.o
  CC      sparc32plus-linux-user/tcg/tcg-op.o
  CC      tricore-softmmu/exec.o
  GEN     moxie-softmmu/hmp-commands-info.h
  GEN     or1k-softmmu/hmp-commands.h
  CC      m68k-linux-user/tcg/tcg.o
  CC      mipsel-linux-user/tcg/tcg.o
  CC      mipsn32-linux-user/tcg/tcg-op.o
  GEN     s390x-softmmu/hmp-commands-info.h
  CC      x86_64-linux-user/tcg/tcg.o
  GEN     ppcemb-softmmu/hmp-commands-info.h
  CC      sparc-linux-user/tcg/tcg-op.o
  GEN     sparc-softmmu/hmp-commands.h
  GEN     xtensaeb-softmmu/config-target.h
  CC      aarch64-linux-user/tcg/tcg-op.o
  CC      nios2-linux-user/tcg/tcg.o
  CC      sh4eb-linux-user/tcg/tcg.o
  GEN     lm32-softmmu/hmp-commands-info.h
  GEN     unicore32-softmmu/hmp-commands-info.h
  CC      xtensaeb-softmmu/exec.o
  CC      ppc64le-linux-user/tcg/tcg.o
  CC      aarch64-linux-user/tcg/optimize.o
  GEN     microblazeel-softmmu/hmp-commands-info.h
  CC      ppc64le-linux-user/tcg/tcg-op.o
  CC      microblaze-linux-user/tcg/tcg.o
  CC      sparc64-linux-user/tcg/tcg-op.o
  CC      s390x-linux-user/tcg/optimize.o
  GEN     m68k-softmmu/hmp-commands-info.h
  GEN     microblaze-softmmu/hmp-commands-info.h
  GEN     xtensa-softmmu/config-target.h
  GEN     moxie-softmmu/config-target.h
  CC      armeb-linux-user/tcg/tcg.o
  GEN     nios2-softmmu/hmp-commands-info.h
  CC      s390x-softmmu/gen-features
  GEN     mips64el-softmmu/hmp-commands.h
  GEN     nios2-softmmu/config-target.h
  CC      xtensa-softmmu/exec.o
  CC      moxie-softmmu/exec.o
  GEN     ppcemb-softmmu/config-target.h
  GEN     unicore32-softmmu/config-target.h
  CC      ppc64le-linux-user/tcg/optimize.o
  CC      i386-linux-user/tcg/tcg-op.o
  GEN     aarch64-softmmu/hmp-commands.h
  CC      ppc64le-linux-user/tcg/tcg-common.o
  GEN     lm32-softmmu/config-target.h
  GEN     mips64el-softmmu/hmp-commands-info.h
  GEN     microblazeel-softmmu/config-target.h
  GEN     sparc-softmmu/hmp-commands-info.h
  GEN     sparc64-softmmu/hmp-commands.h
  CC      mips-linux-user/tcg/tcg.o
  CC      ppc64abi32-linux-user/tcg/tcg.o
  GEN     m68k-softmmu/config-target.h
  CC      lm32-softmmu/exec.o
  CC      unicore32-softmmu/exec.o
  CC      ppcemb-softmmu/exec.o
  GEN     or1k-softmmu/hmp-commands-info.h
  GEN     microblaze-softmmu/config-target.h
  GEN     alpha-softmmu/hmp-commands.h
  GEN     s390x-softmmu/config-target.h
  CC      m68k-softmmu/exec.o
  CC      lm32-softmmu/tcg/tcg.o
  CC      mipsn32-linux-user/tcg/optimize.o
  CC      microblazeel-softmmu/exec.o
  GEN     mips64-softmmu/hmp-commands.h
  GEN     s390x-softmmu/gen-features.h
  GEN     sparc-softmmu/config-target.h
  CC      m68k-softmmu/tcg/tcg.o
  CC      nios2-softmmu/exec.o
  GEN     mipsel-softmmu/hmp-commands.h
  GEN     sh4-softmmu/hmp-commands.h
  CC      microblaze-linux-user/tcg/tcg-op.o
  CC      microblaze-softmmu/exec.o
  CC      s390x-softmmu/exec.o
  CC      sparc-softmmu/exec.o
  GEN     or1k-softmmu/config-target.h
  CC      or1k-softmmu/exec.o
  GEN     mips64el-softmmu/config-target.h
  GEN     aarch64-softmmu/hmp-commands-info.h
  GEN     sh4-softmmu/hmp-commands-info.h
  GEN     sh4eb-softmmu/hmp-commands.h
  CC      m68k-softmmu/tcg/tcg-op.o
  GEN     i386-softmmu/hmp-commands.h
  GEN     ppc64-softmmu/hmp-commands.h
  CC      mips64el-softmmu/exec.o
  GEN     i386-softmmu/hmp-commands-info.h
  GEN     mips-softmmu/hmp-commands.h
  GEN     sparc64-softmmu/hmp-commands-info.h
  GEN     mipsel-softmmu/hmp-commands-info.h
  GEN     arm-softmmu/hmp-commands.h
  GEN     sh4-softmmu/config-target.h
  GEN     aarch64-softmmu/config-target.h
  GEN     mips64-softmmu/hmp-commands-info.h
  CC      s390x-linux-user/tcg/tcg-common.o
  GEN     alpha-softmmu/hmp-commands-info.h
  CC      sh4-softmmu/exec.o
  CC      mips64-linux-user/disas.o
  CC      aarch64-softmmu/exec.o
  GEN     x86_64-softmmu/hmp-commands.h
  GEN     x86_64-softmmu/hmp-commands-info.h
  GEN     ppc-softmmu/hmp-commands.h
  GEN     sh4eb-softmmu/hmp-commands-info.h
  GEN     sparc64-softmmu/config-target.h
  GEN     mipsel-softmmu/config-target.h
  CC      sparc64-softmmu/exec.o
  CC      mipsel-softmmu/exec.o
  GEN     alpha-softmmu/config-target.h
  GEN     i386-softmmu/config-target.h
  GEN     mips64-softmmu/config-target.h
  GEN     sh4eb-softmmu/config-target.h
  CC      alpha-softmmu/exec.o
  CC      x86_64-linux-user/tcg/tcg-op.o
  CC      hppa-linux-user/tcg/tcg-op.o
  CC      mips64-linux-user/gdbstub.o
  GEN     ppc64-softmmu/hmp-commands-info.h
  CC      unicore32-softmmu/tcg/tcg.o
  CC      mips64-softmmu/exec.o
  CC      sh4eb-softmmu/exec.o
  CC      mips64-linux-user/thunk.o
  CC      i386-softmmu/exec.o
  GEN     mips-softmmu/hmp-commands-info.h
  GEN     arm-softmmu/hmp-commands-info.h
  GEN     ppc-softmmu/hmp-commands-info.h
  GEN     x86_64-softmmu/config-target.h
  CC      x86_64-softmmu/exec.o
  GEN     ppc64-softmmu/config-target.h
  GEN     mips-softmmu/config-target.h
  CC      x86_64-linux-user/tcg/optimize.o
  GEN     arm-softmmu/config-target.h
  CC      ppc64-softmmu/exec.o
  CC      mips-softmmu/exec.o
  GEN     ppc-softmmu/config-target.h
  CC      arm-softmmu/exec.o
  CC      ppc-softmmu/exec.o
  CC      s390x-softmmu/tcg/tcg.o
  CC      xtensaeb-softmmu/tcg/tcg.o
  CC      mips64el-linux-user/tcg/tcg-op.o
  CC      x86_64-linux-user/tcg/tcg-common.o
  CC      microblazeel-softmmu/tcg/tcg.o
  CC      mipsel-linux-user/tcg/tcg-op.o
  CC      mips64-softmmu/tcg/tcg.o
  CC      mips64el-softmmu/tcg/tcg.o
  CC      mips-linux-user/tcg/tcg-op.o
  CC      mips64el-softmmu/tcg/tcg-op.o
  CC      aarch64-softmmu/tcg/tcg.o
  CC      arm-softmmu/tcg/tcg.o
  CC      mips64el-softmmu/tcg/optimize.o
  CC      mips-softmmu/tcg/tcg.o
  CC      ppc64-softmmu/tcg/tcg.o
  CC      lm32-softmmu/tcg/tcg-op.o
  CC      mipsn32-linux-user/tcg/tcg-common.o
  CC      mips64el-linux-user/tcg/optimize.o
  CC      sh4-linux-user/tcg/tcg-op.o
  CC      tricore-softmmu/tcg/tcg.o
  CC      microblazeel-linux-user/tcg/tcg-op.o
  CC      mipsn32-linux-user/fpu/softfloat.o
  CC      cris-linux-user/tcg/tcg-op.o
  CC      armeb-linux-user/tcg/tcg-op.o
  CC      mipsn32-linux-user/disas.o
  CC      microblaze-softmmu/tcg/tcg.o
  CC      ppc-softmmu/tcg/tcg.o
  CC      tilegx-linux-user/tcg/tcg-op.o
  CC      ppc-softmmu/tcg/tcg-op.o
  CC      mipsel-softmmu/tcg/tcg.o
  CC      sparc64-linux-user/tcg/optimize.o
  CC      microblazeel-linux-user/tcg/optimize.o
  CC      sh4eb-linux-user/tcg/tcg-op.o
  CC      ppcemb-softmmu/tcg/tcg.o
  CC      ppc64-softmmu/tcg/tcg-op.o
  CC      nios2-linux-user/tcg/tcg-op.o
  CC      alpha-linux-user/tcg/tcg-op.o
  CC      mipsn32-linux-user/gdbstub.o
  CC      ppc64-linux-user/tcg/tcg-op.o
  CC      m68k-linux-user/tcg/tcg-op.o
  CC      aarch64-linux-user/tcg/tcg-common.o
  CC      sparc32plus-linux-user/tcg/optimize.o
  CC      sparc32plus-linux-user/tcg/tcg-common.o
  CC      s390x-linux-user/fpu/softfloat.o
  CC      or1k-linux-user/tcg/tcg-op.o
  CC      mips-softmmu/tcg/tcg-op.o
  CC      mips64el-softmmu/tcg/tcg-common.o
  CC      x86_64-softmmu/tcg/tcg.o
  CC      xtensaeb-softmmu/tcg/tcg-op.o
  CC      hppa-linux-user/tcg/optimize.o
  CC      microblazeel-linux-user/tcg/tcg-common.o
  CC      ppc-linux-user/tcg/tcg-op.o
  CC      aarch64-linux-user/fpu/softfloat.o
  CC      ppc64abi32-linux-user/tcg/tcg-op.o
  CC      cris-softmmu/tcg/tcg.o
  CC      microblaze-linux-user/tcg/optimize.o
  CC      moxie-softmmu/tcg/tcg.o
  CC      hppa-linux-user/tcg/tcg-common.o
  CC      hppa-linux-user/fpu/softfloat.o
  CC      alpha-linux-user/tcg/optimize.o
  CC      ppc-softmmu/tcg/optimize.o
  CC      sparc-linux-user/tcg/optimize.o
  CC      nios2-softmmu/tcg/tcg.o
  CC      sparc64-linux-user/tcg/tcg-common.o
  CC      mipsel-softmmu/tcg/tcg-op.o
  CC      mips64-softmmu/tcg/tcg-op.o
  CC      alpha-softmmu/tcg/tcg.o
  CC      ppc64le-linux-user/fpu/softfloat.o
  CC      mips64el-linux-user/tcg/tcg-common.o
  CC      moxie-softmmu/tcg/tcg-op.o
  CC      sparc32plus-linux-user/fpu/softfloat.o
  CC      nios2-linux-user/tcg/optimize.o
  CC      sparc-softmmu/tcg/tcg.o
  CC      mipsel-linux-user/tcg/optimize.o
  CC      hppa-linux-user/disas.o
  CC      i386-linux-user/tcg/optimize.o
  CC      x86_64-linux-user/fpu/softfloat.o
  CC      sh4-linux-user/tcg/optimize.o
  CC      i386-softmmu/tcg/tcg.o
  CC      x86_64-softmmu/tcg/tcg-op.o
  CC      unicore32-softmmu/tcg/tcg-op.o
  CC      s390x-softmmu/tcg/tcg-op.o
  CC      unicore32-softmmu/tcg/optimize.o
  CC      tricore-softmmu/tcg/tcg-op.o
  CC      mips-softmmu/tcg/optimize.o
  CC      sh4-softmmu/tcg/tcg.o
  CC      s390x-softmmu/tcg/optimize.o
  CC      mipsel-softmmu/tcg/optimize.o
  CC      or1k-softmmu/tcg/tcg.o
  CC      sparc64-linux-user/fpu/softfloat.o
  CC      aarch64-softmmu/tcg/tcg-op.o
  CC      aarch64-softmmu/tcg/optimize.o
  CC      armeb-linux-user/tcg/optimize.o
  CC      alpha-softmmu/tcg/tcg-op.o
  CC      cris-softmmu/tcg/tcg-op.o
  GEN     arm-linux-user/gdbstub-xml.c
  CC      mips64el-linux-user/fpu/softfloat.o
  CC      mips-softmmu/tcg/tcg-common.o
  CC      m68k-softmmu/tcg/optimize.o
  CC      x86_64-linux-user/disas.o
  CC      x86_64-softmmu/tcg/optimize.o
  CC      or1k-softmmu/tcg/tcg-op.o
  CC      x86_64-softmmu/tcg/tcg-common.o
  CC      arm-linux-user/gdbstub.o
  CC      mips64-linux-user/accel/stubs/hax-stub.o
  CC      sparc64-softmmu/tcg/tcg.o
  CC      xtensa-softmmu/tcg/tcg.o
  CC      cris-linux-user/tcg/optimize.o
  CC      arm-softmmu/tcg/tcg-op.o
  CC      microblazeel-softmmu/tcg/tcg-op.o
  CC      ppc64le-linux-user/disas.o
  CC      sparc64-linux-user/disas.o
  CC      mips64-softmmu/tcg/optimize.o
  CC      tricore-softmmu/tcg/optimize.o
  CC      m68k-linux-user/tcg/optimize.o
  CC      m68k-linux-user/tcg/tcg-common.o
  CC      mips-linux-user/tcg/optimize.o
  CC      mips64-linux-user/accel/stubs/kvm-stub.o
  CC      nios2-linux-user/tcg/tcg-common.o
  CC      s390x-softmmu/tcg/tcg-common.o
  CC      armeb-linux-user/tcg/tcg-common.o
  CC      sh4eb-softmmu/tcg/tcg.o
  CC      sh4eb-softmmu/tcg/tcg-op.o
  CC      microblaze-linux-user/tcg/tcg-common.o
  CC      microblaze-softmmu/tcg/tcg-op.o
  CC      aarch64-softmmu/tcg/tcg-common.o
  CC      lm32-softmmu/tcg/optimize.o
  CC      m68k-softmmu/tcg/tcg-common.o
  CC      sparc-linux-user/tcg/tcg-common.o
  CC      ppc-linux-user/tcg/optimize.o
  CC      ppc-linux-user/tcg/tcg-common.o
  CC      ppc64-linux-user/tcg/optimize.o
  CC      mips64-linux-user/accel/tcg/tcg-runtime.o
  CC      ppc-linux-user/fpu/softfloat.o
  CC      tricore-softmmu/tcg/tcg-common.o
  CC      mips64el-linux-user/disas.o
  CC      alpha-linux-user/tcg/tcg-common.o
  CC      arm-linux-user/thunk.o
  CC      mips64el-softmmu/fpu/softfloat.o
  CC      tricore-softmmu/fpu/softfloat.o
  CC      sparc64-softmmu/tcg/tcg-op.o
  CC      microblaze-linux-user/fpu/softfloat.o
  CC      tricore-softmmu/disas.o
  GEN     x86_64-linux-user/gdbstub-xml.c
  CC      sparc32plus-linux-user/disas.o
  CC      mipsel-linux-user/tcg/tcg-common.o
  CC      mips-softmmu/fpu/softfloat.o
  CC      s390x-softmmu/fpu/softfloat.o
  CC      sparc-linux-user/fpu/softfloat.o
  CC      s390x-softmmu/disas.o
  CC      x86_64-softmmu/fpu/softfloat.o
  CC      x86_64-softmmu/disas.o
  CC      i386-softmmu/tcg/tcg-op.o
  CC      ppc64abi32-linux-user/tcg/optimize.o
  CC      ppc-softmmu/tcg/tcg-common.o
  CC      ppc64abi32-linux-user/tcg/tcg-common.o
  CC      mips-softmmu/disas.o
  CC      mips64-linux-user/accel/tcg/cpu-exec.o
  CC      m68k-softmmu/fpu/softfloat.o
  CC      cris-softmmu/tcg/optimize.o
  CC      tilegx-linux-user/tcg/optimize.o
  CC      arm-linux-user/accel/stubs/hax-stub.o
  CC      moxie-softmmu/tcg/optimize.o
  CC      i386-linux-user/tcg/tcg-common.o
  CC      cris-softmmu/tcg/tcg-common.o
  CC      microblazeel-softmmu/tcg/optimize.o
  CC      m68k-softmmu/disas.o
  CC      mips-linux-user/tcg/tcg-common.o
  CC      aarch64-linux-user/disas.o
  CC      mipsel-softmmu/tcg/tcg-common.o
  CC      mipsel-linux-user/fpu/softfloat.o
  CC      ppc-softmmu/fpu/softfloat.o
  CC      i386-linux-user/fpu/softfloat.o
  CC      sparc32plus-linux-user/gdbstub.o
  CC      sh4-softmmu/tcg/tcg-op.o
  CC      sparc-softmmu/tcg/tcg-op.o
  CC      arm-linux-user/accel/stubs/kvm-stub.o
  CC      or1k-softmmu/tcg/optimize.o
  CC      m68k-linux-user/fpu/softfloat.o
  CC      ppc64-softmmu/tcg/optimize.o
  CC      sparc64-softmmu/tcg/optimize.o
  CC      sh4-linux-user/tcg/tcg-common.o
  CC      sparc-softmmu/tcg/optimize.o
  CC      sh4-linux-user/fpu/softfloat.o
  CC      sparc64-linux-user/gdbstub.o
  CC      ppc64abi32-linux-user/fpu/softfloat.o
  CC      cris-linux-user/tcg/tcg-common.o
  CC      mips64-linux-user/accel/tcg/cpu-exec-common.o
  CC      sparc-softmmu/tcg/tcg-common.o
  CC      arm-linux-user/accel/tcg/tcg-runtime.o
  CC      lm32-softmmu/tcg/tcg-common.o
  CC      microblazeel-linux-user/fpu/softfloat.o
  CC      mips-linux-user/fpu/softfloat.o
  CC      aarch64-softmmu/fpu/softfloat.o
  CC      sh4-linux-user/disas.o
  CC      arm-linux-user/accel/tcg/cpu-exec.o
  CC      sh4eb-linux-user/tcg/optimize.o
  CC      cris-linux-user/fpu/softfloat.o
  CC      lm32-softmmu/fpu/softfloat.o
  CC      alpha-softmmu/tcg/optimize.o
  CC      mips64-linux-user/accel/tcg/translate-all.o
  CC      x86_64-linux-user/gdbstub.o
  CC      mipsn32-linux-user/thunk.o
  GEN     x86_64-softmmu/gdbstub-xml.c
  CC      microblaze-softmmu/tcg/optimize.o
  CC      tilegx-linux-user/tcg/tcg-common.o
  CC      or1k-linux-user/tcg/optimize.o
  GEN     s390x-softmmu/gdbstub-xml.c
  CC      microblaze-linux-user/disas.o
  CC      ppc-linux-user/disas.o
  CC      xtensaeb-softmmu/tcg/optimize.o
  CC      cris-linux-user/disas.o
  CC      mipsel-linux-user/disas.o
  CC      mipsn32-linux-user/accel/stubs/hax-stub.o
  CC      mips64el-softmmu/disas.o
  CC      sh4eb-linux-user/tcg/tcg-common.o
  CC      nios2-linux-user/fpu/softfloat.o
  CC      mips64el-softmmu/arch_init.o
  CC      alpha-linux-user/fpu/softfloat.o
  CC      lm32-softmmu/disas.o
  CC      armeb-linux-user/fpu/softfloat.o
  CC      sparc32plus-linux-user/thunk.o
  CC      mipsn32-linux-user/accel/stubs/kvm-stub.o
  CC      arm-linux-user/accel/tcg/cpu-exec-common.o
  CC      sh4-linux-user/gdbstub.o
  GEN     ppc64le-linux-user/gdbstub-xml.c
  CC      mips-linux-user/disas.o
  CC      i386-softmmu/tcg/optimize.o
  CC      tilegx-linux-user/fpu/softfloat.o
  CC      ppc64-linux-user/tcg/tcg-common.o
  CC      ppc-softmmu/disas.o
  CC      mips64el-linux-user/gdbstub.o
  CC      x86_64-softmmu/arch_init.o
  CC      m68k-linux-user/disas.o
  CC      sparc64-softmmu/tcg/tcg-common.o
  CC      arm-softmmu/tcg/optimize.o
  CC      ppc64le-linux-user/gdbstub.o
  CC      mips64-linux-user/accel/tcg/translator.o
  CC      cris-linux-user/gdbstub.o
  CC      arm-linux-user/accel/tcg/translate-all.o
  CC      cris-linux-user/thunk.o
  CC      ppcemb-softmmu/tcg/tcg-op.o
  CC      xtensa-softmmu/tcg/tcg-op.o
  CC      i386-softmmu/tcg/tcg-common.o
  CC      ppc64-linux-user/fpu/softfloat.o
  CC      nios2-linux-user/disas.o
  CC      nios2-softmmu/tcg/tcg-op.o
  CC      mipsn32-linux-user/accel/tcg/tcg-runtime.o
  CC      mipsn32-linux-user/accel/tcg/cpu-exec.o
  CC      moxie-softmmu/tcg/tcg-common.o
  CC      nios2-linux-user/gdbstub.o
  CC      i386-softmmu/fpu/softfloat.o
  CC      or1k-softmmu/tcg/tcg-common.o
  CC      unicore32-softmmu/tcg/tcg-common.o
  CC      mipsel-linux-user/gdbstub.o
  CC      alpha-linux-user/disas.o
  CC      xtensaeb-softmmu/tcg/tcg-common.o
  CC      mips64-linux-user/accel/tcg/user-exec.o
  CC      lm32-softmmu/arch_init.o
  CC      s390x-softmmu/arch_init.o
  CC      sparc64-softmmu/fpu/softfloat.o
  CC      x86_64-linux-user/thunk.o
  CC      mipsel-softmmu/fpu/softfloat.o
  CC      tricore-softmmu/arch_init.o
  CC      aarch64-softmmu/disas.o
  CC      tilegx-linux-user/disas.o
  CC      microblaze-softmmu/tcg/tcg-common.o
  CC      sparc32plus-linux-user/accel/stubs/hax-stub.o
  CC      s390x-linux-user/disas.o
  CC      sh4eb-softmmu/tcg/optimize.o
  CC      sh4eb-softmmu/tcg/tcg-common.o
  CC      s390x-softmmu/cpus.o
  CC      mipsn32el-linux-user/trace/control-target.o
  CC      sh4eb-linux-user/fpu/softfloat.o
  CC      moxie-softmmu/fpu/softfloat.o
  CC      mips-softmmu/arch_init.o
  CC      unicore32-softmmu/fpu/softfloat.o
  CC      ppc64abi32-linux-user/disas.o
  GEN     ppc-softmmu/gdbstub-xml.c
  CC      mips64-softmmu/tcg/tcg-common.o
  CC      microblaze-softmmu/fpu/softfloat.o
  CC      sparc64-linux-user/thunk.o
  CC      x86_64-softmmu/cpus.o
  CC      sh4eb-linux-user/disas.o
  CC      or1k-linux-user/tcg/tcg-common.o
  CC      alpha-softmmu/tcg/tcg-common.o
  CC      mips-softmmu/cpus.o
  CC      sparc32plus-linux-user/accel/stubs/kvm-stub.o
  CC      mips-softmmu/monitor.o
  CC      alpha-linux-user/gdbstub.o
  CC      x86_64-softmmu/monitor.o
  CC      nios2-softmmu/tcg/optimize.o
  CC      tilegx-linux-user/gdbstub.o
  CC      sh4eb-linux-user/gdbstub.o
  CC      mipsel-linux-user/thunk.o
  CC      mipsel-softmmu/disas.o
  CC      or1k-softmmu/fpu/softfloat.o
  CC      sparc32plus-linux-user/accel/tcg/tcg-runtime.o
  CC      mips-softmmu/gdbstub.o
  CC      nios2-softmmu/tcg/tcg-common.o
  GEN     aarch64-linux-user/gdbstub-xml.c
  CC      ppc64-softmmu/tcg/tcg-common.o
  CC      x86_64-softmmu/gdbstub.o
  CC      alpha-softmmu/fpu/softfloat.o
  CC      mips64el-softmmu/cpus.o
  CC      or1k-linux-user/fpu/softfloat.o
  CC      x86_64-linux-user/accel/stubs/hax-stub.o
  CC      mips64-softmmu/fpu/softfloat.o
  CC      mips64-softmmu/disas.o
  CC      arm-linux-user/accel/tcg/translator.o
  CC      aarch64-linux-user/gdbstub.o
  CC      xtensaeb-softmmu/fpu/softfloat.o
  CC      mipsn32-linux-user/accel/tcg/cpu-exec-common.o
  CC      sparc64-softmmu/disas.o
  CC      mips64-linux-user/accel/tcg/user-exec-stub.o
  CC      mipsel-linux-user/accel/stubs/hax-stub.o
  CC      armeb-linux-user/disas.o
  CC      cris-softmmu/fpu/softfloat.o
  CC      mips64el-softmmu/monitor.o
  CC      x86_64-linux-user/accel/stubs/kvm-stub.o
  CC      ppc64-softmmu/fpu/softfloat.o
  CC      or1k-linux-user/disas.o
  GEN     ppc64abi32-linux-user/gdbstub-xml.c
  CC      sparc64-softmmu/arch_init.o
  CC      sparc64-softmmu/cpus.o
  CC      ppcemb-softmmu/tcg/optimize.o
  GEN     armeb-linux-user/gdbstub-xml.c
  CC      ppcemb-softmmu/tcg/tcg-common.o
  CC      sparc32plus-linux-user/accel/tcg/cpu-exec.o
  CC      s390x-softmmu/monitor.o
  CC      mipsn32-linux-user/accel/tcg/translate-all.o
  CC      x86_64-softmmu/balloon.o
  CC      x86_64-softmmu/ioport.o
  CC      mips64-softmmu/arch_init.o
  GEN     s390x-linux-user/gdbstub-xml.c
  CC      aarch64-linux-user/thunk.o
  CC      alpha-softmmu/disas.o
  CC      cris-softmmu/disas.o
  CC      arm-linux-user/accel/tcg/user-exec.o
  CC      moxie-softmmu/disas.o
  CC      mipsel-linux-user/accel/stubs/kvm-stub.o
  CC      mips-softmmu/balloon.o
  CC      mips-softmmu/ioport.o
  CC      mipsn32el-linux-user/trace/generated-helpers.o
  CC      microblaze-softmmu/disas.o
  CC      nios2-softmmu/fpu/softfloat.o
  CC      s390x-linux-user/gdbstub.o
  CC      mips-linux-user/gdbstub.o
  CC      sparc-softmmu/fpu/softfloat.o
  CC      or1k-linux-user/gdbstub.o
  CC      hppa-linux-user/gdbstub.o
  CC      x86_64-softmmu/numa.o
  CC      x86_64-softmmu/qtest.o
  CC      or1k-linux-user/thunk.o
  CC      xtensa-softmmu/tcg/optimize.o
  CC      i386-linux-user/disas.o
  CC      mips64-linux-user/linux-user/main.o
  CC      arm-softmmu/tcg/tcg-common.o
  CC      microblazeel-softmmu/tcg/tcg-common.o
  CC      xtensa-softmmu/tcg/tcg-common.o
  CC      ppc64-softmmu/disas.o
  CC      mips-softmmu/numa.o
  CC      microblazeel-softmmu/fpu/softfloat.o
  CC      mips-linux-user/thunk.o
  CC      microblazeel-linux-user/disas.o
  CC      mipsel-linux-user/accel/tcg/tcg-runtime.o
  CC      microblaze-linux-user/gdbstub.o
  CC      lm32-softmmu/cpus.o
  CC      sparc32plus-linux-user/accel/tcg/cpu-exec-common.o
  CC      mipsn32-linux-user/accel/tcg/translator.o
  CC      x86_64-softmmu/memory.o
  CC      arm-linux-user/accel/tcg/user-exec-stub.o
  CC      or1k-softmmu/disas.o
  CC      hppa-linux-user/thunk.o
  CC      mips64-linux-user/linux-user/syscall.o
  CC      sparc-linux-user/disas.o
  CC      unicore32-softmmu/disas.o
  CC      i386-softmmu/disas.o
  GEN     m68k-linux-user/gdbstub-xml.c
  CC      cris-linux-user/accel/stubs/hax-stub.o
  CC      or1k-linux-user/accel/stubs/hax-stub.o
  CC      or1k-linux-user/accel/stubs/kvm-stub.o
  CC      arm-softmmu/fpu/softfloat.o
  CC      arm-linux-user/linux-user/main.o
  GEN     aarch64-softmmu/gdbstub-xml.c
  CC      sparc32plus-linux-user/accel/tcg/translate-all.o
  CC      sh4-softmmu/tcg/optimize.o
  CC      sh4-softmmu/tcg/tcg-common.o
  CC      unicore32-softmmu/arch_init.o
  CC      ppc64le-linux-user/thunk.o
  CC      sh4eb-softmmu/fpu/softfloat.o
  CC      microblazeel-softmmu/disas.o
  GEN     i386-linux-user/gdbstub-xml.c
  GEN     ppc64-softmmu/gdbstub-xml.c
  CC      m68k-linux-user/gdbstub.o
  CC      sh4eb-softmmu/disas.o
  CC      aarch64-linux-user/accel/stubs/hax-stub.o
  CC      sparc64-softmmu/monitor.o
  CC      xtensa-softmmu/fpu/softfloat.o
  CC      mips64el-linux-user/thunk.o
  CC      sparc32plus-linux-user/accel/tcg/translator.o
  CC      xtensaeb-softmmu/disas.o
  CC      mips-linux-user/accel/stubs/hax-stub.o
  CC      tilegx-linux-user/thunk.o
  CC      sh4-linux-user/thunk.o
  CC      mips64-linux-user/linux-user/strace.o
  CC      microblaze-softmmu/arch_init.o
  CC      or1k-softmmu/arch_init.o
  CC      mips64-linux-user/linux-user/mmap.o
  CC      ppc-softmmu/arch_init.o
  CC      s390x-linux-user/thunk.o
  CC      lm32-softmmu/monitor.o
  CC      ppc64le-linux-user/accel/stubs/hax-stub.o
  CC      nios2-linux-user/thunk.o
  CC      microblazeel-linux-user/gdbstub.o
  GEN     i386-softmmu/gdbstub-xml.c
  CC      microblazeel-linux-user/thunk.o
  CC      microblaze-softmmu/cpus.o
  CC      mips64el-linux-user/accel/stubs/hax-stub.o
  CC      i386-linux-user/gdbstub.o
  CC      aarch64-linux-user/accel/stubs/kvm-stub.o
  CC      sh4eb-linux-user/thunk.o
  CC      mipsel-softmmu/arch_init.o
  CC      sparc32plus-linux-user/accel/tcg/user-exec.o
  CC      lm32-softmmu/gdbstub.o
  CC      ppc64-softmmu/arch_init.o
  CC      ppc64-softmmu/cpus.o
  CC      microblaze-linux-user/thunk.o
  CC      sparc64-softmmu/gdbstub.o
  CC      ppc64le-linux-user/accel/stubs/kvm-stub.o
  CC      cris-softmmu/arch_init.o
  CC      tricore-softmmu/cpus.o
  CC      tilegx-linux-user/accel/stubs/hax-stub.o
  CC      microblaze-softmmu/monitor.o
  CC      mipsn32-linux-user/accel/tcg/user-exec.o
  CC      lm32-softmmu/balloon.o
  CC      ppcemb-softmmu/fpu/softfloat.o
  CC      mips64el-linux-user/accel/stubs/kvm-stub.o
  CC      x86_64-linux-user/accel/tcg/tcg-runtime.o
  CC      nios2-linux-user/accel/stubs/hax-stub.o
  CC      aarch64-linux-user/accel/tcg/tcg-runtime.o
  CC      alpha-softmmu/arch_init.o
  CC      nios2-softmmu/disas.o
  CC      mipsel-linux-user/accel/tcg/cpu-exec.o
  CC      sh4-linux-user/accel/stubs/hax-stub.o
  CC      s390x-linux-user/accel/stubs/hax-stub.o
  CC      xtensaeb-softmmu/arch_init.o
  CC      arm-linux-user/linux-user/syscall.o
  CC      ppc-softmmu/cpus.o
  CC      hppa-linux-user/accel/stubs/hax-stub.o
  CC      x86_64-softmmu/memory_mapping.o
  CC      microblazeel-linux-user/accel/stubs/hax-stub.o
  CC      ppc64abi32-linux-user/gdbstub.o
  CC      sparc32plus-linux-user/accel/tcg/user-exec-stub.o
  CC      x86_64-linux-user/accel/tcg/cpu-exec.o
  CC      mipsel-softmmu/cpus.o
  CC      ppc64le-linux-user/accel/tcg/tcg-runtime.o
  CC      nios2-softmmu/arch_init.o
  CC      unicore32-softmmu/cpus.o
  GEN     ppc-linux-user/gdbstub-xml.c
  CC      sh4-linux-user/accel/stubs/kvm-stub.o
  CC      sh4-linux-user/accel/tcg/tcg-runtime.o
  CC      mips64el-linux-user/accel/tcg/tcg-runtime.o
  CC      i386-softmmu/arch_init.o
  CC      moxie-softmmu/arch_init.o
  CC      xtensaeb-softmmu/cpus.o
  CC      cris-softmmu/cpus.o
  CC      sparc64-linux-user/accel/stubs/hax-stub.o
  CC      s390x-linux-user/accel/stubs/kvm-stub.o
  CC      x86_64-softmmu/dump.o
  CC      cris-linux-user/accel/stubs/kvm-stub.o
  CC      mips64el-softmmu/gdbstub.o
  CC      microblazeel-softmmu/arch_init.o
  CC      x86_64-softmmu/migration/ram.o
  CC      mips64el-softmmu/balloon.o
  CC      hppa-linux-user/accel/stubs/kvm-stub.o
  CC      microblazeel-linux-user/accel/stubs/kvm-stub.o
  CC      unicore32-softmmu/monitor.o
  CC      sh4-softmmu/fpu/softfloat.o
  CC      sparc64-linux-user/accel/stubs/kvm-stub.o
  CC      sparc64-linux-user/accel/tcg/tcg-runtime.o
  CC      ppc-softmmu/monitor.o
  CC      mipsel-softmmu/monitor.o
  CC      lm32-softmmu/ioport.o
  CC      sh4eb-linux-user/accel/stubs/hax-stub.o
  CC      microblaze-linux-user/accel/stubs/hax-stub.o
  CC      sparc-softmmu/disas.o
  CC      mips64el-linux-user/accel/tcg/cpu-exec.o
  CC      s390x-linux-user/accel/tcg/tcg-runtime.o
  CC      tricore-softmmu/monitor.o
  CC      ppc-softmmu/gdbstub.o
  CC      armeb-linux-user/gdbstub.o
  CC      cris-softmmu/monitor.o
  CC      ppc64le-linux-user/accel/tcg/cpu-exec.o
  CC      hppa-linux-user/accel/tcg/tcg-runtime.o
  CC      tricore-softmmu/gdbstub.o
  CC      hppa-linux-user/accel/tcg/cpu-exec.o
  CC      aarch64-linux-user/accel/tcg/cpu-exec.o
  CC      alpha-linux-user/thunk.o
  CC      ppc-softmmu/balloon.o
  CC      aarch64-linux-user/accel/tcg/cpu-exec-common.o
  CC      or1k-softmmu/cpus.o
  CC      ppc64le-linux-user/accel/tcg/cpu-exec-common.o
  CC      mipsn32-linux-user/accel/tcg/user-exec-stub.o
  CC      microblaze-linux-user/accel/stubs/kvm-stub.o
  CC      hppa-linux-user/accel/tcg/cpu-exec-common.o
  CC      mips64-softmmu/cpus.o
  CC      ppc64abi32-linux-user/thunk.o
  CC      mips-softmmu/qtest.o
  CC      or1k-softmmu/monitor.o
  CC      x86_64-linux-user/accel/tcg/cpu-exec-common.o
  CC      sparc-linux-user/gdbstub.o
  CC      or1k-softmmu/gdbstub.o
  CC      sparc32plus-linux-user/linux-user/main.o
  CC      s390x-linux-user/accel/tcg/cpu-exec.o
  CC      hppa-linux-user/accel/tcg/translate-all.o
  CC      sparc64-softmmu/balloon.o
  CC      mipsn32-linux-user/linux-user/main.o
  CC      i386-linux-user/thunk.o
  CC      x86_64-linux-user/accel/tcg/translate-all.o
  CC      aarch64-softmmu/arch_init.o
  CC      ppc64-softmmu/monitor.o
  CC      i386-softmmu/cpus.o
  CC      sh4eb-linux-user/accel/stubs/kvm-stub.o
  CC      mips64el-linux-user/accel/tcg/cpu-exec-common.o
  CC      sparc64-linux-user/accel/tcg/cpu-exec.o
  CC      i386-softmmu/monitor.o
  CC      moxie-softmmu/cpus.o
  CC      m68k-linux-user/thunk.o
  CC      microblaze-linux-user/accel/tcg/tcg-runtime.o
  CC      ppc64le-linux-user/accel/tcg/translate-all.o
  CC      mips64el-softmmu/ioport.o
  CC      mipsn32-linux-user/linux-user/syscall.o
  CC      s390x-linux-user/accel/tcg/cpu-exec-common.o
  CC      mipsel-softmmu/gdbstub.o
  CC      sparc64-softmmu/ioport.o
  CC      or1k-linux-user/accel/tcg/tcg-runtime.o
  CC      mipsel-linux-user/accel/tcg/cpu-exec-common.o
  CC      microblazeel-softmmu/cpus.o
  CC      mips-softmmu/memory.o
  CC      s390x-softmmu/gdbstub.o
  CC      mipsel-linux-user/accel/tcg/translate-all.o
  CC      mips64-softmmu/monitor.o
  GEN     m68k-softmmu/gdbstub-xml.c
  CC      m68k-linux-user/accel/stubs/hax-stub.o
  CC      sh4eb-softmmu/arch_init.o
  CC      armeb-linux-user/thunk.o
  CC      lm32-softmmu/numa.o
  CC      ppc-linux-user/gdbstub.o
  CC      mips64el-linux-user/accel/tcg/translate-all.o
  CC      cris-linux-user/accel/tcg/tcg-runtime.o
  CC      cris-linux-user/accel/tcg/cpu-exec.o
  CC      s390x-softmmu/balloon.o
  CC      alpha-linux-user/accel/stubs/hax-stub.o
  CC      armeb-linux-user/accel/stubs/hax-stub.o
  CC      sh4eb-softmmu/cpus.o
  CC      i386-softmmu/gdbstub.o
  CC      ppcemb-softmmu/disas.o
  CC      mips-linux-user/accel/stubs/kvm-stub.o
  CC      alpha-softmmu/cpus.o
  CC      ppc-linux-user/thunk.o
  CC      mips64el-linux-user/accel/tcg/translator.o
  CC      m68k-softmmu/arch_init.o
  CC      alpha-softmmu/monitor.o
  CC      microblaze-linux-user/accel/tcg/cpu-exec.o
  CC      aarch64-linux-user/accel/tcg/translate-all.o
  CC      x86_64-softmmu/accel/accel.o
  CC      i386-linux-user/accel/stubs/hax-stub.o
  CC      or1k-softmmu/balloon.o
  CC      moxie-softmmu/monitor.o
  CC      mipsn32-linux-user/linux-user/strace.o
  CC      sparc32plus-linux-user/linux-user/syscall.o
  CC      s390x-linux-user/accel/tcg/translate-all.o
  CC      mips64el-softmmu/numa.o
  CC      ppc64abi32-linux-user/accel/stubs/hax-stub.o
  CC      microblaze-linux-user/accel/tcg/cpu-exec-common.o
  CC      i386-linux-user/accel/stubs/kvm-stub.o
  CC      nios2-softmmu/cpus.o
  CC      sparc64-linux-user/accel/tcg/cpu-exec-common.o
  CC      sparc32plus-linux-user/linux-user/strace.o
  CC      aarch64-softmmu/cpus.o
  CC      mips64el-linux-user/accel/tcg/user-exec.o
  GEN     ppcemb-softmmu/gdbstub-xml.c
  CC      lm32-softmmu/qtest.o
  CC      tilegx-linux-user/accel/stubs/kvm-stub.o
  CC      x86_64-linux-user/accel/tcg/translator.o
  CC      microblazeel-softmmu/monitor.o
  CC      m68k-softmmu/cpus.o
  CC      m68k-linux-user/accel/stubs/kvm-stub.o
  CC      nios2-softmmu/monitor.o
  CC      nios2-linux-user/accel/stubs/kvm-stub.o
  CC      nios2-linux-user/accel/tcg/tcg-runtime.o
  CC      microblaze-softmmu/gdbstub.o
  CC      mips-softmmu/memory_mapping.o
  CC      x86_64-softmmu/accel/stubs/hax-stub.o
  CC      mipsn32-linux-user/linux-user/mmap.o
  CC      mips64-linux-user/linux-user/signal.o
  CC      cris-linux-user/accel/tcg/cpu-exec-common.o
  CC      ppc64abi32-linux-user/accel/stubs/kvm-stub.o
  CC      sh4-linux-user/accel/tcg/cpu-exec.o
  CC      hppa-linux-user/accel/tcg/translator.o
  CC      i386-linux-user/accel/tcg/tcg-runtime.o
  CC      sh4-linux-user/accel/tcg/cpu-exec-common.o
  CC      microblazeel-linux-user/accel/tcg/tcg-runtime.o
  CC      mipsel-linux-user/accel/tcg/translator.o
  CC      nios2-softmmu/gdbstub.o
  CC      arm-linux-user/linux-user/strace.o
  CC      xtensaeb-softmmu/monitor.o
  CC      sparc64-linux-user/accel/tcg/translate-all.o
  CC      microblazeel-softmmu/gdbstub.o
  CC      s390x-linux-user/accel/tcg/translator.o
  CC      ppc64le-linux-user/accel/tcg/translator.o
  CC      microblaze-linux-user/accel/tcg/translate-all.o
  CC      microblaze-linux-user/accel/tcg/translator.o
  CC      sparc64-softmmu/numa.o
  CC      m68k-linux-user/accel/tcg/tcg-runtime.o
  CC      ppc-softmmu/ioport.o
  CC      sparc-linux-user/thunk.o
  CC      ppc64-linux-user/disas.o
  CC      i386-linux-user/accel/tcg/cpu-exec.o
  CC      cris-linux-user/accel/tcg/translate-all.o
  CC      sparc-softmmu/arch_init.o
  CC      mips64el-linux-user/accel/tcg/user-exec-stub.o
  CC      nios2-linux-user/accel/tcg/cpu-exec.o
  CC      microblaze-softmmu/balloon.o
  CC      x86_64-softmmu/accel/stubs/kvm-stub.o
  CC      s390x-softmmu/ioport.o
  CC      ppc64abi32-linux-user/accel/tcg/tcg-runtime.o
  CC      or1k-linux-user/accel/tcg/cpu-exec.o
  CC      xtensa-softmmu/disas.o
  CC      tilegx-linux-user/accel/tcg/tcg-runtime.o
  CC      ppc-linux-user/accel/stubs/hax-stub.o
  CC      x86_64-linux-user/accel/tcg/user-exec.o
  CC      alpha-linux-user/accel/stubs/kvm-stub.o
  CC      armeb-linux-user/accel/stubs/kvm-stub.o
  CC      i386-softmmu/balloon.o
  CC      sh4-linux-user/accel/tcg/translate-all.o
  CC      arm-softmmu/disas.o
  CC      mips64el-softmmu/qtest.o
  CC      m68k-linux-user/accel/tcg/cpu-exec.o
  CC      x86_64-softmmu/accel/tcg/tcg-all.o
  CC      s390x-linux-user/accel/tcg/user-exec.o
  CC      tilegx-linux-user/accel/tcg/cpu-exec.o
  CC      tilegx-linux-user/accel/tcg/cpu-exec-common.o
  CC      microblazeel-linux-user/accel/tcg/cpu-exec.o
  CC      x86_64-softmmu/accel/tcg/cputlb.o
  CC      sh4-linux-user/accel/tcg/translator.o
  CC      ppc-linux-user/accel/stubs/kvm-stub.o
  CC      microblazeel-softmmu/balloon.o
  CC      mips-linux-user/accel/tcg/tcg-runtime.o
  CC      hppa-linux-user/accel/tcg/user-exec.o
  CC      arm-linux-user/linux-user/mmap.o
  CC      tilegx-linux-user/accel/tcg/translate-all.o
  CC      aarch64-linux-user/accel/tcg/translator.o
  CC      lm32-softmmu/memory.o
  CC      sparc32plus-linux-user/linux-user/mmap.o
  CC      i386-linux-user/accel/tcg/cpu-exec-common.o
  GEN     ppc64-linux-user/gdbstub-xml.c
  CC      sh4eb-linux-user/accel/tcg/tcg-runtime.o
  CC      armeb-linux-user/accel/tcg/tcg-runtime.o
  CC      alpha-linux-user/accel/tcg/tcg-runtime.o
  CC      sh4eb-linux-user/accel/tcg/cpu-exec.o
  CC      i386-linux-user/accel/tcg/translate-all.o
  CC      mipsel-softmmu/balloon.o
  CC      m68k-linux-user/accel/tcg/cpu-exec-common.o
  CC      sparc64-linux-user/accel/tcg/translator.o
  CC      nios2-linux-user/accel/tcg/cpu-exec-common.o
  CC      s390x-softmmu/numa.o
  CC      ppc64abi32-linux-user/accel/tcg/cpu-exec.o
  CC      mips-linux-user/accel/tcg/cpu-exec.o
  CC      mips-linux-user/accel/tcg/cpu-exec-common.o
  CC      nios2-linux-user/accel/tcg/translate-all.o
  CC      aarch64-linux-user/accel/tcg/user-exec.o
  CC      m68k-softmmu/monitor.o
  CC      lm32-softmmu/memory_mapping.o
  CC      sparc-linux-user/accel/stubs/hax-stub.o
  CC      aarch64-softmmu/monitor.o
  CC      arm-linux-user/linux-user/signal.o
  CC      mips64el-linux-user/linux-user/main.o
  CC      xtensa-softmmu/arch_init.o
  CC      mips64-linux-user/linux-user/elfload.o
  CC      hppa-linux-user/accel/tcg/user-exec-stub.o
  CC      ppc-linux-user/accel/tcg/tcg-runtime.o
  CC      mips64el-linux-user/linux-user/syscall.o
  CC      microblaze-linux-user/accel/tcg/user-exec.o
  CC      aarch64-softmmu/gdbstub.o
  CC      sh4-linux-user/accel/tcg/user-exec.o
  CC      mipsel-linux-user/accel/tcg/user-exec.o
  CC      sparc-softmmu/cpus.o
  CC      sh4-softmmu/disas.o
  CC      microblaze-softmmu/ioport.o
  CC      sparc64-linux-user/accel/tcg/user-exec.o
  CC      mips64-linux-user/linux-user/linuxload.o
  CC      microblaze-linux-user/accel/tcg/user-exec-stub.o
  CC      alpha-linux-user/accel/tcg/cpu-exec.o
  CC      arm-linux-user/linux-user/elfload.o
  CC      mips64el-linux-user/linux-user/strace.o
  CC      ppc64abi32-linux-user/accel/tcg/cpu-exec-common.o
  CC      ppcemb-softmmu/arch_init.o
  CC      ppc64le-linux-user/accel/tcg/user-exec.o
  CC      sparc-linux-user/accel/stubs/kvm-stub.o
  CC      sparc-softmmu/monitor.o
  CC      armeb-linux-user/accel/tcg/cpu-exec.o
  CC      microblazeel-linux-user/accel/tcg/cpu-exec-common.o
  CC      hppa-linux-user/linux-user/main.o
  CC      sparc-linux-user/accel/tcg/tcg-runtime.o
  CC      nios2-softmmu/balloon.o
  CC      mips64-linux-user/linux-user/uaccess.o
  CC      cris-linux-user/accel/tcg/translator.o
  CC      mips64el-softmmu/memory.o
  CC      sh4-softmmu/arch_init.o
  CC      m68k-linux-user/accel/tcg/translate-all.o
  CC      cris-softmmu/gdbstub.o
  CC      ppc64-linux-user/gdbstub.o
  CC      mips-linux-user/accel/tcg/translate-all.o
  CC      armeb-linux-user/accel/tcg/cpu-exec-common.o
  CC      sparc32plus-linux-user/linux-user/signal.o
  CC      or1k-linux-user/accel/tcg/cpu-exec-common.o
  CC      cris-softmmu/balloon.o
  CC      ppc64le-linux-user/accel/tcg/user-exec-stub.o
  CC      x86_64-softmmu/accel/tcg/tcg-runtime.o
  CC      sparc64-softmmu/qtest.o
  CC      moxie-softmmu/gdbstub.o
  CC      alpha-softmmu/gdbstub.o
  CC      moxie-softmmu/balloon.o
  CC      ppc-linux-user/accel/tcg/cpu-exec.o
  CC      alpha-softmmu/balloon.o
  CC      microblazeel-softmmu/ioport.o
  CC      microblaze-linux-user/linux-user/main.o
  CC      ppc-softmmu/numa.o
  CC      ppc64-softmmu/gdbstub.o
  CC      m68k-linux-user/accel/tcg/translator.o
  CC      s390x-linux-user/accel/tcg/user-exec-stub.o
  CC      mips64-softmmu/gdbstub.o
  CC      unicore32-softmmu/gdbstub.o
  CC      mipsel-softmmu/ioport.o
  CC      i386-linux-user/accel/tcg/translator.o
  CC      s390x-linux-user/linux-user/main.o
  CC      sparc-linux-user/accel/tcg/cpu-exec.o
  CC      ppc64abi32-linux-user/accel/tcg/translate-all.o
  CC      microblazeel-linux-user/accel/tcg/translate-all.o
  CC      s390x-linux-user/linux-user/syscall.o
  CC      xtensaeb-softmmu/gdbstub.o
  CC      sh4eb-linux-user/accel/tcg/cpu-exec-common.o
  CC      nios2-linux-user/accel/tcg/translator.o
  CC      x86_64-linux-user/accel/tcg/user-exec-stub.o
  CC      arm-linux-user/linux-user/linuxload.o
  CC      mipsel-linux-user/accel/tcg/user-exec-stub.o
  CC      tricore-softmmu/balloon.o
  CC      mipsel-softmmu/numa.o
  CC      armeb-linux-user/accel/tcg/translate-all.o
  GEN     arm-softmmu/gdbstub-xml.c
  CC      armeb-linux-user/accel/tcg/translator.o
  CC      or1k-linux-user/accel/tcg/translate-all.o
  CC      microblazeel-linux-user/accel/tcg/translator.o
  CC      microblaze-softmmu/numa.o
  CC      microblaze-linux-user/linux-user/syscall.o
  CC      sparc-linux-user/accel/tcg/cpu-exec-common.o
  CC      cris-linux-user/accel/tcg/user-exec.o
  CC      tilegx-linux-user/accel/tcg/translator.o
  CC      s390x-softmmu/qtest.o
  CC      sparc-linux-user/accel/tcg/translate-all.o
  CC      sh4eb-softmmu/monitor.o
  CC      s390x-softmmu/memory.o
  CC      mipsel-softmmu/qtest.o
  CC      microblaze-softmmu/qtest.o
  CC      moxie-softmmu/ioport.o
  CC      sparc64-softmmu/memory.o
  CC      mips64el-softmmu/memory_mapping.o
  CC      sh4-linux-user/accel/tcg/user-exec-stub.o
  CC      microblaze-softmmu/memory.o
  CC      sparc-softmmu/gdbstub.o
  CC      arm-softmmu/arch_init.o
  CC      alpha-linux-user/accel/tcg/cpu-exec-common.o
  CC      cris-softmmu/ioport.o
  CC      x86_64-linux-user/linux-user/main.o
  CC      mips-linux-user/accel/tcg/translator.o
  CC      nios2-linux-user/accel/tcg/user-exec.o
  CC      or1k-softmmu/ioport.o
  CC      tricore-softmmu/ioport.o
  CC      sh4eb-linux-user/accel/tcg/translate-all.o
  CC      mips64-linux-user/linux-user/uname.o
  CC      sparc64-linux-user/accel/tcg/user-exec-stub.o
  CC      hppa-linux-user/linux-user/syscall.o
  CC      arm-softmmu/cpus.o
  CC      i386-linux-user/accel/tcg/user-exec.o
  CC      armeb-linux-user/accel/tcg/user-exec.o
  CC      sparc64-softmmu/memory_mapping.o
  CC      aarch64-linux-user/accel/tcg/user-exec-stub.o
  CC      sparc64-softmmu/dump.o
  CC      sh4eb-softmmu/gdbstub.o
  CC      alpha-linux-user/accel/tcg/translate-all.o
  CC      ppc64abi32-linux-user/accel/tcg/translator.o
  CC      x86_64-softmmu/accel/tcg/cpu-exec.o
  CC      ppc-linux-user/accel/tcg/cpu-exec-common.o
  CC      mips-linux-user/accel/tcg/user-exec.o
  CC      ppc64abi32-linux-user/accel/tcg/user-exec.o
  CC      xtensaeb-softmmu/balloon.o
  CC      moxie-softmmu/numa.o
  CC      ppc64-linux-user/thunk.o
  CC      unicore32-softmmu/balloon.o
  CC      microblazeel-softmmu/numa.o
  CC      sparc-softmmu/balloon.o
  CC      mipsn32-linux-user/linux-user/signal.o
  CC      tilegx-linux-user/accel/tcg/user-exec.o
  CC      sparc64-linux-user/linux-user/main.o
  CC      alpha-linux-user/accel/tcg/translator.o
  CC      ppc-linux-user/accel/tcg/translate-all.o
  CC      aarch64-softmmu/balloon.o
  CC      s390x-linux-user/linux-user/strace.o
  CC      sh4-linux-user/linux-user/main.o
  CC      lm32-softmmu/dump.o
  CC      m68k-linux-user/accel/tcg/user-exec.o
  CC      armeb-linux-user/accel/tcg/user-exec-stub.o
  CC      microblazeel-softmmu/qtest.o
  CC      mips64-softmmu/balloon.o
  CC      sparc-softmmu/ioport.o
  CC      sh4-linux-user/linux-user/syscall.o
  CC      m68k-linux-user/accel/tcg/user-exec-stub.o
  CC      s390x-linux-user/linux-user/mmap.o
  CC      mips-softmmu/dump.o
  CC      mipsel-linux-user/linux-user/main.o
  CC      sparc-softmmu/numa.o
  CC      hppa-linux-user/linux-user/strace.o
  CC      i386-softmmu/ioport.o
  CC      s390x-softmmu/memory_mapping.o
  CC      ppc-softmmu/qtest.o
  CC      aarch64-linux-user/linux-user/main.o
  CC      microblazeel-linux-user/accel/tcg/user-exec.o
  CC      ppc64le-linux-user/linux-user/main.o
  CC      ppcemb-softmmu/cpus.o
  CC      microblazeel-softmmu/memory.o
  CC      nios2-softmmu/ioport.o
  CC      alpha-softmmu/ioport.o
  CC      nios2-softmmu/numa.o
  CC      microblaze-linux-user/linux-user/strace.o
  CC      sparc-linux-user/accel/tcg/translator.o
  CC      nios2-softmmu/qtest.o
  CC      or1k-softmmu/numa.o
  CC      x86_64-softmmu/accel/tcg/cpu-exec-common.o
  CC      mipsel-softmmu/memory.o
  CC      alpha-linux-user/accel/tcg/user-exec.o
  CC      lm32-softmmu/migration/ram.o
  CC      hppa-linux-user/linux-user/mmap.o
  CC      ppc64-softmmu/balloon.o
  CC      hppa-linux-user/linux-user/signal.o
  CC      or1k-linux-user/accel/tcg/translator.o
  CC      nios2-softmmu/memory.o
  CC      sparc64-linux-user/linux-user/syscall.o
  CC      tricore-softmmu/numa.o
  CC      i386-softmmu/numa.o
  CC      x86_64-softmmu/accel/tcg/translate-all.o
  CC      x86_64-linux-user/linux-user/syscall.o
  CC      ppc64le-linux-user/linux-user/syscall.o
  CC      unicore32-softmmu/ioport.o
  CC      microblazeel-softmmu/memory_mapping.o
  CC      mipsel-linux-user/linux-user/syscall.o
  CC      cris-softmmu/numa.o
  CC      x86_64-softmmu/accel/tcg/translator.o
  CC      ppc64-linux-user/accel/stubs/hax-stub.o
  CC      arm-linux-user/linux-user/uaccess.o
  CC      mips64-softmmu/ioport.o
  CC      arm-softmmu/monitor.o
  CC      m68k-softmmu/gdbstub.o
  CC      tilegx-linux-user/accel/tcg/user-exec-stub.o
  CC      xtensa-softmmu/cpus.o
  CC      i386-softmmu/qtest.o
  CC      nios2-linux-user/accel/tcg/user-exec-stub.o
  CC      ppc64-softmmu/ioport.o
  CC      nios2-linux-user/linux-user/main.o
  CC      sparc32plus-linux-user/linux-user/elfload.o
  CC      ppc64-linux-user/accel/stubs/kvm-stub.o
  CC      mips64el-linux-user/linux-user/mmap.o
  CC      sh4-linux-user/linux-user/strace.o
  CC      sh4eb-linux-user/accel/tcg/translator.o
  CC      cris-linux-user/accel/tcg/user-exec-stub.o
  CC      cris-linux-user/linux-user/main.o
  CC      ppc64-linux-user/accel/tcg/tcg-runtime.o
  CC      xtensa-softmmu/monitor.o
  CC      ppc64-softmmu/numa.o
  CC      s390x-linux-user/linux-user/signal.o
  CC      moxie-softmmu/qtest.o
  CC      s390x-softmmu/dump.o
  CC      i386-softmmu/memory.o
  CC      or1k-linux-user/accel/tcg/user-exec.o
  CC      i386-softmmu/memory_mapping.o
  CC      sh4-linux-user/linux-user/mmap.o
  CC      i386-linux-user/accel/tcg/user-exec-stub.o
  CC      sparc-linux-user/accel/tcg/user-exec.o
  CC      microblazeel-softmmu/dump.o
  CC      nios2-linux-user/linux-user/syscall.o
  CC      microblazeel-linux-user/accel/tcg/user-exec-stub.o
  CC      lm32-softmmu/accel/accel.o
  CC      microblazeel-linux-user/linux-user/main.o
  CC      tricore-softmmu/qtest.o
  CC      sparc-softmmu/qtest.o
  CC      xtensaeb-softmmu/ioport.o
  CC      microblaze-linux-user/linux-user/mmap.o
  CC      unicore32-softmmu/numa.o
  CC      alpha-softmmu/numa.o
  CC      ppc-linux-user/accel/tcg/translator.o
  CC      aarch64-linux-user/linux-user/syscall.o
  CC      ppc64abi32-linux-user/accel/tcg/user-exec-stub.o
  CC      or1k-softmmu/qtest.o
  CC      x86_64-linux-user/linux-user/strace.o
  CC      moxie-softmmu/memory.o
  CC      ppc64le-linux-user/linux-user/strace.o
  CC      ppc-softmmu/memory.o
  CC      unicore32-softmmu/qtest.o
  CC      i386-linux-user/linux-user/main.o
  CC      tilegx-linux-user/linux-user/main.o
  CC      armeb-linux-user/linux-user/main.o
  CC      ppcemb-softmmu/monitor.o
  CC      sparc-softmmu/memory.o
  CC      sh4-softmmu/cpus.o
  CC      mips64-softmmu/numa.o
  CC      sparc-softmmu/memory_mapping.o
  CC      alpha-softmmu/qtest.o
  CC      ppc64-linux-user/accel/tcg/cpu-exec.o
  CC      mipsn32-linux-user/linux-user/elfload.o
  CC      cris-softmmu/qtest.o
  CC      sh4eb-linux-user/accel/tcg/user-exec.o
  CC      or1k-linux-user/accel/tcg/user-exec-stub.o
  CC      hppa-linux-user/linux-user/elfload.o
  CC      m68k-linux-user/linux-user/main.o
  CC      aarch64-softmmu/ioport.o
  CC      aarch64-softmmu/numa.o
  CC      tilegx-linux-user/linux-user/syscall.o
  CC      mips64el-linux-user/linux-user/signal.o
  CC      sparc-softmmu/dump.o
  CC      mips-linux-user/accel/tcg/user-exec-stub.o
  CC      mipsel-linux-user/linux-user/strace.o
  CC      tilegx-linux-user/linux-user/strace.o
  CC      mips-softmmu/migration/ram.o
  CC      tricore-softmmu/memory.o
  CC      sparc-softmmu/migration/ram.o
  CC      ppc64abi32-linux-user/linux-user/main.o
  CC      ppc64abi32-linux-user/linux-user/syscall.o
  CC      lm32-softmmu/accel/stubs/hax-stub.o
  CC      microblazeel-linux-user/linux-user/syscall.o
  CC      i386-softmmu/dump.o
  CC      hppa-linux-user/linux-user/linuxload.o
  CC      ppc64-softmmu/qtest.o
  CC      xtensaeb-softmmu/numa.o
  CC      alpha-softmmu/memory.o
  CC      mips64-softmmu/qtest.o
  CC      microblaze-softmmu/memory_mapping.o
  CC      mips64el-softmmu/dump.o
  CC      sparc64-softmmu/migration/ram.o
  CC      nios2-softmmu/memory_mapping.o
  CC      sparc64-softmmu/accel/accel.o
  CC      sparc-linux-user/accel/tcg/user-exec-stub.o
  CC      tilegx-linux-user/linux-user/mmap.o
  CC      mips64el-linux-user/linux-user/elfload.o
  CC      mips-softmmu/accel/accel.o
  CC      mips-linux-user/linux-user/main.o
  CC      ppc64abi32-linux-user/linux-user/strace.o
  CC      ppc64-linux-user/accel/tcg/cpu-exec-common.o
  CC      cris-linux-user/linux-user/syscall.o
  CC      s390x-softmmu/migration/ram.o
  CC      microblaze-softmmu/dump.o
  CC      alpha-linux-user/accel/tcg/user-exec-stub.o
  CCAS    mips64-linux-user/linux-user/safe-syscall.o
  CC      ppc64-softmmu/memory.o
  CC      i386-linux-user/linux-user/syscall.o
  CC      arm-linux-user/linux-user/uname.o
  CC      armeb-linux-user/linux-user/syscall.o
  CC      m68k-softmmu/balloon.o
  CC      ppc-linux-user/accel/tcg/user-exec.o
  CC      or1k-softmmu/memory.o
  CC      sparc64-linux-user/linux-user/strace.o
  CC      alpha-linux-user/linux-user/main.o
  CC      microblaze-linux-user/linux-user/signal.o
  CC      arm-softmmu/gdbstub.o
  CC      arm-softmmu/balloon.o
  CC      sh4eb-linux-user/accel/tcg/user-exec-stub.o
  CC      unicore32-softmmu/memory.o
  CC      cris-linux-user/linux-user/strace.o
  CC      or1k-softmmu/memory_mapping.o
  CC      aarch64-softmmu/qtest.o
  CC      or1k-linux-user/linux-user/main.o
  CC      microblazeel-linux-user/linux-user/strace.o
  CC      ppc64-linux-user/accel/tcg/translate-all.o
  CC      sh4eb-linux-user/linux-user/main.o
  CC      or1k-softmmu/dump.o
  CC      alpha-softmmu/memory_mapping.o
  CC      sh4eb-linux-user/linux-user/syscall.o
  CC      nios2-linux-user/linux-user/strace.o
  CC      cris-softmmu/memory.o
  CC      m68k-linux-user/linux-user/syscall.o
  CC      xtensaeb-softmmu/qtest.o
  CC      cris-linux-user/linux-user/mmap.o
  CC      x86_64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      sparc-linux-user/linux-user/main.o
  CC      ppc-softmmu/memory_mapping.o
  CC      lm32-softmmu/accel/stubs/kvm-stub.o
  CC      ppc-linux-user/accel/tcg/user-exec-stub.o
  CC      ppc64abi32-linux-user/linux-user/mmap.o
  CC      aarch64-linux-user/linux-user/strace.o
  CC      m68k-softmmu/ioport.o
  CC      i386-linux-user/linux-user/strace.o
  CC      moxie-softmmu/memory_mapping.o
  CC      sh4-linux-user/linux-user/signal.o
  CC      x86_64-softmmu/hw/block/virtio-blk.o
  CC      i386-linux-user/linux-user/mmap.o
  CC      microblaze-linux-user/linux-user/elfload.o
  CC      alpha-linux-user/linux-user/syscall.o
  CC      microblazeel-softmmu/migration/ram.o
  CC      mips64el-linux-user/linux-user/linuxload.o
  CC      mips64-softmmu/memory.o
  CC      mips64-softmmu/memory_mapping.o
  CC      mipsel-linux-user/linux-user/mmap.o
  CC      or1k-linux-user/linux-user/syscall.o
  CC      mips64el-linux-user/linux-user/uaccess.o
  CC      sh4eb-linux-user/linux-user/strace.o
  CC      xtensaeb-softmmu/memory.o
  CC      sparc-linux-user/linux-user/syscall.o
  CC      sparc-linux-user/linux-user/strace.o
  CC      s390x-softmmu/accel/accel.o
  CC      sparc32plus-linux-user/linux-user/linuxload.o
  CC      lm32-softmmu/accel/tcg/tcg-all.o
  CC      aarch64-linux-user/linux-user/mmap.o
  CC      arm-softmmu/ioport.o
  CCAS    arm-linux-user/linux-user/safe-syscall.o
  CC      sh4eb-softmmu/balloon.o
  CC      mips-linux-user/linux-user/syscall.o
  CC      mipsel-linux-user/linux-user/signal.o
  CC      ppc64-softmmu/memory_mapping.o
  CC      aarch64-softmmu/memory.o
  CC      x86_64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mips64-softmmu/dump.o
  CC      sh4eb-softmmu/ioport.o
  CC      sh4-softmmu/monitor.o
  CC      m68k-softmmu/numa.o
  CC      alpha-linux-user/linux-user/strace.o
  CC      x86_64-linux-user/linux-user/mmap.o
  CC      sh4eb-softmmu/numa.o
  CC      sh4eb-softmmu/qtest.o
  CC      sh4eb-softmmu/memory.o
  CC      sparc32plus-linux-user/linux-user/uaccess.o
  CC      sparc64-linux-user/linux-user/mmap.o
  CC      xtensaeb-softmmu/memory_mapping.o
  CC      lm32-softmmu/accel/tcg/cputlb.o
  CC      ppc64le-linux-user/linux-user/mmap.o
  CC      or1k-linux-user/linux-user/strace.o
  CC      mips64el-softmmu/migration/ram.o
  CC      microblaze-linux-user/linux-user/linuxload.o
  CC      s390x-softmmu/accel/stubs/hax-stub.o
  CC      microblaze-linux-user/linux-user/uaccess.o
  CC      arm-softmmu/numa.o
  CC      mips-softmmu/accel/stubs/hax-stub.o
  CC      alpha-softmmu/dump.o
  CC      arm-softmmu/qtest.o
  CC      arm-softmmu/memory.o
  CC      ppc64-linux-user/accel/tcg/translator.o
  CC      mips64-softmmu/migration/ram.o
  CC      nios2-linux-user/linux-user/mmap.o
  CC      ppc-linux-user/linux-user/main.o
  CC      mips64-softmmu/accel/accel.o
  CC      mipsel-softmmu/memory_mapping.o
  CC      ppc64le-linux-user/linux-user/signal.o
  CC      mips-linux-user/linux-user/strace.o
  CC      microblaze-softmmu/migration/ram.o
  CC      nios2-softmmu/dump.o
  CC      moxie-softmmu/dump.o
  CC      microblaze-softmmu/accel/accel.o
  CC      moxie-softmmu/migration/ram.o
  CC      m68k-linux-user/linux-user/strace.o
  CC      microblazeel-linux-user/linux-user/mmap.o
  CC      mips-linux-user/linux-user/mmap.o
  CC      ppcemb-softmmu/gdbstub.o
  CC      sparc64-softmmu/accel/stubs/hax-stub.o
  CC      or1k-softmmu/migration/ram.o
  CC      s390x-softmmu/accel/stubs/kvm-stub.o
  CC      mips-softmmu/accel/stubs/kvm-stub.o
  CC      mips64-linux-user/target/mips/translate.o
  CC      arm-linux-user/linux-user/flatload.o
  CC      nios2-softmmu/migration/ram.o
  CC      nios2-softmmu/accel/accel.o
  CC      sh4-softmmu/gdbstub.o
  CC      microblazeel-softmmu/accel/accel.o
  CC      mips-linux-user/linux-user/signal.o
  CC      s390x-linux-user/linux-user/elfload.o
  CC      microblazeel-linux-user/linux-user/signal.o
  CC      x86_64-softmmu/hw/char/virtio-serial-bus.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11.o
  CC      sh4-softmmu/balloon.o
  CC      sparc64-softmmu/accel/stubs/kvm-stub.o
  CC      m68k-softmmu/qtest.o
  CC      microblaze-softmmu/accel/stubs/hax-stub.o
  CC      ppc64abi32-linux-user/linux-user/signal.o
  CC      sh4eb-linux-user/linux-user/mmap.o
  CC      nios2-linux-user/linux-user/signal.o
  CC      ppc-softmmu/dump.o
  CC      mipsel-linux-user/linux-user/elfload.o
  CC      mipsel-softmmu/dump.o
  CC      tricore-softmmu/memory_mapping.o
  CC      mips-softmmu/accel/tcg/tcg-all.o
  CC      s390x-softmmu/accel/tcg/tcg-all.o
  CC      tricore-softmmu/dump.o
  CC      s390x-softmmu/accel/tcg/cputlb.o
  CC      lm32-softmmu/accel/tcg/tcg-runtime.o
  CC      xtensa-softmmu/gdbstub.o
  CC      alpha-softmmu/migration/ram.o
  CC      ppc64abi32-linux-user/linux-user/elfload.o
  CC      tilegx-linux-user/linux-user/signal.o
  CC      xtensaeb-softmmu/dump.o
  CC      x86_64-linux-user/linux-user/signal.o
  CC      moxie-softmmu/accel/accel.o
  CC      i386-linux-user/linux-user/signal.o
  CC      mipsn32-linux-user/linux-user/linuxload.o
  CC      mips64-linux-user/target/mips/dsp_helper.o
  CC      xtensa-softmmu/balloon.o
  CC      sh4-linux-user/linux-user/elfload.o
  CC      sparc64-softmmu/accel/tcg/tcg-all.o
  CC      mips-softmmu/accel/tcg/cputlb.o
  CC      s390x-linux-user/linux-user/linuxload.o
  CC      mipsn32-linux-user/linux-user/uaccess.o
  CC      m68k-linux-user/linux-user/mmap.o
  CC      i386-softmmu/migration/ram.o
  CC      ppc64-linux-user/accel/tcg/user-exec.o
  CC      armeb-linux-user/linux-user/strace.o
  CC      i386-softmmu/windbgstub.o
  CC      tricore-softmmu/migration/ram.o
  CC      ppc-linux-user/linux-user/syscall.o
  CC      microblazeel-softmmu/accel/stubs/hax-stub.o
  CC      ppc-linux-user/linux-user/strace.o
  CC      s390x-softmmu/accel/tcg/tcg-runtime.o
  CC      xtensa-softmmu/ioport.o
  CC      s390x-softmmu/accel/tcg/cpu-exec.o
  CC      aarch64-softmmu/memory_mapping.o
  CC      sparc64-linux-user/linux-user/signal.o
  CC      ppc64abi32-linux-user/linux-user/linuxload.o
  CC      sparc64-softmmu/accel/tcg/cputlb.o
  CC      unicore32-softmmu/memory_mapping.o
  CC      ppc64abi32-linux-user/linux-user/uaccess.o
  CC      ppcemb-softmmu/balloon.o
  CC      sparc-softmmu/accel/accel.o
  CC      sparc-softmmu/accel/stubs/hax-stub.o
  CC      microblazeel-softmmu/accel/stubs/kvm-stub.o
  CC      x86_64-softmmu/hw/core/generic-loader.o
  CC      tricore-softmmu/accel/accel.o
  CC      sh4eb-linux-user/linux-user/signal.o
  CC      tricore-softmmu/accel/stubs/hax-stub.o
  CC      m68k-softmmu/memory.o
  CC      ppc64-softmmu/dump.o
  CC      tricore-softmmu/accel/stubs/kvm-stub.o
  CC      mipsel-linux-user/linux-user/linuxload.o
  CC      s390x-linux-user/linux-user/uaccess.o
  CC      armeb-linux-user/linux-user/mmap.o
  CC      armeb-linux-user/linux-user/signal.o
  CC      nios2-softmmu/accel/stubs/hax-stub.o
  CC      m68k-linux-user/linux-user/signal.o
  CC      mips64el-linux-user/linux-user/uname.o
  CC      mips64el-softmmu/accel/accel.o
  CC      nios2-linux-user/linux-user/elfload.o
  CC      cris-linux-user/linux-user/signal.o
  CC      ppc-softmmu/migration/ram.o
  CC      m68k-softmmu/memory_mapping.o
  CC      m68k-linux-user/linux-user/elfload.o
  CC      sh4-linux-user/linux-user/linuxload.o
  CC      or1k-linux-user/linux-user/mmap.o
  CC      ppcemb-softmmu/ioport.o
  CC      or1k-linux-user/linux-user/signal.o
  CC      x86_64-softmmu/hw/core/null-machine.o
  CC      cris-softmmu/memory_mapping.o
  CC      sparc-softmmu/accel/stubs/kvm-stub.o
  CC      microblazeel-softmmu/accel/tcg/tcg-all.o
  CC      xtensa-softmmu/numa.o
  CC      sparc32plus-linux-user/linux-user/uname.o
  CC      unicore32-softmmu/dump.o
  CC      lm32-softmmu/accel/tcg/cpu-exec.o
  CC      m68k-softmmu/dump.o
  CC      or1k-softmmu/accel/accel.o
  CC      tilegx-linux-user/linux-user/linuxload.o
  CC      tilegx-linux-user/linux-user/elfload.o
  CC      moxie-softmmu/accel/stubs/hax-stub.o
  CC      mips64el-softmmu/accel/stubs/hax-stub.o
  CC      mipsel-linux-user/linux-user/uaccess.o
  CC      or1k-softmmu/accel/stubs/hax-stub.o
  CCAS    sparc32plus-linux-user/linux-user/safe-syscall.o
  CC      ppc-softmmu/accel/accel.o
  CC      microblazeel-softmmu/accel/tcg/cputlb.o
  CC      m68k-softmmu/migration/ram.o
  CC      microblaze-linux-user/linux-user/uname.o
  CC      ppcemb-softmmu/numa.o
  CC      hppa-linux-user/linux-user/uaccess.o
  CC      x86_64-softmmu/hw/display/vga.o
  CC      mipsel-softmmu/migration/ram.o
  CC      aarch64-softmmu/dump.o
  CC      s390x-softmmu/accel/tcg/cpu-exec-common.o
  CC      sh4eb-linux-user/linux-user/elfload.o
  CC      s390x-linux-user/linux-user/uname.o
  CC      ppc-softmmu/accel/kvm/kvm-all.o
  CC      xtensa-softmmu/qtest.o
  CC      xtensa-softmmu/memory.o
  CC      sparc-softmmu/accel/tcg/tcg-all.o
  CC      m68k-softmmu/accel/accel.o
  CC      mips64el-softmmu/accel/stubs/kvm-stub.o
  CC      moxie-softmmu/accel/stubs/kvm-stub.o
  CC      sparc-linux-user/linux-user/mmap.o
  CC      ppc64-linux-user/accel/tcg/user-exec-stub.o
  CC      mipsel-linux-user/linux-user/uname.o
  CC      alpha-linux-user/linux-user/mmap.o
  CCAS    microblaze-linux-user/linux-user/safe-syscall.o
  CC      hppa-linux-user/linux-user/uname.o
  CC      x86_64-softmmu/hw/display/virtio-gpu.o
  CC      sh4-linux-user/linux-user/uaccess.o
  CC      nios2-softmmu/accel/stubs/kvm-stub.o
  CC      sh4eb-linux-user/linux-user/linuxload.o
  CC      sparc64-softmmu/accel/tcg/tcg-runtime.o
  CC      nios2-softmmu/accel/tcg/tcg-all.o
  CC      ppc64-linux-user/linux-user/main.o
  CC      sparc-linux-user/linux-user/signal.o
  CC      sh4eb-linux-user/linux-user/uaccess.o
  CC      cris-softmmu/dump.o
  CC      alpha-softmmu/accel/accel.o
  CC      ppc-softmmu/accel/stubs/hax-stub.o
  CC      nios2-softmmu/accel/tcg/cputlb.o
  CC      or1k-softmmu/accel/stubs/kvm-stub.o
  CC      sparc-softmmu/accel/tcg/cputlb.o
  CC      sparc32plus-linux-user/target/sparc/translate.o
  CCAS    mipsel-linux-user/linux-user/safe-syscall.o
  CCAS    hppa-linux-user/linux-user/safe-syscall.o
  CC      or1k-softmmu/accel/tcg/tcg-all.o
  CC      microblaze-softmmu/accel/stubs/kvm-stub.o
  CC      aarch64-softmmu/migration/ram.o
  CC      mipsel-linux-user/target/mips/translate.o
  CC      microblaze-softmmu/accel/tcg/tcg-all.o
  CC      mipsn32-linux-user/linux-user/uname.o
  CC      sparc64-linux-user/linux-user/elfload.o
  CC      sparc64-linux-user/linux-user/linuxload.o
  CC      i386-softmmu/windbgstub-utils.o
  CC      m68k-softmmu/accel/stubs/hax-stub.o
  CC      mips-linux-user/linux-user/elfload.o
  CC      microblazeel-softmmu/accel/tcg/tcg-runtime.o
  CC      ppcemb-softmmu/qtest.o
  CC      mips-linux-user/linux-user/linuxload.o
  CC      moxie-softmmu/accel/tcg/tcg-all.o
  CC      mips64el-softmmu/accel/tcg/tcg-all.o
  CC      x86_64-softmmu/hw/display/virtio-gpu-3d.o
  CC      xtensaeb-softmmu/migration/ram.o
  CC      sparc32plus-linux-user/target/sparc/helper.o
  CC      mips64-softmmu/accel/stubs/hax-stub.o
  CC      mips64el-softmmu/accel/tcg/cputlb.o
  CC      m68k-softmmu/accel/stubs/kvm-stub.o
  CC      nios2-softmmu/accel/tcg/tcg-runtime.o
  CC      or1k-linux-user/linux-user/elfload.o
  CC      alpha-softmmu/accel/stubs/hax-stub.o
  CC      ppc64abi32-linux-user/linux-user/uname.o
  CC      i386-linux-user/linux-user/elfload.o
  CC      lm32-softmmu/accel/tcg/cpu-exec-common.o
  CC      cris-softmmu/migration/ram.o
  CC      microblazeel-linux-user/linux-user/elfload.o
  CC      microblazeel-linux-user/linux-user/linuxload.o
  CC      i386-linux-user/linux-user/linuxload.o
  CC      microblaze-softmmu/accel/tcg/cputlb.o
  CC      x86_64-softmmu/hw/display/virtio-gpu-pci.o
  CC      or1k-softmmu/accel/tcg/cputlb.o
  CC      sh4eb-softmmu/memory_mapping.o
  CC      or1k-linux-user/linux-user/linuxload.o
  CC      tricore-softmmu/accel/tcg/tcg-all.o
  CC      alpha-softmmu/accel/stubs/kvm-stub.o
  CC      moxie-softmmu/accel/tcg/cputlb.o
  CC      sh4-softmmu/ioport.o
  CC      mips-softmmu/accel/tcg/tcg-runtime.o
  CC      mips64-softmmu/accel/stubs/kvm-stub.o
  CC      x86_64-linux-user/linux-user/elfload.o
  CC      arm-softmmu/memory_mapping.o
  CC      xtensaeb-softmmu/accel/accel.o
  CC      xtensaeb-softmmu/accel/stubs/hax-stub.o
  CC      m68k-softmmu/accel/tcg/tcg-all.o
  CC      arm-softmmu/dump.o
  CC      ppc64-softmmu/migration/ram.o
  CC      sparc-linux-user/linux-user/elfload.o
  CCAS    mipsn32-linux-user/linux-user/safe-syscall.o
  CC      i386-linux-user/linux-user/uaccess.o
  CC      nios2-linux-user/linux-user/linuxload.o
  CC      sparc-linux-user/linux-user/linuxload.o
  CC      unicore32-softmmu/migration/ram.o
  CCAS    mips64el-linux-user/linux-user/safe-syscall.o
  CC      microblaze-softmmu/accel/tcg/tcg-runtime.o
  CC      sparc-softmmu/accel/tcg/tcg-runtime.o
  CC      or1k-linux-user/linux-user/uaccess.o
  CC      ppc-softmmu/accel/tcg/tcg-all.o
  CC      or1k-linux-user/linux-user/uname.o
  CC      sh4-linux-user/linux-user/uname.o
  CC      mips-linux-user/linux-user/uaccess.o
  CCAS    or1k-linux-user/linux-user/safe-syscall.o
  CC      sparc-softmmu/accel/tcg/cpu-exec.o
  CC      mips64-linux-user/target/mips/op_helper.o
  CC      mips64el-linux-user/target/mips/translate.o
  CC      mips64-softmmu/accel/tcg/tcg-all.o
  CC      nios2-softmmu/accel/tcg/cpu-exec.o
  CC      sh4eb-linux-user/linux-user/uname.o
  CC      alpha-softmmu/accel/tcg/tcg-all.o
  CC      mips-softmmu/accel/tcg/cpu-exec.o
  CC      x86_64-linux-user/linux-user/linuxload.o
  CC      ppcemb-softmmu/memory.o
  CC      i386-softmmu/accel/accel.o
  CC      aarch64-linux-user/linux-user/signal.o
  CC      ppc64-softmmu/accel/accel.o
  CC      sh4eb-softmmu/dump.o
  CC      mips64el-linux-user/target/mips/dsp_helper.o
  CC      tricore-softmmu/accel/tcg/cputlb.o
  CC      mips64el-linux-user/target/mips/op_helper.o
  CC      lm32-softmmu/accel/tcg/translate-all.o
  CCAS    sh4eb-linux-user/linux-user/safe-syscall.o
  CC      microblazeel-linux-user/linux-user/uaccess.o
  CC      alpha-softmmu/accel/tcg/cputlb.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11_cpdo.o
  CC      mips64-softmmu/accel/tcg/cputlb.o
  CC      m68k-linux-user/linux-user/linuxload.o
  CCAS    sh4-linux-user/linux-user/safe-syscall.o
  CC      ppc-linux-user/linux-user/mmap.o
  CC      xtensa-softmmu/memory_mapping.o
  CC      mipsel-linux-user/target/mips/dsp_helper.o
  CC      mipsel-linux-user/target/mips/op_helper.o
  CC      mipsel-linux-user/target/mips/lmi_helper.o
  CC      cris-softmmu/accel/accel.o
  CC      mipsn32-linux-user/target/mips/translate.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11_cpdt.o
  CC      sh4-linux-user/linux-user/flatload.o
  CC      microblazeel-softmmu/accel/tcg/cpu-exec.o
  CC      microblaze-linux-user/linux-user/flatload.o
  CC      mipsn32-linux-user/target/mips/dsp_helper.o
  CC      ppc-softmmu/accel/tcg/cputlb.o
  CC      aarch64-linux-user/linux-user/elfload.o
  CC      tilegx-linux-user/linux-user/uaccess.o
  CC      sh4-softmmu/numa.o
  CC      mipsel-softmmu/accel/accel.o
  CC      or1k-softmmu/accel/tcg/tcg-runtime.o
  CC      m68k-linux-user/linux-user/uaccess.o
  CC      i386-softmmu/accel/stubs/hax-stub.o
  CC      i386-softmmu/accel/stubs/kvm-stub.o
  CC      ppc64-linux-user/linux-user/syscall.o
  CC      ppc-linux-user/linux-user/signal.o
  CC      arm-softmmu/migration/ram.o
  CC      or1k-linux-user/target/openrisc/cpu.o
  CC      mips-linux-user/linux-user/uname.o
  CC      microblaze-softmmu/accel/tcg/cpu-exec.o
  CC      lm32-softmmu/accel/tcg/translator.o
  CC      ppc64-linux-user/linux-user/strace.o
  CCAS    ppc64abi32-linux-user/linux-user/safe-syscall.o
  CC      mipsel-softmmu/accel/stubs/hax-stub.o
  CC      sh4eb-softmmu/migration/ram.o
  CC      hppa-linux-user/target/hppa/translate.o
  CC      ppcemb-softmmu/memory_mapping.o
  CC      tricore-softmmu/accel/tcg/tcg-runtime.o
  CC      tricore-softmmu/accel/tcg/cpu-exec.o
  CC      tricore-softmmu/accel/tcg/cpu-exec-common.o
  CC      sparc32plus-linux-user/target/sparc/cpu.o
  CC      cris-linux-user/linux-user/elfload.o
  CC      cris-softmmu/accel/stubs/hax-stub.o
  CC      xtensa-softmmu/dump.o
  CC      mips64-softmmu/accel/tcg/tcg-runtime.o
  CC      cris-linux-user/linux-user/linuxload.o
  CC      m68k-linux-user/linux-user/uname.o
  CC      microblaze-linux-user/target/microblaze/translate.o
  CC      sh4eb-linux-user/linux-user/flatload.o
  CC      i386-softmmu/accel/tcg/tcg-all.o
  CC      arm-softmmu/accel/accel.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpa11_cprt.o
  CC      microblazeel-softmmu/accel/tcg/cpu-exec-common.o
  CC      ppc64-linux-user/linux-user/mmap.o
  CC      ppc64abi32-linux-user/target/ppc/cpu-models.o
  CCAS    m68k-linux-user/linux-user/safe-syscall.o
  CC      m68k-softmmu/accel/tcg/cputlb.o
  CC      ppc64-softmmu/accel/kvm/kvm-all.o
  CC      mips64el-linux-user/target/mips/lmi_helper.o
  CC      ppc64-softmmu/accel/stubs/hax-stub.o
  CC      mipsel-softmmu/accel/stubs/kvm-stub.o
  CC      sparc-softmmu/accel/tcg/cpu-exec-common.o
  CC      ppc64le-linux-user/linux-user/elfload.o
  CC      alpha-linux-user/linux-user/signal.o
  CC      ppcemb-softmmu/dump.o
  CC      aarch64-softmmu/accel/accel.o
  CC      s390x-softmmu/accel/tcg/translate-all.o
  CC      xtensa-softmmu/migration/ram.o
  CC      lm32-softmmu/hw/core/generic-loader.o
  CC      sparc-softmmu/accel/tcg/translate-all.o
  CC      unicore32-softmmu/accel/accel.o
  CC      sh4-softmmu/qtest.o
  CC      mips64-softmmu/accel/tcg/cpu-exec.o
  CC      x86_64-softmmu/hw/display/virtio-vga.o
  CC      mips64-softmmu/accel/tcg/cpu-exec-common.o
  CC      i386-softmmu/accel/tcg/cputlb.o
  CC      x86_64-linux-user/linux-user/uaccess.o
  CC      xtensaeb-softmmu/accel/stubs/kvm-stub.o
  CC      armeb-linux-user/linux-user/elfload.o
  CC      tricore-softmmu/accel/tcg/translate-all.o
  CC      ppc-softmmu/accel/tcg/tcg-runtime.o
  CC      xtensa-softmmu/accel/accel.o
  CCAS    mips-linux-user/linux-user/safe-syscall.o
  CC      nios2-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips64-softmmu/accel/tcg/translate-all.o
  CC      arm-linux-user/linux-user/arm/nwfpe/fpopcode.o
  CC      mips64el-linux-user/target/mips/helper.o
  CC      ppc64le-linux-user/linux-user/linuxload.o
  CC      mips64el-linux-user/target/mips/cpu.o
  CC      mipsel-softmmu/accel/tcg/tcg-all.o
  CC      mips64el-linux-user/target/mips/gdbstub.o
  CC      sparc32plus-linux-user/target/sparc/fop_helper.o
  CC      cris-softmmu/accel/stubs/kvm-stub.o
  CC      ppc-linux-user/linux-user/elfload.o
  CC      mips-linux-user/target/mips/translate.o
  CC      aarch64-softmmu/accel/stubs/hax-stub.o
  CC      xtensaeb-softmmu/accel/tcg/tcg-all.o
  CC      ppc64-linux-user/linux-user/signal.o
  CC      mipsn32-linux-user/target/mips/op_helper.o
  CC      mipsel-linux-user/target/mips/helper.o
  CC      arm-linux-user/linux-user/arm/nwfpe/single_cpdo.o
  CC      ppc64le-linux-user/linux-user/uaccess.o
  CC      mips-linux-user/target/mips/dsp_helper.o
  CC      cris-linux-user/linux-user/uaccess.o
  CC      lm32-softmmu/hw/core/null-machine.o
  CC      mipsel-softmmu/accel/tcg/cputlb.o
  CC      alpha-softmmu/accel/tcg/tcg-runtime.o
  CC      sparc32plus-linux-user/target/sparc/cc_helper.o
  CC      sparc64-softmmu/accel/tcg/cpu-exec.o
  CC      arm-softmmu/accel/stubs/hax-stub.o
  CC      mips-softmmu/accel/tcg/cpu-exec-common.o
  CC      x86_64-softmmu/hw/intc/apic.o
  CC      mips-softmmu/accel/tcg/translate-all.o
  CC      mips-softmmu/accel/tcg/translator.o
  CC      mips64el-linux-user/target/mips/msa_helper.o
  CC      cris-softmmu/accel/tcg/tcg-all.o
  CC      tricore-softmmu/accel/tcg/translator.o
  CC      arm-softmmu/accel/stubs/kvm-stub.o
  CC      x86_64-softmmu/hw/intc/apic_common.o
  CC      ppc64-linux-user/linux-user/elfload.o
  CC      aarch64-softmmu/accel/stubs/kvm-stub.o
  CC      cris-linux-user/linux-user/uname.o
  CC      xtensaeb-softmmu/accel/tcg/cputlb.o
  CC      tricore-softmmu/hw/core/generic-loader.o
  CC      tricore-softmmu/hw/core/null-machine.o
  CC      lm32-softmmu/hw/input/milkymist-softusb.o
  CC      alpha-linux-user/linux-user/elfload.o
  CC      mips-softmmu/hw/9pfs/virtio-9p-device.o
  CC      mips64el-softmmu/accel/tcg/tcg-runtime.o
  CC      unicore32-softmmu/accel/stubs/hax-stub.o
  CC      microblaze-softmmu/accel/tcg/cpu-exec-common.o
  CC      arm-linux-user/linux-user/arm/nwfpe/double_cpdo.o
  CC      sh4-softmmu/memory.o
  CC      sparc64-softmmu/accel/tcg/cpu-exec-common.o
  CC      xtensa-softmmu/accel/stubs/hax-stub.o
  CC      cris-softmmu/accel/tcg/cputlb.o
  CC      nios2-linux-user/linux-user/uaccess.o
  CC      mips-softmmu/hw/block/virtio-blk.o
  CC      ppc64abi32-linux-user/target/ppc/cpu.o
  CC      mipsel-linux-user/target/mips/cpu.o
  CC      mips-linux-user/target/mips/op_helper.o
  CC      microblazeel-linux-user/linux-user/uname.o
  CC      i386-softmmu/accel/tcg/tcg-runtime.o
  CC      sparc-linux-user/linux-user/uaccess.o
  CC      alpha-softmmu/accel/tcg/cpu-exec.o
  CC      aarch64-softmmu/accel/tcg/tcg-all.o
  CC      nios2-linux-user/linux-user/uname.o
  CC      mips-linux-user/target/mips/lmi_helper.o
  CC      lm32-softmmu/hw/misc/milkymist-hpdmc.o
  CC      unicore32-softmmu/accel/stubs/kvm-stub.o
  CC      s390x-softmmu/accel/tcg/translator.o
  CC      mips-softmmu/hw/block/dataplane/virtio-blk.o
  CC      lm32-softmmu/hw/misc/milkymist-pfpu.o
  CC      xtensa-softmmu/accel/stubs/kvm-stub.o
  CC      sh4eb-softmmu/accel/accel.o
  CC      unicore32-softmmu/accel/tcg/tcg-all.o
  CC      microblaze-linux-user/target/microblaze/op_helper.o
  CC      microblazeel-softmmu/accel/tcg/translate-all.o
  CC      arm-linux-user/linux-user/arm/nwfpe/extended_cpdo.o
  CC      microblaze-linux-user/target/microblaze/helper.o
  CC      sparc-softmmu/accel/tcg/translator.o
  CC      aarch64-softmmu/accel/tcg/cputlb.o
  CC      mipsn32-linux-user/target/mips/lmi_helper.o
  CC      xtensaeb-softmmu/accel/tcg/tcg-runtime.o
  CC      moxie-softmmu/accel/tcg/tcg-runtime.o
  CCAS    cris-linux-user/linux-user/safe-syscall.o
  CCAS    nios2-linux-user/linux-user/safe-syscall.o
  CCAS    s390x-linux-user/linux-user/safe-syscall.o
  CC      cris-linux-user/target/cris/translate.o
  CC      tilegx-linux-user/linux-user/uname.o
  CC      ppc64-softmmu/accel/tcg/tcg-all.o
  CC      sparc64-softmmu/accel/tcg/translate-all.o
  CC      or1k-softmmu/accel/tcg/cpu-exec.o
  CC      mips-linux-user/target/mips/helper.o
  CC      nios2-softmmu/accel/tcg/translate-all.o
  CC      mips-linux-user/target/mips/cpu.o
  CC      cris-linux-user/target/cris/op_helper.o
  CC      mipsel-softmmu/accel/tcg/tcg-runtime.o
  CC      alpha-linux-user/linux-user/linuxload.o
  CC      or1k-linux-user/target/openrisc/exception.o
  CC      aarch64-linux-user/linux-user/linuxload.o
  CC      aarch64-linux-user/linux-user/uaccess.o
  CC      mips64el-softmmu/accel/tcg/cpu-exec.o
  CC      mipsn32-linux-user/target/mips/helper.o
  CC      x86_64-linux-user/linux-user/uname.o
  CC      arm-softmmu/accel/tcg/tcg-all.o
  CC      alpha-softmmu/accel/tcg/cpu-exec-common.o
  CC      armeb-linux-user/linux-user/linuxload.o
  CC      mipsel-linux-user/target/mips/gdbstub.o
  CC      unicore32-softmmu/accel/tcg/cputlb.o
  CC      sh4eb-softmmu/accel/stubs/hax-stub.o
  CC      x86_64-softmmu/hw/intc/ioapic.o
  CC      sh4eb-softmmu/accel/stubs/kvm-stub.o
  CC      mipsel-linux-user/target/mips/msa_helper.o
  CC      xtensaeb-softmmu/accel/tcg/cpu-exec.o
  CC      ppc64le-linux-user/linux-user/uname.o
  CC      arm-linux-user/target/arm/arm-semi.o
  CC      aarch64-softmmu/accel/tcg/tcg-runtime.o
  CC      sh4eb-linux-user/target/sh4/translate.o
  CC      s390x-softmmu/hw/9pfs/virtio-9p-device.o
  CC      lm32-softmmu/hw/misc/mmio_interface.o
  CC      moxie-softmmu/accel/tcg/cpu-exec.o
  CC      ppc64-softmmu/accel/tcg/cputlb.o
  CC      s390x-softmmu/hw/block/virtio-blk.o
  CC      sh4eb-softmmu/accel/tcg/tcg-all.o
  CC      mips64el-linux-user/target/mips/mips-semi.o
  CC      mipsel-linux-user/target/mips/mips-semi.o
  CC      sparc-softmmu/hw/core/generic-loader.o
  CC      aarch64-softmmu/accel/tcg/cpu-exec.o
  CC      sh4-softmmu/memory_mapping.o
  CC      alpha-softmmu/accel/tcg/translate-all.o
  CC      sparc-linux-user/linux-user/uname.o
  CC      arm-softmmu/accel/tcg/cputlb.o
  CC      microblaze-softmmu/accel/tcg/translate-all.o
  CC      s390x-linux-user/target/s390x/cpu.o
  CCAS    x86_64-linux-user/linux-user/safe-syscall.o
  CC      or1k-linux-user/target/openrisc/interrupt.o
  CC      s390x-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mips-softmmu/hw/char/virtio-serial-bus.o
  CC      alpha-softmmu/accel/tcg/translator.o
  CC      aarch64-linux-user/linux-user/uname.o
  CC      x86_64-linux-user/target/i386/helper.o
  CC      microblazeel-softmmu/accel/tcg/translator.o
  CC      sh4eb-linux-user/target/sh4/op_helper.o
  CC      x86_64-linux-user/target/i386/cpu.o
  CC      hppa-linux-user/target/hppa/helper.o
  CC      sparc32plus-linux-user/target/sparc/win_helper.o
  CC      sh4eb-softmmu/accel/tcg/cputlb.o
  GEN     trace/generated-helpers.c
  CC      alpha-linux-user/linux-user/uaccess.o
  CC      ppcemb-softmmu/migration/ram.o
  CC      m68k-linux-user/linux-user/flatload.o
  CC      sh4-linux-user/target/sh4/translate.o
  CC      sparc64-linux-user/linux-user/uaccess.o
  CC      sparc-softmmu/hw/core/null-machine.o
  CC      hppa-linux-user/target/hppa/cpu.o
  CC      microblazeel-softmmu/hw/core/generic-loader.o
  CC      or1k-softmmu/accel/tcg/cpu-exec-common.o
  CC      lm32-softmmu/hw/net/milkymist-minimac2.o
  CC      nios2-linux-user/target/nios2/translate.o
  CC      tricore-softmmu/hw/misc/mmio_interface.o
  CC      xtensa-softmmu/accel/tcg/tcg-all.o
  CC      m68k-linux-user/linux-user/m68k-sim.o
  GEN     trace/generated-helpers.c
  CC      x86_64-softmmu/hw/isa/lpc_ich9.o
  CC      i386-linux-user/linux-user/uname.o
  CC      xtensa-softmmu/accel/tcg/cputlb.o
  CC      aarch64-softmmu/accel/tcg/cpu-exec-common.o
  CC      s390x-linux-user/target/s390x/cpu_models.o
  CC      arm-softmmu/accel/tcg/tcg-runtime.o
  CC      m68k-linux-user/target/m68k/m68k-semi.o
  CC      hppa-linux-user/target/hppa/op_helper.o
  CCAS    aarch64-linux-user/linux-user/safe-syscall.o
  CC      aarch64-linux-user/linux-user/flatload.o
  CC      sparc-softmmu/hw/display/tcx.o
  CC      nios2-linux-user/target/nios2/op_helper.o
  CC      sparc64-softmmu/accel/tcg/translator.o
  CC      cris-softmmu/accel/tcg/tcg-runtime.o
  CC      mips64el-softmmu/accel/tcg/cpu-exec-common.o
  CC      cris-softmmu/accel/tcg/cpu-exec.o
  CC      aarch64-softmmu/accel/tcg/translate-all.o
  CC      ppcemb-softmmu/accel/accel.o
  CC      s390x-linux-user/target/s390x/cpu_features.o
  CC      alpha-softmmu/hw/9pfs/virtio-9p-device.o
  CC      cris-linux-user/target/cris/helper.o
  CC      microblaze-linux-user/target/microblaze/cpu.o
  CC      xtensa-softmmu/accel/tcg/tcg-runtime.o
  CC      mips64el-softmmu/accel/tcg/translate-all.o
  CC      nios2-softmmu/accel/tcg/translator.o
  CC      microblazeel-softmmu/hw/core/null-machine.o
  CC      or1k-softmmu/accel/tcg/translate-all.o
  CC      tricore-softmmu/hw/net/vhost_net.o
  CC      nios2-softmmu/hw/core/generic-loader.o
  CCAS    tilegx-linux-user/linux-user/safe-syscall.o
  CC      moxie-softmmu/accel/tcg/cpu-exec-common.o
  CC      tilegx-linux-user/target/tilegx/cpu.o
  CC      alpha-linux-user/linux-user/uname.o
  CC      microblaze-softmmu/accel/tcg/translator.o
  CC      sparc-softmmu/hw/display/cg3.o
  CC      sh4eb-softmmu/accel/tcg/tcg-runtime.o
  CC      mips64el-softmmu/accel/tcg/translator.o
  CC      armeb-linux-user/linux-user/uaccess.o
  CC      lm32-softmmu/hw/net/vhost_net.o
  CC      arm-linux-user/target/arm/kvm-stub.o
  CC      alpha-softmmu/hw/block/virtio-blk.o
  CC      or1k-linux-user/target/openrisc/mmu.o
  CC      mips64-softmmu/accel/tcg/translator.o
  CC      x86_64-linux-user/target/i386/gdbstub.o
  CC      mipsn32-linux-user/target/mips/cpu.o
  CC      x86_64-linux-user/target/i386/windbgstub.o
  CC      microblazeel-softmmu/hw/misc/mmio_interface.o
  CCAS    ppc64le-linux-user/linux-user/safe-syscall.o
  CC      unicore32-softmmu/accel/tcg/tcg-runtime.o
  CC      xtensaeb-softmmu/accel/tcg/cpu-exec-common.o
  CC      or1k-linux-user/target/openrisc/translate.o
  CC      ppc64abi32-linux-user/target/ppc/translate.o
  CC      ppc64abi32-linux-user/target/ppc/kvm-stub.o
  CC      s390x-softmmu/hw/char/virtio-serial-bus.o
  CCAS    i386-linux-user/linux-user/safe-syscall.o
  CC      ppc-softmmu/accel/tcg/cpu-exec.o
  CC      arm-softmmu/accel/tcg/cpu-exec.o
  CC      mips64el-linux-user/trace/control-target.o
  CC      tilegx-linux-user/target/tilegx/translate.o
  CC      hppa-linux-user/target/hppa/gdbstub.o
  CC      tricore-softmmu/hw/net/rocker/qmp-norocker.o
  LINK    mipsn32el-linux-user/qemu-mipsn32el
  CC      arm-linux-user/target/arm/translate.o
  CC      x86_64-softmmu/hw/misc/vmport.o
  CC      mips64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      aarch64-linux-user/target/arm/arm-semi.o
  CC      moxie-softmmu/accel/tcg/translate-all.o
  CC      mipsn32-linux-user/target/mips/gdbstub.o
  CC      s390x-linux-user/target/s390x/gdbstub.o
  CC      sparc64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      tilegx-linux-user/target/tilegx/helper.o
  CC      sparc64-linux-user/linux-user/uname.o
  CCAS    sparc64-linux-user/linux-user/safe-syscall.o
  CC      sh4eb-softmmu/accel/tcg/cpu-exec.o
  CC      ppc64-softmmu/accel/tcg/tcg-runtime.o
  CC      sh4eb-softmmu/accel/tcg/cpu-exec-common.o
  CC      mips-softmmu/hw/core/generic-loader.o
  CC      unicore32-softmmu/accel/tcg/cpu-exec.o
  CCAS    microblazeel-linux-user/linux-user/safe-syscall.o
  CC      mipsel-linux-user/trace/control-target.o
  CC      lm32-softmmu/hw/net/rocker/qmp-norocker.o
  CC      cris-linux-user/target/cris/cpu.o
  CC      nios2-softmmu/hw/core/null-machine.o
  CC      sh4-linux-user/target/sh4/op_helper.o
  CC      microblazeel-softmmu/hw/net/xilinx_ethlite.o
  CC      armeb-linux-user/linux-user/uname.o
  CC      tricore-softmmu/hw/vfio/common.o
  CC      microblaze-softmmu/hw/core/generic-loader.o
  CC      i386-linux-user/linux-user/vm86.o
  CC      mips-softmmu/hw/core/null-machine.o
  CCAS    alpha-linux-user/linux-user/safe-syscall.o
  CC      nios2-linux-user/target/nios2/helper.o
  CC      moxie-softmmu/accel/tcg/translator.o
  CC      ppcemb-softmmu/accel/kvm/kvm-all.o
  CC      mips-softmmu/hw/display/vga.o
  CC      sparc-softmmu/hw/intc/grlib_irqmp.o
  CC      i386-linux-user/target/i386/helper.o
  CC      mips64-softmmu/hw/block/virtio-blk.o
  CC      alpha-linux-user/target/alpha/translate.o
  CC      s390x-softmmu/hw/char/terminal3270.o
  CC      cris-softmmu/accel/tcg/cpu-exec-common.o
  CC      sh4-softmmu/dump.o
  CC      microblazeel-linux-user/linux-user/flatload.o
  CC      m68k-linux-user/target/m68k/translate.o
  CC      ppc64le-linux-user/target/ppc/cpu-models.o
  CC      arm-softmmu/accel/tcg/cpu-exec-common.o
  CC      lm32-softmmu/hw/sd/milkymist-memcard.o
  CC      mipsel-softmmu/accel/tcg/cpu-exec.o
  CC      xtensaeb-softmmu/accel/tcg/translate-all.o
  CC      tilegx-linux-user/target/tilegx/simd_helper.o
  CC      sparc64-linux-user/target/sparc/translate.o
  CC      m68k-linux-user/target/m68k/op_helper.o
  CC      arm-linux-user/target/arm/op_helper.o
  CC      x86_64-softmmu/hw/misc/ivshmem.o
  CC      x86_64-softmmu/hw/misc/pvpanic.o
  CC      i386-softmmu/accel/tcg/cpu-exec.o
  CC      sparc64-softmmu/hw/block/virtio-blk.o
  CC      s390x-linux-user/target/s390x/interrupt.o
  CC      nios2-softmmu/hw/intc/nios2_iic.o
  CC      sparc-softmmu/hw/misc/eccmemctl.o
  CC      ppc64le-linux-user/target/ppc/cpu.o
  CC      m68k-softmmu/accel/tcg/tcg-runtime.o
  CC      or1k-softmmu/accel/tcg/translator.o
  GEN     trace/generated-helpers.c
  CC      lm32-softmmu/hw/vfio/common.o
  CC      x86_64-linux-user/target/i386/xsave_helper.o
  CC      sh4-softmmu/migration/ram.o
  CC      microblazeel-softmmu/hw/net/vhost_net.o
  CC      ppc-softmmu/accel/tcg/cpu-exec-common.o
  CC      aarch64-softmmu/accel/tcg/translator.o
  CC      hppa-linux-user/trace/control-target.o
  CC      lm32-softmmu/hw/vfio/platform.o
  CC      microblaze-softmmu/hw/core/null-machine.o
  CC      mips64el-softmmu/hw/9pfs/virtio-9p-device.o
  CC      sh4eb-linux-user/target/sh4/helper.o
  CC      nios2-linux-user/target/nios2/cpu.o
  CC      ppcemb-softmmu/accel/stubs/hax-stub.o
  CC      microblaze-linux-user/target/microblaze/gdbstub.o
  CC      alpha-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mipsel-softmmu/accel/tcg/cpu-exec-common.o
  CC      x86_64-linux-user/target/i386/translate.o
  CC      ppc64-softmmu/accel/tcg/cpu-exec.o
  CC      xtensaeb-softmmu/accel/tcg/translator.o
  CC      sparc64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mips64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      i386-softmmu/accel/tcg/cpu-exec-common.o
  CC      s390x-linux-user/target/s390x/helper.o
  CC      mips-linux-user/target/mips/gdbstub.o
  CC      nios2-linux-user/target/nios2/mmu.o
  CC      sh4eb-linux-user/target/sh4/cpu.o
  CC      microblazeel-linux-user/target/microblaze/translate.o
  CC      microblaze-softmmu/hw/misc/mmio_interface.o
  CC      microblazeel-linux-user/target/microblaze/op_helper.o
  CC      or1k-softmmu/hw/core/generic-loader.o
  CC      sh4-softmmu/accel/accel.o
  CC      nios2-softmmu/hw/misc/mmio_interface.o
  CC      sh4eb-linux-user/target/sh4/gdbstub.o
  CC      mips64el-softmmu/hw/block/virtio-blk.o
  CC      moxie-softmmu/hw/core/generic-loader.o
  CC      ppc-softmmu/accel/tcg/translate-all.o
  CC      tricore-softmmu/hw/vfio/platform.o
  CC      microblazeel-softmmu/hw/net/rocker/qmp-norocker.o
  CC      s390x-softmmu/hw/core/generic-loader.o
  CC      m68k-softmmu/accel/tcg/cpu-exec.o
  CC      aarch64-linux-user/target/arm/kvm-stub.o
  CC      cris-linux-user/target/cris/gdbstub.o
  CCAS    sparc-linux-user/linux-user/safe-syscall.o
  CC      ppc64le-linux-user/target/ppc/translate.o
  CC      moxie-softmmu/hw/core/null-machine.o
  CC      sparc-softmmu/hw/misc/slavio_misc.o
  CC      mips64-linux-user/target/mips/lmi_helper.o
  CC      mips-linux-user/target/mips/msa_helper.o
  CC      sh4eb-softmmu/accel/tcg/translate-all.o
  CC      hppa-linux-user/trace/generated-helpers.o
  CC      mips-softmmu/hw/display/virtio-gpu.o
  CC      s390x-linux-user/target/s390x/translate.o
  CC      i386-linux-user/target/i386/cpu.o
  CC      sh4-softmmu/accel/stubs/hax-stub.o
  CC      m68k-linux-user/target/m68k/helper.o
  CC      i386-softmmu/accel/tcg/translate-all.o
  GEN     trace/generated-helpers.c
  CC      nios2-linux-user/trace/control-target.o
  CC      cris-softmmu/accel/tcg/translate-all.o
  CC      moxie-softmmu/hw/display/vga.o
  CC      xtensaeb-softmmu/hw/core/generic-loader.o
  CC      or1k-softmmu/hw/core/null-machine.o
  CC      aarch64-softmmu/hw/9pfs/virtio-9p-device.o
  CC      mipsel-softmmu/accel/tcg/translate-all.o
  CC      microblaze-softmmu/hw/net/xilinx_ethlite.o
  CC      i386-softmmu/accel/tcg/translator.o
  CC      alpha-softmmu/hw/char/virtio-serial-bus.o
  CC      nios2-softmmu/hw/net/vhost_net.o
  CC      sparc64-softmmu/hw/char/virtio-serial-bus.o
  CC      aarch64-linux-user/target/arm/translate.o
  CC      sparc64-softmmu/hw/core/generic-loader.o
  CC      sparc64-softmmu/hw/core/null-machine.o
  CC      microblazeel-softmmu/hw/vfio/common.o
  CC      sh4-linux-user/target/sh4/helper.o
  CC      sparc-linux-user/target/sparc/translate.o
  CC      mipsn32-linux-user/target/mips/msa_helper.o
  CC      x86_64-softmmu/hw/misc/mmio_interface.o
  CC      or1k-softmmu/hw/intc/ompic.o
  CC      s390x-softmmu/hw/core/null-machine.o
  CC      mips64-softmmu/hw/char/virtio-serial-bus.o
  CC      i386-linux-user/target/i386/gdbstub.o
  CC      sh4-softmmu/accel/stubs/kvm-stub.o
  CC      ppc64abi32-linux-user/target/ppc/dfp_helper.o
  CC      sparc-softmmu/hw/misc/mmio_interface.o
  CC      sparc-linux-user/target/sparc/helper.o
  GEN     trace/generated-helpers.c
  CC      microblaze-linux-user/trace/control-target.o
  CC      mipsel-linux-user/trace/generated-helpers.o
  CC      alpha-linux-user/target/alpha/helper.o
  CC      sparc64-softmmu/hw/display/vga.o
  CC      sparc-softmmu/hw/net/vhost_net.o
  CC      nios2-softmmu/hw/net/rocker/qmp-norocker.o
  CC      sparc-softmmu/hw/net/rocker/qmp-norocker.o
  CC      or1k-softmmu/hw/misc/mmio_interface.o
  CC      mips-linux-user/target/mips/mips-semi.o
  CC      aarch64-linux-user/target/arm/op_helper.o
  CC      aarch64-linux-user/target/arm/helper.o
  CC      sparc64-softmmu/hw/display/virtio-gpu.o
  CC      ppc64le-linux-user/target/ppc/kvm-stub.o
  CC      alpha-linux-user/target/alpha/cpu.o
  LINK    hppa-linux-user/qemu-hppa
  CC      s390x-softmmu/hw/display/virtio-gpu.o
  CC      x86_64-softmmu/hw/net/virtio-net.o
  CC      cris-softmmu/accel/tcg/translator.o
  CC      ppc64-softmmu/accel/tcg/cpu-exec-common.o
  CC      sh4eb-softmmu/accel/tcg/translator.o
  CC      microblaze-softmmu/hw/net/vhost_net.o
  CC      mips64el-softmmu/hw/block/dataplane/virtio-blk.o
  CC      mips64-softmmu/hw/core/generic-loader.o
  CC      nios2-linux-user/trace/generated-helpers.o
  CC      xtensaeb-softmmu/hw/core/null-machine.o
  CC      aarch64-softmmu/hw/adc/stm32f2xx_adc.o
  CC      mipsel-softmmu/accel/tcg/translator.o
  CC      nios2-softmmu/hw/timer/altera_timer.o
  CC      s390x-softmmu/hw/display/virtio-gpu-3d.o
  GEN     trace/generated-helpers.c
  CC      m68k-softmmu/accel/tcg/cpu-exec-common.o
  CC      tricore-softmmu/hw/vfio/spapr.o
  CC      sparc-linux-user/target/sparc/cpu.o
  CC      m68k-linux-user/target/m68k/cpu.o
  CC      sparc-softmmu/hw/vfio/common.o
  CC      ppc-softmmu/accel/tcg/translator.o
  CC      sparc32plus-linux-user/target/sparc/mmu_helper.o
  CC      ppc64le-linux-user/target/ppc/dfp_helper.o
  CC      aarch64-softmmu/hw/block/virtio-blk.o
  CC      or1k-softmmu/hw/net/vhost_net.o
  CC      arm-linux-user/target/arm/helper.o
  CC      or1k-softmmu/hw/net/rocker/qmp-norocker.o
  CC      i386-softmmu/hw/9pfs/virtio-9p-device.o
  CC      microblaze-linux-user/trace/generated-helpers.o
  CC      nios2-softmmu/hw/vfio/common.o
  CC      tilegx-linux-user/trace/control-target.o
  CC      mips64el-softmmu/hw/char/virtio-serial-bus.o
  CC      ppc-softmmu/hw/9pfs/virtio-9p-device.o
  CC      lm32-softmmu/hw/vfio/spapr.o
  CC      microblaze-softmmu/hw/net/rocker/qmp-norocker.o
  CC      or1k-linux-user/target/openrisc/exception_helper.o
  CC      ppc64le-linux-user/target/ppc/excp_helper.o
  CC      ppc64-linux-user/linux-user/linuxload.o
  CC      aarch64-linux-user/target/arm/cpu.o
  CC      nios2-softmmu/hw/vfio/platform.o
  CC      s390x-linux-user/target/s390x/cc_helper.o
  CC      alpha-linux-user/target/alpha/int_helper.o
  CC      m68k-softmmu/accel/tcg/translate-all.o
  CC      mips64-linux-user/target/mips/helper.o
  CC      ppcemb-softmmu/accel/tcg/tcg-all.o
  CC      ppc64abi32-linux-user/target/ppc/excp_helper.o
  CCAS    armeb-linux-user/linux-user/safe-syscall.o
  CC      xtensaeb-softmmu/hw/misc/mmio_interface.o
  CC      x86_64-linux-user/target/i386/bpt_helper.o
  CC      sparc-linux-user/target/sparc/fop_helper.o
  CC      sparc64-linux-user/target/sparc/helper.o
  CC      sparc-linux-user/target/sparc/cc_helper.o
  CC      tricore-softmmu/hw/tricore/tricore_testboard.o
  CC      mips-softmmu/hw/display/virtio-gpu-3d.o
  CC      alpha-linux-user/target/alpha/fpu_helper.o
  CC      or1k-softmmu/hw/vfio/common.o
  CC      sparc-softmmu/hw/vfio/platform.o
  CC      microblazeel-softmmu/hw/vfio/platform.o
  CC      sparc64-softmmu/hw/display/virtio-gpu-3d.o
  CC      microblaze-softmmu/hw/vfio/common.o
  LINK    nios2-linux-user/qemu-nios2
  CC      microblazeel-softmmu/hw/vfio/spapr.o
  CC      sparc32plus-linux-user/target/sparc/ldst_helper.o
  CC      or1k-linux-user/target/openrisc/fpu_helper.o
  CC      s390x-linux-user/target/s390x/excp_helper.o
  CC      arm-softmmu/accel/tcg/translate-all.o
  CC      arm-softmmu/accel/tcg/translator.o
  CC      i386-softmmu/hw/block/virtio-blk.o
  CC      ppcemb-softmmu/accel/tcg/cputlb.o
  CC      alpha-softmmu/hw/core/generic-loader.o
  CC      arm-softmmu/hw/9pfs/virtio-9p-device.o
  CC      armeb-linux-user/linux-user/flatload.o
  CC      mips64-softmmu/hw/core/null-machine.o
  CC      mips64el-softmmu/hw/core/generic-loader.o
  CC      lm32-softmmu/hw/lm32/lm32_boards.o
  CC      cris-softmmu/hw/core/generic-loader.o
  LINK    microblaze-linux-user/qemu-microblaze
  CC      ppc64abi32-linux-user/target/ppc/fpu_helper.o
  CC      sparc64-linux-user/target/sparc/cpu.o
  GEN     trace/generated-helpers.c
  CC      mips-softmmu/hw/display/virtio-gpu-pci.o
  CC      ppc64abi32-linux-user/target/ppc/int_helper.o
  CC      mips64-softmmu/hw/display/vga.o
  CC      ppc64-softmmu/accel/tcg/translate-all.o
  CC      sparc-linux-user/target/sparc/win_helper.o
  CC      mips64-softmmu/hw/display/virtio-gpu.o
  CC      x86_64-linux-user/target/i386/cc_helper.o
  CC      sparc64-linux-user/target/sparc/fop_helper.o
  CC      tricore-softmmu/target/tricore/translate.o
  CC      arm-softmmu/hw/adc/stm32f2xx_adc.o
  CC      sparc64-linux-user/target/sparc/cc_helper.o
  CC      unicore32-softmmu/accel/tcg/cpu-exec-common.o
  CC      s390x-linux-user/target/s390x/fpu_helper.o
  CC      xtensaeb-softmmu/hw/net/vhost_net.o
  CC      i386-softmmu/hw/block/dataplane/virtio-blk.o
  CC      arm-linux-user/target/arm/cpu.o
  CC      arm-softmmu/hw/block/virtio-blk.o
  CC      sh4-softmmu/accel/tcg/tcg-all.o
  CC      sh4eb-softmmu/hw/9pfs/virtio-9p-device.o
  CC      i386-softmmu/hw/char/virtio-serial-bus.o
  CC      sparc32plus-linux-user/target/sparc/int64_helper.o
  CC      sparc-linux-user/target/sparc/mmu_helper.o
  CC      microblazeel-linux-user/target/microblaze/helper.o
  CC      or1k-linux-user/target/openrisc/interrupt_helper.o
  CC      mips-softmmu/hw/intc/mips_gic.o
  CC      alpha-linux-user/target/alpha/vax_helper.o
  CC      alpha-linux-user/target/alpha/sys_helper.o
  CC      arm-softmmu/hw/block/dataplane/virtio-blk.o
  CC      unicore32-softmmu/accel/tcg/translate-all.o
  CC      ppc-softmmu/hw/block/virtio-blk.o
  CC      ppc-softmmu/hw/block/dataplane/virtio-blk.o
  CC      alpha-softmmu/hw/core/null-machine.o
  CC      mips-softmmu/hw/misc/ivshmem.o
  CC      aarch64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      xtensaeb-softmmu/hw/net/rocker/qmp-norocker.o
  CC      sh4eb-linux-user/trace/control-target.o
  GEN     trace/generated-helpers.c
  CC      cris-softmmu/hw/core/null-machine.o
  CC      i386-softmmu/hw/core/generic-loader.o
  CC      microblazeel-linux-user/target/microblaze/cpu.o
  CC      mips-softmmu/hw/misc/mips_cmgcr.o
  CC      mipsel-softmmu/hw/9pfs/virtio-9p-device.o
  CC      sparc64-linux-user/target/sparc/win_helper.o
  CC      ppc64le-linux-user/target/ppc/fpu_helper.o
  CC      lm32-softmmu/hw/lm32/milkymist.o
  CC      sparc64-linux-user/target/sparc/mmu_helper.o
  CC      mipsn32-linux-user/target/mips/mips-semi.o
  CC      tilegx-linux-user/trace/generated-helpers.o
  CC      cris-linux-user/trace/control-target.o
  CC      xtensa-softmmu/accel/tcg/cpu-exec.o
  CC      ppc64le-linux-user/target/ppc/int_helper.o
  CC      s390x-softmmu/hw/display/virtio-gpu-pci.o
  CC      microblazeel-softmmu/hw/microblaze/petalogix_s3adsp1800_mmu.o
  CC      mips64el-softmmu/hw/core/null-machine.o
  CC      aarch64-softmmu/hw/char/exynos4210_uart.o
  CC      sh4-softmmu/accel/tcg/cputlb.o
  CC      i386-linux-user/target/i386/windbgstub.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11.o
  CC      alpha-linux-user/target/alpha/mem_helper.o
  CC      arm-linux-user/target/arm/neon_helper.o
  CC      sh4-softmmu/accel/tcg/tcg-runtime.o
  CC      xtensaeb-softmmu/hw/vfio/common.o
  CC      xtensaeb-softmmu/hw/vfio/platform.o
  CC      tricore-softmmu/target/tricore/helper.o
  CC      x86_64-softmmu/hw/net/vhost_net.o
  CC      m68k-linux-user/target/m68k/fpu_helper.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11_cpdo.o
  CC      x86_64-linux-user/target/i386/excp_helper.o
  CC      mips64-softmmu/hw/display/virtio-gpu-3d.o
  CC      sparc32plus-linux-user/target/sparc/vis_helper.o
  CC      microblaze-softmmu/hw/vfio/platform.o
  CC      s390x-softmmu/hw/intc/s390_flic.o
  CC      i386-softmmu/hw/core/null-machine.o
  CC      alpha-softmmu/hw/display/vga.o
  CC      ppc64-linux-user/linux-user/uaccess.o
  CC      cris-softmmu/hw/misc/mmio_interface.o
  CC      sparc-linux-user/target/sparc/ldst_helper.o
  GEN     trace/generated-helpers.c
  CC      sh4eb-linux-user/trace/generated-helpers.o
  CC      sh4eb-softmmu/hw/block/tc58128.o
  CC      sh4eb-softmmu/hw/block/virtio-blk.o
  CC      microblazeel-softmmu/hw/microblaze/petalogix_ml605_mmu.o
  CC      mips64el-softmmu/hw/display/vga.o
  CC      m68k-linux-user/target/m68k/gdbstub.o
  CC      m68k-softmmu/accel/tcg/translator.o
  CC      moxie-softmmu/hw/misc/mmio_interface.o
  CC      mipsel-softmmu/hw/block/virtio-blk.o
  CC      cris-linux-user/trace/generated-helpers.o
  CC      or1k-linux-user/target/openrisc/mmu_helper.o
  CC      nios2-softmmu/hw/vfio/spapr.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11_cpdt.o
/var/tmp/patchew-tester-tmp-yk6niwxj/src/target/i386/windbgstub.c: In function ‘kd_api_read_msr’:
/var/tmp/patchew-tester-tmp-yk6niwxj/src/target/i386/windbgstub.c:1081:9: error: implicit declaration of function ‘cpu_get_apic_base’ [-Werror=implicit-function-declaration]
         val = cpu_get_apic_base(x86_env_get_cpu(env)->apic_state);
         ^
/var/tmp/patchew-tester-tmp-yk6niwxj/src/target/i386/windbgstub.c:1081:9: error: nested extern declaration of ‘cpu_get_apic_base’ [-Werror=nested-externs]
/var/tmp/patchew-tester-tmp-yk6niwxj/src/target/i386/windbgstub.c: In function ‘kd_api_write_msr’:
/var/tmp/patchew-tester-tmp-yk6niwxj/src/target/i386/windbgstub.c:1238:9: error: implicit declaration of function ‘cpu_set_apic_base’ [-Werror=implicit-function-declaration]
         cpu_set_apic_base(x86_env_get_cpu(env)->apic_state, val);
         ^
/var/tmp/patchew-tester-tmp-yk6niwxj/src/target/i386/windbgstub.c:1238:9: error: nested extern declaration of ‘cpu_set_apic_base’ [-Werror=nested-externs]
  CC      cris-softmmu/hw/net/etraxfs_eth.o
  CC      sparc-softmmu/hw/vfio/spapr.o
cc1: all warnings being treated as errors
make[1]: *** [target/i386/windbgstub.o] Error 1
make: *** [subdir-i386-linux-user] Error 2
make: *** Waiting for unfinished jobs....
  CC      alpha-softmmu/hw/display/virtio-gpu.o
  CC      aarch64-softmmu/hw/char/omap_uart.o
  CC      sh4-linux-user/target/sh4/cpu.o
  CC      mips-softmmu/hw/misc/mips_cpc.o
  CC      ppc-softmmu/hw/char/virtio-serial-bus.o
  CC      ppcemb-softmmu/accel/tcg/tcg-runtime.o
  CC      alpha-softmmu/hw/display/virtio-gpu-3d.o
  CC      ppc-linux-user/linux-user/linuxload.o
  CC      arm-linux-user/target/arm/iwmmxt_helper.o
  CC      lm32-softmmu/target/lm32/translate.o
  CC      moxie-softmmu/hw/net/vhost_net.o
  CC      ppc64abi32-linux-user/target/ppc/timebase_helper.o
  CC      alpha-softmmu/hw/display/virtio-gpu-pci.o
  GEN     trace/generated-helpers.c
  LINK    tilegx-linux-user/qemu-tilegx
  CC      mips64el-linux-user/trace/generated-helpers.o
  CC      mips64el-softmmu/hw/display/virtio-gpu.o
  GEN     trace/generated-helpers.c
  CC      m68k-linux-user/trace/control-target.o
  CC      alpha-softmmu/hw/misc/ivshmem.o
  CC      ppc64-softmmu/accel/tcg/translator.o
  CC      or1k-softmmu/hw/vfio/platform.o
  CC      aarch64-linux-user/target/arm/neon_helper.o
  CC      x86_64-softmmu/hw/scsi/virtio-scsi.o
  CC      xtensa-softmmu/accel/tcg/cpu-exec-common.o
  CC      sparc32plus-linux-user/target/sparc/gdbstub.o
  CC      mipsel-softmmu/hw/block/dataplane/virtio-blk.o
  CC      or1k-linux-user/target/openrisc/sys_helper.o
  CC      or1k-linux-user/target/openrisc/gdbstub.o
  GEN     trace/generated-helpers.c
  CC      alpha-linux-user/target/alpha/gdbstub.o
  CC      or1k-linux-user/trace/control-target.o
  CC      microblazeel-linux-user/target/microblaze/gdbstub.o
  CC      sparc64-softmmu/hw/display/virtio-gpu-pci.o
  CC      mipsn32-linux-user/trace/control-target.o
  CC      mips64-softmmu/hw/display/virtio-gpu-pci.o
  CC      sparc64-linux-user/target/sparc/ldst_helper.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpa11_cprt.o
  CC      arm-softmmu/hw/char/exynos4210_uart.o
  CC      mipsel-softmmu/hw/char/virtio-serial-bus.o
  CC      moxie-softmmu/hw/net/rocker/qmp-norocker.o
  CC      ppc64-linux-user/linux-user/uname.o
  CC      microblazeel-softmmu/hw/microblaze/boot.o
  CC      alpha-softmmu/hw/misc/mmio_interface.o
  CC      s390x-softmmu/hw/misc/mmio_interface.o
  CC      sparc-softmmu/hw/sparc/sun4m.o
  CC      i386-softmmu/hw/display/vga.o
  CC      i386-softmmu/hw/display/virtio-gpu.o
  LINK    cris-linux-user/qemu-cris
  CC      alpha-softmmu/hw/net/virtio-net.o
  CC      mips-softmmu/hw/misc/mips_itu.o
  LINK    sh4eb-linux-user/qemu-sh4eb
  CC      or1k-softmmu/hw/vfio/spapr.o
  CC      sh4-linux-user/target/sh4/gdbstub.o
  CC      cris-softmmu/hw/net/vhost_net.o
  CCAS    ppc64-linux-user/linux-user/safe-syscall.o
  CC      lm32-softmmu/target/lm32/op_helper.o
  CC      mipsel-softmmu/hw/core/generic-loader.o
  CC      unicore32-softmmu/accel/tcg/translator.o
  GEN     trace/generated-helpers.c
  CC      nios2-softmmu/hw/nios2/boot.o
  CC      sparc64-softmmu/hw/misc/ivshmem.o
  CC      ppcemb-softmmu/accel/tcg/cpu-exec.o
  CC      x86_64-linux-user/target/i386/fpu_helper.o
  CC      i386-softmmu/hw/display/virtio-gpu-3d.o
  CC      aarch64-softmmu/hw/char/digic-uart.o
  CC      alpha-linux-user/trace/control-target.o
  CC      microblaze-softmmu/hw/vfio/spapr.o
  CC      sh4-softmmu/accel/tcg/cpu-exec.o
  CC      ppc64-softmmu/hw/9pfs/virtio-9p-device.o
  GEN     trace/generated-helpers.c
  CC      arm-softmmu/hw/char/omap_uart.o
  CC      ppc-softmmu/hw/core/generic-loader.o
  CC      sparc-linux-user/target/sparc/int32_helper.o
  CC      xtensaeb-softmmu/hw/vfio/spapr.o
  CC      m68k-softmmu/hw/char/mcf_uart.o
  CC      moxie-softmmu/hw/timer/mc146818rtc.o
  CC      x86_64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      s390x-softmmu/hw/net/virtio-net.o
  CC      sparc32plus-linux-user/trace/control-target.o
  GEN     trace/generated-helpers.c
  CC      or1k-linux-user/trace/generated-helpers.o
  CC      sparc64-softmmu/hw/misc/mmio_interface.o
  CC      x86_64-linux-user/target/i386/int_helper.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/fpopcode.o
  CC      ppc-softmmu/hw/core/null-machine.o
  CC      x86_64-linux-user/target/i386/mem_helper.o
  CC      mips64el-softmmu/hw/display/virtio-gpu-3d.o
  CC      mips64-linux-user/target/mips/cpu.o
  CC      ppcemb-softmmu/accel/tcg/cpu-exec-common.o
  CC      xtensaeb-softmmu/hw/xtensa/pic_cpu.o
  CC      cris-softmmu/hw/net/rocker/qmp-norocker.o
  CC      m68k-linux-user/gdbstub-xml.o
  CC      ppcemb-softmmu/accel/tcg/translate-all.o
  GEN     trace/generated-helpers.c
  CC      mips64-linux-user/target/mips/gdbstub.o
  CC      sparc-softmmu/hw/sparc/leon3.o
  CC      nios2-softmmu/hw/nios2/cpu_pic.o
  CC      microblaze-softmmu/hw/microblaze/petalogix_s3adsp1800_mmu.o
  CC      aarch64-softmmu/hw/char/stm32f2xx_usart.o
  CC      xtensa-softmmu/accel/tcg/translate-all.o
  CC      x86_64-linux-user/target/i386/misc_helper.o
  CC      microblazeel-linux-user/trace/control-target.o
  CC      sh4-linux-user/trace/control-target.o
  CC      arm-linux-user/target/arm/gdbstub.o
  CC      microblazeel-softmmu/target/microblaze/translate.o
  CC      arm-softmmu/hw/char/digic-uart.o
  CC      mips-softmmu/hw/misc/mmio_interface.o
  CC      microblazeel-softmmu/target/microblaze/op_helper.o
  CC      nios2-softmmu/hw/nios2/10m50_devboard.o
  CC      lm32-softmmu/target/lm32/helper.o
  CC      lm32-softmmu/target/lm32/cpu.o
  CC      cris-softmmu/hw/vfio/common.o
  CC      s390x-linux-user/target/s390x/int_helper.o
  CC      or1k-softmmu/hw/openrisc/pic_cpu.o
  CC      arm-linux-user/target/arm/crypto_helper.o
  CC      x86_64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      sh4eb-softmmu/hw/block/dataplane/virtio-blk.o
  CC      microblaze-softmmu/hw/microblaze/petalogix_ml605_mmu.o
  CC      lm32-softmmu/target/lm32/gdbstub.o
  CC      unicore32-softmmu/hw/core/generic-loader.o
  CC      i386-softmmu/hw/display/virtio-gpu-pci.o
  CC      alpha-linux-user/trace/generated-helpers.o
  CC      x86_64-linux-user/target/i386/mpx_helper.o
  CC      ppc64-softmmu/hw/block/virtio-blk.o
  CC      ppc64-linux-user/target/ppc/cpu-models.o
  CC      cris-softmmu/hw/vfio/platform.o
  CC      ppc64-linux-user/target/ppc/cpu.o
  CC      aarch64-linux-user/target/arm/iwmmxt_helper.o
  CC      cris-softmmu/hw/vfio/spapr.o
  CC      microblazeel-softmmu/target/microblaze/helper.o
  CC      mipsn32-linux-user/trace/generated-helpers.o
  CC      ppc64abi32-linux-user/target/ppc/misc_helper.o
  CC      nios2-softmmu/target/nios2/translate.o
  CC      sparc32plus-linux-user/trace/generated-helpers.o
  CC      ppc-softmmu/hw/display/sm501.o
  CC      xtensa-softmmu/accel/tcg/translator.o
  CC      s390x-linux-user/target/s390x/mem_helper.o
  CC      m68k-softmmu/hw/core/generic-loader.o
  LINK    or1k-linux-user/qemu-or1k
  CC      armeb-linux-user/linux-user/arm/nwfpe/single_cpdo.o
  CC      xtensaeb-softmmu/hw/xtensa/sim.o
  CC      mips-softmmu/hw/net/virtio-net.o
  CC      aarch64-softmmu/hw/char/bcm2835_aux.o
  CC      sh4-linux-user/trace/generated-helpers.o
  CC      xtensaeb-softmmu/hw/xtensa/xtfpga.o
  CC      sparc64-softmmu/hw/net/virtio-net.o
  CC      arm-softmmu/hw/char/stm32f2xx_usart.o
  CC      xtensa-softmmu/hw/core/generic-loader.o
  CC      sparc-softmmu/target/sparc/machine.o
  CC      microblazeel-linux-user/trace/generated-helpers.o
  CC      ppc64abi32-linux-user/target/ppc/mem_helper.o
  CC      or1k-softmmu/hw/openrisc/cputimer.o
  CC      ppc-linux-user/linux-user/uaccess.o
  CC      sparc64-linux-user/target/sparc/int64_helper.o
  CC      sh4eb-softmmu/hw/char/sh_serial.o
  CC      tricore-softmmu/target/tricore/cpu.o
  CC      x86_64-softmmu/hw/scsi/vhost-scsi.o
  CC      sparc-softmmu/target/sparc/monitor.o
  CC      or1k-softmmu/hw/openrisc/openrisc_sim.o
  CC      aarch64-linux-user/target/arm/gdbstub.o
  CC      s390x-softmmu/hw/net/vhost_net.o
  CC      ppc-linux-user/linux-user/uname.o
  CC      ppc-softmmu/hw/display/vga.o
  CC      mips64-softmmu/hw/intc/mips_gic.o
  CC      mipsel-softmmu/hw/core/null-machine.o
  CC      mipsel-softmmu/hw/display/vga.o
  CC      mips-linux-user/trace/control-target.o
  CC      moxie-softmmu/hw/vfio/common.o
  CC      ppc-softmmu/hw/display/virtio-gpu.o
  CC      ppc-softmmu/hw/display/virtio-gpu-3d.o
  CC      microblaze-softmmu/hw/microblaze/boot.o
  CC      unicore32-softmmu/hw/core/null-machine.o
  LINK    alpha-linux-user/qemu-alpha
  CC      s390x-linux-user/target/s390x/misc_helper.o
  CC      sparc-linux-user/target/sparc/gdbstub.o
  CC      x86_64-linux-user/target/i386/seg_helper.o
  CC      moxie-softmmu/hw/vfio/platform.o
  CC      cris-softmmu/hw/cris/boot.o
  CC      sparc64-softmmu/hw/net/vhost_net.o
  CC      arm-softmmu/hw/char/bcm2835_aux.o
  CC      arm-softmmu/hw/char/virtio-serial-bus.o
  CC      sparc-softmmu/target/sparc/translate.o
  LINK    sparc32plus-linux-user/qemu-sparc32plus
  CC      cris-softmmu/hw/cris/axis_dev88.o
  CC      xtensa-softmmu/hw/core/null-machine.o
  CC      ppc64-softmmu/hw/block/dataplane/virtio-blk.o
  CC      m68k-softmmu/hw/core/null-machine.o
  CC      aarch64-softmmu/hw/char/virtio-serial-bus.o
  CC      i386-softmmu/hw/display/virtio-vga.o
  LINK    microblazeel-linux-user/qemu-microblazeel
  LINK    sh4-linux-user/qemu-sh4
  CC      armeb-linux-user/linux-user/arm/nwfpe/double_cpdo.o
  CC      mips64el-softmmu/hw/display/virtio-gpu-pci.o
  CC      ppc64-softmmu/hw/char/spapr_vty.o
  CC      i386-softmmu/hw/intc/apic.o
  CC      xtensaeb-softmmu/target/xtensa/xtensa-semi.o
  CC      ppc-softmmu/hw/display/virtio-gpu-pci.o
  CC      mips64el-softmmu/hw/intc/mips_gic.o
  CC      s390x-linux-user/target/s390x/crypto_helper.o
  CC      moxie-softmmu/hw/vfio/spapr.o
  CC      mips64-softmmu/hw/misc/ivshmem.o
  CC      sh4eb-softmmu/hw/char/virtio-serial-bus.o
  CC      or1k-softmmu/target/openrisc/machine.o
  CC      x86_64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      sh4-softmmu/accel/tcg/cpu-exec-common.o
  CC      microblaze-softmmu/target/microblaze/translate.o
  CC      sparc64-softmmu/hw/scsi/virtio-scsi.o
  CC      unicore32-softmmu/hw/misc/mmio_interface.o
  CC      mips64-linux-user/target/mips/msa_helper.o
  CC      m68k-softmmu/hw/misc/mmio_interface.o
  GEN     trace/generated-helpers.c
  CC      s390x-linux-user/target/s390x/kvm-stub.o
  CC      ppcemb-softmmu/accel/tcg/translator.o
  CC      armeb-linux-user/linux-user/arm/nwfpe/extended_cpdo.o
  CC      xtensa-softmmu/hw/misc/mmio_interface.o
  CC      mips64el-softmmu/hw/misc/ivshmem.o
  CC      sparc-linux-user/trace/control-target.o
  CC      aarch64-linux-user/target/arm/cpu64.o
  CC      sparc-softmmu/target/sparc/helper.o
  CC      tricore-softmmu/target/tricore/op_helper.o
  CC      ppc64le-linux-user/target/ppc/timebase_helper.o
  CC      mips-softmmu/hw/net/vhost_net.o
  CC      xtensa-softmmu/hw/net/vhost_net.o
  CC      lm32-softmmu/target/lm32/lm32-semi.o
  CC      x86_64-softmmu/hw/timer/mc146818rtc.o
  CC      ppc64le-linux-user/target/ppc/misc_helper.o
  CC      alpha-softmmu/hw/net/vhost_net.o
  CC      moxie-softmmu/hw/moxie/moxiesim.o
  CCAS    ppc-linux-user/linux-user/safe-syscall.o
  CC      microblazeel-softmmu/target/microblaze/cpu.o
  CC      ppc-linux-user/target/ppc/cpu-models.o
  CC      microblazeel-softmmu/target/microblaze/gdbstub.o
  CC      x86_64-linux-user/target/i386/smm_helper.o
  CC      m68k-softmmu/hw/net/mcf_fec.o
  CC      alpha-softmmu/hw/scsi/virtio-scsi.o
  CC      lm32-softmmu/target/lm32/machine.o
  CC      unicore32-softmmu/hw/net/vhost_net.o
  CC      ppc64-softmmu/hw/char/virtio-serial-bus.o
  CC      or1k-softmmu/target/openrisc/cpu.o
  CC      mips64el-softmmu/hw/misc/mips_cmgcr.o
  CC      aarch64-linux-user/target/arm/translate-a64.o
  CC      sh4-softmmu/accel/tcg/translate-all.o
  CC      mips-softmmu/hw/scsi/virtio-scsi.o
  CC      xtensa-softmmu/hw/net/rocker/qmp-norocker.o
  CC      mips64-softmmu/hw/misc/mips_cmgcr.o
  CC      armeb-linux-user/target/arm/arm-semi.o
  CC      ppcemb-softmmu/hw/9pfs/virtio-9p-device.o
  CC      ppcemb-softmmu/hw/block/virtio-blk.o
  CC      unicore32-softmmu/hw/net/rocker/qmp-norocker.o
  CC      mips-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      x86_64-linux-user/target/i386/svm_helper.o
  CC      mipsel-softmmu/hw/display/virtio-gpu.o
  CC      xtensaeb-softmmu/target/xtensa/core-dc232b.o
  CC      ppc64abi32-linux-user/target/ppc/user_only_helper.o
  CC      sh4eb-softmmu/hw/core/generic-loader.o
  CC      mips-softmmu/hw/scsi/vhost-scsi-common.o
  CC      m68k-softmmu/hw/net/vhost_net.o
  CC      sparc-linux-user/trace/generated-helpers.o
  CC      ppc-softmmu/hw/i2c/ppc4xx_i2c.o
  CC      microblazeel-softmmu/target/microblaze/mmu.o
  CC      cris-softmmu/target/cris/translate.o
  GEN     trace/generated-helpers.c
  CC      sh4-softmmu/accel/tcg/translator.o
  CC      microblaze-softmmu/target/microblaze/op_helper.o
  CC      s390x-softmmu/hw/net/rocker/qmp-norocker.o
  GEN     trace/generated-helpers.c
  CC      ppc64le-linux-user/target/ppc/mem_helper.o
  CC      ppcemb-softmmu/hw/block/dataplane/virtio-blk.o
  CC      moxie-softmmu/target/moxie/translate.o
  CC      mipsel-softmmu/hw/display/virtio-gpu-3d.o
  CC      ppc-linux-user/target/ppc/cpu.o
  CC      mips-softmmu/hw/scsi/vhost-scsi.o
  CC      sparc64-linux-user/target/sparc/vis_helper.o
  CC      lm32-softmmu/trace/control-target.o
  CC      xtensa-softmmu/hw/vfio/common.o
  GEN     trace/generated-helpers.c
  CC      unicore32-softmmu/hw/vfio/common.o
  CC      ppc64-linux-user/target/ppc/translate.o
  CC      s390x-linux-user/trace/control-target.o
  CC      xtensa-softmmu/hw/vfio/platform.o
  CC      sparc64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      x86_64-softmmu/hw/vfio/common.o
  CC      m68k-linux-user/trace/generated-helpers.o
  CC      arm-softmmu/hw/core/generic-loader.o
  CC      mips64-linux-user/target/mips/mips-semi.o
  CC      moxie-softmmu/target/moxie/helper.o
  GEN     trace/generated-helpers.c
  CC      unicore32-softmmu/hw/vfio/platform.o
  CC      mips-linux-user/trace/generated-helpers.o
  CC      mips64-softmmu/hw/misc/mips_cpc.o
  CC      xtensaeb-softmmu/target/xtensa/core-dc233c.o
  CC      mips64el-softmmu/hw/misc/mips_cpc.o
  CC      s390x-softmmu/hw/scsi/virtio-scsi.o
  CC      or1k-softmmu/target/openrisc/exception.o
  CC      xtensa-softmmu/hw/vfio/spapr.o
  CC      armeb-linux-user/target/arm/kvm-stub.o
  CC      sparc-softmmu/target/sparc/cpu.o
  CC      nios2-softmmu/target/nios2/op_helper.o
  CC      s390x-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      i386-softmmu/hw/intc/apic_common.o
  GEN     trace/generated-helpers.c
  CC      or1k-softmmu/target/openrisc/interrupt.o
  CC      xtensa-softmmu/hw/xtensa/pic_cpu.o
  CC      m68k-softmmu/hw/net/rocker/qmp-norocker.o
  CC      microblazeel-softmmu/trace/control-target.o
  CC      ppc64le-linux-user/target/ppc/user_only_helper.o
  CC      mips-softmmu/hw/scsi/vhost-user-scsi.o
  CC      aarch64-softmmu/hw/core/generic-loader.o
  CC      i386-softmmu/hw/intc/ioapic.o
  CC      moxie-softmmu/target/moxie/machine.o
  CC      arm-softmmu/hw/core/null-machine.o
  CC      arm-softmmu/hw/cpu/arm11mpcore.o
  CC      mipsel-softmmu/hw/display/virtio-gpu-pci.o
  CC      unicore32-softmmu/hw/vfio/spapr.o
  CC      aarch64-linux-user/target/arm/helper-a64.o
  CC      ppcemb-softmmu/hw/char/virtio-serial-bus.o
  CC      lm32-softmmu/trace/generated-helpers.o
  CC      armeb-linux-user/target/arm/translate.o
  CC      xtensaeb-softmmu/target/xtensa/core-fsf.o
  CC      aarch64-softmmu/hw/core/null-machine.o
  LINK    sparc-linux-user/qemu-sparc
  CC      ppc64le-linux-user/target/ppc/gdbstub.o
  CC      armeb-linux-user/target/arm/op_helper.o
  CC      sh4eb-softmmu/hw/core/null-machine.o
  CC      s390x-softmmu/hw/scsi/vhost-scsi-common.o
  CC      ppc-linux-user/target/ppc/translate.o
  CC      xtensa-softmmu/hw/xtensa/sim.o
  CC      m68k-softmmu/hw/vfio/common.o
  CC      ppc64le-linux-user/target/ppc/../../libdecnumber/decContext.o
  CC      nios2-softmmu/target/nios2/helper.o
  CC      alpha-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      mips64el-softmmu/hw/misc/mips_itu.o
  CC      or1k-softmmu/target/openrisc/mmu.o
  CC      mipsel-softmmu/hw/intc/mips_gic.o
  CC      ppc-linux-user/target/ppc/kvm-stub.o
  CC      mips64-softmmu/hw/misc/mips_itu.o
  CC      xtensaeb-softmmu/target/xtensa/monitor.o
  CC      mips64-softmmu/hw/misc/mmio_interface.o
  CC      unicore32-softmmu/hw/unicore32/puv3.o
  CC      sh4eb-softmmu/hw/display/sm501.o
  CC      or1k-softmmu/target/openrisc/translate.o
  CC      armeb-linux-user/target/arm/helper.o
  CC      i386-softmmu/hw/isa/lpc_ich9.o
  CC      s390x-linux-user/gdbstub-xml.o
  CC      xtensaeb-softmmu/target/xtensa/translate.o
  CC      mips64el-softmmu/hw/misc/mmio_interface.o
  CC      sh4-softmmu/hw/9pfs/virtio-9p-device.o
  CC      arm-softmmu/hw/cpu/realview_mpcore.o
  CC      mips-softmmu/hw/timer/mips_gictimer.o
  CC      x86_64-linux-user/target/i386/kvm-stub.o
  CC      arm-softmmu/hw/cpu/a9mpcore.o
  CC      xtensaeb-softmmu/target/xtensa/op_helper.o
  CC      i386-softmmu/hw/misc/vmport.o
  CC      aarch64-softmmu/hw/cpu/arm11mpcore.o
  CC      armeb-linux-user/target/arm/cpu.o
  CC      sparc64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      sparc64-softmmu/hw/scsi/vhost-scsi.o
  CC      ppc64le-linux-user/target/ppc/../../libdecnumber/decNumber.o
  CC      s390x-softmmu/hw/scsi/vhost-scsi.o
  CC      nios2-softmmu/target/nios2/cpu.o
  CC      i386-softmmu/hw/misc/ivshmem.o
  CC      arm-linux-user/trace/control-target.o
  CC      moxie-softmmu/target/moxie/cpu.o
  CC      ppc64le-linux-user/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      cris-softmmu/target/cris/op_helper.o
  CC      ppc64-linux-user/target/ppc/kvm-stub.o
  CC      armeb-linux-user/target/arm/neon_helper.o
  CC      ppc64abi32-linux-user/target/ppc/gdbstub.o
  CC      aarch64-softmmu/hw/cpu/realview_mpcore.o
  CC      sh4-softmmu/hw/block/tc58128.o
  CC      cris-softmmu/target/cris/helper.o
  CC      sparc64-linux-user/target/sparc/gdbstub.o
  CC      s390x-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc-linux-user/target/ppc/dfp_helper.o
  CC      ppc64le-linux-user/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      ppc-softmmu/hw/intc/openpic_kvm.o
  CC      mips64el-softmmu/hw/net/virtio-net.o
  CC      tricore-softmmu/target/tricore/fpu_helper.o
  LINK    lm32-softmmu/qemu-system-lm32
  CC      ppc64-softmmu/hw/core/generic-loader.o
  CC      aarch64-linux-user/target/arm/gdbstub64.o
  CC      mips-softmmu/hw/timer/mc146818rtc.o
  CC      arm-softmmu/hw/cpu/a15mpcore.o
  CC      ppc64-linux-user/target/ppc/dfp_helper.o
  CC      i386-softmmu/hw/misc/pvpanic.o
  CC      alpha-softmmu/hw/scsi/vhost-scsi-common.o
  CC      s390x-linux-user/trace/generated-helpers.o
  CC      mips-softmmu/hw/vfio/common.o
  CC      s390x-softmmu/hw/vfio/common.o
  CC      sh4eb-softmmu/hw/display/vga.o
  CC      mipsel-softmmu/hw/misc/ivshmem.o
  CC      m68k-softmmu/hw/vfio/platform.o
  CC      or1k-softmmu/target/openrisc/exception_helper.o
  CC      ppc64le-linux-user/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      mips64-softmmu/hw/net/virtio-net.o
  CC      mipsel-softmmu/hw/misc/mips_cmgcr.o
  GEN     trace/generated-helpers.c
  CC      ppc64-softmmu/hw/core/null-machine.o
  GEN     trace/generated-helpers.c
  CC      sparc64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      nios2-softmmu/target/nios2/mmu.o
  CC      arm-softmmu/hw/display/omap_dss.o
  CC      ppc-linux-user/target/ppc/excp_helper.o
  CC      mips64-linux-user/trace/control-target.o
  CC      or1k-softmmu/target/openrisc/fpu_helper.o
  CC      ppc-softmmu/hw/misc/ivshmem.o
  CC      mipsel-softmmu/hw/misc/mips_cpc.o
  CC      sparc-softmmu/target/sparc/fop_helper.o
  CC      xtensa-softmmu/hw/xtensa/xtfpga.o
  CC      tricore-softmmu/trace/control-target.o
  CC      s390x-softmmu/hw/vfio/pci.o
  CC      xtensa-softmmu/target/xtensa/xtensa-semi.o
  CC      microblaze-softmmu/target/microblaze/helper.o
  CC      sh4-softmmu/hw/block/virtio-blk.o
  CC      arm-softmmu/hw/display/omap_lcdc.o
  CC      ppc64-linux-user/target/ppc/excp_helper.o
  CC      unicore32-softmmu/target/unicore32/translate.o
  CC      moxie-softmmu/target/moxie/mmu.o
  CC      aarch64-linux-user/target/arm/crypto_helper.o
  CC      nios2-softmmu/target/nios2/monitor.o
  CC      or1k-softmmu/target/openrisc/interrupt_helper.o
  CC      m68k-softmmu/hw/vfio/spapr.o
  CC      aarch64-softmmu/hw/cpu/a9mpcore.o
  CC      xtensa-softmmu/target/xtensa/core-dc232b.o
  CC      or1k-softmmu/target/openrisc/mmu_helper.o
  CC      ppc64-linux-user/target/ppc/fpu_helper.o
  CC      mips64-softmmu/hw/net/vhost_net.o
  CC      arm-linux-user/gdbstub-xml.o
  GEN     trace/generated-helpers.c
  CC      ppc64-linux-user/target/ppc/int_helper.o
  CC      sh4eb-softmmu/hw/display/virtio-gpu.o
  CC      xtensaeb-softmmu/target/xtensa/helper.o
  CC      alpha-softmmu/hw/scsi/vhost-scsi.o
  CC      cris-softmmu/target/cris/cpu.o
  CC      x86_64-linux-user/trace/control-target.o
  CC      sparc-softmmu/target/sparc/cc_helper.o
  CC      ppcemb-softmmu/hw/core/generic-loader.o
  CC      microblaze-softmmu/target/microblaze/cpu.o
  CC      ppcemb-softmmu/hw/core/null-machine.o
  CC      m68k-softmmu/hw/m68k/an5206.o
  CC      xtensaeb-softmmu/target/xtensa/cpu.o
  CC      ppc64-softmmu/hw/display/sm501.o
  CC      sparc64-softmmu/hw/timer/mc146818rtc.o
  CC      or1k-softmmu/target/openrisc/sys_helper.o
  CC      mips64el-softmmu/hw/net/vhost_net.o
  CC      armeb-linux-user/target/arm/iwmmxt_helper.o
  CC      ppcemb-softmmu/hw/display/sm501.o
  CC      x86_64-softmmu/hw/vfio/pci.o
  CC      s390x-softmmu/hw/vfio/pci-quirks.o
  CC      ppc64-linux-user/target/ppc/timebase_helper.o
  CC      mips-softmmu/hw/vfio/pci.o
  CC      i386-softmmu/hw/misc/mmio_interface.o
  CC      arm-softmmu/hw/display/pxa2xx_lcd.o
  CC      xtensa-softmmu/target/xtensa/core-dc233c.o
  CC      sparc64-softmmu/hw/vfio/common.o
  CC      xtensaeb-softmmu/target/xtensa/gdbstub.o
  LINK    m68k-linux-user/qemu-m68k
  CC      armeb-linux-user/target/arm/gdbstub.o
  CC      nios2-softmmu/trace/control-target.o
  GEN     trace/generated-helpers.c
  CC      ppc-linux-user/target/ppc/fpu_helper.o
  GEN     trace/generated-helpers.c
  CC      mips64-linux-user/trace/generated-helpers.o
  CC      microblazeel-softmmu/trace/generated-helpers.o
  CC      cris-softmmu/target/cris/gdbstub.o
  CC      moxie-softmmu/trace/control-target.o
  CC      ppc64-linux-user/target/ppc/misc_helper.o
  CC      aarch64-softmmu/hw/cpu/a15mpcore.o
  CC      i386-softmmu/hw/net/virtio-net.o
  CC      sparc-softmmu/target/sparc/win_helper.o
  CC      arm-linux-user/trace/generated-helpers.o
  CC      ppc64-linux-user/target/ppc/mem_helper.o
  CC      sh4eb-softmmu/hw/display/virtio-gpu-3d.o
  CC      ppc-linux-user/target/ppc/int_helper.o
  CC      arm-softmmu/hw/display/bcm2835_fb.o
  CC      mips64-softmmu/hw/scsi/virtio-scsi.o
  CC      ppc-softmmu/hw/misc/mmio_interface.o
  CC      tricore-softmmu/trace/generated-helpers.o
  CC      alpha-softmmu/hw/scsi/vhost-user-scsi.o
  CC      i386-softmmu/hw/net/vhost_net.o
  CC      mipsel-softmmu/hw/misc/mips_itu.o
  CC      microblaze-softmmu/target/microblaze/gdbstub.o
  CC      or1k-softmmu/target/openrisc/gdbstub.o
  CC      cris-softmmu/target/cris/mmu.o
  CC      ppc64abi32-linux-user/target/ppc/../../libdecnumber/decContext.o
  CC      microblaze-softmmu/target/microblaze/mmu.o
  CC      sparc64-softmmu/hw/vfio/pci.o
  CC      aarch64-linux-user/trace/control-target.o
  CC      xtensa-softmmu/target/xtensa/core-fsf.o
  CC      ppc64abi32-linux-user/target/ppc/../../libdecnumber/decNumber.o
  CC      ppc64abi32-linux-user/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      mips-softmmu/hw/vfio/pci-quirks.o
  CC      m68k-softmmu/hw/m68k/mcf5208.o
  CC      arm-softmmu/hw/display/vga.o
  CC      ppc64-softmmu/hw/display/vga.o
  CC      armeb-linux-user/target/arm/crypto_helper.o
  CC      sh4eb-softmmu/hw/display/virtio-gpu-pci.o
  CC      alpha-softmmu/hw/timer/mc146818rtc.o
  CC      x86_64-linux-user/gdbstub-xml.o
  CC      nios2-softmmu/trace/generated-helpers.o
  CC      arm-softmmu/hw/display/virtio-gpu.o
  CC      moxie-softmmu/trace/generated-helpers.o
  CC      aarch64-softmmu/hw/display/omap_dss.o
  GEN     trace/generated-helpers.c
  CC      cris-softmmu/target/cris/machine.o
  CC      sparc-softmmu/target/sparc/mmu_helper.o
  GEN     trace/generated-helpers.c
  CC      mipsel-softmmu/hw/misc/mmio_interface.o
  GEN     trace/generated-helpers.c
  CC      xtensa-softmmu/target/xtensa/monitor.o
  CC      ppc64le-linux-user/trace/control-target.o
  CC      alpha-softmmu/hw/vfio/common.o
  GEN     trace/generated-helpers.c
  CC      sparc64-linux-user/trace/control-target.o
  CC      sh4-softmmu/hw/block/dataplane/virtio-blk.o
  CC      sparc-softmmu/target/sparc/ldst_helper.o
  CC      xtensaeb-softmmu/trace/control-target.o
  CC      unicore32-softmmu/target/unicore32/op_helper.o
  LINK    microblazeel-softmmu/qemu-system-microblazeel
  CC      mips-softmmu/hw/vfio/platform.o
  CC      sparc64-softmmu/hw/vfio/pci-quirks.o
  CC      ppc64-softmmu/hw/display/virtio-gpu.o
  CC      aarch64-softmmu/hw/display/omap_lcdc.o
  GEN     trace/generated-helpers.c
  CC      ppc-softmmu/hw/net/xilinx_ethlite.o
  CC      i386-softmmu/hw/scsi/virtio-scsi.o
  CC      sh4eb-softmmu/hw/intc/sh_intc.o
  CC      m68k-softmmu/hw/m68k/mcf5206.o
  CC      unicore32-softmmu/target/unicore32/helper.o
  CC      m68k-softmmu/hw/m68k/mcf_intc.o
  CC      aarch64-linux-user/gdbstub-xml.o
  CC      ppcemb-softmmu/hw/display/vga.o
  CC      sparc64-softmmu/hw/vfio/platform.o
  CC      xtensa-softmmu/target/xtensa/translate.o
  GEN     trace/generated-helpers.c
  CC      mips64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  GEN     trace/generated-helpers.c
  CC      mips64el-softmmu/hw/scsi/virtio-scsi.o
  CC      arm-softmmu/hw/display/virtio-gpu-3d.o
  CC      microblaze-softmmu/trace/control-target.o
  CC      cris-softmmu/trace/control-target.o
  CC      mips64el-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      mipsel-softmmu/hw/net/virtio-net.o
  CC      arm-softmmu/hw/display/virtio-gpu-pci.o
  CC      m68k-softmmu/target/m68k/m68k-semi.o
  LINK    moxie-softmmu/qemu-system-moxie
  CC      sparc-softmmu/target/sparc/int32_helper.o
  CC      sh4eb-softmmu/hw/misc/ivshmem.o
  LINK    nios2-softmmu/qemu-system-nios2
  CC      sparc64-linux-user/trace/generated-helpers.o
  CC      m68k-softmmu/target/m68k/translate.o
  CC      sh4eb-softmmu/hw/misc/mmio_interface.o
  CC      ppc64le-linux-user/gdbstub-xml.o
  CC      armeb-linux-user/trace/control-target.o
  CC      mipsel-softmmu/hw/net/vhost_net.o
  CC      sh4-softmmu/hw/char/sh_serial.o
  CC      sh4-softmmu/hw/char/virtio-serial-bus.o
  CC      mips-softmmu/hw/vfio/spapr.o
  CC      m68k-softmmu/target/m68k/op_helper.o
  CC      alpha-softmmu/hw/vfio/pci.o
  CC      mipsel-softmmu/hw/scsi/virtio-scsi.o
  CC      ppc-softmmu/hw/net/virtio-net.o
  CC      s390x-softmmu/hw/vfio/ccw.o
  CC      x86_64-linux-user/trace/generated-helpers.o
  CC      i386-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      s390x-softmmu/hw/vfio/platform.o
  CC      arm-softmmu/hw/dma/omap_dma.o
  CC      s390x-softmmu/hw/vfio/spapr.o
  CC      sh4eb-softmmu/hw/net/virtio-net.o
  CC      mips-softmmu/hw/virtio/virtio.o
  CC      ppcemb-softmmu/hw/display/virtio-gpu.o
  CC      microblaze-softmmu/trace/generated-helpers.o
  CC      or1k-softmmu/trace/control-target.o
  CC      aarch64-softmmu/hw/display/pxa2xx_lcd.o
  CC      ppcemb-softmmu/hw/display/virtio-gpu-3d.o
  CC      m68k-softmmu/target/m68k/helper.o
  CC      ppc64abi32-linux-user/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      ppc64le-linux-user/trace/generated-helpers.o
  CC      ppc64-softmmu/hw/display/virtio-gpu-3d.o
  CC      x86_64-softmmu/hw/vfio/pci-quirks.o
  CC      mips64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      ppc64-linux-user/target/ppc/user_only_helper.o
  CC      xtensa-softmmu/target/xtensa/op_helper.o
  CC      sparc-softmmu/target/sparc/gdbstub.o
  CC      sh4eb-softmmu/hw/net/vhost_net.o
  CC      xtensa-softmmu/target/xtensa/helper.o
  CC      sh4eb-softmmu/hw/scsi/virtio-scsi.o
  CC      xtensa-softmmu/target/xtensa/cpu.o
  CC      aarch64-linux-user/trace/generated-helpers.o
  CC      ppc64-softmmu/hw/display/virtio-gpu-pci.o
  CC      ppc64abi32-linux-user/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      mips-softmmu/hw/virtio/virtio-balloon.o
  CC      mips-softmmu/hw/virtio/vhost.o
  LINK    sparc64-linux-user/qemu-sparc64
  CC      x86_64-softmmu/hw/vfio/platform.o
  CC      sh4-softmmu/hw/core/generic-loader.o
  CC      unicore32-softmmu/target/unicore32/cpu.o
  CC      s390x-softmmu/hw/virtio/virtio.o
  CC      or1k-softmmu/trace/generated-helpers.o
  CC      aarch64-softmmu/hw/display/bcm2835_fb.o
  CC      ppc-softmmu/hw/net/vhost_net.o
  CC      ppc-linux-user/target/ppc/timebase_helper.o
  CC      aarch64-softmmu/hw/display/vga.o
  CC      ppcemb-softmmu/hw/display/virtio-gpu-pci.o
  CC      mips-softmmu/hw/virtio/vhost-backend.o
  GEN     trace/generated-helpers.c
  LINK    microblaze-softmmu/qemu-system-microblaze
  GEN     trace/generated-helpers.c
  CC      sparc64-softmmu/hw/vfio/spapr.o
  CC      ppc-softmmu/hw/net/fsl_etsec/etsec.o
  CC      sparc-softmmu/trace/control-target.o
  CC      mips64el-softmmu/hw/scsi/vhost-scsi-common.o
  CC      m68k-softmmu/target/m68k/cpu.o
  CC      m68k-softmmu/target/m68k/fpu_helper.o
  CC      m68k-softmmu/target/m68k/gdbstub.o
  CC      ppc64abi32-linux-user/trace/control-target.o
  CC      ppc-linux-user/target/ppc/misc_helper.o
  CC      i386-softmmu/hw/scsi/vhost-scsi-common.o
  GEN     trace/generated-helpers.c
  CC      mips64-softmmu/hw/scsi/vhost-scsi.o
  CC      mips64el-softmmu/hw/scsi/vhost-scsi.o
  CC      sh4eb-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      xtensaeb-softmmu/trace/generated-helpers.o
  CC      arm-softmmu/hw/dma/soc_dma.o
  CC      sh4-softmmu/hw/core/null-machine.o
  CC      mips-softmmu/hw/virtio/vhost-user.o
  CC      ppc-linux-user/target/ppc/mem_helper.o
  CC      sparc64-softmmu/hw/virtio/virtio.o
  CC      ppc-linux-user/target/ppc/user_only_helper.o
  CC      ppc-softmmu/hw/net/fsl_etsec/registers.o
  CC      armeb-linux-user/gdbstub-xml.o
  CC      alpha-softmmu/hw/vfio/pci-quirks.o
  CC      sh4eb-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mips-softmmu/hw/virtio/vhost-vsock.o
  CC      x86_64-softmmu/hw/vfio/spapr.o
  CC      sparc64-softmmu/hw/virtio/virtio-balloon.o
  CC      ppc64-linux-user/target/ppc/gdbstub.o
  CC      ppc64-linux-user/target/ppc/../../libdecnumber/decContext.o
  CC      m68k-softmmu/trace/control-target.o
  LINK    or1k-softmmu/qemu-system-or1k
  CC      ppcemb-softmmu/hw/i2c/ppc4xx_i2c.o
  CC      ppcemb-softmmu/hw/misc/ivshmem.o
  CC      mipsel-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      i386-softmmu/hw/scsi/vhost-scsi.o
  CC      sparc-softmmu/trace/generated-helpers.o
  CC      i386-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc64-linux-user/target/ppc/../../libdecnumber/decNumber.o
  CC      ppc64-linux-user/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      x86_64-softmmu/hw/virtio/virtio.o
  CC      x86_64-softmmu/hw/virtio/virtio-balloon.o
  CC      arm-softmmu/hw/dma/pxa2xx_dma.o
  CC      sh4-softmmu/hw/display/sm501.o
  CC      ppc64abi32-linux-user/gdbstub-xml.o
  CC      cris-softmmu/trace/generated-helpers.o
  CC      arm-softmmu/hw/dma/bcm2835_dma.o
  CC      sh4-softmmu/hw/display/vga.o
  CC      mips64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      mips-softmmu/hw/virtio/virtio-crypto.o
  CC      mips-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      arm-softmmu/hw/gpio/omap_gpio.o
  CC      ppc64-softmmu/hw/display/virtio-vga.o
  CC      mips64el-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc-linux-user/target/ppc/gdbstub.o
  CC      mips64el-softmmu/hw/timer/mips_gictimer.o
  CC      ppcemb-softmmu/hw/misc/mmio_interface.o
  CC      m68k-softmmu/gdbstub-xml.o
  CC      x86_64-softmmu/hw/virtio/vhost.o
  CC      ppc64abi32-linux-user/trace/generated-helpers.o
  CC      xtensa-softmmu/target/xtensa/gdbstub.o
  CC      s390x-softmmu/hw/virtio/virtio-balloon.o
  CC      m68k-softmmu/trace/generated-helpers.o
  CC      mips-softmmu/hw/mips/mips_r4k.o
  CC      i386-softmmu/hw/timer/mc146818rtc.o
  CC      armeb-linux-user/trace/generated-helpers.o
  CC      sh4eb-softmmu/hw/scsi/vhost-scsi.o
  CC      arm-softmmu/hw/gpio/imx_gpio.o
  CC      x86_64-softmmu/hw/virtio/vhost-backend.o
  CC      ppc64-linux-user/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      mips-softmmu/hw/mips/mips_malta.o
  CC      ppcemb-softmmu/hw/net/xilinx_ethlite.o
  CC      sh4-softmmu/hw/display/virtio-gpu.o
  CC      alpha-softmmu/hw/vfio/platform.o
  CC      mipsel-softmmu/hw/scsi/vhost-scsi.o
  CC      mipsel-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mipsel-softmmu/hw/scsi/vhost-user-scsi.o
  CC      alpha-softmmu/hw/vfio/spapr.o
  CC      mipsel-softmmu/hw/timer/mips_gictimer.o
  CC      sh4eb-softmmu/hw/scsi/vhost-user-scsi.o
  LINK    sparc-softmmu/qemu-system-sparc
  CC      sparc64-softmmu/hw/virtio/vhost.o
  CC      ppc-softmmu/hw/net/fsl_etsec/rings.o
  CC      sh4-softmmu/hw/display/virtio-gpu-3d.o
  CC      mips-softmmu/hw/mips/mips_mipssim.o
  CC      mipsel-softmmu/hw/timer/mc146818rtc.o
  CC      sparc64-softmmu/hw/virtio/vhost-backend.o
  CC      i386-softmmu/hw/vfio/common.o
  CC      x86_64-softmmu/hw/virtio/vhost-user.o
  CC      unicore32-softmmu/target/unicore32/ucf64_helper.o
  CC      ppc-linux-user/target/ppc/../../libdecnumber/decContext.o
  CC      ppc64-softmmu/hw/i2c/ppc4xx_i2c.o
  CC      unicore32-softmmu/target/unicore32/softmmu.o
  CC      ppcemb-softmmu/hw/net/virtio-net.o
  CC      mipsel-softmmu/hw/vfio/common.o
  CC      ppc-linux-user/target/ppc/../../libdecnumber/decNumber.o
  CC      ppc64-softmmu/hw/intc/openpic_kvm.o
  CC      mips-softmmu/hw/mips/addr.o
  CC      x86_64-softmmu/hw/virtio/vhost-vsock.o
  CC      arm-softmmu/hw/gpio/bcm2835_gpio.o
  CC      mips64-softmmu/hw/timer/mips_gictimer.o
  CC      mips64-softmmu/hw/timer/mc146818rtc.o
  CC      ppcemb-softmmu/hw/net/vhost_net.o
  CC      ppc64-linux-user/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      sh4eb-softmmu/hw/timer/sh_timer.o
  CC      sh4eb-softmmu/hw/timer/mc146818rtc.o
  CC      mips64el-softmmu/hw/timer/mc146818rtc.o
  CC      arm-softmmu/hw/i2c/omap_i2c.o
  CC      mips-softmmu/hw/mips/mips_int.o
  CC      s390x-softmmu/hw/virtio/vhost.o
  CC      sh4-softmmu/hw/display/virtio-gpu-pci.o
  CC      mips64-softmmu/hw/vfio/common.o
  CC      mips-softmmu/hw/mips/gt64xxx_pci.o
  CC      mips-softmmu/hw/mips/cps.o
  CC      s390x-softmmu/hw/virtio/vhost-backend.o
  CC      s390x-softmmu/hw/virtio/vhost-user.o
  CC      mips-softmmu/target/mips/translate.o
  CC      mips-softmmu/target/mips/dsp_helper.o
  CC      sh4-softmmu/hw/intc/sh_intc.o
  CC      sh4-softmmu/hw/misc/ivshmem.o
  CC      mipsel-softmmu/hw/vfio/pci.o
  CC      mips-softmmu/target/mips/op_helper.o
  CC      ppc64-softmmu/hw/intc/xics.o
  LINK    cris-softmmu/qemu-system-cris
  CC      ppcemb-softmmu/hw/scsi/virtio-scsi.o
  CC      x86_64-softmmu/hw/virtio/virtio-crypto.o
  CC      ppc-linux-user/target/ppc/../../libdecnumber/dpd/decimal32.o
  GEN     trace/generated-helpers.c
  CC      ppc64-softmmu/hw/intc/xics_spapr.o
  CC      unicore32-softmmu/trace/control-target.o
  CC      ppcemb-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      ppcemb-softmmu/hw/scsi/vhost-scsi-common.o
  CC      alpha-softmmu/hw/virtio/virtio.o
  CC      mips64-softmmu/hw/vfio/pci.o
  CC      mips64-softmmu/hw/vfio/pci-quirks.o
  CC      x86_64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      ppcemb-softmmu/hw/scsi/vhost-scsi.o
  CC      sh4eb-softmmu/hw/vfio/common.o
  CC      ppc-softmmu/hw/net/fsl_etsec/miim.o
  CC      ppc64-softmmu/hw/intc/xics_kvm.o
  CC      sparc64-softmmu/hw/virtio/vhost-user.o
  CC      sparc64-softmmu/hw/virtio/vhost-vsock.o
  CC      mips64el-softmmu/hw/vfio/common.o
  CC      x86_64-softmmu/hw/i386/multiboot.o
  CC      ppc-softmmu/hw/scsi/virtio-scsi.o
  CC      ppc64-softmmu/hw/intc/xics_pnv.o
  CC      arm-softmmu/hw/input/pxa2xx_keypad.o
  CC      aarch64-softmmu/hw/display/virtio-gpu.o
  CC      arm-softmmu/hw/input/tsc210x.o
  CC      aarch64-softmmu/hw/display/virtio-gpu-3d.o
  CC      x86_64-softmmu/hw/i386/pc.o
  CC      s390x-softmmu/hw/virtio/vhost-vsock.o
  CC      i386-softmmu/hw/vfio/pci.o
  CC      mips-softmmu/target/mips/lmi_helper.o
  CC      ppc-linux-user/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      ppc-linux-user/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      s390x-softmmu/hw/virtio/virtio-crypto.o
  CC      ppcemb-softmmu/hw/scsi/vhost-user-scsi.o
  CC      mips-softmmu/target/mips/helper.o
  CC      ppc-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      s390x-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      ppcemb-softmmu/hw/vfio/common.o
  CC      sh4-softmmu/hw/misc/mmio_interface.o
  CC      mips64-softmmu/hw/vfio/platform.o
  CC      mips-softmmu/target/mips/cpu.o
  CC      alpha-softmmu/hw/virtio/virtio-balloon.o
  CC      unicore32-softmmu/trace/generated-helpers.o
  CC      sh4eb-softmmu/hw/vfio/pci.o
  CC      mipsel-softmmu/hw/vfio/pci-quirks.o
  CC      alpha-softmmu/hw/virtio/vhost.o
  CC      ppcemb-softmmu/hw/vfio/pci.o
  GEN     trace/generated-helpers.c
  CC      ppc64-softmmu/hw/misc/ivshmem.o
  CC      ppc64-softmmu/hw/misc/mmio_interface.o
  CC      arm-softmmu/hw/intc/armv7m_nvic.o
  CC      sparc64-softmmu/hw/virtio/virtio-crypto.o
  CC      aarch64-softmmu/hw/display/virtio-gpu-pci.o
  CC      ppc64-softmmu/hw/net/spapr_llan.o
  CC      sh4-softmmu/hw/net/virtio-net.o
  CC      ppc64-softmmu/hw/net/xilinx_ethlite.o
  CC      s390x-softmmu/hw/s390x/s390-virtio-hcall.o
  CC      sh4-softmmu/hw/net/vhost_net.o
  CC      aarch64-softmmu/hw/display/dpcd.o
  GEN     trace/generated-helpers.c
  CC      i386-softmmu/hw/vfio/pci-quirks.o
  CC      aarch64-softmmu/hw/display/xlnx_dp.o
  CC      ppcemb-softmmu/hw/vfio/pci-quirks.o
  CC      ppc64-softmmu/hw/net/virtio-net.o
  CC      ppc64-linux-user/trace/control-target.o
  CC      ppc64-softmmu/hw/net/vhost_net.o
  CC      mips64-softmmu/hw/vfio/spapr.o
  CC      ppc64-softmmu/hw/net/fsl_etsec/etsec.o
  CC      sh4eb-softmmu/hw/vfio/pci-quirks.o
  CC      mips64-softmmu/hw/virtio/virtio.o
  CC      mipsel-softmmu/hw/vfio/platform.o
  CC      s390x-softmmu/hw/s390x/sclp.o
  CC      ppcemb-softmmu/hw/vfio/platform.o
  CC      sh4eb-softmmu/hw/vfio/platform.o
  CC      ppc-linux-user/trace/control-target.o
  CC      ppc-linux-user/gdbstub-xml.o
  CC      ppc64-softmmu/hw/net/fsl_etsec/registers.o
  CC      ppc-softmmu/hw/scsi/vhost-scsi-common.o
  CC      sparc64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      s390x-softmmu/hw/s390x/event-facility.o
  CC      mipsel-softmmu/hw/vfio/spapr.o
  CC      mips64-softmmu/hw/virtio/virtio-balloon.o
  CC      mips64el-softmmu/hw/vfio/pci.o
  CC      ppc-softmmu/hw/scsi/vhost-scsi.o
  CC      aarch64-softmmu/hw/dma/xlnx_dpdma.o
  LINK    unicore32-softmmu/qemu-system-unicore32
  CC      ppc-softmmu/hw/scsi/vhost-user-scsi.o
  CC      x86_64-softmmu/hw/i386/pc_piix.o
  CC      mips64el-softmmu/hw/vfio/pci-quirks.o
  CC      aarch64-softmmu/hw/dma/omap_dma.o
  CC      i386-softmmu/hw/vfio/platform.o
  CC      ppc-softmmu/hw/timer/mc146818rtc.o
  CC      ppcemb-softmmu/hw/vfio/spapr.o
  CC      ppc64-softmmu/hw/net/fsl_etsec/rings.o
  CC      x86_64-softmmu/hw/i386/pc_q35.o
  CC      sparc64-softmmu/hw/sparc64/sparc64.o
  CC      aarch64-softmmu/hw/dma/soc_dma.o
  LINK    s390x-linux-user/qemu-s390x
  CC      mips-softmmu/target/mips/gdbstub.o
  CC      x86_64-softmmu/hw/i386/pc_sysfw.o
  CC      s390x-softmmu/hw/s390x/sclpquiesce.o
  CC      sparc64-softmmu/hw/sparc64/sun4u.o
  CC      alpha-softmmu/hw/virtio/vhost-backend.o
  CC      i386-softmmu/hw/vfio/spapr.o
  CC      sh4-softmmu/hw/scsi/virtio-scsi.o
  CC      ppc64-linux-user/gdbstub-xml.o
  GEN     trace/generated-helpers.c
  CC      ppcemb-softmmu/hw/virtio/virtio.o
  CC      s390x-softmmu/hw/s390x/sclpcpu.o
  CC      ppcemb-softmmu/hw/virtio/virtio-balloon.o
  CC      ppc64-softmmu/hw/net/fsl_etsec/miim.o
  CC      sparc64-softmmu/hw/sparc64/niagara.o
  CC      sparc64-softmmu/target/sparc/machine.o
  CC      ppc-softmmu/hw/vfio/common.o
  CC      mipsel-softmmu/hw/virtio/virtio.o
  CC      mips64-softmmu/hw/virtio/vhost.o
  CC      sparc64-softmmu/target/sparc/monitor.o
  CC      ppc64-softmmu/hw/nvram/spapr_nvram.o
  CC      sparc64-softmmu/target/sparc/translate.o
  CC      sh4eb-softmmu/hw/vfio/spapr.o
  CC      mips-softmmu/target/mips/msa_helper.o
  CC      arm-softmmu/hw/intc/exynos4210_gic.o
  CC      arm-softmmu/hw/intc/exynos4210_combiner.o
  CC      arm-softmmu/hw/intc/omap_intc.o
  CC      mipsel-softmmu/hw/virtio/virtio-balloon.o
  CC      xtensa-softmmu/trace/control-target.o
  CC      mips-softmmu/target/mips/mips-semi.o
  CC      mipsel-softmmu/hw/virtio/vhost.o
  CC      ppc64-softmmu/hw/scsi/virtio-scsi.o
  CC      ppc64-softmmu/hw/scsi/spapr_vscsi.o
  CC      mipsel-softmmu/hw/virtio/vhost-backend.o
  CC      ppc64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      mipsel-softmmu/hw/virtio/vhost-user.o
  CC      ppcemb-softmmu/hw/virtio/vhost.o
  LINK    xtensaeb-softmmu/qemu-system-xtensaeb
  CC      mips64el-softmmu/hw/vfio/platform.o
  CC      ppc-softmmu/hw/vfio/pci.o
  CC      alpha-softmmu/hw/virtio/vhost-user.o
  CC      mipsel-softmmu/hw/virtio/vhost-vsock.o
  CC      ppc-softmmu/hw/vfio/pci-quirks.o
  CC      s390x-softmmu/hw/s390x/ipl.o
  CC      ppcemb-softmmu/hw/virtio/vhost-backend.o
  CC      ppc-linux-user/trace/generated-helpers.o
  CC      aarch64-softmmu/hw/dma/pxa2xx_dma.o
  CC      i386-softmmu/hw/virtio/virtio.o
  CC      ppcemb-softmmu/hw/virtio/vhost-user.o
  CC      arm-softmmu/hw/intc/bcm2835_ic.o
  CC      ppcemb-softmmu/hw/virtio/vhost-vsock.o
  CC      ppc-softmmu/hw/vfio/platform.o
  CC      sh4eb-softmmu/hw/virtio/virtio.o
  CC      x86_64-softmmu/hw/i386/x86-iommu.o
  CC      aarch64-softmmu/hw/dma/bcm2835_dma.o
  CC      arm-softmmu/hw/intc/bcm2836_control.o
  CC      mipsel-softmmu/hw/virtio/virtio-crypto.o
  CC      ppc64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mips-softmmu/target/mips/machine.o
  CC      mips64el-softmmu/hw/vfio/spapr.o
  CC      i386-softmmu/hw/virtio/virtio-balloon.o
  CC      ppcemb-softmmu/hw/virtio/virtio-crypto.o
  CC      mips-softmmu/target/mips/cp0_timer.o
  CC      mips64el-softmmu/hw/virtio/virtio.o
  CC      mipsel-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      ppc64-linux-user/trace/generated-helpers.o
  CC      x86_64-softmmu/hw/i386/intel_iommu.o
  GEN     trace/generated-helpers.c
  CC      ppcemb-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      mips-softmmu/trace/control-target.o
  CC      ppcemb-softmmu/hw/ppc/ppc.o
  CC      ppc64-softmmu/hw/scsi/vhost-scsi.o
  CC      ppc64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      aarch64-softmmu/hw/gpio/omap_gpio.o
  CC      arm-softmmu/hw/intc/allwinner-a10-pic.o
  CC      ppcemb-softmmu/hw/ppc/ppc_booke.o
  CC      alpha-softmmu/hw/virtio/vhost-vsock.o
  CC      ppcemb-softmmu/hw/ppc/fdt.o
  CC      alpha-softmmu/hw/virtio/virtio-crypto.o
  CC      alpha-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      s390x-softmmu/hw/s390x/css.o
  CC      s390x-softmmu/hw/s390x/s390-virtio-ccw.o
  CC      x86_64-softmmu/hw/i386/amd_iommu.o
  CC      ppcemb-softmmu/hw/ppc/ppc405_boards.o
  CC      arm-softmmu/hw/intc/aspeed_vic.o
  CC      sh4-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      ppc64-softmmu/hw/timer/mc146818rtc.o
  CC      sparc64-softmmu/target/sparc/helper.o
  CC      sparc64-softmmu/target/sparc/cpu.o
  CC      xtensa-softmmu/trace/generated-helpers.o
  CC      aarch64-softmmu/hw/gpio/imx_gpio.o
  CC      ppc-softmmu/hw/vfio/spapr.o
  CC      ppc-softmmu/hw/virtio/virtio.o
  CC      mips64-softmmu/hw/virtio/vhost-backend.o
  CC      arm-softmmu/hw/intc/arm_gicv3_cpuif.o
  CC      mips64el-softmmu/hw/virtio/virtio-balloon.o
  CC      ppcemb-softmmu/hw/ppc/ppc4xx_devs.o
  CC      arm-softmmu/hw/misc/ivshmem.o
  CC      mips64-softmmu/hw/virtio/vhost-user.o
  CC      sparc64-softmmu/target/sparc/fop_helper.o
  CC      mipsel-softmmu/hw/mips/mips_r4k.o
  CC      s390x-softmmu/hw/s390x/3270-ccw.o
  CC      ppc-softmmu/hw/virtio/virtio-balloon.o
  CC      ppcemb-softmmu/hw/ppc/ppc405_uc.o
  CC      aarch64-softmmu/hw/gpio/bcm2835_gpio.o
  CC      aarch64-softmmu/hw/i2c/omap_i2c.o
  CC      mipsel-softmmu/hw/mips/mips_malta.o
  CC      mipsel-softmmu/hw/mips/mips_mipssim.o
  CC      aarch64-softmmu/hw/input/pxa2xx_keypad.o
  CC      ppc-softmmu/hw/virtio/vhost.o
  CC      mips-softmmu/trace/generated-helpers.o
  CC      mips64el-softmmu/hw/virtio/vhost.o
  CC      sh4eb-softmmu/hw/virtio/virtio-balloon.o
  CC      ppcemb-softmmu/hw/ppc/ppc440_bamboo.o
  CC      ppcemb-softmmu/hw/ppc/ppc4xx_pci.o
  CC      ppcemb-softmmu/hw/ppc/virtex_ml507.o
  CC      arm-softmmu/hw/misc/arm_sysctl.o
  CC      ppc64-softmmu/hw/vfio/common.o
  CC      arm-softmmu/hw/misc/cbus.o
  CC      mipsel-softmmu/hw/mips/addr.o
  CC      alpha-softmmu/hw/alpha/dp264.o
  CC      s390x-softmmu/hw/s390x/virtio-ccw.o
  CC      sh4eb-softmmu/hw/virtio/vhost.o
  CC      arm-softmmu/hw/misc/exynos4210_pmu.o
  CC      mips64-softmmu/hw/virtio/vhost-vsock.o
  CC      alpha-softmmu/hw/alpha/pci.o
  CC      alpha-softmmu/hw/alpha/typhoon.o
  CC      ppcemb-softmmu/target/ppc/cpu-models.o
  CC      sh4eb-softmmu/hw/virtio/vhost-backend.o
  CC      i386-softmmu/hw/virtio/vhost.o
  CC      sh4-softmmu/hw/scsi/vhost-scsi-common.o
  CC      mips64el-softmmu/hw/virtio/vhost-backend.o
  CC      mips64el-softmmu/hw/virtio/vhost-user.o
  CC      i386-softmmu/hw/virtio/vhost-backend.o
  CC      mipsel-softmmu/hw/mips/mips_int.o
  CC      sparc64-softmmu/target/sparc/cc_helper.o
  CC      sparc64-softmmu/target/sparc/win_helper.o
  CC      ppc-softmmu/hw/virtio/vhost-backend.o
  CC      ppc-softmmu/hw/virtio/vhost-user.o
  CC      arm-softmmu/hw/misc/exynos4210_clk.o
  CC      arm-softmmu/hw/misc/exynos4210_rng.o
  CC      ppc-softmmu/hw/virtio/vhost-vsock.o
  CC      s390x-softmmu/hw/s390x/css-bridge.o
  CC      ppc64-softmmu/hw/vfio/pci.o
  CC      ppc64-softmmu/hw/vfio/pci-quirks.o
  CC      alpha-softmmu/target/alpha/machine.o
  CC      ppcemb-softmmu/target/ppc/cpu.o
  CC      aarch64-softmmu/hw/input/tsc210x.o
  CC      aarch64-softmmu/hw/intc/armv7m_nvic.o
  CC      ppcemb-softmmu/target/ppc/translate.o
  CC      ppc64-softmmu/hw/vfio/platform.o
  CC      ppc64-softmmu/hw/vfio/spapr.o
  CC      ppcemb-softmmu/target/ppc/machine.o
  CC      sh4eb-softmmu/hw/virtio/vhost-user.o
  CC      sh4eb-softmmu/hw/virtio/vhost-vsock.o
  CC      s390x-softmmu/hw/s390x/ccw-device.o
  CC      mips64el-softmmu/hw/virtio/vhost-vsock.o
  CC      mips64el-softmmu/hw/virtio/virtio-crypto.o
  CC      mips64el-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      sparc64-softmmu/target/sparc/mmu_helper.o
  CC      mipsel-softmmu/hw/mips/gt64xxx_pci.o
  CC      aarch64-softmmu/hw/intc/exynos4210_gic.o
  CC      mipsel-softmmu/hw/mips/cps.o
  CC      x86_64-softmmu/hw/i386/kvmvapic.o
  CC      mips64-softmmu/hw/virtio/virtio-crypto.o
  CC      ppc-softmmu/hw/virtio/virtio-crypto.o
  CC      x86_64-softmmu/hw/i386/acpi-build.o
  CC      ppcemb-softmmu/target/ppc/mmu_helper.o
  CC      sh4-softmmu/hw/scsi/vhost-scsi.o
  CC      arm-softmmu/hw/misc/imx_ccm.o
  CC      ppcemb-softmmu/target/ppc/mmu-hash32.o
  CC      ppc-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      mips64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      sh4eb-softmmu/hw/virtio/virtio-crypto.o
  CC      sh4eb-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      sh4-softmmu/hw/scsi/vhost-user-scsi.o
  CC      ppc-softmmu/hw/ppc/ppc.o
  CC      ppc-softmmu/hw/ppc/ppc_booke.o
  CC      ppcemb-softmmu/target/ppc/monitor.o
  CC      mipsel-softmmu/target/mips/translate.o
  CC      ppcemb-softmmu/target/ppc/arch_dump.o
  CC      arm-softmmu/hw/misc/imx31_ccm.o
  CC      sh4-softmmu/hw/timer/sh_timer.o
  CC      mips64-softmmu/hw/mips/mips_r4k.o
  CC      aarch64-softmmu/hw/intc/exynos4210_combiner.o
  CC      ppc-softmmu/hw/ppc/fdt.o
  CC      mips64el-softmmu/hw/mips/mips_r4k.o
  CC      ppcemb-softmmu/target/ppc/kvm.o
  CC      sh4-softmmu/hw/timer/mc146818rtc.o
  CC      sparc64-softmmu/target/sparc/ldst_helper.o
  CC      s390x-softmmu/hw/s390x/s390-pci-bus.o
  CC      mips64el-softmmu/hw/mips/mips_malta.o
  CC      arm-softmmu/hw/misc/imx25_ccm.o
  CC      mips64el-softmmu/hw/mips/mips_mipssim.o
  CC      s390x-softmmu/hw/s390x/s390-pci-inst.o
  CC      ppc-softmmu/hw/ppc/ppc405_boards.o
  CC      mips64el-softmmu/hw/mips/addr.o
  CC      sh4-softmmu/hw/vfio/common.o
  CC      ppc-softmmu/hw/ppc/ppc4xx_devs.o
  CC      ppcemb-softmmu/target/ppc/dfp_helper.o
  CC      sparc64-softmmu/target/sparc/int64_helper.o
  CC      ppc-softmmu/hw/ppc/ppc405_uc.o
  CC      mipsel-softmmu/target/mips/dsp_helper.o
  CC      alpha-softmmu/target/alpha/translate.o
  CC      i386-softmmu/hw/virtio/vhost-user.o
  CC      mipsel-softmmu/target/mips/op_helper.o
  CC      ppcemb-softmmu/target/ppc/excp_helper.o
  CC      arm-softmmu/hw/misc/imx6_ccm.o
  CC      mipsel-softmmu/target/mips/lmi_helper.o
  CC      ppcemb-softmmu/target/ppc/fpu_helper.o
  CC      arm-softmmu/hw/misc/imx6_src.o
  CC      arm-softmmu/hw/misc/mst_fpga.o
  CC      sh4-softmmu/hw/vfio/pci.o
  CC      sh4eb-softmmu/hw/sh4/shix.o
  CC      mipsel-softmmu/target/mips/helper.o
  CC      ppc-softmmu/hw/ppc/ppc440_bamboo.o
  CC      sparc64-softmmu/target/sparc/vis_helper.o
  CC      ppc-softmmu/hw/ppc/ppc4xx_pci.o
  CC      i386-softmmu/hw/virtio/vhost-vsock.o
  CC      mips64el-softmmu/hw/mips/mips_int.o
  CC      ppc-softmmu/hw/ppc/prep.o
  CC      sh4-softmmu/hw/vfio/pci-quirks.o
  LINK    xtensa-softmmu/qemu-system-xtensa
  CC      arm-softmmu/hw/misc/omap_clk.o
  CC      aarch64-softmmu/hw/intc/omap_intc.o
  CC      ppc-softmmu/hw/ppc/prep_systemio.o
  CC      ppcemb-softmmu/target/ppc/int_helper.o
  CC      aarch64-softmmu/hw/intc/bcm2835_ic.o
  CC      sh4-softmmu/hw/vfio/platform.o
  CC      sh4eb-softmmu/hw/sh4/r2d.o
  CC      mipsel-softmmu/target/mips/cpu.o
  CC      ppc-softmmu/hw/ppc/rs6000_mc.o
  CC      s390x-softmmu/hw/s390x/s390-skeys.o
  CC      ppc64-softmmu/hw/virtio/virtio.o
  CC      sparc64-softmmu/target/sparc/gdbstub.o
  CC      mips64-softmmu/hw/mips/mips_malta.o
  CC      s390x-softmmu/hw/s390x/s390-stattrib.o
  CC      arm-softmmu/hw/misc/omap_gpmc.o
  CC      mips64-softmmu/hw/mips/mips_mipssim.o
  GEN     trace/generated-helpers.c
  CC      i386-softmmu/hw/virtio/virtio-crypto.o
  CC      ppc64-softmmu/hw/virtio/virtio-balloon.o
  CC      sparc64-softmmu/trace/control-target.o
  CC      aarch64-softmmu/hw/intc/bcm2836_control.o
  CC      ppc-softmmu/hw/ppc/mac_oldworld.o
  CC      sh4-softmmu/hw/vfio/spapr.o
  CC      mipsel-softmmu/target/mips/gdbstub.o
  CC      mips64el-softmmu/hw/mips/mips_jazz.o
  CC      arm-softmmu/hw/misc/omap_l4.o
  CC      sh4eb-softmmu/hw/sh4/sh7750.o
  CC      arm-softmmu/hw/misc/omap_sdrc.o
  CC      sh4eb-softmmu/hw/sh4/sh7750_regnames.o
  CC      arm-softmmu/hw/misc/omap_tap.o
  CC      sh4eb-softmmu/hw/sh4/sh_pci.o
  CC      sh4-softmmu/hw/virtio/virtio.o
  CC      ppc-softmmu/hw/ppc/mac_newworld.o
  CC      mipsel-softmmu/target/mips/msa_helper.o
  CC      sh4-softmmu/hw/virtio/virtio-balloon.o
  CC      sh4eb-softmmu/target/sh4/translate.o
  CC      ppcemb-softmmu/target/ppc/timebase_helper.o
  CC      mips64-softmmu/hw/mips/addr.o
  CC      x86_64-softmmu/target/i386/helper.o
  CC      mips64el-softmmu/hw/mips/mips_fulong2e.o
  CC      sh4eb-softmmu/target/sh4/op_helper.o
  CC      mipsel-softmmu/target/mips/mips-semi.o
  CC      ppc-softmmu/hw/ppc/e500.o
  CC      aarch64-softmmu/hw/intc/allwinner-a10-pic.o
  CC      mipsel-softmmu/target/mips/machine.o
  CC      sh4-softmmu/hw/virtio/vhost.o
  CC      sparc64-softmmu/trace/generated-helpers.o
  CC      s390x-softmmu/hw/s390x/s390-ccw.o
  CC      sh4-softmmu/hw/virtio/vhost-backend.o
  CC      mips64-softmmu/hw/mips/mips_int.o
  CC      mipsel-softmmu/target/mips/cp0_timer.o
  CC      arm-softmmu/hw/misc/bcm2835_mbox.o
  CC      i386-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      arm-softmmu/hw/misc/bcm2835_property.o
  CC      ppcemb-softmmu/target/ppc/misc_helper.o
  CC      arm-softmmu/hw/misc/bcm2835_rng.o
  CC      arm-softmmu/hw/misc/zynq_slcr.o
  CC      x86_64-softmmu/target/i386/cpu.o
  CC      x86_64-softmmu/target/i386/gdbstub.o
  CC      x86_64-softmmu/target/i386/windbgstub.o
  CC      mips64-softmmu/hw/mips/mips_jazz.o
  CC      x86_64-softmmu/target/i386/xsave_helper.o
  CC      mips64-softmmu/hw/mips/gt64xxx_pci.o
  CC      ppc-softmmu/hw/ppc/mpc8544ds.o
  CC      mips64el-softmmu/hw/mips/gt64xxx_pci.o
  CC      ppc64-softmmu/hw/virtio/vhost.o
  CC      alpha-softmmu/target/alpha/helper.o
  CC      aarch64-softmmu/hw/intc/aspeed_vic.o
  CC      sh4eb-softmmu/target/sh4/helper.o
  CC      sh4-softmmu/hw/virtio/vhost-user.o
  CC      s390x-softmmu/target/s390x/cpu.o
  CC      ppc-softmmu/hw/ppc/e500plat.o
  CC      mips64el-softmmu/hw/mips/cps.o
  CC      i386-softmmu/hw/i386/multiboot.o
  CC      s390x-softmmu/target/s390x/cpu_models.o
  CC      i386-softmmu/hw/i386/pc.o
  GEN     trace/generated-helpers.c
  CC      sh4-softmmu/hw/virtio/vhost-vsock.o
  CC      aarch64-softmmu/hw/intc/arm_gicv3_cpuif.o
  CC      x86_64-softmmu/target/i386/translate.o
  CC      i386-softmmu/hw/i386/pc_piix.o
  CC      alpha-softmmu/target/alpha/cpu.o
  CC      s390x-softmmu/target/s390x/cpu_features.o
  CC      aarch64-softmmu/hw/misc/ivshmem.o
  CC      sh4eb-softmmu/target/sh4/cpu.o
  CC      ppcemb-softmmu/target/ppc/mem_helper.o
  CC      mipsel-softmmu/trace/control-target.o
  CC      ppc64-softmmu/hw/virtio/vhost-backend.o
  CC      mips64el-softmmu/hw/mips/boston.o
  CC      ppc-softmmu/hw/ppc/mpc8544_guts.o
  CC      s390x-softmmu/target/s390x/gdbstub.o
  CC      ppc-softmmu/hw/ppc/ppce500_spin.o
  CC      s390x-softmmu/target/s390x/interrupt.o
  CC      sh4eb-softmmu/target/sh4/monitor.o
  CC      ppc64-softmmu/hw/virtio/vhost-user.o
  CC      ppc64-softmmu/hw/virtio/vhost-vsock.o
  CC      x86_64-softmmu/target/i386/bpt_helper.o
  CC      aarch64-softmmu/hw/misc/arm_sysctl.o
  CC      ppcemb-softmmu/target/ppc/gdbstub.o
  CC      ppc-softmmu/hw/ppc/virtex_ml507.o
  CC      mips64-softmmu/hw/mips/cps.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/decContext.o
  CC      mips64el-softmmu/target/mips/translate.o
  CC      alpha-softmmu/target/alpha/int_helper.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/decNumber.o
  CC      arm-softmmu/hw/misc/zynq-xadc.o
  CC      ppc64-softmmu/hw/virtio/virtio-crypto.o
  LINK    m68k-softmmu/qemu-system-m68k
  CC      arm-softmmu/hw/misc/stm32f2xx_syscfg.o
  CC      arm-softmmu/hw/misc/mps2-scc.o
  CC      i386-softmmu/hw/i386/pc_q35.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      sh4eb-softmmu/target/sh4/gdbstub.o
  CC      ppc-softmmu/target/ppc/cpu-models.o
  CC      mips64-softmmu/target/mips/translate.o
  CC      x86_64-softmmu/target/i386/cc_helper.o
  CC      mips64el-softmmu/target/mips/dsp_helper.o
  CC      alpha-softmmu/target/alpha/fpu_helper.o
  CC      ppc-softmmu/target/ppc/cpu.o
  CC      arm-softmmu/hw/misc/aspeed_scu.o
  CC      arm-softmmu/hw/misc/aspeed_sdmc.o
  CC      mips64el-softmmu/target/mips/op_helper.o
  CC      sh4-softmmu/hw/virtio/virtio-crypto.o
  CC      sh4-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      x86_64-softmmu/target/i386/excp_helper.o
  CC      aarch64-softmmu/hw/misc/cbus.o
  CC      ppc-softmmu/target/ppc/translate.o
  CC      sh4-softmmu/hw/sh4/shix.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      aarch64-softmmu/hw/misc/exynos4210_pmu.o
  CC      mips64el-softmmu/target/mips/lmi_helper.o
  CC      x86_64-softmmu/target/i386/fpu_helper.o
  CC      mips64-softmmu/target/mips/dsp_helper.o
  CC      ppc-softmmu/target/ppc/machine.o
  CC      aarch64-softmmu/hw/misc/exynos4210_clk.o
  CC      mips64-softmmu/target/mips/op_helper.o
  CC      ppc-softmmu/target/ppc/mmu_helper.o
  CC      alpha-softmmu/target/alpha/vax_helper.o
  CC      mipsel-softmmu/trace/generated-helpers.o
  CC      ppc-softmmu/target/ppc/mmu-hash32.o
  CC      ppcemb-softmmu/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      s390x-softmmu/target/s390x/helper.o
  CC      ppc64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      alpha-softmmu/target/alpha/sys_helper.o
  CC      sh4-softmmu/hw/sh4/r2d.o
  CC      ppc-softmmu/target/ppc/monitor.o
  CC      x86_64-softmmu/target/i386/int_helper.o
  CC      ppc64-softmmu/hw/ppc/ppc.o
  CC      arm-softmmu/hw/misc/mmio_interface.o
  CC      x86_64-softmmu/target/i386/mem_helper.o
  CC      x86_64-softmmu/target/i386/misc_helper.o
  CC      aarch64-softmmu/hw/misc/exynos4210_rng.o
  CC      mips64-softmmu/target/mips/lmi_helper.o
  CC      ppc64-softmmu/hw/ppc/ppc_booke.o
  CC      ppc-softmmu/target/ppc/arch_dump.o
  GEN     trace/generated-helpers.c
  CC      sh4-softmmu/hw/sh4/sh7750.o
  CC      x86_64-softmmu/target/i386/mpx_helper.o
  GEN     trace/generated-helpers.c
  CC      mips64-softmmu/target/mips/helper.o
  CC      i386-softmmu/hw/i386/pc_sysfw.o
  CC      mips64-softmmu/target/mips/cpu.o
  CC      arm-softmmu/hw/misc/msf2-sysreg.o
  CC      sh4-softmmu/hw/sh4/sh7750_regnames.o
  CC      sh4-softmmu/hw/sh4/sh_pci.o
  CC      s390x-softmmu/target/s390x/translate.o
  CC      x86_64-softmmu/target/i386/seg_helper.o
  CC      mips64el-softmmu/target/mips/helper.o
  CC      x86_64-softmmu/target/i386/smm_helper.o
  CC      ppcemb-softmmu/trace/control-target.o
  CC      x86_64-softmmu/target/i386/svm_helper.o
  CC      aarch64-softmmu/hw/misc/imx_ccm.o
  CC      aarch64-softmmu/hw/misc/imx31_ccm.o
  CC      aarch64-softmmu/hw/misc/imx25_ccm.o
  CC      mips64el-softmmu/target/mips/cpu.o
  CC      alpha-softmmu/target/alpha/mem_helper.o
  CC      aarch64-softmmu/hw/misc/imx6_ccm.o
  CC      s390x-softmmu/target/s390x/cc_helper.o
  CC      alpha-softmmu/target/alpha/gdbstub.o
  CC      ppc64-softmmu/hw/ppc/fdt.o
  CC      ppc-softmmu/target/ppc/kvm.o
  CC      s390x-softmmu/target/s390x/excp_helper.o
  CC      arm-softmmu/hw/net/virtio-net.o
  CC      sh4eb-softmmu/trace/control-target.o
  CC      sh4-softmmu/target/sh4/translate.o
  CC      x86_64-softmmu/target/i386/machine.o
  GEN     trace/generated-helpers.c
  CC      arm-softmmu/hw/net/vhost_net.o
  CC      ppc64-softmmu/hw/ppc/spapr.o
  CC      x86_64-softmmu/target/i386/arch_memory_mapping.o
  CC      alpha-softmmu/trace/control-target.o
  CC      mips64el-softmmu/target/mips/gdbstub.o
  CC      ppc-softmmu/target/ppc/dfp_helper.o
  LINK    tricore-softmmu/qemu-system-tricore
  CC      s390x-softmmu/target/s390x/fpu_helper.o
  CC      i386-softmmu/hw/i386/x86-iommu.o
  CC      sh4-softmmu/target/sh4/op_helper.o
  CC      ppcemb-softmmu/gdbstub-xml.o
  CC      ppc64-softmmu/hw/ppc/spapr_vio.o
  CC      mips64-softmmu/target/mips/gdbstub.o
  CC      sh4-softmmu/target/sh4/helper.o
  CC      mips64-softmmu/target/mips/msa_helper.o
  CC      aarch64-softmmu/hw/misc/imx6_src.o
  CC      mips64-softmmu/target/mips/mips-semi.o
  CC      s390x-softmmu/target/s390x/int_helper.o
  CC      ppc-softmmu/target/ppc/excp_helper.o
  CC      x86_64-softmmu/target/i386/arch_dump.o
  CC      sh4-softmmu/target/sh4/cpu.o
  CC      ppc64-softmmu/hw/ppc/spapr_events.o
  CC      mips64el-softmmu/target/mips/msa_helper.o
  CC      ppcemb-softmmu/trace/generated-helpers.o
  CC      x86_64-softmmu/target/i386/monitor.o
  CC      i386-softmmu/hw/i386/intel_iommu.o
  CC      x86_64-softmmu/target/i386/kvm-stub.o
  CC      arm-softmmu/hw/pcmcia/pxa2xx.o
  LINK    mipsel-linux-user/qemu-mipsel
  CC      mips64el-softmmu/target/mips/mips-semi.o
  CC      arm-softmmu/hw/scsi/virtio-scsi.o
  GEN     trace/generated-helpers.c
  CC      mips64-softmmu/target/mips/machine.o
  CC      ppc-softmmu/target/ppc/fpu_helper.o
  CC      x86_64-softmmu/trace/control-target.o
  CC      sh4-softmmu/target/sh4/monitor.o
  CC      s390x-softmmu/target/s390x/mem_helper.o
  CC      mips64-softmmu/target/mips/cp0_timer.o
  CC      mips64el-softmmu/target/mips/machine.o
  CC      sh4-softmmu/target/sh4/gdbstub.o
  CC      x86_64-softmmu/gdbstub-xml.o
  CC      ppc-softmmu/target/ppc/int_helper.o
  CC      mips64el-softmmu/target/mips/cp0_timer.o
  CC      aarch64-softmmu/hw/misc/mst_fpga.o
  GEN     trace/generated-helpers.c
  CC      i386-softmmu/hw/i386/amd_iommu.o
  CC      s390x-softmmu/target/s390x/misc_helper.o
  CC      alpha-softmmu/trace/generated-helpers.o
  CC      arm-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      sh4-softmmu/trace/control-target.o
  CC      ppc64-softmmu/hw/ppc/spapr_hcall.o
  CC      x86_64-softmmu/trace/generated-helpers.o
  CC      i386-softmmu/hw/i386/kvmvapic.o
  GEN     trace/generated-helpers.c
  CC      sh4eb-softmmu/trace/generated-helpers.o
  GEN     trace/generated-helpers.c
  CC      mips64-softmmu/trace/control-target.o
  CC      aarch64-softmmu/hw/misc/omap_clk.o
  CC      mips64el-softmmu/trace/control-target.o
  CC      s390x-softmmu/target/s390x/crypto_helper.o
  CC      aarch64-softmmu/hw/misc/omap_gpmc.o
  CC      s390x-softmmu/target/s390x/machine.o
  CC      ppc-softmmu/target/ppc/timebase_helper.o
  CC      s390x-softmmu/target/s390x/ioinst.o
  CC      ppc-softmmu/target/ppc/misc_helper.o
  CC      arm-softmmu/hw/scsi/vhost-scsi-common.o
  CC      ppc64-softmmu/hw/ppc/spapr_iommu.o
  CC      s390x-softmmu/target/s390x/arch_dump.o
  CC      sh4-softmmu/trace/generated-helpers.o
  CC      aarch64-softmmu/hw/misc/omap_l4.o
  CC      mips64-softmmu/trace/generated-helpers.o
  CC      mips64el-softmmu/trace/generated-helpers.o
  CC      ppc-softmmu/target/ppc/mem_helper.o
  CC      arm-softmmu/hw/scsi/vhost-scsi.o
  CC      ppc64-softmmu/hw/ppc/spapr_rtas.o
  CC      ppc-softmmu/target/ppc/gdbstub.o
  CC      aarch64-softmmu/hw/misc/omap_sdrc.o
  CC      aarch64-softmmu/hw/misc/omap_tap.o
  CC      aarch64-softmmu/hw/misc/bcm2835_mbox.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/decContext.o
  CC      arm-softmmu/hw/scsi/vhost-user-scsi.o
  CC      aarch64-softmmu/hw/misc/bcm2835_property.o
  CC      arm-softmmu/hw/sd/omap_mmc.o
  CC      aarch64-softmmu/hw/misc/bcm2835_rng.o
  CC      aarch64-softmmu/hw/misc/zynq_slcr.o
  CC      aarch64-softmmu/hw/misc/zynq-xadc.o
  CC      i386-softmmu/hw/i386/acpi-build.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/decNumber.o
  CC      ppc64-softmmu/hw/ppc/spapr_pci.o
  LINK    alpha-softmmu/qemu-system-alpha
  CC      ppc64-softmmu/hw/ppc/spapr_rtc.o
  CC      arm-softmmu/hw/sd/pxa2xx_mmci.o
  CC      i386-softmmu/target/i386/helper.o
  CC      arm-softmmu/hw/sd/bcm2835_sdhost.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      arm-softmmu/hw/ssi/omap_spi.o
  CC      ppc64-softmmu/hw/ppc/spapr_drc.o
  CC      s390x-softmmu/target/s390x/mmu_helper.o
  CC      i386-softmmu/target/i386/cpu.o
  CC      ppc64-softmmu/hw/ppc/spapr_rng.o
  CC      s390x-softmmu/target/s390x/diag.o
  CC      s390x-softmmu/target/s390x/sigp.o
  CC      ppc64-softmmu/hw/ppc/spapr_cpu_core.o
  CC      i386-softmmu/target/i386/gdbstub.o
  CC      s390x-softmmu/target/s390x/kvm-stub.o
  CC      aarch64-softmmu/hw/misc/stm32f2xx_syscfg.o
  CC      arm-softmmu/hw/ssi/imx_spi.o
  CC      arm-softmmu/hw/timer/exynos4210_mct.o
  CC      aarch64-softmmu/hw/misc/mps2-scc.o
  CC      aarch64-softmmu/hw/misc/auxbus.o
  GEN     trace/generated-helpers.c
  CC      arm-softmmu/hw/timer/exynos4210_pwm.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      aarch64-softmmu/hw/misc/aspeed_scu.o
  CC      i386-softmmu/target/i386/windbgstub.o
  CC      ppc-softmmu/target/ppc/../../libdecnumber/dpd/decimal128.o
  CC      arm-softmmu/hw/timer/exynos4210_rtc.o
  GEN     trace/generated-helpers.c
  CC      ppc64-softmmu/hw/ppc/spapr_ovec.o
  CC      arm-softmmu/hw/timer/omap_gptimer.o
  CC      aarch64-softmmu/hw/misc/aspeed_sdmc.o
  CC      ppc-softmmu/trace/control-target.o
  CC      aarch64-softmmu/hw/misc/mmio_interface.o
  CC      arm-softmmu/hw/timer/omap_synctimer.o
  CC      aarch64-softmmu/hw/misc/msf2-sysreg.o
  CC      ppc-softmmu/gdbstub-xml.o
  CC      i386-softmmu/target/i386/xsave_helper.o
  CC      i386-softmmu/target/i386/translate.o
  CC      arm-softmmu/hw/timer/pxa2xx_timer.o
  CC      ppc-softmmu/trace/generated-helpers.o
  LINK    mips-linux-user/qemu-mips
  CC      s390x-softmmu/trace/control-target.o
  CC      arm-softmmu/hw/timer/digic-timer.o
  CC      ppc64-softmmu/hw/ppc/pnv.o
  CC      ppc64-softmmu/hw/ppc/pnv_xscom.o
  CC      aarch64-softmmu/hw/net/virtio-net.o
  CC      arm-softmmu/hw/timer/allwinner-a10-pit.o
  CC      arm-softmmu/hw/usb/tusb6010.o
  CC      arm-softmmu/hw/vfio/common.o
  CC      s390x-softmmu/gdbstub-xml.o
  CC      aarch64-softmmu/hw/net/vhost_net.o
  CC      ppc64-softmmu/hw/ppc/pnv_core.o
  CC      i386-softmmu/target/i386/bpt_helper.o
  CC      i386-softmmu/target/i386/cc_helper.o
  CC      arm-softmmu/hw/vfio/pci.o
  CC      aarch64-softmmu/hw/pcmcia/pxa2xx.o
  CC      arm-softmmu/hw/vfio/pci-quirks.o
  CC      ppc64-softmmu/hw/ppc/pnv_lpc.o
  CC      aarch64-softmmu/hw/scsi/virtio-scsi.o
  CC      aarch64-softmmu/hw/scsi/virtio-scsi-dataplane.o
  CC      i386-softmmu/target/i386/excp_helper.o
  CC      arm-softmmu/hw/vfio/platform.o
  CC      aarch64-softmmu/hw/scsi/vhost-scsi-common.o
  CC      aarch64-softmmu/hw/scsi/vhost-scsi.o
  CC      s390x-softmmu/trace/generated-helpers.o
  CC      ppc64-softmmu/hw/ppc/pnv_psi.o
  CC      aarch64-softmmu/hw/scsi/vhost-user-scsi.o
  CC      arm-softmmu/hw/vfio/calxeda-xgmac.o
  CC      aarch64-softmmu/hw/sd/omap_mmc.o
  CC      arm-softmmu/hw/vfio/amd-xgbe.o
  CC      i386-softmmu/target/i386/fpu_helper.o
  CC      i386-softmmu/target/i386/int_helper.o
  CC      i386-softmmu/target/i386/mem_helper.o
  CC      ppc64-softmmu/hw/ppc/pnv_occ.o
  CC      i386-softmmu/target/i386/misc_helper.o
  CC      aarch64-softmmu/hw/sd/pxa2xx_mmci.o
  CC      ppc64-softmmu/hw/ppc/pnv_bmc.o
  CC      ppc64-softmmu/hw/ppc/spapr_pci_vfio.o
  CC      i386-softmmu/target/i386/mpx_helper.o
  CC      i386-softmmu/target/i386/seg_helper.o
  CC      ppc64-softmmu/hw/ppc/spapr_rtas_ddw.o
  CC      ppc64-softmmu/hw/ppc/ppc405_boards.o
  CC      aarch64-softmmu/hw/sd/bcm2835_sdhost.o
  CC      arm-softmmu/hw/vfio/spapr.o
  CC      aarch64-softmmu/hw/ssi/omap_spi.o
  CC      ppc64-softmmu/hw/ppc/ppc4xx_devs.o
  CC      ppc64-softmmu/hw/ppc/ppc405_uc.o
  CC      arm-softmmu/hw/virtio/virtio.o
  CC      arm-softmmu/hw/virtio/virtio-balloon.o
  CC      arm-softmmu/hw/virtio/vhost.o
  CC      arm-softmmu/hw/virtio/vhost-backend.o
  CC      aarch64-softmmu/hw/ssi/imx_spi.o
  CC      ppc64-softmmu/hw/ppc/ppc440_bamboo.o
  CC      ppc64-softmmu/hw/ppc/ppc4xx_pci.o
  CC      arm-softmmu/hw/virtio/vhost-user.o
  CC      arm-softmmu/hw/virtio/vhost-vsock.o
  CC      ppc64-softmmu/hw/ppc/prep.o
  LINK    x86_64-linux-user/qemu-x86_64
  CC      aarch64-softmmu/hw/timer/exynos4210_mct.o
  CC      arm-softmmu/hw/virtio/virtio-crypto.o
  CC      aarch64-softmmu/hw/timer/exynos4210_pwm.o
  CC      ppc64-softmmu/hw/ppc/prep_systemio.o
  CC      ppc64-softmmu/hw/ppc/rs6000_mc.o
  CC      i386-softmmu/target/i386/smm_helper.o
  CC      i386-softmmu/target/i386/svm_helper.o
  CC      ppc64-softmmu/hw/ppc/mac_oldworld.o
  CC      aarch64-softmmu/hw/timer/exynos4210_rtc.o
  CC      arm-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      aarch64-softmmu/hw/timer/omap_gptimer.o
  CC      ppc64-softmmu/hw/ppc/mac_newworld.o
  CC      ppc64-softmmu/hw/ppc/e500.o
  CC      aarch64-softmmu/hw/timer/omap_synctimer.o
  CC      arm-softmmu/hw/arm/boot.o
  CC      ppc64-softmmu/hw/ppc/mpc8544ds.o
  CC      i386-softmmu/target/i386/machine.o
  CC      ppc64-softmmu/hw/ppc/e500plat.o
  CC      i386-softmmu/target/i386/arch_memory_mapping.o
  CC      i386-softmmu/target/i386/arch_dump.o
  CC      arm-softmmu/hw/arm/collie.o
  CC      aarch64-softmmu/hw/timer/pxa2xx_timer.o
  CC      ppc64-softmmu/hw/ppc/mpc8544_guts.o
  CC      arm-softmmu/hw/arm/exynos4_boards.o
  CC      arm-softmmu/hw/arm/gumstix.o
  CC      arm-softmmu/hw/arm/highbank.o
  CC      i386-softmmu/target/i386/monitor.o
  CC      i386-softmmu/target/i386/kvm-stub.o
  LINK    sh4eb-softmmu/qemu-system-sh4eb
  CC      ppc64-softmmu/hw/ppc/ppce500_spin.o
  LINK    mipsn32-linux-user/qemu-mipsn32
  CC      ppc64-softmmu/hw/ppc/virtex_ml507.o
  CC      aarch64-softmmu/hw/timer/digic-timer.o
  CC      ppc64-softmmu/target/ppc/cpu-models.o
  GEN     trace/generated-helpers.c
  CC      arm-softmmu/hw/arm/digic_boards.o
  CC      ppc64-softmmu/target/ppc/cpu.o
  CC      arm-softmmu/hw/arm/integratorcp.o
  CC      aarch64-softmmu/hw/timer/allwinner-a10-pit.o
  CC      ppc64-softmmu/target/ppc/translate.o
  CC      aarch64-softmmu/hw/usb/tusb6010.o
  CC      arm-softmmu/hw/arm/mainstone.o
  CC      ppc64-softmmu/target/ppc/machine.o
  CC      i386-softmmu/trace/control-target.o
  CC      ppc64-softmmu/target/ppc/mmu_helper.o
  CC      aarch64-softmmu/hw/vfio/common.o
  CC      arm-softmmu/hw/arm/musicpal.o
  CC      ppc64-softmmu/target/ppc/mmu-hash32.o
  CC      arm-softmmu/hw/arm/nseries.o
  CC      ppc64-softmmu/target/ppc/monitor.o
  CC      i386-softmmu/gdbstub-xml.o
  CC      ppc64-softmmu/target/ppc/arch_dump.o
  CC      aarch64-softmmu/hw/vfio/pci.o
  CC      ppc64-softmmu/target/ppc/mmu-hash64.o
  CC      arm-softmmu/hw/arm/omap_sx1.o
  CC      ppc64-softmmu/target/ppc/mmu-book3s-v3.o
  CC      aarch64-softmmu/hw/vfio/pci-quirks.o
  CC      arm-softmmu/hw/arm/palm.o
  CC      arm-softmmu/hw/arm/realview.o
  CC      aarch64-softmmu/hw/vfio/platform.o
  CC      ppc64-softmmu/target/ppc/compat.o
  CC      ppc64-softmmu/target/ppc/mmu-radix64.o
  CC      ppc64-softmmu/target/ppc/kvm.o
  CC      i386-softmmu/trace/generated-helpers.o
  CC      arm-softmmu/hw/arm/spitz.o
  CC      arm-softmmu/hw/arm/stellaris.o
  CC      arm-softmmu/hw/arm/tosa.o
  CC      aarch64-softmmu/hw/vfio/calxeda-xgmac.o
  CC      ppc64-softmmu/target/ppc/dfp_helper.o
  CC      aarch64-softmmu/hw/vfio/amd-xgbe.o
  CC      aarch64-softmmu/hw/vfio/spapr.o
  CC      aarch64-softmmu/hw/virtio/virtio.o
  CC      ppc64-softmmu/target/ppc/excp_helper.o
  CC      arm-softmmu/hw/arm/versatilepb.o
  CC      ppc64-softmmu/target/ppc/fpu_helper.o
  CC      aarch64-softmmu/hw/virtio/virtio-balloon.o
  CC      aarch64-softmmu/hw/virtio/vhost.o
  CC      arm-softmmu/hw/arm/vexpress.o
  CC      arm-softmmu/hw/arm/virt.o
  CC      aarch64-softmmu/hw/virtio/vhost-backend.o
  CC      aarch64-softmmu/hw/virtio/vhost-user.o
  LINK    mips64-linux-user/qemu-mips64
  CC      aarch64-softmmu/hw/virtio/vhost-vsock.o
  CC      aarch64-softmmu/hw/virtio/virtio-crypto.o
  CC      arm-softmmu/hw/arm/xilinx_zynq.o
  CC      arm-softmmu/hw/arm/z2.o
  CC      ppc64-softmmu/target/ppc/int_helper.o
  CC      ppc64-softmmu/target/ppc/timebase_helper.o
  CC      aarch64-softmmu/hw/virtio/virtio-crypto-pci.o
  CC      ppc64-softmmu/target/ppc/misc_helper.o
  CC      arm-softmmu/hw/arm/virt-acpi-build.o
  CC      aarch64-softmmu/hw/arm/boot.o
  CC      aarch64-softmmu/hw/arm/collie.o
  CC      arm-softmmu/hw/arm/netduino2.o
  CC      aarch64-softmmu/hw/arm/exynos4_boards.o
  CC      aarch64-softmmu/hw/arm/gumstix.o
  CC      arm-softmmu/hw/arm/sysbus-fdt.o
  CC      aarch64-softmmu/hw/arm/highbank.o
  CC      ppc64-softmmu/target/ppc/mem_helper.o
  CC      arm-softmmu/hw/arm/armv7m.o
  CC      ppc64-softmmu/target/ppc/gdbstub.o
  CC      aarch64-softmmu/hw/arm/digic_boards.o
  CC      aarch64-softmmu/hw/arm/integratorcp.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/decContext.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/decNumber.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/dpd/decimal32.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/dpd/decimal64.o
  CC      aarch64-softmmu/hw/arm/mainstone.o
  CC      arm-softmmu/hw/arm/exynos4210.o
  CC      ppc64-softmmu/target/ppc/../../libdecnumber/dpd/decimal128.o
  LINK    arm-linux-user/qemu-arm
  CC      arm-softmmu/hw/arm/pxa2xx.o
  CC      aarch64-softmmu/hw/arm/musicpal.o
  GEN     trace/generated-helpers.c
  CC      arm-softmmu/hw/arm/pxa2xx_gpio.o
  CC      aarch64-softmmu/hw/arm/nseries.o
  LINK    sparc64-softmmu/qemu-system-sparc64
  CC      arm-softmmu/hw/arm/pxa2xx_pic.o
  CC      aarch64-softmmu/hw/arm/omap_sx1.o
  CC      arm-softmmu/hw/arm/digic.o
  CC      ppc64-softmmu/trace/control-target.o
  CC      aarch64-softmmu/hw/arm/palm.o
  CC      arm-softmmu/hw/arm/omap1.o
  CC      ppc64-softmmu/gdbstub-xml.o
  CC      arm-softmmu/hw/arm/omap2.o
  CC      arm-softmmu/hw/arm/strongarm.o
  CC      arm-softmmu/hw/arm/allwinner-a10.o
  CC      aarch64-softmmu/hw/arm/realview.o
  CC      ppc64-softmmu/trace/generated-helpers.o
  CC      arm-softmmu/hw/arm/cubieboard.o
  CC      aarch64-softmmu/hw/arm/spitz.o
  CC      aarch64-softmmu/hw/arm/stellaris.o
  CC      aarch64-softmmu/hw/arm/tosa.o
  CC      arm-softmmu/hw/arm/bcm2835_peripherals.o
  CC      arm-softmmu/hw/arm/bcm2836.o
  CC      aarch64-softmmu/hw/arm/versatilepb.o
  CC      arm-softmmu/hw/arm/raspi.o
  CC      aarch64-softmmu/hw/arm/vexpress.o
  CC      arm-softmmu/hw/arm/stm32f205_soc.o
  CC      aarch64-softmmu/hw/arm/virt.o
  CC      arm-softmmu/hw/arm/fsl-imx25.o
  CC      arm-softmmu/hw/arm/imx25_pdk.o
  CC      aarch64-softmmu/hw/arm/xilinx_zynq.o
  CC      aarch64-softmmu/hw/arm/z2.o
  CC      aarch64-softmmu/hw/arm/virt-acpi-build.o
  CC      arm-softmmu/hw/arm/fsl-imx31.o
  CC      aarch64-softmmu/hw/arm/netduino2.o
  LINK    aarch64-linux-user/qemu-aarch64
  CC      aarch64-softmmu/hw/arm/sysbus-fdt.o
  CC      aarch64-softmmu/hw/arm/exynos4210.o
  CC      aarch64-softmmu/hw/arm/armv7m.o
  CC      arm-softmmu/hw/arm/kzm.o
  CC      aarch64-softmmu/hw/arm/pxa2xx.o
  CC      aarch64-softmmu/hw/arm/pxa2xx_gpio.o
  CC      aarch64-softmmu/hw/arm/pxa2xx_pic.o
  CC      aarch64-softmmu/hw/arm/digic.o
  CC      arm-softmmu/hw/arm/fsl-imx6.o
  CC      arm-softmmu/hw/arm/sabrelite.o
  CC      arm-softmmu/hw/arm/aspeed_soc.o
  CC      aarch64-softmmu/hw/arm/omap1.o
  CC      arm-softmmu/hw/arm/aspeed.o
  CC      arm-softmmu/hw/arm/mps2.o
  CC      arm-softmmu/hw/arm/msf2-soc.o
  CC      arm-softmmu/hw/arm/msf2-som.o
  CC      aarch64-softmmu/hw/arm/omap2.o
  CC      aarch64-softmmu/hw/arm/strongarm.o
  CC      arm-softmmu/target/arm/arm-semi.o
  CC      arm-softmmu/target/arm/machine.o
  CC      arm-softmmu/target/arm/psci.o
  CC      aarch64-softmmu/hw/arm/allwinner-a10.o
  CC      arm-softmmu/target/arm/arch_dump.o
  CC      aarch64-softmmu/hw/arm/cubieboard.o
  CC      arm-softmmu/target/arm/monitor.o
  CC      aarch64-softmmu/hw/arm/bcm2835_peripherals.o
  CC      arm-softmmu/target/arm/kvm-stub.o
  CC      aarch64-softmmu/hw/arm/bcm2836.o
  CC      arm-softmmu/target/arm/translate.o
  CC      arm-softmmu/target/arm/op_helper.o
  CC      aarch64-softmmu/hw/arm/raspi.o
  CC      arm-softmmu/target/arm/helper.o
  CC      aarch64-softmmu/hw/arm/stm32f205_soc.o
  CC      arm-softmmu/target/arm/cpu.o
  CC      aarch64-softmmu/hw/arm/xlnx-zynqmp.o
  CC      aarch64-softmmu/hw/arm/xlnx-zcu102.o
  CC      aarch64-softmmu/hw/arm/fsl-imx25.o
  CC      arm-softmmu/target/arm/neon_helper.o
  CC      arm-softmmu/target/arm/iwmmxt_helper.o
  CC      arm-softmmu/target/arm/gdbstub.o
  CC      arm-softmmu/target/arm/crypto_helper.o
  CC      aarch64-softmmu/hw/arm/imx25_pdk.o
  CC      arm-softmmu/target/arm/arm-powerctl.o
  CC      aarch64-softmmu/hw/arm/fsl-imx31.o
  CC      aarch64-softmmu/hw/arm/kzm.o
  GEN     trace/generated-helpers.c
  CC      arm-softmmu/trace/control-target.o
  CC      aarch64-softmmu/hw/arm/sabrelite.o
  CC      aarch64-softmmu/hw/arm/fsl-imx6.o
  CC      aarch64-softmmu/hw/arm/aspeed_soc.o
  CC      aarch64-softmmu/hw/arm/aspeed.o
  CC      aarch64-softmmu/hw/arm/mps2.o
  CC      arm-softmmu/gdbstub-xml.o
  CC      aarch64-softmmu/hw/arm/msf2-soc.o
  CC      arm-softmmu/trace/generated-helpers.o
  CC      aarch64-softmmu/hw/arm/msf2-som.o
  CC      aarch64-softmmu/target/arm/arm-semi.o
  CC      aarch64-softmmu/target/arm/machine.o
  CC      aarch64-softmmu/target/arm/psci.o
  CC      aarch64-softmmu/target/arm/arch_dump.o
  CC      aarch64-softmmu/target/arm/monitor.o
  CC      aarch64-softmmu/target/arm/kvm-stub.o
  CC      aarch64-softmmu/target/arm/translate.o
  CC      aarch64-softmmu/target/arm/op_helper.o
  CC      aarch64-softmmu/target/arm/helper.o
  CC      aarch64-softmmu/target/arm/cpu.o
  CC      aarch64-softmmu/target/arm/neon_helper.o
  CC      aarch64-softmmu/target/arm/iwmmxt_helper.o
  CC      aarch64-softmmu/target/arm/gdbstub.o
  CC      aarch64-softmmu/target/arm/cpu64.o
  CC      aarch64-softmmu/target/arm/translate-a64.o
  CC      aarch64-softmmu/target/arm/helper-a64.o
  CC      aarch64-softmmu/target/arm/gdbstub64.o
  CC      aarch64-softmmu/target/arm/crypto_helper.o
  LINK    sh4-softmmu/qemu-system-sh4
  CC      aarch64-softmmu/target/arm/arm-powerctl.o
  GEN     trace/generated-helpers.c
  CC      aarch64-softmmu/trace/control-target.o
  CC      aarch64-softmmu/gdbstub-xml.o
  CC      aarch64-softmmu/trace/generated-helpers.o
  LINK    mips64el-linux-user/qemu-mips64el
  LINK    armeb-linux-user/qemu-armeb
  LINK    s390x-softmmu/qemu-system-s390x
  LINK    x86_64-softmmu/qemu-system-x86_64
  LINK    mips-softmmu/qemu-system-mips
  LINK    i386-softmmu/qemu-system-i386
  LINK    ppc-linux-user/qemu-ppc
  LINK    ppc64abi32-linux-user/qemu-ppc64abi32
  LINK    mipsel-softmmu/qemu-system-mipsel
  LINK    arm-softmmu/qemu-system-arm
  LINK    ppc64-linux-user/qemu-ppc64
  LINK    ppc64le-linux-user/qemu-ppc64le
  LINK    aarch64-softmmu/qemu-system-aarch64
  LINK    mips64-softmmu/qemu-system-mips64
  LINK    mips64el-softmmu/qemu-system-mips64el
  LINK    ppcemb-softmmu/qemu-system-ppcemb
  LINK    ppc-softmmu/qemu-system-ppc
  LINK    ppc64-softmmu/qemu-system-ppc64
=== OUTPUT END ===

Test command exited with code: 2


---
Email generated automatically by Patchew [http://patchew.org/].
Please send your feedback to patchew-devel@freelists.org

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 05/45] windbg: added helper features
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 05/45] windbg: added helper features Mihail Abakumov
@ 2017-11-28  8:18   ` Ladi Prosek
  2017-11-28  8:34     ` Peter Maydell
  0 siblings, 1 reply; 70+ messages in thread
From: Ladi Prosek @ 2017-11-28  8:18 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:07 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Added some helper features for windbgstub.
>
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgstub-utils.h |   27 +++++++++++++++++++++++++++
>  include/exec/windbgstub.h       |    6 ++++++
>  2 files changed, 33 insertions(+)
>
> diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
> index 2390597f1f..e9f5223e94 100755
> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -13,7 +13,34 @@
>  #define WINDBGSTUB_UTILS_H
>
>  #include "qemu/osdep.h"
> +#include "qemu/error-report.h"
> +#include "log.h"
> +#include "cpu.h"
>  #include "exec/windbgstub.h"
>  #include "exec/windbgkd.h"
>
> +#define WINDBG_DEBUG(...) do {             \
> +    if (WINDBG_DEBUG_ON) {                 \
> +        qemu_log(WINDBG ": " __VA_ARGS__); \
> +        qemu_log("\n");                    \
> +    }                                      \
> +} while (false)
> +
> +#define WINDBG_ERROR(...) error_report(WINDBG ": " __VA_ARGS__)
> +
> +#define FMT_ADDR "addr:0x" TARGET_FMT_lx
> +#define FMT_ERR  "Error:%d"
> +
> +#define UINT8_P(ptr) ((uint8_t *) (ptr))
> +#define UINT32_P(ptr) ((uint32_t *) (ptr))

This doesn't cross-compile on Linux:

In file included from
/home/lprosek/qemu/target/i386/windbgstub.c:15:0:
/home/lprosek/qemu/target/i386/windbgstub.c: In function
'kd_api_read_msr':
/home/lprosek/qemu/include/exec/windbgstub-utils.h:35:24: error: cast
to pointer from integer of different size
[-Werror=int-to-pointer-cast]
 #define UINT32_P(ptr) ((uint32_t *) (ptr))
                        ^
/home/lprosek/qemu/target/i386/windbgstub.c:1210:27: note: in
expansion of macro 'UINT32_P'
     m64c->DataValueLow  = UINT32_P(val)[0];
                           ^~~~~~~~
/home/lprosek/qemu/include/exec/windbgstub-utils.h:35:24: error: cast
to pointer from integer of different size
[-Werror=int-to-pointer-cast]
 #define UINT32_P(ptr) ((uint32_t *) (ptr))
                        ^
/home/lprosek/qemu/target/i386/windbgstub.c:1211:27: note: in
expansion of macro 'UINT32_P'
     m64c->DataValueHigh = UINT32_P(val)[1];
                           ^~~~~~~~


The macro or the places where it's used need to make sure that the
argument is of the right size. I hacked around it by doing:

--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -32,7 +32,7 @@
 #define FMT_ERR  "Error:%d"

 #define UINT8_P(ptr) ((uint8_t *) (ptr))
-#define UINT32_P(ptr) ((uint32_t *) (ptr))
+#define UINT32_P(ptr) ((uint32_t *) (size_t) (ptr))
 #define PTR(var) UINT8_P(&var)


> +#define PTR(var) UINT8_P(&var)
> +
> +#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
> +
> +#define READ_VMEM(cpu, addr, type) ({                         \
> +    type _t;                                                  \
> +    cpu_memory_rw_debug(cpu, addr, PTR(_t), sizeof(type), 0); \
> +    _t;                                                       \
> +})
> +
>  #endif
> diff --git a/include/exec/windbgstub.h b/include/exec/windbgstub.h
> index 1a6e1cc6e5..21bc552e58 100755
> --- a/include/exec/windbgstub.h
> +++ b/include/exec/windbgstub.h
> @@ -12,6 +12,12 @@
>  #ifndef WINDBGSTUB_H
>  #define WINDBGSTUB_H
>
> +#define WINDBG "windbg"
> +
> +#ifndef WINDBG_DEBUG_ON
> +#define WINDBG_DEBUG_ON false
> +#endif
> +
>  int windbg_server_start(const char *device);
>
>  #endif
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 05/45] windbg: added helper features
  2017-11-28  8:18   ` Ladi Prosek
@ 2017-11-28  8:34     ` Peter Maydell
  2017-11-28  9:01       ` Paolo Bonzini
  0 siblings, 1 reply; 70+ messages in thread
From: Peter Maydell @ 2017-11-28  8:34 UTC (permalink / raw)
  To: Ladi Prosek
  Cc: Mihail Abakumov, Stefan Weil, qemu-devel, Pavel Dovgalyuk,
	Roman Kagan, Paolo Bonzini, Denis V. Lunev

On 28 November 2017 at 08:18, Ladi Prosek <lprosek@redhat.com> wrote:
> On Tue, Nov 21, 2017 at 3:07 PM, Mihail Abakumov
> <mikhail.abakumov@ispras.ru> wrote:
>> Added some helper features for windbgstub.

> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -32,7 +32,7 @@
>  #define FMT_ERR  "Error:%d"
>
>  #define UINT8_P(ptr) ((uint8_t *) (ptr))
> -#define UINT32_P(ptr) ((uint32_t *) (ptr))
> +#define UINT32_P(ptr) ((uint32_t *) (size_t) (ptr))
>  #define PTR(var) UINT8_P(&var)

Hiding casts behind macros like this doesn't seem worthwhile
to me anyway -- all it's doing is obscuring what's going on.
And casting an arbitrary pointer to a uint32_t* is somewhat
alarming -- the alignment requirements may not be met.
Chances are high that code using that macro is not correct.

thanks
-- PMM

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 05/45] windbg: added helper features
  2017-11-28  8:34     ` Peter Maydell
@ 2017-11-28  9:01       ` Paolo Bonzini
  0 siblings, 0 replies; 70+ messages in thread
From: Paolo Bonzini @ 2017-11-28  9:01 UTC (permalink / raw)
  To: Peter Maydell, Ladi Prosek
  Cc: Mihail Abakumov, Stefan Weil, qemu-devel, Pavel Dovgalyuk,
	Roman Kagan, Denis V. Lunev

On 28/11/2017 09:34, Peter Maydell wrote:
>>  #define FMT_ERR  "Error:%d"
>>
>>  #define UINT8_P(ptr) ((uint8_t *) (ptr))
>> -#define UINT32_P(ptr) ((uint32_t *) (ptr))
>> +#define UINT32_P(ptr) ((uint32_t *) (size_t) (ptr))
>>  #define PTR(var) UINT8_P(&var)
> Hiding casts behind macros like this doesn't seem worthwhile
> to me anyway -- all it's doing is obscuring what's going on.
> And casting an arbitrary pointer to a uint32_t* is somewhat
> alarming -- the alignment requirements may not be met.
> Chances are high that code using that macro is not correct.

And also, we already have ldb_p and ldl_*_p that do exactly what you
want (and give you an opportunity to specify the intended endianness,
probably little-endian).

Thanks,

Paolo

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 01/45] windbg: added empty windbgstub files
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 01/45] windbg: added empty windbgstub files Mihail Abakumov
@ 2017-11-28 12:10   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-28 12:10 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:07 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  Makefile.target                 |    7 +++++++
>  include/exec/windbgstub-utils.h |   18 ++++++++++++++++++
>  include/exec/windbgstub.h       |   17 +++++++++++++++++
>  stubs/Makefile.objs             |    1 +
>  stubs/windbgstub.c              |   18 ++++++++++++++++++
>  target/i386/Makefile.objs       |    2 +-
>  target/i386/windbgstub.c        |   12 ++++++++++++
>  windbgstub-utils.c              |   12 ++++++++++++
>  windbgstub.c                    |   19 +++++++++++++++++++
>  9 files changed, 105 insertions(+), 1 deletion(-)
>  create mode 100755 include/exec/windbgstub-utils.h
>  create mode 100755 include/exec/windbgstub.h
>  create mode 100755 stubs/windbgstub.c
>  create mode 100755 target/i386/windbgstub.c
>  create mode 100755 windbgstub-utils.c
>  create mode 100755 windbgstub.c
>
> diff --git a/Makefile.target b/Makefile.target
> index 7f42c45db8..6df0836509 100644
> --- a/Makefile.target
> +++ b/Makefile.target
> @@ -148,6 +148,13 @@ obj-y += dump.o
>  obj-y += migration/ram.o
>  LIBS := $(libs_softmmu) $(LIBS)
>
> +# WinDbg support
> +ifeq ($(TARGET_NAME), i386)
> +ifneq ($(TARGET_NAME), x86_64)

This is odd. Did you add the second by mistake? Thanks!

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 45/45] windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 45/45] windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex Mihail Abakumov
@ 2017-11-28 12:44   ` Ladi Prosek
  2017-12-05 11:28     ` Mihail Abakumov
  0 siblings, 1 reply; 70+ messages in thread
From: Ladi Prosek @ 2017-11-28 12:44 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:11 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
[...]
> diff --git a/windbgstub.c b/windbgstub.c
> index 36372c0ea5..3bcf6a8cbb 100755
> --- a/windbgstub.c
> +++ b/windbgstub.c
> @@ -224,6 +224,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
>          kd_api_query_memory(cpu, &ctx->data);
>          break;
>
> +    case DbgKdGetContextExApi:
> +        kd_api_get_context_ex(cpu, &ctx->data);
> +        break;
> +
> +    case DbgKdSetContextExApi:
> +        kd_api_set_context_ex(cpu, &ctx->data);
> +        break;
> +
>      default:
>          kd_api_unsupported(cpu, &ctx->data);
>          break;
> @@ -262,12 +270,12 @@ static void windbg_process_control_packet(ParsingContext *ctx)
>
>      case PACKET_TYPE_KD_RESET:
>      {
> -        SizedBuf buf = kd_gen_load_symbols_sc(qemu_get_cpu(0));
> +        windbg_send_control_packet(ctx->packet.PacketType);
> +        windbg_state->ctrl_packet_id = INITIAL_PACKET_ID;

You didn't mention it in the cover email so I'd like to be sure. This
is what fixed the initial handshake so it works without -b now, is
that correct? Thanks!

> +        SizedBuf buf = kd_gen_load_symbols_sc(qemu_get_cpu(0));
>          windbg_send_data_packet(buf.data, buf.size,
>                                  PACKET_TYPE_KD_STATE_CHANGE64);
> -        windbg_send_control_packet(ctx->packet.PacketType);
> -        windbg_state->ctrl_packet_id = INITIAL_PACKET_ID;
>          SBUF_FREE(buf);
>          break;
>      }
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 03/45] windbg: modified windbgkd.h
  2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 03/45] windbg: modified windbgkd.h Mihail Abakumov
@ 2017-11-28 12:54   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-28 12:54 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:07 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Added useful name arrays of some defines. Not used yet. Needs for the future.
>
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgkd.h |   75 +++++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 75 insertions(+)
>
> diff --git a/include/exec/windbgkd.h b/include/exec/windbgkd.h
> index b8f98925e7..40a23f8cd0 100755
> --- a/include/exec/windbgkd.h
> +++ b/include/exec/windbgkd.h
> @@ -870,4 +870,79 @@ typedef struct _DBGKD_TRACE_IO {
>     } u;
>  } DBGKD_TRACE_IO, *PDBGKD_TRACE_IO;
>
> +__attribute__ ((unused)) /* maybe unused */
> +static const char *kd_api_names[] = {
> +    "DbgKdReadVirtualMemoryApi",
> +    "DbgKdWriteVirtualMemoryApi",
> +    "DbgKdGetContextApi",
> +    "DbgKdSetContextApi",
> +    "DbgKdWriteBreakPointApi",
> +    "DbgKdRestoreBreakPointApi",
> +    "DbgKdContinueApi",
> +    "DbgKdReadControlSpaceApi",
> +    "DbgKdWriteControlSpaceApi",
> +    "DbgKdReadIoSpaceApi",
> +    "DbgKdWriteIoSpaceApi",
> +    "DbgKdRebootApi",
> +    "DbgKdContinueApi2",
> +    "DbgKdReadPhysicalMemoryApi",
> +    "DbgKdWritePhysicalMemoryApi",
> +    "DbgKdQuerySpecialCallsApi",
> +    "DbgKdSetSpecialCallApi",
> +    "DbgKdClearSpecialCallsApi",
> +    "DbgKdSetInternalBreakPointApi",
> +    "DbgKdGetInternalBreakPointApi",
> +    "DbgKdReadIoSpaceExtendedApi",
> +    "DbgKdWriteIoSpaceExtendedApi",
> +    "DbgKdGetVersionApi",
> +    "DbgKdWriteBreakPointExApi",
> +    "DbgKdRestoreBreakPointExApi",
> +    "DbgKdCauseBugCheckApi",
> +    "",
> +    "",
> +    "",
> +    "",
> +    "",
> +    "",
> +    "DbgKdSwitchProcessor",
> +    "DbgKdPageInApi",
> +    "DbgKdReadMachineSpecificRegister",
> +    "DbgKdWriteMachineSpecificRegister",
> +    "OldVlm1",
> +    "OldVlm2",
> +    "DbgKdSearchMemoryApi",
> +    "DbgKdGetBusDataApi",
> +    "DbgKdSetBusDataApi",
> +    "DbgKdCheckLowMemoryApi",
> +    "DbgKdClearAllInternalBreakpointsApi",
> +    "DbgKdFillMemoryApi",
> +    "DbgKdQueryMemoryApi",
> +    "DbgKdSwitchPartition",
> +    "DbgKdUnknownApi"
> +};
> +
> +__attribute__ ((unused)) /* maybe unused */
> +static const char *kd_packet_type_names[] = {
> +    "PACKET_TYPE_UNUSED",
> +    "PACKET_TYPE_KD_STATE_CHANGE32",
> +    "PACKET_TYPE_KD_STATE_MANIPULATE",
> +    "PACKET_TYPE_KD_DEBUG_IO",
> +    "PACKET_TYPE_KD_ACKNOWLEDGE",
> +    "PACKET_TYPE_KD_RESEND",
> +    "PACKET_TYPE_KD_RESET",
> +    "PACKET_TYPE_KD_STATE_CHANGE64",
> +    "PACKET_TYPE_KD_POLL_BREAKIN",
> +    "PACKET_TYPE_KD_TRACE_IO",
> +    "PACKET_TYPE_KD_CONTROL_REQUEST",
> +    "PACKET_TYPE_KD_FILE_IO",
> +    "PACKET_TYPE_MAX"
> +};
> +
> +#define KD_API_NAME(id) \
> +    (id >= DbgKdMinimumManipulate && id < DbgKdMaximumManipulate) ? \
> +        kd_api_names[id - DbgKdMinimumManipulate] : \
> +        kd_api_names[DbgKdMaximumManipulate - DbgKdMinimumManipulate] \

nice-to-have: Build-time assert that kd_api_names has
(DbgKdMaximumManipulate - DbgKdMinimumManipulate + 1) elements.

> +#define KD_PKT_TYPE_NAME(id) kd_packet_type_names[id]

nice-to-have: A ternary similar to what KD_API_NAME has for extra safety.

>  #endif
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 10/45] windbg: structures for parsing data stream
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 10/45] windbg: structures for parsing data stream Mihail Abakumov
@ 2017-11-28 13:45   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-28 13:45 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:08 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Added structures for parsing data stream from windbg to packet.
>
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgstub-utils.h |   11 +++++++++++
>  windbgstub.c                    |   30 ++++++++++++++++++++++++++++++
>  2 files changed, 41 insertions(+)
>
> diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
> index 42dbca1e22..2d74fb847a 100755
> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -48,6 +48,17 @@ typedef struct InitedAddr {
>      bool is_init;
>  } InitedAddr;
>
> +typedef struct PacketData {
> +    union {
> +        struct {
> +            DBGKD_MANIPULATE_STATE64 m64;
> +            uint8_t extra[PACKET_MAX_SIZE - sizeof(DBGKD_MANIPULATE_STATE64)];

nit:
  uint8_t extra[0];

The buf field below already defines the size and in a more readable way.

> +        };
> +        uint8_t buf[PACKET_MAX_SIZE];
> +    };
> +    uint16_t extra_size;
> +} PacketData;
> +
>  InitedAddr *windbg_get_KPCR(void);
>  InitedAddr *windbg_get_version(void);
>
> diff --git a/windbgstub.c b/windbgstub.c
> index e9aabd807b..395f244d4f 100755
> --- a/windbgstub.c
> +++ b/windbgstub.c
> @@ -19,6 +19,36 @@
>  #include "sysemu/kvm.h"
>  #include "sysemu/reset.h"
>
> +typedef enum ParsingState {
> +    STATE_LEADER,
> +    STATE_PACKET_TYPE,
> +    STATE_PACKET_BYTE_COUNT,
> +    STATE_PACKET_ID,
> +    STATE_PACKET_CHECKSUM,
> +    STATE_PACKET_DATA,
> +    STATE_TRAILING_BYTE,
> +} ParsingState;
> +
> +typedef enum ParsingResult {
> +    RESULT_NONE,
> +    RESULT_BREAKIN_BYTE,
> +    RESULT_UNKNOWN_PACKET,
> +    RESULT_CONTROL_PACKET,
> +    RESULT_DATA_PACKET,
> +    RESULT_ERROR,
> +} ParsingResult;
> +
> +typedef struct ParsingContext {
> +    /* index in the current buffer,
> +       which depends on the current state */
> +    int index;
> +    ParsingState state;
> +    ParsingResult result;
> +    KD_PACKET packet;
> +    PacketData data;
> +    const char *name;
> +} ParsingContext;
> +
>  typedef struct WindbgState {
>      bool is_loaded;
>
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 15/45] windbg: sized data buffer
  2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 15/45] windbg: sized data buffer Mihail Abakumov
@ 2017-11-28 14:07   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-28 14:07 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:08 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Defined useful sized data buffer. It contains pointer to data and size of this data. Also, defined some macros for init and free.
>
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgstub-utils.h |   16 ++++++++++++++++
>  1 file changed, 16 insertions(+)
>
> diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
> index 6ce870beb1..b729cd604e 100755
> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -67,6 +67,22 @@ typedef struct PacketData {
>      uint16_t extra_size;
>  } PacketData;
>
> +typedef struct SizedBuf {
> +    uint8_t *data;
> +    size_t size;
> +} SizedBuf;
> +
> +#define SBUF_INIT(buf, mem_ptr, len) do { \
> +    buf.data = mem_ptr;                   \
> +    buf.size = len;                       \
> +} while (false)
> +#define SBUF_MALLOC(buf, size) SBUF_INIT(buf, g_malloc0(size), size)
> +#define SBUF_FREE(buf) do { \
> +    g_free(buf.data);       \
> +    buf.data = NULL;        \
> +    buf.size = 0;           \
> +} while (false)
> +

I don't think that this is necessary. These macros are used for ~240
byte data structures and the points where they are allocated and freed
are super close together.

I'd just put them on the stack in the callers of kd_gen_exception_sc()
and kd_gen_load_symbols_sc() (only one caller each) and remove this
patch.

>  InitedAddr *windbg_get_KPCR(void);
>  InitedAddr *windbg_get_version(void);
>
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 26/45] windbg: implemented windbg_read_context
  2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 26/45] windbg: implemented windbg_read_context Mihail Abakumov
@ 2017-11-28 14:57   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-28 14:57 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:09 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  target/i386/windbgstub.c |   96 ++++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 96 insertions(+)
>
> diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
> index bf1afab1f8..1fccd8eee7 100755
> --- a/target/i386/windbgstub.c
> +++ b/target/i386/windbgstub.c
> @@ -276,6 +276,102 @@ typedef struct _CPU_KPROCESSOR_STATE {
>  static int windbg_read_context(CPUState *cpu, uint8_t *buf, int buf_size,
>                                 int offset, int len)
>  {
> +    CPUArchState *env = cpu->env_ptr;
> +    CPU_CONTEXT *cc;
> +    bool new_mem;
> +
> +    if (len < 0 || len > buf_size) {
> +        WINDBG_ERROR("windbg_read_context: incorrect length %d", len);
> +        return 1;
> +    }
> +
> +    if (offset < 0 || offset + len > sizeof(CPU_CONTEXT)) {
> +        WINDBG_ERROR("windbg_read_context: incorrect offset %d", offset);
> +        return 2;
> +    }
> +
> +    new_mem = len != sizeof(CPU_CONTEXT) || offset != 0;
> +    if (new_mem) {
> +        cc = g_new0(CPU_CONTEXT, 1);
> +    } else {
> +        cc = (CPU_CONTEXT *) buf;
> +        memset(cc, 0, sizeof(CPU_CONTEXT));
> +    }
> +
> +    cc->ContextFlags = CPU_CONTEXT_ALL;

This deserves at least a comment. Was it maybe for debugging and
accidentally left in the code or is it really intentional?

Also, I believe that cc->ContextFlags should not be accessed directly
in this function but with stl_p / ldl_p.

> +    if (cc->ContextFlags & CPU_CONTEXT_SEGMENTS) {
> +        stw_p(&cc->SegCs, env->segs[R_CS].selector);
> +        stw_p(&cc->SegDs, env->segs[R_DS].selector);
> +        stw_p(&cc->SegEs, env->segs[R_ES].selector);
> +        stw_p(&cc->SegFs, env->segs[R_FS].selector);
> +        stw_p(&cc->SegGs, env->segs[R_GS].selector);
> +        stw_p(&cc->SegSs, env->segs[R_SS].selector);
> +    }
> +
> +    if (cc->ContextFlags & CPU_CONTEXT_DEBUG_REGISTERS) {
> +        sttul_p(&cc->Dr0, env->dr[0]);
> +        sttul_p(&cc->Dr1, env->dr[1]);
> +        sttul_p(&cc->Dr2, env->dr[2]);
> +        sttul_p(&cc->Dr3, env->dr[3]);
> +        sttul_p(&cc->Dr6, env->dr[6]);
> +        sttul_p(&cc->Dr7, env->dr[7]);
> +    }
> +
> +    if (cc->ContextFlags & CPU_CONTEXT_INTEGER) {
> +        stl_p(&cc->Edi, env->regs[R_EDI]);
> +        stl_p(&cc->Esi, env->regs[R_ESI]);
> +        stl_p(&cc->Ebx, env->regs[R_EBX]);
> +        stl_p(&cc->Edx, env->regs[R_EDX]);
> +        stl_p(&cc->Ecx, env->regs[R_ECX]);
> +        stl_p(&cc->Eax, env->regs[R_EAX]);
> +        stl_p(&cc->Ebp, env->regs[R_EBP]);
> +        stl_p(&cc->Esp, env->regs[R_ESP]);
> +        stl_p(&cc->Eip, env->eip);
> +        stl_p(&cc->EFlags, env->eflags);
> +    }
> +
> +    if (cc->ContextFlags & CPU_CONTEXT_FLOATING_POINT) {
> +        uint32_t swd = 0, twd = 0;
> +        swd = env->fpus & ~(7 << 11);
> +        swd |= (env->fpstt & 7) << 11;
> +        int i;
> +        for (i = 0; i < 8; ++i) {
> +            twd |= (!env->fptags[i]) << i;
> +        }
> +
> +        stl_p(&cc->FloatSave.ControlWord, env->fpuc);
> +        stl_p(&cc->FloatSave.StatusWord, swd);
> +        stl_p(&cc->FloatSave.TagWord, twd);
> +        stl_p(&cc->FloatSave.ErrorOffset, UINT32_P(&env->fpip)[0]);
> +        stl_p(&cc->FloatSave.ErrorSelector, UINT32_P(&env->fpip)[1]);
> +        stl_p(&cc->FloatSave.DataOffset, UINT32_P(&env->fpdp)[0]);
> +        stl_p(&cc->FloatSave.DataSelector, UINT32_P(&env->fpdp)[1]);
> +        stl_p(&cc->FloatSave.Cr0NpxState, env->xcr0);
> +
> +        for (i = 0; i < 8; ++i) {
> +            memcpy(PTR(cc->FloatSave.RegisterArea[i * 10]),
> +                   PTR(env->fpregs[i]), 10);
> +        }
> +    }
> +
> +    if (cc->ContextFlags & CPU_CONTEXT_EXTENDED_REGISTERS) {
> +        uint8_t *ptr = cc->ExtendedRegisters + 160;
> +        int i;
> +        for (i = 0; i < 8; ++i, ptr += 16) {
> +            stq_p(ptr,     env->xmm_regs[i].ZMM_Q(0));
> +            stq_p(ptr + 8, env->xmm_regs[i].ZMM_Q(1));
> +        }
> +
> +        stl_p(cc->ExtendedRegisters + 24, env->mxcsr);
> +    }
> +
> +    stl_p(&cc->ContextFlags, cc->ContextFlags);
> +
> +    if (new_mem) {
> +        memcpy(buf, (uint8_t *) cc + offset, len);
> +        g_free(cc);
> +    }
>      return 0;
>  }
>
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing Mihail Abakumov
@ 2017-11-29  7:13   ` Ladi Prosek
  2017-12-06  7:29     ` Mihail Abakumov
  0 siblings, 1 reply; 70+ messages in thread
From: Ladi Prosek @ 2017-11-29  7:13 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:10 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Added handler registration of gdb debug exception. Its exception also can be used for windbg.
>
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  cpus.c                  |   18 +++++++++++++++++-
>  gdbstub.c               |    4 ++++
>  include/sysemu/sysemu.h |    2 ++
>  windbgstub.c            |   16 ++++++++++++----
>  4 files changed, 35 insertions(+), 5 deletions(-)
>
> diff --git a/cpus.c b/cpus.c
> index 9bed61eefc..212553b7e3 100644
> --- a/cpus.c
> +++ b/cpus.c
> @@ -77,6 +77,8 @@ int64_t max_advance;
>  static QEMUTimer *throttle_timer;
>  static unsigned int throttle_percentage;
>
> +static void (*excp_debug_handler)(CPUState *cpu);
> +
>  #define CPU_THROTTLE_PCT_MIN 1
>  #define CPU_THROTTLE_PCT_MAX 99
>  #define CPU_THROTTLE_TIMESLICE_NS 10000000
> @@ -960,9 +962,23 @@ static bool cpu_can_run(CPUState *cpu)
>      return true;
>  }
>
> +bool register_excp_debug_handler(void (*handler)(CPUState *cpu))
> +{
> +    if (excp_debug_handler == NULL) {
> +        excp_debug_handler = handler;
> +        return true;
> +    } else {
> +        error_report("ERROR: Something debugger already using");

So I take it that -windbg and -gdb cannot be used at the same time.
Should it be handled in a more explicit way with a more user-friendly
error?

Right now I get this error, which is more like an implementation
detail (could the debug handler be refactored into a multicast event
in the future?) and does not even make sense as a sentence.

> +        return false;
> +    }
> +}
> +
>  static void cpu_handle_guest_debug(CPUState *cpu)
>  {
> -    gdb_set_stop_cpu(cpu);
> +    if (excp_debug_handler != NULL) {
> +        excp_debug_handler(cpu);
> +    }
> +
>      qemu_system_debug_request();
>      cpu->stopped = true;
>  }
> diff --git a/gdbstub.c b/gdbstub.c
> index 2a94030d3b..8c76f54117 100644
> --- a/gdbstub.c
> +++ b/gdbstub.c
> @@ -2006,6 +2006,10 @@ int gdbserver_start(const char *device)
>      s->mon_chr = mon_chr;
>      s->current_syscall_cb = NULL;
>
> +    if (!register_excp_debug_handler(gdb_set_stop_cpu)) {
> +        exit(1);
> +    }
> +
>      return 0;
>  }
>
> diff --git a/include/sysemu/sysemu.h b/include/sysemu/sysemu.h
> index b21369672a..34588c99b4 100644
> --- a/include/sysemu/sysemu.h
> +++ b/include/sysemu/sysemu.h
> @@ -193,6 +193,8 @@ QemuOpts *qemu_get_machine_opts(void);
>
>  bool defaults_enabled(void);
>
> +bool register_excp_debug_handler(void (*handler)(CPUState *cpu));
> +
>  extern QemuOptsList qemu_legacy_drive_opts;
>  extern QemuOptsList qemu_common_drive_opts;
>  extern QemuOptsList qemu_drive_opts;
> diff --git a/windbgstub.c b/windbgstub.c
> index 489abe6d6c..b33f412659 100755
> --- a/windbgstub.c
> +++ b/windbgstub.c
> @@ -115,16 +115,20 @@ static void windbg_send_control_packet(uint16_t type)
>      windbg_state->ctrl_packet_id ^= 1;
>  }
>
> -static void windbg_vm_stop(void)
> +static void windbg_bp_handler(CPUState *cpu)
>  {
> -    CPUState *cpu = qemu_get_cpu(0);
> -    vm_stop(RUN_STATE_PAUSED);
> -
>      SizedBuf buf = kd_gen_exception_sc(cpu);
>      windbg_send_data_packet(buf.data, buf.size, PACKET_TYPE_KD_STATE_CHANGE64);
>      SBUF_FREE(buf);
>  }
>
> +static void windbg_vm_stop(void)
> +{
> +    CPUState *cpu = qemu_get_cpu(0);
> +    vm_stop(RUN_STATE_PAUSED);
> +    windbg_bp_handler(cpu);
> +}
> +
>  static void windbg_process_manipulate_packet(ParsingContext *ctx)
>  {
>      CPUState *cpu;
> @@ -432,6 +436,10 @@ int windbg_server_start(const char *device)
>
>      qemu_register_reset(windbg_handle_reset, NULL);
>
> +    if (!register_excp_debug_handler(windbg_bp_handler)) {
> +        exit(1);
> +    }
> +
>      atexit(windbg_exit);
>      return 0;
>  }
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 40/45] windbg: implemented kd_api_read_msr and kd_api_write_msr
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 40/45] windbg: implemented kd_api_read_msr and kd_api_write_msr Mihail Abakumov
@ 2017-11-29  7:25   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-29  7:25 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:11 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgstub-utils.h |    2
>  target/i386/windbgstub.c        |  319 +++++++++++++++++++++++++++++++++++++++
>  windbgstub.c                    |    8 +
>  3 files changed, 329 insertions(+)
>
> diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
> index bc5b6a8468..73d49b774d 100755
> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -100,6 +100,8 @@ void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
>  void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd);
>  void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
>  void kd_api_get_version(CPUState *cpu, PacketData *pd);
> +void kd_api_read_msr(CPUState *cpu, PacketData *pd);
> +void kd_api_write_msr(CPUState *cpu, PacketData *pd);
>  void kd_api_unsupported(CPUState *cpu, PacketData *pd);
>
>  SizedBuf kd_gen_exception_sc(CPUState *cpu);
> diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
> index 43e6d45df9..735b2edd5f 100755
> --- a/target/i386/windbgstub.c
> +++ b/target/i386/windbgstub.c
> @@ -1003,6 +1003,325 @@ void kd_api_write_control_space(CPUState *cpu, PacketData *pd)
>      stl_p(&mem->ActualBytesWritten, len);
>  }
>
> +void kd_api_read_msr(CPUState *cpu, PacketData *pd)
> +{
> +    DBGKD_READ_WRITE_MSR *m64c = &pd->m64.u.ReadWriteMsr;
> +    CPUArchState *env = cpu->env_ptr;
> +
> +    uint64_t val;
> +
> +    cpu_svm_check_intercept_param(env, SVM_EXIT_MSR, 0, 0);
> +
> +    switch ((uint32_t)env->regs[R_ECX]) {
> +    case MSR_IA32_SYSENTER_CS:
> +        val = env->sysenter_cs;
> +        break;
> +    case MSR_IA32_SYSENTER_ESP:
> +        val = env->sysenter_esp;
> +        break;
> +    case MSR_IA32_SYSENTER_EIP:
> +        val = env->sysenter_eip;
> +        break;
> +    case MSR_IA32_APICBASE:
> +        val = cpu_get_apic_base(x86_env_get_cpu(env)->apic_state);
> +        break;
> +    case MSR_EFER:
> +        val = env->efer;
> +        break;
> +    case MSR_STAR:
> +        val = env->star;
> +        break;
> +    case MSR_PAT:
> +        val = env->pat;
> +        break;
> +    case MSR_VM_HSAVE_PA:
> +        val = env->vm_hsave;
> +        break;
> +    case MSR_IA32_PERF_STATUS:
> +        /* tsc_increment_by_tick */
> +        val = 1000ULL;
> +        /* CPU multiplier */
> +        val |= (((uint64_t)4ULL) << 40);
> +        break;
> +#ifdef TARGET_X86_64
> +    case MSR_LSTAR:
> +        val = env->lstar;
> +        break;
> +    case MSR_CSTAR:
> +        val = env->cstar;
> +        break;
> +    case MSR_FMASK:
> +        val = env->fmask;
> +        break;
> +    case MSR_FSBASE:
> +        val = env->segs[R_FS].base;
> +        break;
> +    case MSR_GSBASE:
> +        val = env->segs[R_GS].base;
> +        break;
> +    case MSR_KERNELGSBASE:
> +        val = env->kernelgsbase;
> +        break;
> +    case MSR_TSC_AUX:
> +        val = env->tsc_aux;
> +        break;
> +#endif
> +    case MSR_MTRRphysBase(0):
> +    case MSR_MTRRphysBase(1):
> +    case MSR_MTRRphysBase(2):
> +    case MSR_MTRRphysBase(3):
> +    case MSR_MTRRphysBase(4):
> +    case MSR_MTRRphysBase(5):
> +    case MSR_MTRRphysBase(6):
> +    case MSR_MTRRphysBase(7):
> +        val = env->mtrr_var[((uint32_t)env->regs[R_ECX] -
> +                             MSR_MTRRphysBase(0)) / 2].base;
> +        break;
> +    case MSR_MTRRphysMask(0):
> +    case MSR_MTRRphysMask(1):
> +    case MSR_MTRRphysMask(2):
> +    case MSR_MTRRphysMask(3):
> +    case MSR_MTRRphysMask(4):
> +    case MSR_MTRRphysMask(5):
> +    case MSR_MTRRphysMask(6):
> +    case MSR_MTRRphysMask(7):
> +        val = env->mtrr_var[((uint32_t)env->regs[R_ECX] -
> +                             MSR_MTRRphysMask(0)) / 2].mask;
> +        break;
> +    case MSR_MTRRfix64K_00000:
> +        val = env->mtrr_fixed[0];
> +        break;
> +    case MSR_MTRRfix16K_80000:
> +    case MSR_MTRRfix16K_A0000:
> +        val = env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
> +                              MSR_MTRRfix16K_80000 + 1];
> +        break;
> +    case MSR_MTRRfix4K_C0000:
> +    case MSR_MTRRfix4K_C8000:
> +    case MSR_MTRRfix4K_D0000:
> +    case MSR_MTRRfix4K_D8000:
> +    case MSR_MTRRfix4K_E0000:
> +    case MSR_MTRRfix4K_E8000:
> +    case MSR_MTRRfix4K_F0000:
> +    case MSR_MTRRfix4K_F8000:
> +        val = env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
> +                              MSR_MTRRfix4K_C0000 + 3];
> +        break;
> +    case MSR_MTRRdefType:
> +        val = env->mtrr_deftype;
> +        break;
> +    case MSR_MTRRcap:
> +        if (env->features[FEAT_1_EDX] & CPUID_MTRR) {
> +            val = MSR_MTRRcap_VCNT | MSR_MTRRcap_FIXRANGE_SUPPORT |
> +                MSR_MTRRcap_WC_SUPPORTED;
> +        } else {
> +            /* XXX: exception? */
> +            val = 0;
> +        }
> +        break;
> +    case MSR_MCG_CAP:
> +        val = env->mcg_cap;
> +        break;
> +    case MSR_MCG_CTL:
> +        if (env->mcg_cap & MCG_CTL_P) {
> +            val = env->mcg_ctl;
> +        } else {
> +            val = 0;
> +        }
> +        break;
> +    case MSR_MCG_STATUS:
> +        val = env->mcg_status;
> +        break;
> +    case MSR_IA32_MISC_ENABLE:
> +        val = env->msr_ia32_misc_enable;
> +        break;
> +    case MSR_IA32_BNDCFGS:
> +        val = env->msr_bndcfgs;
> +        break;
> +    default:
> +        if ((uint32_t)env->regs[R_ECX] >= MSR_MC0_CTL
> +            && (uint32_t)env->regs[R_ECX] < MSR_MC0_CTL +
> +            (4 * env->mcg_cap & 0xff)) {
> +            uint32_t offset = (uint32_t)env->regs[R_ECX] - MSR_MC0_CTL;
> +            val = env->mce_banks[offset];
> +            break;
> +        }
> +        /* XXX: exception? */
> +        val = 0;
> +        break;
> +    }
> +
> +    stq_p(&val, val);
> +    m64c->DataValueLow  = UINT32_P(val)[0];
> +    m64c->DataValueHigh = UINT32_P(val)[1];
> +    pd->m64.ReturnStatus = STATUS_SUCCESS;
> +}
> +
> +void kd_api_write_msr(CPUState *cpu, PacketData *pd)
> +{
> +    DBGKD_READ_WRITE_MSR *m64c = &pd->m64.u.ReadWriteMsr;
> +    CPUArchState *env = cpu->env_ptr;
> +
> +    uint64_t val;
> +
> +    cpu_svm_check_intercept_param(env, SVM_EXIT_MSR, 1, 0);
> +
> +    val = m64c->DataValueLow | ((uint64_t) m64c->DataValueHigh) << 32;
> +    val = ldq_p(&val);
> +
> +    switch ((uint32_t)env->regs[R_ECX]) {
> +    case MSR_IA32_SYSENTER_CS:
> +        env->sysenter_cs = val & 0xffff;
> +        break;
> +    case MSR_IA32_SYSENTER_ESP:
> +        env->sysenter_esp = val;
> +        break;
> +    case MSR_IA32_SYSENTER_EIP:
> +        env->sysenter_eip = val;
> +        break;
> +    case MSR_IA32_APICBASE:
> +        cpu_set_apic_base(x86_env_get_cpu(env)->apic_state, val);
> +        break;
> +    case MSR_EFER:
> +        {
> +            uint64_t update_mask;
> +
> +            update_mask = 0;
> +            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_SYSCALL) {
> +                update_mask |= MSR_EFER_SCE;
> +            }
> +            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM) {
> +                update_mask |= MSR_EFER_LME;
> +            }
> +            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_FFXSR) {
> +                update_mask |= MSR_EFER_FFXSR;
> +            }
> +            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_NX) {
> +                update_mask |= MSR_EFER_NXE;
> +            }
> +            if (env->features[FEAT_8000_0001_ECX] & CPUID_EXT3_SVM) {
> +                update_mask |= MSR_EFER_SVME;
> +            }
> +            if (env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_FFXSR) {
> +                update_mask |= MSR_EFER_FFXSR;
> +            }
> +            cpu_load_efer(env, (env->efer & ~update_mask) |
> +                          (val & update_mask));
> +        }
> +        break;
> +    case MSR_STAR:
> +        env->star = val;
> +        break;
> +    case MSR_PAT:
> +        env->pat = val;
> +        break;
> +    case MSR_VM_HSAVE_PA:
> +        env->vm_hsave = val;
> +        break;
> +#ifdef TARGET_X86_64
> +    case MSR_LSTAR:
> +        env->lstar = val;
> +        break;
> +    case MSR_CSTAR:
> +        env->cstar = val;
> +        break;
> +    case MSR_FMASK:
> +        env->fmask = val;
> +        break;
> +    case MSR_FSBASE:
> +        env->segs[R_FS].base = val;
> +        break;
> +    case MSR_GSBASE:
> +        env->segs[R_GS].base = val;
> +        break;
> +    case MSR_KERNELGSBASE:
> +        env->kernelgsbase = val;
> +        break;
> +#endif
> +    case MSR_MTRRphysBase(0):
> +    case MSR_MTRRphysBase(1):
> +    case MSR_MTRRphysBase(2):
> +    case MSR_MTRRphysBase(3):
> +    case MSR_MTRRphysBase(4):
> +    case MSR_MTRRphysBase(5):
> +    case MSR_MTRRphysBase(6):
> +    case MSR_MTRRphysBase(7):
> +        env->mtrr_var[((uint32_t)env->regs[R_ECX] -
> +                       MSR_MTRRphysBase(0)) / 2].base = val;
> +        break;
> +    case MSR_MTRRphysMask(0):
> +    case MSR_MTRRphysMask(1):
> +    case MSR_MTRRphysMask(2):
> +    case MSR_MTRRphysMask(3):
> +    case MSR_MTRRphysMask(4):
> +    case MSR_MTRRphysMask(5):
> +    case MSR_MTRRphysMask(6):
> +    case MSR_MTRRphysMask(7):
> +        env->mtrr_var[((uint32_t)env->regs[R_ECX] -
> +                       MSR_MTRRphysMask(0)) / 2].mask = val;
> +        break;
> +    case MSR_MTRRfix64K_00000:
> +        env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
> +                        MSR_MTRRfix64K_00000] = val;
> +        break;
> +    case MSR_MTRRfix16K_80000:
> +    case MSR_MTRRfix16K_A0000:
> +        env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
> +                        MSR_MTRRfix16K_80000 + 1] = val;
> +        break;
> +    case MSR_MTRRfix4K_C0000:
> +    case MSR_MTRRfix4K_C8000:
> +    case MSR_MTRRfix4K_D0000:
> +    case MSR_MTRRfix4K_D8000:
> +    case MSR_MTRRfix4K_E0000:
> +    case MSR_MTRRfix4K_E8000:
> +    case MSR_MTRRfix4K_F0000:
> +    case MSR_MTRRfix4K_F8000:
> +        env->mtrr_fixed[(uint32_t)env->regs[R_ECX] -
> +                        MSR_MTRRfix4K_C0000 + 3] = val;
> +        break;
> +    case MSR_MTRRdefType:
> +        env->mtrr_deftype = val;
> +        break;
> +    case MSR_MCG_STATUS:
> +        env->mcg_status = val;
> +        break;
> +    case MSR_MCG_CTL:
> +        if ((env->mcg_cap & MCG_CTL_P)
> +            && (val == 0 || val == ~(uint64_t)0)) {
> +            env->mcg_ctl = val;
> +        }
> +        break;
> +    case MSR_TSC_AUX:
> +        env->tsc_aux = val;
> +        break;
> +    case MSR_IA32_MISC_ENABLE:
> +        env->msr_ia32_misc_enable = val;
> +        break;
> +    case MSR_IA32_BNDCFGS:
> +        /* FIXME: #GP if reserved bits are set.  */
> +        /* FIXME: Extend highest implemented bit of linear address.  */
> +        env->msr_bndcfgs = val;
> +        cpu_sync_bndcs_hflags(env);
> +        break;
> +    default:
> +        if ((uint32_t)env->regs[R_ECX] >= MSR_MC0_CTL
> +            && (uint32_t)env->regs[R_ECX] < MSR_MC0_CTL +
> +            (4 * env->mcg_cap & 0xff)) {
> +            uint32_t offset = (uint32_t)env->regs[R_ECX] - MSR_MC0_CTL;
> +            if ((offset & 0x3) != 0
> +                || (val == 0 || val == ~(uint64_t)0)) {
> +                env->mce_banks[offset] = val;
> +            }
> +            break;
> +        }
> +        /* XXX: exception? */
> +        break;
> +    }
> +
> +    pd->m64.ReturnStatus = STATUS_SUCCESS;
> +}
> +

It looks like you copied most of this code from helper_rdmsr() and
helper_wrmsr(). That's a bunch of duplicated non-trivial logic. Any
chance it could be de-duped by having one call the other or
introducing common helper functions?

>  bool windbg_on_load(void)
>  {
>      CPUState *cpu = qemu_get_cpu(0);
> diff --git a/windbgstub.c b/windbgstub.c
> index ddca290694..0268d0818e 100755
> --- a/windbgstub.c
> +++ b/windbgstub.c
> @@ -197,6 +197,14 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
>          kd_api_write_physical_memory(cpu, &ctx->data);
>          break;
>
> +    case DbgKdReadMachineSpecificRegister:
> +        kd_api_read_msr(cpu, &ctx->data);
> +        break;
> +
> +    case DbgKdWriteMachineSpecificRegister:
> +        kd_api_write_msr(cpu, &ctx->data);
> +        break;
> +
>      case DbgKdGetVersionApi:
>          kd_api_get_version(cpu, &ctx->data);
>          break;
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 41/45] windbg: implemented kd_api_search_memory
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 41/45] windbg: implemented kd_api_search_memory Mihail Abakumov
@ 2017-11-29  7:55   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-29  7:55 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:11 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgstub-utils.h |    1 +
>  windbgstub-utils.c              |   33 +++++++++++++++++++++++++++++++++
>  windbgstub.c                    |    4 ++++
>  3 files changed, 38 insertions(+)
>
> diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
> index 73d49b774d..c2eb8a75a7 100755
> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -102,6 +102,7 @@ void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
>  void kd_api_get_version(CPUState *cpu, PacketData *pd);
>  void kd_api_read_msr(CPUState *cpu, PacketData *pd);
>  void kd_api_write_msr(CPUState *cpu, PacketData *pd);
> +void kd_api_search_memory(CPUState *cpu, PacketData *pd);
>  void kd_api_unsupported(CPUState *cpu, PacketData *pd);
>
>  SizedBuf kd_gen_exception_sc(CPUState *cpu);
> diff --git a/windbgstub-utils.c b/windbgstub-utils.c
> index 7ef301bac7..1f4590f338 100755
> --- a/windbgstub-utils.c
> +++ b/windbgstub-utils.c
> @@ -261,6 +261,39 @@ void kd_api_get_version(CPUState *cpu, PacketData *pd)
>      }
>  }
>
> +void kd_api_search_memory(CPUState *cpu, PacketData *pd)
> +{
> +    DBGKD_SEARCH_MEMORY *m64c = &pd->m64.u.SearchMemory;
> +    int s_len = MAX(ldq_p(&m64c->SearchLength), 1);
> +    int p_len = MIN(ldl_p(&m64c->PatternLength), pd->extra_size);
> +    target_ulong addr = ldq_p(&m64c->SearchAddress);
> +    int size = MIN(s_len, 10);
> +    uint8_t mem[size + p_len];

Is this allocation bounded by a reasonably small number? What's the
maximum PatternLength?

> +    int i, err;
> +
> +    pd->extra_size = 0;
> +    pd->m64.ReturnStatus = STATUS_NO_MORE_ENTRIES;
> +
> +    while (s_len) {
> +        err = cpu_memory_rw_debug(cpu, addr, mem, size + p_len, 0);
> +        if (!err) {
> +            for (i = 0; i < size; ++i) {
> +                if (memcmp(mem + i, pd->extra, p_len) == 0) {
> +                    stl_p(&m64c->FoundAddress, addr + i);
> +                    pd->m64.ReturnStatus = STATUS_SUCCESS;
> +                    return;
> +                }
> +            }
> +        } else {
> +            WINDBG_DEBUG("search_memory: No physical page mapped: " FMT_ADDR,
> +                         addr);
> +        }
> +        s_len -= size;
> +        addr += size;
> +        size = MIN(s_len, 10);
> +    }
> +}
> +

Too bad that you can't use memmem(). This implementation screams
O(N^2) to me. One of the things that can be improved later I guess.

I would at least up the step from 10 to 1024 so we don't call
cpu_memory_rw_debug() that often.

>  void kd_api_unsupported(CPUState *cpu, PacketData *pd)
>  {
>      WINDBG_ERROR("Caught unimplemented api %s",
> diff --git a/windbgstub.c b/windbgstub.c
> index 0268d0818e..d35ff6ba96 100755
> --- a/windbgstub.c
> +++ b/windbgstub.c
> @@ -212,6 +212,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
>      case DbgKdClearAllInternalBreakpointsApi:
>          return;
>
> +    case DbgKdSearchMemoryApi:
> +        kd_api_search_memory(cpu, &ctx->data);
> +        break;
> +
>      default:
>          kd_api_unsupported(cpu, &ctx->data);
>          break;
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 43/45] windbg: implemented kd_api_query_memory
  2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 43/45] windbg: implemented kd_api_query_memory Mihail Abakumov
@ 2017-11-29  8:03   ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-11-29  8:03 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:11 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgstub-utils.h |    1 +
>  windbgstub-utils.c              |   12 ++++++++++++
>  windbgstub.c                    |    4 ++++
>  3 files changed, 17 insertions(+)
>
> diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
> index e144294b51..fa1ebbb6d2 100755
> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -105,6 +105,7 @@ void kd_api_write_msr(CPUState *cpu, PacketData *pd);
>  void kd_api_search_memory(CPUState *cpu, PacketData *pd);
>  void kd_api_fill_memory(CPUState *cpu, PacketData *pd);
>  void kd_api_unsupported(CPUState *cpu, PacketData *pd);
> +void kd_api_query_memory(CPUState *cpu, PacketData *pd);
>
>  SizedBuf kd_gen_exception_sc(CPUState *cpu);
>  SizedBuf kd_gen_load_symbols_sc(CPUState *cpu);
> diff --git a/windbgstub-utils.c b/windbgstub-utils.c
> index fb2c378460..edd23c1971 100755
> --- a/windbgstub-utils.c
> +++ b/windbgstub-utils.c
> @@ -333,6 +333,18 @@ void kd_api_fill_memory(CPUState *cpu, PacketData *pd)
>      }
>  }
>
> +void kd_api_query_memory(CPUState *cpu, PacketData *pd)
> +{
> +    DBGKD_QUERY_MEMORY *mem = &pd->m64.u.QueryMemory;
> +
> +    mem->AddressSpace = DBGKD_QUERY_MEMORY_PROCESS;
> +    mem->Flags = DBGKD_QUERY_MEMORY_READ |
> +                 DBGKD_QUERY_MEMORY_WRITE |
> +                 DBGKD_QUERY_MEMORY_EXECUTE;
> +    mem->AddressSpace = ldl_p(&mem->AddressSpace);
> +    mem->Flags = ldl_p(&mem->Flags);

This should be:

void kd_api_query_memory(CPUState *cpu, PacketData *pd)
{
    DBGKD_QUERY_MEMORY *mem = &pd->m64.u.QueryMemory;

    stl_p(&mem->AddressSpace, DBGKD_QUERY_MEMORY_PROCESS);
    stl_p(&mem->Flags, DBGKD_QUERY_MEMORY_READ |
                 DBGKD_QUERY_MEMORY_WRITE |
                 DBGKD_QUERY_MEMORY_EXECUTE);

> +}
> +
>  void kd_api_unsupported(CPUState *cpu, PacketData *pd)
>  {
>      WINDBG_ERROR("Caught unimplemented api %s",
> diff --git a/windbgstub.c b/windbgstub.c
> index b348028dfd..36372c0ea5 100755
> --- a/windbgstub.c
> +++ b/windbgstub.c
> @@ -220,6 +220,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
>          kd_api_fill_memory(cpu, &ctx->data);
>          break;
>
> +    case DbgKdQueryMemoryApi:
> +        kd_api_query_memory(cpu, &ctx->data);
> +        break;
> +
>      default:
>          kd_api_unsupported(cpu, &ctx->data);
>          break;
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version
  2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version Mihail Abakumov
@ 2017-11-29  8:14   ` Ladi Prosek
  2017-12-06  9:00     ` Mihail Abakumov
  0 siblings, 1 reply; 70+ messages in thread
From: Ladi Prosek @ 2017-11-29  8:14 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:10 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
> ---
>  include/exec/windbgstub-utils.h |    1 +
>  windbgstub-utils.c              |   22 ++++++++++++++++++++++
>  windbgstub.c                    |    4 ++++
>  3 files changed, 27 insertions(+)
>
> diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
> index be48f69f40..bc5b6a8468 100755
> --- a/include/exec/windbgstub-utils.h
> +++ b/include/exec/windbgstub-utils.h
> @@ -99,6 +99,7 @@ void kd_api_read_io_space(CPUState *cpu, PacketData *pd);
>  void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
>  void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd);
>  void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
> +void kd_api_get_version(CPUState *cpu, PacketData *pd);
>  void kd_api_unsupported(CPUState *cpu, PacketData *pd);
>
>  SizedBuf kd_gen_exception_sc(CPUState *cpu);
> diff --git a/windbgstub-utils.c b/windbgstub-utils.c
> index 6708e62798..7ef301bac7 100755
> --- a/windbgstub-utils.c
> +++ b/windbgstub-utils.c
> @@ -239,6 +239,28 @@ void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd)
>      stl_p(&mem->ActualBytesWritten, len);
>  }
>
> +void kd_api_get_version(CPUState *cpu, PacketData *pd)
> +{
> +    DBGKD_GET_VERSION64 *kdver;
> +    int err = cpu_memory_rw_debug(cpu, version.addr, PTR(pd->m64) + 0x10,
> +                                  sizeof(DBGKD_MANIPULATE_STATE64) - 0x10, 0);
> +    if (!err) {
> +        kdver = (DBGKD_GET_VERSION64 *) (PTR(pd->m64) + 0x10);
> +
> +        stw_p(&kdver->MajorVersion, kdver->MajorVersion);
> +        stw_p(&kdver->MinorVersion, kdver->MinorVersion);
> +        stw_p(&kdver->Flags, kdver->Flags);
> +        stw_p(&kdver->MachineType, kdver->MachineType);
> +        stw_p(&kdver->Unused[0], kdver->Unused[0]);
> +        sttul_p(&kdver->KernBase, kdver->KernBase);
> +        sttul_p(&kdver->PsLoadedModuleList, kdver->PsLoadedModuleList);
> +        sttul_p(&kdver->DebuggerDataList, kdver->DebuggerDataList);
> +    } else {
> +        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;

The ReturnStatus field must be written using st* as well. You have
this direct write in many functions.

> +        WINDBG_ERROR("get_version: " FMT_ERR, err);
> +    }
> +}
> +
>  void kd_api_unsupported(CPUState *cpu, PacketData *pd)
>  {
>      WINDBG_ERROR("Caught unimplemented api %s",
> diff --git a/windbgstub.c b/windbgstub.c
> index 72324ae53d..ddca290694 100755
> --- a/windbgstub.c
> +++ b/windbgstub.c
> @@ -197,6 +197,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx)
>          kd_api_write_physical_memory(cpu, &ctx->data);
>          break;
>
> +    case DbgKdGetVersionApi:
> +        kd_api_get_version(cpu, &ctx->data);
> +        break;
> +
>      case DbgKdClearAllInternalBreakpointsApi:
>          return;
>
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 00/45] Windbg supporting
  2017-11-21 16:23 ` no-reply
@ 2017-11-29  8:23   ` Ladi Prosek
  2017-12-06  9:14     ` Mihail Abakumov
  0 siblings, 1 reply; 70+ messages in thread
From: Ladi Prosek @ 2017-11-29  8:23 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Tue, Nov 21, 2017 at 3:07 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> An update of:
>
>         v1: https://lists.nongnu.org/archive/html/qemu-devel/2017-09/msg07092.html
>
> We made the debugger module WinDbg (like GDB) for QEMU. This is the replacement of the remote stub in Windows kernel. Used for remote Windows kernel debugging without debugging mode.
>
> WinDbg is a multipurpose debugger for the Microsoft Windows computer operating system, distributed by Microsoft. Recent versions of WinDbg have been and are being distributed as part of the free Debugging Tools for Windows suite.
>
> How to start debugging QEMU using WinDbg:
>   Run QEMU with next option:
>     -windbg pipe:<name>
>   QEMU will start and pause for waiting WinDbg connection.
>   Run WinDbg with next options:
>     -b -k com:pipe,baud=115200,port=\\.\pipe\<name>,resets=0
>   Wait for debugger connect to kernel.
>
> Note: You can add Symbol Search Path in WinDbg such as srv*c:\tmp*http://msdl.microsoft.com/download/symbols.
>
> How it works:
> The WinDbg debugger has the possibility of connecting to a remote debug service (Kdsrv.exe) in the Windows kernel. Therefore, it is possible to connect to the guest system running in the QEMU emulator. Kernel debugging is possible only with the enabled debugging mode, may change at the same time. Our module of WinDbg debugger for QEMU is an alternative of the remote debugging service in the kernel. Thus, the debugger connects to the debugging module, not to the kernel of the operating system. The module obtains all the necessary information answering debugger requests from the QEMU emulator. At the same time for debugging there is no need to enable debugging mode in the kernel. This leads to hidden debugging. Our module supports all features of WinDbg regarding remote debugging, besides interception of events and exceptions. Only i386 is supported now.
>
> Changed in v3:
>
>  - Add a support of the new api functions from the WinDbg v10.
>
> Changed in v2:
>
>  - Move target specific code in the 'target/' directory. (Alistair Francis)
>  - Change 'kd_api_fill_memory'. Made a fill of memory by line segments. Before that, a full array was immediately collected and written in RAM. (Ladi Prosek)
>  - Change 'kd_api_search_memory'. Made a search for memory by line segments. (Ladi Prosek)
>  - Change ld* to st* where it needs. (Ladi Prosek)
>  - Add a additional check of input arguments in 'windbg_read_context' and 'windbg_read_ks_regs'. (Ladi Prosek)
>  - Fix typos. (Ladi Prosek)
>  - Add a fliping back 'windbg_state->is_loaded' after reset VM.
>  - Add a check to disabled kvm. It is supported yet. (Ladi Prosek)
>  - Add a check to device in windbg option. Only pipe is supporting now. (Alistair Francis)
>  - Add a check to 'ifdef' WINDBG_DEBUG_ON before define it. (Alistair Francis)
>  - Replace printf to qemu_log. (Alistair Francis)
>  - Fix build on s390x host. (patchew)
>  - Fix code style error. (patchew)


Thanks, v3 is working with a Win10 windbg for me!

A few things I noticed during my testing (Win7 32-bit guest):

* Windbg prints:

  ReadVirtual: 827403d0 not properly sign extended

after connecting. That's likely a bug hiding somewhere.

* lm prints only nt and a bunch of unloaded crash dump modules. This
doesn't look expected and blocks what I believe is the most common way
of initiating debugging which is setting a breakpoint on a specific
driver function. Additionally, after rebooting the guest, lm prints
only nt, nothing else. Do you see the same thing?

  kd> lm
  start    end        module name
  8260b000 82a1d000   nt         (pdb symbols)          C:\Program
Files (x86)\Windows
Kits\10\Debuggers\x64\sym\ntkrpamp.pdb\684DA42A30CC450F81C535B4D18944B12\ntkrpamp.pdb

  Unloaded modules:
  869da000 869e7000   crashdmp.sys
  869e7000 869f2000   dump_ataport.sys
  869f2000 869fb000   dump_atapi.sys
  86800000 86811000   dump_dumpfve.sys

* It seems to work on a Linux host as well! Still ok to keep it
limited to pipe: for now, especially if you don't test on Linux.

* Wondering about the legal aspects of copying code from winnt.h. I'll
let others confirm that it's ok.

I have replied to some of the patches with comments.

Thank you!
Ladi

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 45/45] windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex
  2017-11-28 12:44   ` Ladi Prosek
@ 2017-12-05 11:28     ` Mihail Abakumov
  0 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-12-05 11:28 UTC (permalink / raw)
  To: Ladi Prosek
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

Ladi Prosek писал 2017-11-28 15:44:
> On Tue, Nov 21, 2017 at 3:11 PM, Mihail Abakumov
> <mikhail.abakumov@ispras.ru> wrote:
> [...]
>> diff --git a/windbgstub.c b/windbgstub.c
>> index 36372c0ea5..3bcf6a8cbb 100755
>> --- a/windbgstub.c
>> +++ b/windbgstub.c
>> @@ -224,6 +224,14 @@ static void 
>> windbg_process_manipulate_packet(ParsingContext *ctx)
>>          kd_api_query_memory(cpu, &ctx->data);
>>          break;
>> 
>> +    case DbgKdGetContextExApi:
>> +        kd_api_get_context_ex(cpu, &ctx->data);
>> +        break;
>> +
>> +    case DbgKdSetContextExApi:
>> +        kd_api_set_context_ex(cpu, &ctx->data);
>> +        break;
>> +
>>      default:
>>          kd_api_unsupported(cpu, &ctx->data);
>>          break;
>> @@ -262,12 +270,12 @@ static void 
>> windbg_process_control_packet(ParsingContext *ctx)
>> 
>>      case PACKET_TYPE_KD_RESET:
>>      {
>> -        SizedBuf buf = kd_gen_load_symbols_sc(qemu_get_cpu(0));
>> +        windbg_send_control_packet(ctx->packet.PacketType);
>> +        windbg_state->ctrl_packet_id = INITIAL_PACKET_ID;
> 
> You didn't mention it in the cover email so I'd like to be sure. This
> is what fixed the initial handshake so it works without -b now, is
> that correct? Thanks!
> 
Yes. It seems for me more logical to send a response first, then a state 
packet.
Apparently, before that I made a typo. Now Windbg connects immediately, 
and
for stopping it is necessary to press ctrl+break. But now the option 
'-b' does
not work in the old version.

>> +        SizedBuf buf = kd_gen_load_symbols_sc(qemu_get_cpu(0));
>>          windbg_send_data_packet(buf.data, buf.size,
>>                                  PACKET_TYPE_KD_STATE_CHANGE64);
>> -        windbg_send_control_packet(ctx->packet.PacketType);
>> -        windbg_state->ctrl_packet_id = INITIAL_PACKET_ID;
>>          SBUF_FREE(buf);
>>          break;
>>      }
>> 

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing
  2017-11-29  7:13   ` Ladi Prosek
@ 2017-12-06  7:29     ` Mihail Abakumov
  2017-12-06  9:23       ` Ladi Prosek
  0 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-12-06  7:29 UTC (permalink / raw)
  To: Ladi Prosek
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

Ladi Prosek писал 2017-11-29 10:13:
> On Tue, Nov 21, 2017 at 3:10 PM, Mihail Abakumov
> <mikhail.abakumov@ispras.ru> wrote:
>> Added handler registration of gdb debug exception. Its exception also 
>> can be used for windbg.
>> 
>> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
>> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
>> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
>> ---
>>  cpus.c                  |   18 +++++++++++++++++-
>>  gdbstub.c               |    4 ++++
>>  include/sysemu/sysemu.h |    2 ++
>>  windbgstub.c            |   16 ++++++++++++----
>>  4 files changed, 35 insertions(+), 5 deletions(-)
>> 
>> diff --git a/cpus.c b/cpus.c
>> index 9bed61eefc..212553b7e3 100644
>> --- a/cpus.c
>> +++ b/cpus.c
>> @@ -77,6 +77,8 @@ int64_t max_advance;
>>  static QEMUTimer *throttle_timer;
>>  static unsigned int throttle_percentage;
>> 
>> +static void (*excp_debug_handler)(CPUState *cpu);
>> +
>>  #define CPU_THROTTLE_PCT_MIN 1
>>  #define CPU_THROTTLE_PCT_MAX 99
>>  #define CPU_THROTTLE_TIMESLICE_NS 10000000
>> @@ -960,9 +962,23 @@ static bool cpu_can_run(CPUState *cpu)
>>      return true;
>>  }
>> 
>> +bool register_excp_debug_handler(void (*handler)(CPUState *cpu))
>> +{
>> +    if (excp_debug_handler == NULL) {
>> +        excp_debug_handler = handler;
>> +        return true;
>> +    } else {
>> +        error_report("ERROR: Something debugger already using");
> 
> So I take it that -windbg and -gdb cannot be used at the same time.
> Should it be handled in a more explicit way with a more user-friendly
> error?
> 
> Right now I get this error, which is more like an implementation
> detail (could the debug handler be refactored into a multicast event
> in the future?) and does not even make sense as a sentence.

Yes. I have added a more user-friendly error. "Something debugger is
already in use. '-gdb' and '-windbg' cannot be used at the same time".
Or what do you mean under the explicit way? How to do it better?

> 
>> +        return false;
>> +    }
>> +}
>> +
>>  static void cpu_handle_guest_debug(CPUState *cpu)
>>  {
>> -    gdb_set_stop_cpu(cpu);
>> +    if (excp_debug_handler != NULL) {
>> +        excp_debug_handler(cpu);
>> +    }
>> +
>>      qemu_system_debug_request();
>>      cpu->stopped = true;
>>  }
>> diff --git a/gdbstub.c b/gdbstub.c
>> index 2a94030d3b..8c76f54117 100644
>> --- a/gdbstub.c
>> +++ b/gdbstub.c
>> @@ -2006,6 +2006,10 @@ int gdbserver_start(const char *device)
>>      s->mon_chr = mon_chr;
>>      s->current_syscall_cb = NULL;
>> 
>> +    if (!register_excp_debug_handler(gdb_set_stop_cpu)) {
>> +        exit(1);
>> +    }
>> +
>>      return 0;
>>  }
>> 
>> diff --git a/include/sysemu/sysemu.h b/include/sysemu/sysemu.h
>> index b21369672a..34588c99b4 100644
>> --- a/include/sysemu/sysemu.h
>> +++ b/include/sysemu/sysemu.h
>> @@ -193,6 +193,8 @@ QemuOpts *qemu_get_machine_opts(void);
>> 
>>  bool defaults_enabled(void);
>> 
>> +bool register_excp_debug_handler(void (*handler)(CPUState *cpu));
>> +
>>  extern QemuOptsList qemu_legacy_drive_opts;
>>  extern QemuOptsList qemu_common_drive_opts;
>>  extern QemuOptsList qemu_drive_opts;
>> diff --git a/windbgstub.c b/windbgstub.c
>> index 489abe6d6c..b33f412659 100755
>> --- a/windbgstub.c
>> +++ b/windbgstub.c
>> @@ -115,16 +115,20 @@ static void windbg_send_control_packet(uint16_t 
>> type)
>>      windbg_state->ctrl_packet_id ^= 1;
>>  }
>> 
>> -static void windbg_vm_stop(void)
>> +static void windbg_bp_handler(CPUState *cpu)
>>  {
>> -    CPUState *cpu = qemu_get_cpu(0);
>> -    vm_stop(RUN_STATE_PAUSED);
>> -
>>      SizedBuf buf = kd_gen_exception_sc(cpu);
>>      windbg_send_data_packet(buf.data, buf.size, 
>> PACKET_TYPE_KD_STATE_CHANGE64);
>>      SBUF_FREE(buf);
>>  }
>> 
>> +static void windbg_vm_stop(void)
>> +{
>> +    CPUState *cpu = qemu_get_cpu(0);
>> +    vm_stop(RUN_STATE_PAUSED);
>> +    windbg_bp_handler(cpu);
>> +}
>> +
>>  static void windbg_process_manipulate_packet(ParsingContext *ctx)
>>  {
>>      CPUState *cpu;
>> @@ -432,6 +436,10 @@ int windbg_server_start(const char *device)
>> 
>>      qemu_register_reset(windbg_handle_reset, NULL);
>> 
>> +    if (!register_excp_debug_handler(windbg_bp_handler)) {
>> +        exit(1);
>> +    }
>> +
>>      atexit(windbg_exit);
>>      return 0;
>>  }
>> 

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version
  2017-11-29  8:14   ` Ladi Prosek
@ 2017-12-06  9:00     ` Mihail Abakumov
  2017-12-06  9:37       ` Ladi Prosek
  0 siblings, 1 reply; 70+ messages in thread
From: Mihail Abakumov @ 2017-12-06  9:00 UTC (permalink / raw)
  To: Ladi Prosek
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

Ladi Prosek писал 2017-11-29 11:14:
> On Tue, Nov 21, 2017 at 3:10 PM, Mihail Abakumov
> <mikhail.abakumov@ispras.ru> wrote:
>> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
>> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
>> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
>> ---
>>  include/exec/windbgstub-utils.h |    1 +
>>  windbgstub-utils.c              |   22 ++++++++++++++++++++++
>>  windbgstub.c                    |    4 ++++
>>  3 files changed, 27 insertions(+)
>> 
>> diff --git a/include/exec/windbgstub-utils.h 
>> b/include/exec/windbgstub-utils.h
>> index be48f69f40..bc5b6a8468 100755
>> --- a/include/exec/windbgstub-utils.h
>> +++ b/include/exec/windbgstub-utils.h
>> @@ -99,6 +99,7 @@ void kd_api_read_io_space(CPUState *cpu, PacketData 
>> *pd);
>>  void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
>>  void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd);
>>  void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
>> +void kd_api_get_version(CPUState *cpu, PacketData *pd);
>>  void kd_api_unsupported(CPUState *cpu, PacketData *pd);
>> 
>>  SizedBuf kd_gen_exception_sc(CPUState *cpu);
>> diff --git a/windbgstub-utils.c b/windbgstub-utils.c
>> index 6708e62798..7ef301bac7 100755
>> --- a/windbgstub-utils.c
>> +++ b/windbgstub-utils.c
>> @@ -239,6 +239,28 @@ void kd_api_write_physical_memory(CPUState *cpu, 
>> PacketData *pd)
>>      stl_p(&mem->ActualBytesWritten, len);
>>  }
>> 
>> +void kd_api_get_version(CPUState *cpu, PacketData *pd)
>> +{
>> +    DBGKD_GET_VERSION64 *kdver;
>> +    int err = cpu_memory_rw_debug(cpu, version.addr, PTR(pd->m64) + 
>> 0x10,
>> +                                  sizeof(DBGKD_MANIPULATE_STATE64) - 
>> 0x10, 0);
>> +    if (!err) {
>> +        kdver = (DBGKD_GET_VERSION64 *) (PTR(pd->m64) + 0x10);
>> +
>> +        stw_p(&kdver->MajorVersion, kdver->MajorVersion);
>> +        stw_p(&kdver->MinorVersion, kdver->MinorVersion);
>> +        stw_p(&kdver->Flags, kdver->Flags);
>> +        stw_p(&kdver->MachineType, kdver->MachineType);
>> +        stw_p(&kdver->Unused[0], kdver->Unused[0]);
>> +        sttul_p(&kdver->KernBase, kdver->KernBase);
>> +        sttul_p(&kdver->PsLoadedModuleList, 
>> kdver->PsLoadedModuleList);
>> +        sttul_p(&kdver->DebuggerDataList, kdver->DebuggerDataList);
>> +    } else {
>> +        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
> 
> The ReturnStatus field must be written using st* as well. You have
> this direct write in many functions.
> 

I'm doing stl_p for status before sending of packet in the 
'windbg_process_manipulate_packet',
because this is a global field of structure. Is that bad?

>> +        WINDBG_ERROR("get_version: " FMT_ERR, err);
>> +    }
>> +}
>> +
>>  void kd_api_unsupported(CPUState *cpu, PacketData *pd)
>>  {
>>      WINDBG_ERROR("Caught unimplemented api %s",
>> diff --git a/windbgstub.c b/windbgstub.c
>> index 72324ae53d..ddca290694 100755
>> --- a/windbgstub.c
>> +++ b/windbgstub.c
>> @@ -197,6 +197,10 @@ static void 
>> windbg_process_manipulate_packet(ParsingContext *ctx)
>>          kd_api_write_physical_memory(cpu, &ctx->data);
>>          break;
>> 
>> +    case DbgKdGetVersionApi:
>> +        kd_api_get_version(cpu, &ctx->data);
>> +        break;
>> +
>>      case DbgKdClearAllInternalBreakpointsApi:
>>          return;
>> 
>> 

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 00/45] Windbg supporting
  2017-11-29  8:23   ` Ladi Prosek
@ 2017-12-06  9:14     ` Mihail Abakumov
  0 siblings, 0 replies; 70+ messages in thread
From: Mihail Abakumov @ 2017-12-06  9:14 UTC (permalink / raw)
  To: Ladi Prosek
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

Ladi Prosek писал 2017-11-29 11:23:
> On Tue, Nov 21, 2017 at 3:07 PM, Mihail Abakumov
> <mikhail.abakumov@ispras.ru> wrote:
>> An update of:
>> 
>>         v1: 
>> https://lists.nongnu.org/archive/html/qemu-devel/2017-09/msg07092.html
>> 
>> We made the debugger module WinDbg (like GDB) for QEMU. This is the 
>> replacement of the remote stub in Windows kernel. Used for remote 
>> Windows kernel debugging without debugging mode.
>> 
>> WinDbg is a multipurpose debugger for the Microsoft Windows computer 
>> operating system, distributed by Microsoft. Recent versions of WinDbg 
>> have been and are being distributed as part of the free Debugging 
>> Tools for Windows suite.
>> 
>> How to start debugging QEMU using WinDbg:
>>   Run QEMU with next option:
>>     -windbg pipe:<name>
>>   QEMU will start and pause for waiting WinDbg connection.
>>   Run WinDbg with next options:
>>     -b -k com:pipe,baud=115200,port=\\.\pipe\<name>,resets=0
>>   Wait for debugger connect to kernel.
>> 
>> Note: You can add Symbol Search Path in WinDbg such as 
>> srv*c:\tmp*http://msdl.microsoft.com/download/symbols.
>> 
>> How it works:
>> The WinDbg debugger has the possibility of connecting to a remote 
>> debug service (Kdsrv.exe) in the Windows kernel. Therefore, it is 
>> possible to connect to the guest system running in the QEMU emulator. 
>> Kernel debugging is possible only with the enabled debugging mode, may 
>> change at the same time. Our module of WinDbg debugger for QEMU is an 
>> alternative of the remote debugging service in the kernel. Thus, the 
>> debugger connects to the debugging module, not to the kernel of the 
>> operating system. The module obtains all the necessary information 
>> answering debugger requests from the QEMU emulator. At the same time 
>> for debugging there is no need to enable debugging mode in the kernel. 
>> This leads to hidden debugging. Our module supports all features of 
>> WinDbg regarding remote debugging, besides interception of events and 
>> exceptions. Only i386 is supported now.
>> 
>> Changed in v3:
>> 
>>  - Add a support of the new api functions from the WinDbg v10.
>> 
>> Changed in v2:
>> 
>>  - Move target specific code in the 'target/' directory. (Alistair 
>> Francis)
>>  - Change 'kd_api_fill_memory'. Made a fill of memory by line 
>> segments. Before that, a full array was immediately collected and 
>> written in RAM. (Ladi Prosek)
>>  - Change 'kd_api_search_memory'. Made a search for memory by line 
>> segments. (Ladi Prosek)
>>  - Change ld* to st* where it needs. (Ladi Prosek)
>>  - Add a additional check of input arguments in 'windbg_read_context' 
>> and 'windbg_read_ks_regs'. (Ladi Prosek)
>>  - Fix typos. (Ladi Prosek)
>>  - Add a fliping back 'windbg_state->is_loaded' after reset VM.
>>  - Add a check to disabled kvm. It is supported yet. (Ladi Prosek)
>>  - Add a check to device in windbg option. Only pipe is supporting 
>> now. (Alistair Francis)
>>  - Add a check to 'ifdef' WINDBG_DEBUG_ON before define it. (Alistair 
>> Francis)
>>  - Replace printf to qemu_log. (Alistair Francis)
>>  - Fix build on s390x host. (patchew)
>>  - Fix code style error. (patchew)
> 
> 
> Thanks, v3 is working with a Win10 windbg for me!
> 
> A few things I noticed during my testing (Win7 32-bit guest):
> 
> * Windbg prints:
> 
>   ReadVirtual: 827403d0 not properly sign extended
> 
> after connecting. That's likely a bug hiding somewhere.
> 

This is due to the fact that the cpu_memory_rw_debug function cannot
return the required memory region. No physical page mapped.

> * lm prints only nt and a bunch of unloaded crash dump modules. This
> doesn't look expected and blocks what I believe is the most common way
> of initiating debugging which is setting a breakpoint on a specific
> driver function. Additionally, after rebooting the guest, lm prints
> only nt, nothing else. Do you see the same thing?

Yes, the same.

> 
>   kd> lm
>   start    end        module name
>   8260b000 82a1d000   nt         (pdb symbols)          C:\Program
> Files (x86)\Windows
> Kits\10\Debuggers\x64\sym\ntkrpamp.pdb\684DA42A30CC450F81C535B4D18944B12\ntkrpamp.pdb
> 
>   Unloaded modules:
>   869da000 869e7000   crashdmp.sys
>   869e7000 869f2000   dump_ataport.sys
>   869f2000 869fb000   dump_atapi.sys
>   86800000 86811000   dump_dumpfve.sys
> 
> * It seems to work on a Linux host as well! Still ok to keep it
> limited to pipe: for now, especially if you don't test on Linux.
> 
> * Wondering about the legal aspects of copying code from winnt.h. I'll
> let others confirm that it's ok.
> 
> I have replied to some of the patches with comments.
> 
> Thank you!
> Ladi

-- 
Thanks,
Mihail

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing
  2017-12-06  7:29     ` Mihail Abakumov
@ 2017-12-06  9:23       ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-12-06  9:23 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Wed, Dec 6, 2017 at 8:29 AM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Ladi Prosek писал 2017-11-29 10:13:
>
>> On Tue, Nov 21, 2017 at 3:10 PM, Mihail Abakumov
>> <mikhail.abakumov@ispras.ru> wrote:
>>>
>>> Added handler registration of gdb debug exception. Its exception also can
>>> be used for windbg.
>>>
>>> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
>>> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
>>> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
>>> ---
>>>  cpus.c                  |   18 +++++++++++++++++-
>>>  gdbstub.c               |    4 ++++
>>>  include/sysemu/sysemu.h |    2 ++
>>>  windbgstub.c            |   16 ++++++++++++----
>>>  4 files changed, 35 insertions(+), 5 deletions(-)
>>>
>>> diff --git a/cpus.c b/cpus.c
>>> index 9bed61eefc..212553b7e3 100644
>>> --- a/cpus.c
>>> +++ b/cpus.c
>>> @@ -77,6 +77,8 @@ int64_t max_advance;
>>>  static QEMUTimer *throttle_timer;
>>>  static unsigned int throttle_percentage;
>>>
>>> +static void (*excp_debug_handler)(CPUState *cpu);
>>> +
>>>  #define CPU_THROTTLE_PCT_MIN 1
>>>  #define CPU_THROTTLE_PCT_MAX 99
>>>  #define CPU_THROTTLE_TIMESLICE_NS 10000000
>>> @@ -960,9 +962,23 @@ static bool cpu_can_run(CPUState *cpu)
>>>      return true;
>>>  }
>>>
>>> +bool register_excp_debug_handler(void (*handler)(CPUState *cpu))
>>> +{
>>> +    if (excp_debug_handler == NULL) {
>>> +        excp_debug_handler = handler;
>>> +        return true;
>>> +    } else {
>>> +        error_report("ERROR: Something debugger already using");
>>
>>
>> So I take it that -windbg and -gdb cannot be used at the same time.
>> Should it be handled in a more explicit way with a more user-friendly
>> error?
>>
>> Right now I get this error, which is more like an implementation
>> detail (could the debug handler be refactored into a multicast event
>> in the future?) and does not even make sense as a sentence.
>
>
> Yes. I have added a more user-friendly error. "Something debugger is
> already in use. '-gdb' and '-windbg' cannot be used at the same time".
> Or what do you mean under the explicit way? How to do it better?

Yes, "'-gdb' and '-windbg' cannot be used at the same time" would be
nicer. By being more explicit I mean issuing the error from the code
that parses the options.

In other words, I can imagine an implementation of
register_excp_debug_handler() that allows registering multiple
handlers. But running windbg and gdb at the same would probably still
not be a good idea.

Maybe I'm nit-picking and it's ok for the error to stay here.
Wondering what other reviewers think.

>>
>>> +        return false;
>>> +    }
>>> +}
>>> +
>>>  static void cpu_handle_guest_debug(CPUState *cpu)
>>>  {
>>> -    gdb_set_stop_cpu(cpu);
>>> +    if (excp_debug_handler != NULL) {
>>> +        excp_debug_handler(cpu);
>>> +    }
>>> +
>>>      qemu_system_debug_request();
>>>      cpu->stopped = true;
>>>  }
>>> diff --git a/gdbstub.c b/gdbstub.c
>>> index 2a94030d3b..8c76f54117 100644
>>> --- a/gdbstub.c
>>> +++ b/gdbstub.c
>>> @@ -2006,6 +2006,10 @@ int gdbserver_start(const char *device)
>>>      s->mon_chr = mon_chr;
>>>      s->current_syscall_cb = NULL;
>>>
>>> +    if (!register_excp_debug_handler(gdb_set_stop_cpu)) {
>>> +        exit(1);
>>> +    }
>>> +
>>>      return 0;
>>>  }
>>>
>>> diff --git a/include/sysemu/sysemu.h b/include/sysemu/sysemu.h
>>> index b21369672a..34588c99b4 100644
>>> --- a/include/sysemu/sysemu.h
>>> +++ b/include/sysemu/sysemu.h
>>> @@ -193,6 +193,8 @@ QemuOpts *qemu_get_machine_opts(void);
>>>
>>>  bool defaults_enabled(void);
>>>
>>> +bool register_excp_debug_handler(void (*handler)(CPUState *cpu));
>>> +
>>>  extern QemuOptsList qemu_legacy_drive_opts;
>>>  extern QemuOptsList qemu_common_drive_opts;
>>>  extern QemuOptsList qemu_drive_opts;
>>> diff --git a/windbgstub.c b/windbgstub.c
>>> index 489abe6d6c..b33f412659 100755
>>> --- a/windbgstub.c
>>> +++ b/windbgstub.c
>>> @@ -115,16 +115,20 @@ static void windbg_send_control_packet(uint16_t
>>> type)
>>>      windbg_state->ctrl_packet_id ^= 1;
>>>  }
>>>
>>> -static void windbg_vm_stop(void)
>>> +static void windbg_bp_handler(CPUState *cpu)
>>>  {
>>> -    CPUState *cpu = qemu_get_cpu(0);
>>> -    vm_stop(RUN_STATE_PAUSED);
>>> -
>>>      SizedBuf buf = kd_gen_exception_sc(cpu);
>>>      windbg_send_data_packet(buf.data, buf.size,
>>> PACKET_TYPE_KD_STATE_CHANGE64);
>>>      SBUF_FREE(buf);
>>>  }
>>>
>>> +static void windbg_vm_stop(void)
>>> +{
>>> +    CPUState *cpu = qemu_get_cpu(0);
>>> +    vm_stop(RUN_STATE_PAUSED);
>>> +    windbg_bp_handler(cpu);
>>> +}
>>> +
>>>  static void windbg_process_manipulate_packet(ParsingContext *ctx)
>>>  {
>>>      CPUState *cpu;
>>> @@ -432,6 +436,10 @@ int windbg_server_start(const char *device)
>>>
>>>      qemu_register_reset(windbg_handle_reset, NULL);
>>>
>>> +    if (!register_excp_debug_handler(windbg_bp_handler)) {
>>> +        exit(1);
>>> +    }
>>> +
>>>      atexit(windbg_exit);
>>>      return 0;
>>>  }
>>>
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

* Re: [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version
  2017-12-06  9:00     ` Mihail Abakumov
@ 2017-12-06  9:37       ` Ladi Prosek
  0 siblings, 0 replies; 70+ messages in thread
From: Ladi Prosek @ 2017-12-06  9:37 UTC (permalink / raw)
  To: Mihail Abakumov
  Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
	Denis V. Lunev

On Wed, Dec 6, 2017 at 10:00 AM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Ladi Prosek писал 2017-11-29 11:14:
>
>> On Tue, Nov 21, 2017 at 3:10 PM, Mihail Abakumov
>> <mikhail.abakumov@ispras.ru> wrote:
>>>
>>> Signed-off-by: Mihail Abakumov <mikhail.abakumov@ispras.ru>
>>> Signed-off-by: Pavel Dovgalyuk <dovgaluk@ispras.ru>
>>> Signed-off-by: Dmitriy Koltunov <koltunov@ispras.ru>
>>> ---
>>>  include/exec/windbgstub-utils.h |    1 +
>>>  windbgstub-utils.c              |   22 ++++++++++++++++++++++
>>>  windbgstub.c                    |    4 ++++
>>>  3 files changed, 27 insertions(+)
>>>
>>> diff --git a/include/exec/windbgstub-utils.h
>>> b/include/exec/windbgstub-utils.h
>>> index be48f69f40..bc5b6a8468 100755
>>> --- a/include/exec/windbgstub-utils.h
>>> +++ b/include/exec/windbgstub-utils.h
>>> @@ -99,6 +99,7 @@ void kd_api_read_io_space(CPUState *cpu, PacketData
>>> *pd);
>>>  void kd_api_write_io_space(CPUState *cpu, PacketData *pd);
>>>  void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd);
>>>  void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd);
>>> +void kd_api_get_version(CPUState *cpu, PacketData *pd);
>>>  void kd_api_unsupported(CPUState *cpu, PacketData *pd);
>>>
>>>  SizedBuf kd_gen_exception_sc(CPUState *cpu);
>>> diff --git a/windbgstub-utils.c b/windbgstub-utils.c
>>> index 6708e62798..7ef301bac7 100755
>>> --- a/windbgstub-utils.c
>>> +++ b/windbgstub-utils.c
>>> @@ -239,6 +239,28 @@ void kd_api_write_physical_memory(CPUState *cpu,
>>> PacketData *pd)
>>>      stl_p(&mem->ActualBytesWritten, len);
>>>  }
>>>
>>> +void kd_api_get_version(CPUState *cpu, PacketData *pd)
>>> +{
>>> +    DBGKD_GET_VERSION64 *kdver;
>>> +    int err = cpu_memory_rw_debug(cpu, version.addr, PTR(pd->m64) +
>>> 0x10,
>>> +                                  sizeof(DBGKD_MANIPULATE_STATE64) -
>>> 0x10, 0);
>>> +    if (!err) {
>>> +        kdver = (DBGKD_GET_VERSION64 *) (PTR(pd->m64) + 0x10);
>>> +
>>> +        stw_p(&kdver->MajorVersion, kdver->MajorVersion);
>>> +        stw_p(&kdver->MinorVersion, kdver->MinorVersion);
>>> +        stw_p(&kdver->Flags, kdver->Flags);
>>> +        stw_p(&kdver->MachineType, kdver->MachineType);
>>> +        stw_p(&kdver->Unused[0], kdver->Unused[0]);
>>> +        sttul_p(&kdver->KernBase, kdver->KernBase);
>>> +        sttul_p(&kdver->PsLoadedModuleList, kdver->PsLoadedModuleList);
>>> +        sttul_p(&kdver->DebuggerDataList, kdver->DebuggerDataList);
>>> +    } else {
>>> +        pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL;
>>
>>
>> The ReturnStatus field must be written using st* as well. You have
>> this direct write in many functions.
>>
>
> I'm doing stl_p for status before sending of packet in the
> 'windbg_process_manipulate_packet',
> because this is a global field of structure. Is that bad?

I see. Technically it's probably ok, as long as you make sure that the
field is always aligned. But having the field hold two representations
of the value depending on where exactly in the program you are is not
good style. Imagine debugging it, looking at the contents of the
structure, and not being sure if you're looking at the host or guest
byte order. Plus everybody reading the code will be confused just like
me :)

>>> +        WINDBG_ERROR("get_version: " FMT_ERR, err);
>>> +    }
>>> +}
>>> +
>>>  void kd_api_unsupported(CPUState *cpu, PacketData *pd)
>>>  {
>>>      WINDBG_ERROR("Caught unimplemented api %s",
>>> diff --git a/windbgstub.c b/windbgstub.c
>>> index 72324ae53d..ddca290694 100755
>>> --- a/windbgstub.c
>>> +++ b/windbgstub.c
>>> @@ -197,6 +197,10 @@ static void
>>> windbg_process_manipulate_packet(ParsingContext *ctx)
>>>          kd_api_write_physical_memory(cpu, &ctx->data);
>>>          break;
>>>
>>> +    case DbgKdGetVersionApi:
>>> +        kd_api_get_version(cpu, &ctx->data);
>>> +        break;
>>> +
>>>      case DbgKdClearAllInternalBreakpointsApi:
>>>          return;
>>>
>>>
>

^ permalink raw reply	[flat|nested] 70+ messages in thread

end of thread, other threads:[~2017-12-06  9:38 UTC | newest]

Thread overview: 70+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-11-21 14:07 [Qemu-devel] [PATCH v3 00/45] Windbg supporting Mihail Abakumov
2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 01/45] windbg: added empty windbgstub files Mihail Abakumov
2017-11-28 12:10   ` Ladi Prosek
2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 02/45] windbg: added windbg's KD header file Mihail Abakumov
2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 03/45] windbg: modified windbgkd.h Mihail Abakumov
2017-11-28 12:54   ` Ladi Prosek
2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 04/45] windbg: added '-windbg' option Mihail Abakumov
2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 05/45] windbg: added helper features Mihail Abakumov
2017-11-28  8:18   ` Ladi Prosek
2017-11-28  8:34     ` Peter Maydell
2017-11-28  9:01       ` Paolo Bonzini
2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 06/45] windbg: added WindbgState Mihail Abakumov
2017-11-21 14:07 ` [Qemu-devel] [PATCH v3 07/45] windbg: added chardev Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 08/45] windbg: hook to wrmsr operation Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 09/45] windbg: handler of fs/gs register Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 10/45] windbg: structures for parsing data stream Mihail Abakumov
2017-11-28 13:45   ` Ladi Prosek
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 11/45] windbg: " Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 12/45] windbg: send data and control packets Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 13/45] windbg: handler of parsing context Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 14/45] windbg: init DBGKD_ANY_WAIT_STATE_CHANGE Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 15/45] windbg: sized data buffer Mihail Abakumov
2017-11-28 14:07   ` Ladi Prosek
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 16/45] windbg: generate ExceptionStateChange Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 17/45] windbg: generate LoadSymbolsStateChange Mihail Abakumov
2017-11-21 14:08 ` [Qemu-devel] [PATCH v3 18/45] windbg: windbg_vm_stop Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 19/45] windbg: implemented windbg_process_control_packet Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 20/45] windbg: implemented windbg_process_data_packet Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 21/45] windbg: implemented windbg_process_manipulate_packet Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 22/45] windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 23/45] windbg: kernel's structures Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 24/45] windbg: implemented kd_api_get_context and kd_api_set_context Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 25/45] windbg: implemented kd_api_read_control_space and kd_api_write_control_space Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 26/45] windbg: implemented windbg_read_context Mihail Abakumov
2017-11-28 14:57   ` Ladi Prosek
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 27/45] windbg: implemented windbg_write_context Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 28/45] windbg: implemented windbg_read_ks_regs Mihail Abakumov
2017-11-21 14:09 ` [Qemu-devel] [PATCH v3 29/45] windbg: implemented windbg_write_ks_regs Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 30/45] windbg: implemented windbg_set_sr Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 31/45] windbg: implemented windbg_set_dr Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 32/45] windbg: implemented windbg_set_dr7 Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 33/45] windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 34/45] windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 35/45] windbg: debug exception subscribing Mihail Abakumov
2017-11-29  7:13   ` Ladi Prosek
2017-12-06  7:29     ` Mihail Abakumov
2017-12-06  9:23       ` Ladi Prosek
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 36/45] windbg: implemented kd_api_continue Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 37/45] windbg: implemented kd_api_read_io_space and kd_api_write_io_space Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 38/45] windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory Mihail Abakumov
2017-11-21 14:10 ` [Qemu-devel] [PATCH v3 39/45] windbg: implemented kd_api_get_version Mihail Abakumov
2017-11-29  8:14   ` Ladi Prosek
2017-12-06  9:00     ` Mihail Abakumov
2017-12-06  9:37       ` Ladi Prosek
2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 40/45] windbg: implemented kd_api_read_msr and kd_api_write_msr Mihail Abakumov
2017-11-29  7:25   ` Ladi Prosek
2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 41/45] windbg: implemented kd_api_search_memory Mihail Abakumov
2017-11-29  7:55   ` Ladi Prosek
2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 42/45] windbg: implemented kd_api_fill_memory Mihail Abakumov
2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 43/45] windbg: implemented kd_api_query_memory Mihail Abakumov
2017-11-29  8:03   ` Ladi Prosek
2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 44/45] windbg: added new api functions Mihail Abakumov
2017-11-21 14:11 ` [Qemu-devel] [PATCH v3 45/45] windbg: implemented kd_api_get_context_ex and kd_api_set_context_ex Mihail Abakumov
2017-11-28 12:44   ` Ladi Prosek
2017-12-05 11:28     ` Mihail Abakumov
2017-11-21 15:00 ` [Qemu-devel] [PATCH v3 00/45] Windbg supporting no-reply
2017-11-21 15:05 ` no-reply
2017-11-21 16:23 ` no-reply
2017-11-29  8:23   ` Ladi Prosek
2017-12-06  9:14     ` Mihail Abakumov

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.