* [Qemu-devel] [PATCH v2 01/43] windbg: added empty windbgstub files
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
@ 2017-10-17 13:08 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 02/43] windbg: added windbg's KD header file Mihail Abakumov
` (44 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:08 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 | 5 +++++
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 | 13 +++++++++++++
windbgstub-utils.c | 12 ++++++++++++
windbgstub.c | 19 +++++++++++++++++++
9 files changed, 104 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..0272b5e0ab 100644
--- a/Makefile.target
+++ b/Makefile.target
@@ -148,6 +148,11 @@ obj-y += dump.o
obj-y += migration/ram.o
LIBS := $(libs_softmmu) $(LIBS)
+# WinDbg support
+ifeq ($(TARGET_NAME), i386)
+obj-y += windbgstub.o windbgstub-utils.o
+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..f54f5178fb
--- /dev/null
+++ b/target/i386/windbgstub.c
@@ -0,0 +1,13 @@
+/*
+ * 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-utils.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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 02/43] windbg: added windbg's KD header file
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
2017-10-17 13:08 ` [Qemu-devel] [PATCH v2 01/43] windbg: added empty windbgstub files Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 03/43] windbg: modified windbgkd.h Mihail Abakumov
` (43 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 03/43] windbg: modified windbgkd.h
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
2017-10-17 13:08 ` [Qemu-devel] [PATCH v2 01/43] windbg: added empty windbgstub files Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 02/43] windbg: added windbg's KD header file Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 04/43] windbg: added '-windbg' option Mihail Abakumov
` (42 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 04/43] windbg: added '-windbg' option
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (2 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 03/43] windbg: modified windbgkd.h Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 05/43] windbg: added helper features Mihail Abakumov
` (41 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 05/43] windbg: added helper features
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (3 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 04/43] windbg: added '-windbg' option Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 06/43] windbg: added WindbgState Mihail Abakumov
` (40 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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 | 34 ++++++++++++++++++++++++++++++++++
include/exec/windbgstub.h | 6 ++++++
2 files changed, 40 insertions(+)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 2390597f1f..1c27ee4ce8 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -13,7 +13,41 @@
#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"
+#ifndef TARGET_I386
+#error Unsupported Architecture
+#endif
+#ifdef TARGET_X86_64 /* Unimplemented yet */
+#error Unsupported Architecture
+#endif
+
+# 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 06/43] windbg: added WindbgState
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (4 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 05/43] windbg: added helper features Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 07/43] windbg: added chardev Mihail Abakumov
` (39 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 07/43] windbg: added chardev
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (5 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 06/43] windbg: added WindbgState Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 08/43] windbg: hook to wrmsr operation Mihail Abakumov
` (38 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 08/43] windbg: hook to wrmsr operation
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (6 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 07/43] windbg: added chardev Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 09/43] windbg: handler of fs/gs register Mihail Abakumov
` (37 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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 | 5 +++++
windbgstub.c | 13 +++++++++++++
6 files changed, 27 insertions(+)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 1c27ee4ce8..825d58b76b 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -50,4 +50,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 f54f5178fb..f2f83423a0 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -11,3 +11,8 @@
#include "qemu/osdep.h"
#include "exec/windbgstub-utils.h"
+
+bool windbg_on_load(void)
+{
+ return false;
+}
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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 09/43] windbg: handler of fs/gs register
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (7 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 08/43] windbg: hook to wrmsr operation Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 10/43] windbg: structures for parsing data stream Mihail Abakumov
` (36 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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 825d58b76b..ff260287dc 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -50,6 +50,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 f2f83423a0..83e80bdfc8 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -12,7 +12,54 @@
#include "qemu/osdep.h"
#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;
}
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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 10/43] windbg: structures for parsing data stream
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (8 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 09/43] windbg: handler of fs/gs register Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 11/43] windbg: " Mihail Abakumov
` (35 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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 ff260287dc..d6abb82dfa 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -55,6 +55,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 11/43] windbg: parsing data stream
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (9 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 10/43] windbg: structures for parsing data stream Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 12/43] windbg: send data and control packets Mihail Abakumov
` (34 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 12/43] windbg: send data and control packets
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (10 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 11/43] windbg: " Mihail Abakumov
@ 2017-10-17 13:09 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 13/43] windbg: handler of parsing context Mihail Abakumov
` (33 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:09 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 13/43] windbg: handler of parsing context
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (11 preceding siblings ...)
2017-10-17 13:09 ` [Qemu-devel] [PATCH v2 12/43] windbg: send data and control packets Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 14/43] windbg: init DBGKD_ANY_WAIT_STATE_CHANGE Mihail Abakumov
` (32 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:10 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 14/43] windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (12 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 13/43] windbg: handler of parsing context Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 15/43] windbg: sized data buffer Mihail Abakumov
` (31 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:10 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 d6abb82dfa..5aa54550cd 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -50,6 +50,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 83e80bdfc8..da0aeb4f1b 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -15,9 +15,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)
@@ -63,3 +67,48 @@ 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);
+ }
+}
^ permalink raw reply related [flat|nested] 56+ messages in thread
* [Qemu-devel] [PATCH v2 15/43] windbg: sized data buffer
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (13 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 14/43] windbg: init DBGKD_ANY_WAIT_STATE_CHANGE Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 16/43] windbg: generate ExceptionStateChange Mihail Abakumov
` (30 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:10 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 5aa54550cd..f0da3cbd86 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -74,6 +74,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 16/43] windbg: generate ExceptionStateChange
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (14 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 15/43] windbg: sized data buffer Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 17/43] windbg: generate LoadSymbolsStateChange Mihail Abakumov
` (29 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:10 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 f0da3cbd86..fea04cbc89 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -93,6 +93,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 da0aeb4f1b..334642b677 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -68,7 +68,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)
{
@@ -112,3 +111,22 @@ static void kd_init_state_change(CPUState *cpu,
stw_p(&cr->InstructionCount, DBGKD_MAXSTREAM);
}
}
+
+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;
+}
^ permalink raw reply related [flat|nested] 56+ messages in thread
* [Qemu-devel] [PATCH v2 17/43] windbg: generate LoadSymbolsStateChange
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (15 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 16/43] windbg: generate ExceptionStateChange Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 18/43] windbg: windbg_vm_stop Mihail Abakumov
` (28 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:10 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 fea04cbc89..1c43be7c41 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -94,6 +94,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 334642b677..314301545b 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -130,3 +130,18 @@ 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;
+}
^ permalink raw reply related [flat|nested] 56+ messages in thread
* [Qemu-devel] [PATCH v2 18/43] windbg: windbg_vm_stop
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (16 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 17/43] windbg: generate LoadSymbolsStateChange Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 19/43] windbg: implemented windbg_process_control_packet Mihail Abakumov
` (27 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:10 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 19/43] windbg: implemented windbg_process_control_packet
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (17 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 18/43] windbg: windbg_vm_stop Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 20/43] windbg: implemented windbg_process_data_packet Mihail Abakumov
` (26 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 20/43] windbg: implemented windbg_process_data_packet
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (18 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 19/43] windbg: implemented windbg_process_control_packet Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 21/43] windbg: implemented windbg_process_manipulate_packet Mihail Abakumov
` (25 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 21/43] windbg: implemented windbg_process_manipulate_packet
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (19 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 20/43] windbg: implemented windbg_process_data_packet Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 22/43] windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory Mihail Abakumov
` (24 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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 | 10 ++++++++++
windbgstub.c | 26 +++++++++++++++++++++++++-
3 files changed, 37 insertions(+), 1 deletion(-)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 1c43be7c41..01f115f091 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -93,6 +93,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..501a7435df 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -23,3 +23,13 @@ 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;
+
+ exit(1);
+}
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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 22/43] windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (20 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 21/43] windbg: implemented windbg_process_manipulate_packet Mihail Abakumov
@ 2017-10-17 13:10 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 23/43] windbg: kernel's structures Mihail Abakumov
` (23 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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 | 47 +++++++++++++++++++++++++++++++++++++++
windbgstub.c | 8 +++++++
3 files changed, 57 insertions(+)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 01f115f091..552318ad05 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -93,6 +93,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 501a7435df..c363d905af 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 23/43] windbg: kernel's structures
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (21 preceding siblings ...)
2017-10-17 13:10 ` [Qemu-devel] [PATCH v2 22/43] windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 24/43] windbg: implemented kd_api_get_context and kd_api_set_context Mihail Abakumov
` (22 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:11 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 314301545b..dcbb8313b5 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -24,6 +24,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;
+
+typedef struct _CPU_KPROCESSOR_STATE {
+ CPU_CONTEXT ContextFrame;
+ CPU_KSPECIAL_REGISTERS SpecialRegisters;
+} CPU_KPROCESSOR_STATE, *PCPU_KPROCESSOR_STATE;
+
+#endif
+
bool windbg_on_load(void)
{
CPUState *cpu = qemu_get_cpu(0);
^ permalink raw reply related [flat|nested] 56+ messages in thread
* [Qemu-devel] [PATCH v2 24/43] windbg: implemented kd_api_get_context and kd_api_set_context
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (22 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 23/43] windbg: kernel's structures Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 25/43] windbg: implemented kd_api_read_control_space and kd_api_write_control_space Mihail Abakumov
` (21 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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 | 39 +++++++++++++++++++++++++++++++++++++++
windbgstub.c | 8 ++++++++
3 files changed, 49 insertions(+)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 552318ad05..39fbfc8d3a 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -95,6 +95,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 dcbb8313b5..175fa09f24 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -271,6 +271,45 @@ typedef struct _CPU_KPROCESSOR_STATE {
#endif
+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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 25/43] windbg: implemented kd_api_read_control_space and kd_api_write_control_space
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (23 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 24/43] windbg: implemented kd_api_get_context and kd_api_set_context Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 26/43] windbg: implemented windbg_read_context Mihail Abakumov
` (20 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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 | 89 +++++++++++++++++++++++++++++++++++++++
windbgstub.c | 8 ++++
3 files changed, 99 insertions(+)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 39fbfc8d3a..468a874ab7 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -97,6 +97,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 175fa09f24..3e238525da 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -283,6 +283,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;
@@ -310,6 +322,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 26/43] windbg: implemented windbg_read_context
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (24 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 25/43] windbg: implemented kd_api_read_control_space and kd_api_write_control_space Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 27/43] windbg: implemented windbg_write_context Mihail Abakumov
` (19 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
target/i386/windbgstub.c | 96 ++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 96 insertions(+)
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 3e238525da..a3ec5c1c6a 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -274,6 +274,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 27/43] windbg: implemented windbg_write_context
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (25 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 26/43] windbg: implemented windbg_read_context Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 28/43] windbg: implemented windbg_read_ks_regs Mihail Abakumov
` (18 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
target/i386/windbgstub.c | 212 ++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 212 insertions(+)
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index a3ec5c1c6a..490dadbae1 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -271,6 +271,12 @@ typedef struct _CPU_KPROCESSOR_STATE {
#endif
+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)
{
@@ -376,6 +382,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 28/43] windbg: implemented windbg_read_ks_regs
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (26 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 27/43] windbg: implemented windbg_write_context Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 29/43] windbg: implemented windbg_write_ks_regs Mihail Abakumov
` (17 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
target/i386/windbgstub.c | 39 +++++++++++++++++++++++++++++++++++++++
1 file changed, 39 insertions(+)
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 490dadbae1..b22584a45a 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -594,6 +594,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 29/43] windbg: implemented windbg_write_ks_regs
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (27 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 28/43] windbg: implemented windbg_read_ks_regs Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 30/43] windbg: implemented windbg_set_sr Mihail Abakumov
` (16 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
target/i386/windbgstub.c | 111 ++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 111 insertions(+)
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index b22584a45a..fbb42d05bd 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -639,6 +639,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 30/43] windbg: implemented windbg_set_sr
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (28 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 29/43] windbg: implemented windbg_write_ks_regs Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 31/43] windbg: implemented windbg_set_dr Mihail Abakumov
` (15 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
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 fbb42d05bd..d67ad8cf0c 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -275,7 +275,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 31/43] windbg: implemented windbg_set_dr
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (29 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 30/43] windbg: implemented windbg_set_sr Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 32/43] windbg: implemented windbg_set_dr7 Mihail Abakumov
` (14 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:11 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 d67ad8cf0c..7dff5e6c1b 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -12,6 +12,21 @@
#include "qemu/osdep.h"
#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
@@ -271,9 +286,42 @@ typedef struct _CPU_KPROCESSOR_STATE {
#endif
-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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 32/43] windbg: implemented windbg_set_dr7
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (30 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 31/43] windbg: implemented windbg_set_dr Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 33/43] windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove Mihail Abakumov
` (13 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
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 7dff5e6c1b..570e68a735 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -297,7 +297,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 33/43] windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (31 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 32/43] windbg: implemented windbg_set_dr7 Mihail Abakumov
@ 2017-10-17 13:11 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 34/43] windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint Mihail Abakumov
` (12 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13: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>
---
target/i386/windbgstub.c | 56 ++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 56 insertions(+)
diff --git a/target/i386/windbgstub.c b/target/i386/windbgstub.c
index 570e68a735..f9336b607f 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -288,11 +288,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 34/43] windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (32 preceding siblings ...)
2017-10-17 13:11 ` [Qemu-devel] [PATCH v2 33/43] windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 35/43] windbg: debug exception subscribing Mihail Abakumov
` (11 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 468a874ab7..8cea2afdf1 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -97,6 +97,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 c363d905af..0f23f3c865 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 35/43] windbg: debug exception subscribing
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (33 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 34/43] windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 36/43] windbg: implemented kd_api_continue Mihail Abakumov
` (10 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 36/43] windbg: implemented kd_api_continue
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (34 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 35/43] windbg: debug exception subscribing Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 37/43] windbg: implemented kd_api_read_io_space and kd_api_write_io_space Mihail Abakumov
` (9 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 8cea2afdf1..49b05226b3 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -99,6 +99,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 0f23f3c865..dce2b4ccde 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 37/43] windbg: implemented kd_api_read_io_space and kd_api_write_io_space
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (35 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 36/43] windbg: implemented kd_api_continue Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 38/43] windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory Mihail Abakumov
` (8 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 49b05226b3..dde88f24c9 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -102,6 +102,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 dce2b4ccde..b32b4ea570 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 38/43] windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (36 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 37/43] windbg: implemented kd_api_read_io_space and kd_api_write_io_space Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 39/43] windbg: implemented kd_api_get_version Mihail Abakumov
` (7 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 dde88f24c9..8b0091c53b 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -104,6 +104,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 b32b4ea570..319e70e01d 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 39/43] windbg: implemented kd_api_get_version
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (37 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 38/43] windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 40/43] windbg: implemented kd_api_read_msr and kd_api_write_msr Mihail Abakumov
` (6 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 8b0091c53b..0fcef14f20 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -106,6 +106,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 319e70e01d..40f859009a 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 40/43] windbg: implemented kd_api_read_msr and kd_api_write_msr
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (38 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 39/43] windbg: implemented kd_api_get_version Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 41/43] windbg: implemented kd_api_search_memory Mihail Abakumov
` (5 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 0fcef14f20..0199a47343 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -107,6 +107,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 f9336b607f..12c0aca9ae 100755
--- a/target/i386/windbgstub.c
+++ b/target/i386/windbgstub.c
@@ -1001,6 +1001,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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 41/43] windbg: implemented kd_api_search_memory
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (39 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 40/43] windbg: implemented kd_api_read_msr and kd_api_write_msr Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 42/43] windbg: implemented kd_api_fill_memory Mihail Abakumov
` (4 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 0199a47343..6c587dadd8 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -109,6 +109,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 40f859009a..8417de8fb1 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 42/43] windbg: implemented kd_api_fill_memory
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (40 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 41/43] windbg: implemented kd_api_search_memory Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 43/43] windbg: implemented kd_api_query_memory Mihail Abakumov
` (3 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 6c587dadd8..0438ea44b6 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -110,6 +110,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 8417de8fb1..444bb0474d 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] 56+ messages in thread
* [Qemu-devel] [PATCH v2 43/43] windbg: implemented kd_api_query_memory
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (41 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 42/43] windbg: implemented kd_api_fill_memory Mihail Abakumov
@ 2017-10-17 13:12 ` Mihail Abakumov
2017-10-17 14:11 ` [Qemu-devel] [PATCH v2 00/43] Windbg supporting no-reply
` (2 subsequent siblings)
45 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-10-17 13:12 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 | 14 ++++++++++++++
windbgstub.c | 4 ++++
3 files changed, 19 insertions(+)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h
index 0438ea44b6..190fdab6b2 100755
--- a/include/exec/windbgstub-utils.h
+++ b/include/exec/windbgstub-utils.h
@@ -112,6 +112,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 444bb0474d..7de2fd6ade 100755
--- a/windbgstub-utils.c
+++ b/windbgstub-utils.c
@@ -333,6 +333,20 @@ 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;
+
+ if (ldl_p(&mem->AddressSpace) == DBGKD_QUERY_MEMORY_VIRTUAL) {
+ 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] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (42 preceding siblings ...)
2017-10-17 13:12 ` [Qemu-devel] [PATCH v2 43/43] windbg: implemented kd_api_query_memory Mihail Abakumov
@ 2017-10-17 14:11 ` no-reply
2017-10-17 15:04 ` no-reply
2017-10-23 8:31 ` Ladi Prosek
45 siblings, 0 replies; 56+ messages in thread
From: no-reply @ 2017-10-17 14:11 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.
Type: series
Message-id: 150824572545.6816.5099701189660002212.stgit@Misha-PC.lan02.inno
Subject: [Qemu-devel] [PATCH v2 00/43] 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 ==="
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/150824572545.6816.5099701189660002212.stgit@Misha-PC.lan02.inno -> patchew/150824572545.6816.5099701189660002212.stgit@Misha-PC.lan02.inno
Switched to a new branch 'test'
781761e windbg: implemented kd_api_query_memory
51254e4 windbg: implemented kd_api_fill_memory
66690a9 windbg: implemented kd_api_search_memory
2f6279f windbg: implemented kd_api_read_msr and kd_api_write_msr
ecbb8a4 windbg: implemented kd_api_get_version
99404b5 windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
ece9ee6 windbg: implemented kd_api_read_io_space and kd_api_write_io_space
8dee089 windbg: implemented kd_api_continue
319a1cf windbg: debug exception subscribing
0aae017 windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
87f6155 windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
6039691 windbg: implemented windbg_set_dr7
d6d36a9 windbg: implemented windbg_set_dr
fa3991d windbg: implemented windbg_set_sr
583ea26 windbg: implemented windbg_write_ks_regs
fdf270f windbg: implemented windbg_read_ks_regs
05da1b9 windbg: implemented windbg_write_context
69df19d windbg: implemented windbg_read_context
d75b301 windbg: implemented kd_api_read_control_space and kd_api_write_control_space
128fdb1 windbg: implemented kd_api_get_context and kd_api_set_context
982f109 windbg: kernel's structures
cc26403 windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
8254436 windbg: implemented windbg_process_manipulate_packet
3891584 windbg: implemented windbg_process_data_packet
d9b0dc0 windbg: implemented windbg_process_control_packet
7c49481 windbg: windbg_vm_stop
c2b182a windbg: generate LoadSymbolsStateChange
e1e0fa6 windbg: generate ExceptionStateChange
1b46d89 windbg: sized data buffer
1e2b131 windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
c539c2e windbg: handler of parsing context
aa620f7 windbg: send data and control packets
ec009bb windbg: parsing data stream
d92166f windbg: structures for parsing data stream
c5af1bf windbg: handler of fs/gs register
b2913d7 windbg: hook to wrmsr operation
ea4c4d5 windbg: added chardev
e3dcaa4 windbg: added WindbgState
3b4e42a windbg: added helper features
5193519 windbg: added '-windbg' option
ff48de6 windbg: modified windbgkd.h
034025d windbg: added windbg's KD header file
0645652 windbg: added empty windbgstub files
=== OUTPUT BEGIN ===
=== ENV ===
XDG_SESSION_ID=50280
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-ocfdhvn7/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
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
distribution-gpg-keys-1.14-1.fc25.noarch
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
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
mock-1.4.3-1.fc25.noarch
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
=== TEST BEGIN ===
Using CC: /home/fam/bin/cc
Install prefix /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install
BIOS directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/share/qemu
firmware path /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/share/qemu-firmware
binary directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/bin
library directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/lib
module directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/lib/qemu
libexec directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/libexec
include directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/include
config directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/etc
local state directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/var
Manual directory /var/tmp/patchew-tester-tmp-ocfdhvn7/src/install/share/man
ELF interp prefix /usr/gnemul/qemu-%M
Source path /var/tmp/patchew-tester-tmp-ocfdhvn7/src
GIT submodules ui/keycodemapdb
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
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
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 alpha-softmmu/config-devices.mak
GEN arm-softmmu/config-devices.mak
GEN lm32-softmmu/config-devices.mak.tmp
GEN aarch64-softmmu/config-devices.mak
GEN m68k-softmmu/config-devices.mak.tmp
GEN microblazeel-softmmu/config-devices.mak.tmp
GEN m68k-softmmu/config-devices.mak
GEN lm32-softmmu/config-devices.mak
GEN microblaze-softmmu/config-devices.mak.tmp
GEN mips64el-softmmu/config-devices.mak.tmp
GEN i386-softmmu/config-devices.mak
GEN microblazeel-softmmu/config-devices.mak
GEN mips64-softmmu/config-devices.mak.tmp
GEN mipsel-softmmu/config-devices.mak.tmp
GEN mipsel-softmmu/config-devices.mak
GEN mips-softmmu/config-devices.mak.tmp
GEN microblaze-softmmu/config-devices.mak
GEN moxie-softmmu/config-devices.mak.tmp
GEN mips64-softmmu/config-devices.mak
GEN mips-softmmu/config-devices.mak
GEN nios2-softmmu/config-devices.mak.tmp
GEN moxie-softmmu/config-devices.mak
GEN or1k-softmmu/config-devices.mak.tmp
GEN nios2-softmmu/config-devices.mak
GEN ppcemb-softmmu/config-devices.mak.tmp
GEN ppc64-softmmu/config-devices.mak.tmp
GEN mips64el-softmmu/config-devices.mak
GEN ppc-softmmu/config-devices.mak.tmp
GEN or1k-softmmu/config-devices.mak
GEN s390x-softmmu/config-devices.mak.tmp
GEN ppc64-softmmu/config-devices.mak
GEN ppcemb-softmmu/config-devices.mak
GEN sh4-softmmu/config-devices.mak.tmp
GEN sh4eb-softmmu/config-devices.mak.tmp
GEN s390x-softmmu/config-devices.mak
GEN sparc64-softmmu/config-devices.mak.tmp
GEN ppc-softmmu/config-devices.mak
GEN sh4eb-softmmu/config-devices.mak
GEN sh4-softmmu/config-devices.mak
GEN sparc-softmmu/config-devices.mak.tmp
GEN tricore-softmmu/config-devices.mak.tmp
GEN unicore32-softmmu/config-devices.mak.tmp
GEN tricore-softmmu/config-devices.mak
GEN x86_64-softmmu/config-devices.mak.tmp
GEN unicore32-softmmu/config-devices.mak
GEN sparc-softmmu/config-devices.mak
GEN x86_64-softmmu/config-devices.mak
GEN sparc64-softmmu/config-devices.mak
GEN xtensa-softmmu/config-devices.mak.tmp
GEN aarch64-linux-user/config-devices.mak.tmp
GEN xtensaeb-softmmu/config-devices.mak.tmp
GEN alpha-linux-user/config-devices.mak.tmp
GEN xtensaeb-softmmu/config-devices.mak
GEN xtensa-softmmu/config-devices.mak
GEN aarch64-linux-user/config-devices.mak
GEN alpha-linux-user/config-devices.mak
GEN arm-linux-user/config-devices.mak.tmp
GEN armeb-linux-user/config-devices.mak.tmp
GEN cris-linux-user/config-devices.mak.tmp
GEN hppa-linux-user/config-devices.mak.tmp
GEN armeb-linux-user/config-devices.mak
GEN hppa-linux-user/config-devices.mak
GEN arm-linux-user/config-devices.mak
GEN cris-linux-user/config-devices.mak
GEN i386-linux-user/config-devices.mak.tmp
GEN m68k-linux-user/config-devices.mak.tmp
GEN i386-linux-user/config-devices.mak
GEN microblazeel-linux-user/config-devices.mak.tmp
GEN microblaze-linux-user/config-devices.mak.tmp
GEN mips64el-linux-user/config-devices.mak.tmp
GEN m68k-linux-user/config-devices.mak
GEN mips64-linux-user/config-devices.mak.tmp
GEN microblaze-linux-user/config-devices.mak
GEN mipsel-linux-user/config-devices.mak.tmp
GEN mipsel-linux-user/config-devices.mak
GEN microblazeel-linux-user/config-devices.mak
GEN mips64el-linux-user/config-devices.mak
GEN mips-linux-user/config-devices.mak.tmp
GEN mips-linux-user/config-devices.mak
GEN mipsn32el-linux-user/config-devices.mak.tmp
GEN nios2-linux-user/config-devices.mak.tmp
GEN mipsn32-linux-user/config-devices.mak.tmp
GEN mipsn32el-linux-user/config-devices.mak
GEN mips64-linux-user/config-devices.mak
GEN ppc64abi32-linux-user/config-devices.mak.tmp
GEN nios2-linux-user/config-devices.mak
GEN or1k-linux-user/config-devices.mak.tmp
GEN mipsn32-linux-user/config-devices.mak
GEN or1k-linux-user/config-devices.mak
GEN ppc64le-linux-user/config-devices.mak.tmp
GEN ppc64-linux-user/config-devices.mak.tmp
GEN ppc64le-linux-user/config-devices.mak
GEN s390x-linux-user/config-devices.mak.tmp
GEN ppc-linux-user/config-devices.mak.tmp
GEN ppc64abi32-linux-user/config-devices.mak
GEN sh4eb-linux-user/config-devices.mak.tmp
GEN ppc64-linux-user/config-devices.mak
GEN sh4-linux-user/config-devices.mak.tmp
GEN s390x-linux-user/config-devices.mak
GEN sh4eb-linux-user/config-devices.mak
GEN ppc-linux-user/config-devices.mak
GEN sparc32plus-linux-user/config-devices.mak.tmp
GEN sparc64-linux-user/config-devices.mak.tmp
GEN sparc-linux-user/config-devices.mak.tmp
GEN sh4-linux-user/config-devices.mak
GEN tilegx-linux-user/config-devices.mak.tmp
GEN sparc32plus-linux-user/config-devices.mak
GEN x86_64-linux-user/config-devices.mak.tmp
GEN sparc-linux-user/config-devices.mak
GEN sparc64-linux-user/config-devices.mak
GEN x86_64-linux-user/config-devices.mak
GEN config-host.h
GEN qemu-options.def
GEN tilegx-linux-user/config-devices.mak
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
GEN qmp-introspect.h
GEN qmp-introspect.c
GEN trace/generated-tcg-tracers.h
GEN trace/generated-helpers-wrappers.h
GEN trace/generated-helpers.c
GEN trace/generated-helpers.h
GEN module_block.h
GEN tests/test-qapi-types.h
GEN tests/test-qapi-visit.h
GIT ui/keycodemapdb
GEN tests/test-qmp-commands.h
GEN tests/test-qmp-introspect.h
GEN tests/test-qapi-event.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/intc/trace.h
GEN hw/char/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/display/trace.h
GEN hw/nvram/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/i386/trace.h
GEN hw/i386/xen/trace.h
GEN hw/mem/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 target/arm/trace.h
GEN net/trace.h
GEN target/i386/trace.h
GEN target/mips/trace.h
GEN target/sparc/trace.h
GEN target/s390x/trace.h
GEN qom/trace.h
GEN target/ppc/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 trace-root.c
GEN scsi/trace.h
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/char/trace.c
GEN hw/block/dataplane/trace.c
GEN hw/net/trace.c
GEN hw/intc/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/input/trace.c
GEN hw/timer/trace.c
GEN hw/display/trace.c
GEN hw/sparc/trace.c
GEN hw/sd/trace.c
GEN hw/dma/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 qapi/trace.c
GEN linux-user/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
GEN ui/input-keymap-linux-to-qcode.c
GEN ui/input-keymap-qnum-to-qcode.c
GEN ui/input-keymap-qcode-to-qnum.c
CC tests/qemu-iotests/socket_scm_helper.o
GEN docs/version.texi
GEN qemu-options.texi
GEN qemu-monitor.texi
GEN qemu-img-cmds.texi
GEN qemu-monitor-info.texi
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-qmp-commands.h
GEN qga/qapi-generated/qga-qapi-types.c
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-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 qobject/qnull.o
CC qapi/qapi-util.o
CC qobject/qnum.o
CC qobject/qdict.o
CC qobject/qstring.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/unicode.o
CC util/bufferiszero.o
CC util/qemu-timer-common.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/host-utils.o
CC util/module.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/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/hexdump.o
CC util/crc32c.o
CC util/throttle.o
CC util/uuid.o
CC util/getauxval.o
CC util/readline.o
CC util/rcu.o
CC util/qemu-coroutine-lock.o
CC util/qemu-coroutine.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/audio/trace.o
CC hw/virtio/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/sd/trace.o
CC hw/sparc/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/i386/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 linux-user/trace.o
CC qapi/trace.o
CC accel/tcg/trace.o
CC nbd/trace.o
CC accel/kvm/trace.o
CC scsi/trace.o
CC stubs/arch-query-cpu-def.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-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/trace-control.o
CC stubs/uuid.o
CC stubs/vm-stop.o
CC stubs/vmstate.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/xen-hvm.o
CC stubs/pci-host-piix.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 qemu-nbd.o
CC contrib/ivshmem-server/main.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/snapshot.o
CC block/block-backend.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/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/iscsi.o
CC block/nfs.o
CC block/curl.o
CC block/gluster.o
CC block/rbd.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-nettle.o
CC crypto/hmac.o
CC crypto/aes.o
CC crypto/desrfb.o
CC crypto/tlscreds.o
CC crypto/cipher.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/qom-qobject.o
CC qom/container.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 qemu-bridge-helper.o
CC scsi/qemu-pr-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/ossaudio.o
CC audio/sdlaudio.o
CC audio/wavcapture.o
CC backends/rng-egd.o
CC backends/rng.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/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/coxattr.o
CC hw/9pfs/cofile.o
CC hw/9pfs/9p-handle.o
CC hw/9pfs/9p-synth.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_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/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/core/qdev.o
CC hw/char/sclpconsole-lm.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/machine.o
CC hw/core/sysbus.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/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_eeprom.o
CC hw/i2c/smbus.o
CC hw/i2c/i2c-ddc.o
CC hw/i2c/versatile_i2c.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/microdrive.o
CC hw/ide/via.o
CC hw/ide/ahci.o
CC hw/ide/ich.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/lm32_pic.o
CC hw/intc/imx_avic.o
CC hw/intc/realview_gic.o
CC hw/intc/slavio_intctl.o
CC hw/intc/ioapic_common.o
CC hw/intc/arm_gic.o
CC hw/intc/arm_gic_common.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_redist.o
CC hw/intc/arm_gicv3_dist.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_bt.o
CC hw/ipmi/isa_ipmi_kcs.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/a9scu.o
CC hw/misc/arm_integrator_debug.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_pci_bridge.o
CC hw/pci-bridge/pcie_root_port.o
CC hw/pci-bridge/gen_pcie_root_port.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/vmw_pvscsi.o
CC hw/scsi/megasas.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/sdhci.o
CC hw/sd/core.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/puv3_ost.o
CC hw/timer/pl031.o
CC hw/timer/twl92230.o
CC hw/timer/slavio_timer.o
CC hw/timer/xilinx_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/aspeed_timer.o
CC hw/timer/stm32f2xx_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-wacom.o
CC hw/usb/dev-uas.o
CC hw/usb/dev-storage.o
CC hw/usb/dev-audio.o
CC hw/usb/dev-serial.o
CC hw/usb/dev-bluetooth.o
CC hw/usb/dev-network.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/dump.o
CC net/socket.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 qom/cpu.o
CC net/tap-linux.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-char.o
CC replay/replay-snapshot.o
CC replay/replay-audio.o
CC replay/replay-net.o
CC slirp/if.o
CC slirp/cksum.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-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
CC ui/shader.o
VERT ui/shader/texture-blit-vert.h
FRAG ui/shader/texture-blit-frag.h
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
CCAS s390-ccw/start.o
CC s390-ccw/main.o
LINK tests/qemu-iotests/socket_scm_helper
CC s390-ccw/bootmap.o
GEN qemu-doc.html
GEN qemu-doc.txt
GEN qemu.1
CC s390-ccw/sclp.o
GEN qemu-img.1
CC s390-ccw/virtio.o
GEN docs/interop/qemu-qmp-ref.html
CC s390-ccw/virtio-scsi.o
GEN docs/interop/qemu-qmp-ref.txt
CC s390-ccw/virtio-blkdev.o
s390-netboot.img not built since roms/SLOF/ is not available.
BUILD s390-ccw/s390-ccw.elf
GEN docs/interop/qemu-qmp-ref.7
STRIP s390-ccw/s390-ccw.img
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/qapi-generated/qga-qapi-types.o
CC qga/channel-posix.o
CC qga/qapi-generated/qga-qapi-visit.o
CC qga/qapi-generated/qga-qmp-marshal.o
AR libqemuutil.a
CC qemu-img.o
LINK qemu-io
LINK fsdev/virtfs-proxy-helper
LINK scsi/qemu-pr-helper
LINK qemu-bridge-helper
CC ui/console-gl.o
LINK qemu-ga
LINK qemu-keymap
LINK ivshmem-client
LINK ivshmem-server
LINK qemu-nbd
GEN aarch64-softmmu/hmp-commands.h
GEN alpha-softmmu/hmp-commands.h
GEN aarch64-softmmu/hmp-commands-info.h
GEN alpha-softmmu/hmp-commands-info.h
GEN alpha-softmmu/config-target.h
GEN aarch64-softmmu/config-target.h
GEN arm-softmmu/hmp-commands.h
GEN arm-softmmu/hmp-commands-info.h
CC aarch64-softmmu/exec.o
CC alpha-softmmu/exec.o
GEN arm-softmmu/config-target.h
GEN cris-softmmu/hmp-commands.h
GEN cris-softmmu/hmp-commands-info.h
GEN cris-softmmu/config-target.h
CC cris-softmmu/exec.o
CC arm-softmmu/exec.o
CC aarch64-softmmu/tcg/tcg.o
CC alpha-softmmu/tcg/tcg.o
CC cris-softmmu/tcg/tcg.o
CC arm-softmmu/tcg/tcg.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/tcg-op.o
CC cris-softmmu/tcg/optimize.o
CC aarch64-softmmu/tcg/optimize.o
CC arm-softmmu/tcg/optimize.o
CC alpha-softmmu/tcg/optimize.o
CC cris-softmmu/tcg/tcg-common.o
CC aarch64-softmmu/tcg/tcg-common.o
CC arm-softmmu/tcg/tcg-common.o
CC cris-softmmu/fpu/softfloat.o
CC aarch64-softmmu/fpu/softfloat.o
CC arm-softmmu/fpu/softfloat.o
CC alpha-softmmu/tcg/tcg-common.o
CC alpha-softmmu/fpu/softfloat.o
CC aarch64-softmmu/disas.o
CC cris-softmmu/disas.o
GEN aarch64-softmmu/gdbstub-xml.c
CC cris-softmmu/arch_init.o
CC arm-softmmu/disas.o
CC cris-softmmu/cpus.o
CC alpha-softmmu/disas.o
GEN arm-softmmu/gdbstub-xml.c
CC aarch64-softmmu/arch_init.o
CC alpha-softmmu/arch_init.o
CC aarch64-softmmu/cpus.o
CC cris-softmmu/monitor.o
CC arm-softmmu/arch_init.o
CC alpha-softmmu/cpus.o
CC arm-softmmu/cpus.o
CC aarch64-softmmu/monitor.o
CC alpha-softmmu/monitor.o
CC cris-softmmu/gdbstub.o
CC arm-softmmu/monitor.o
CC cris-softmmu/balloon.o
CC alpha-softmmu/gdbstub.o
CC aarch64-softmmu/gdbstub.o
CC cris-softmmu/ioport.o
CC cris-softmmu/numa.o
CC arm-softmmu/gdbstub.o
CC alpha-softmmu/balloon.o
CC aarch64-softmmu/balloon.o
CC cris-softmmu/qtest.o
CC alpha-softmmu/ioport.o
CC arm-softmmu/balloon.o
CC aarch64-softmmu/ioport.o
CC arm-softmmu/ioport.o
CC alpha-softmmu/numa.o
CC cris-softmmu/memory.o
CC aarch64-softmmu/numa.o
CC arm-softmmu/numa.o
CC alpha-softmmu/qtest.o
CC aarch64-softmmu/qtest.o
CC arm-softmmu/qtest.o
CC alpha-softmmu/memory.o
CC aarch64-softmmu/memory.o
CC arm-softmmu/memory.o
CC cris-softmmu/memory_mapping.o
CC cris-softmmu/dump.o
CC aarch64-softmmu/memory_mapping.o
CC alpha-softmmu/memory_mapping.o
CC aarch64-softmmu/dump.o
CC arm-softmmu/memory_mapping.o
CC cris-softmmu/migration/ram.o
CC alpha-softmmu/dump.o
CC arm-softmmu/dump.o
CC aarch64-softmmu/migration/ram.o
CC cris-softmmu/accel/accel.o
CC alpha-softmmu/migration/ram.o
CC cris-softmmu/accel/stubs/hax-stub.o
CC arm-softmmu/migration/ram.o
CC cris-softmmu/accel/stubs/kvm-stub.o
CC alpha-softmmu/accel/accel.o
CC aarch64-softmmu/accel/accel.o
CC cris-softmmu/accel/tcg/tcg-all.o
CC alpha-softmmu/accel/stubs/hax-stub.o
CC aarch64-softmmu/accel/stubs/hax-stub.o
CC cris-softmmu/accel/tcg/cputlb.o
CC arm-softmmu/accel/accel.o
CC alpha-softmmu/accel/stubs/kvm-stub.o
CC aarch64-softmmu/accel/stubs/kvm-stub.o
CC arm-softmmu/accel/stubs/hax-stub.o
CC aarch64-softmmu/accel/tcg/tcg-all.o
CC alpha-softmmu/accel/tcg/tcg-all.o
CC arm-softmmu/accel/stubs/kvm-stub.o
CC alpha-softmmu/accel/tcg/cputlb.o
CC aarch64-softmmu/accel/tcg/cputlb.o
CC arm-softmmu/accel/tcg/tcg-all.o
CC cris-softmmu/accel/tcg/tcg-runtime.o
CC arm-softmmu/accel/tcg/cputlb.o
CC cris-softmmu/accel/tcg/cpu-exec.o
CC alpha-softmmu/accel/tcg/tcg-runtime.o
CC alpha-softmmu/accel/tcg/cpu-exec.o
CC cris-softmmu/accel/tcg/cpu-exec-common.o
CC aarch64-softmmu/accel/tcg/tcg-runtime.o
CC alpha-softmmu/accel/tcg/cpu-exec-common.o
CC cris-softmmu/accel/tcg/translate-all.o
CC aarch64-softmmu/accel/tcg/cpu-exec.o
CC arm-softmmu/accel/tcg/tcg-runtime.o
CC alpha-softmmu/accel/tcg/translate-all.o
CC cris-softmmu/accel/tcg/translator.o
CC arm-softmmu/accel/tcg/cpu-exec.o
CC alpha-softmmu/accel/tcg/translator.o
CC cris-softmmu/hw/core/generic-loader.o
CC aarch64-softmmu/accel/tcg/cpu-exec-common.o
CC cris-softmmu/hw/core/null-machine.o
CC alpha-softmmu/hw/9pfs/virtio-9p-device.o
CC aarch64-softmmu/accel/tcg/translate-all.o
CC cris-softmmu/hw/misc/mmio_interface.o
CC arm-softmmu/accel/tcg/cpu-exec-common.o
CC alpha-softmmu/hw/block/virtio-blk.o
CC cris-softmmu/hw/net/etraxfs_eth.o
CC arm-softmmu/accel/tcg/translate-all.o
CC cris-softmmu/hw/net/vhost_net.o
CC aarch64-softmmu/accel/tcg/translator.o
CC alpha-softmmu/hw/block/dataplane/virtio-blk.o
CC cris-softmmu/hw/net/rocker/qmp-norocker.o
CC arm-softmmu/accel/tcg/translator.o
CC alpha-softmmu/hw/char/virtio-serial-bus.o
CC cris-softmmu/hw/vfio/common.o
CC aarch64-softmmu/hw/9pfs/virtio-9p-device.o
CC aarch64-softmmu/hw/adc/stm32f2xx_adc.o
CC arm-softmmu/hw/9pfs/virtio-9p-device.o
CC aarch64-softmmu/hw/block/virtio-blk.o
CC alpha-softmmu/hw/core/generic-loader.o
CC arm-softmmu/hw/adc/stm32f2xx_adc.o
CC cris-softmmu/hw/vfio/platform.o
CC alpha-softmmu/hw/core/null-machine.o
CC arm-softmmu/hw/block/virtio-blk.o
CC alpha-softmmu/hw/display/vga.o
CC aarch64-softmmu/hw/block/dataplane/virtio-blk.o
CC cris-softmmu/hw/vfio/spapr.o
CC aarch64-softmmu/hw/char/exynos4210_uart.o
CC arm-softmmu/hw/block/dataplane/virtio-blk.o
CC cris-softmmu/hw/cris/boot.o
CC aarch64-softmmu/hw/char/omap_uart.o
CC arm-softmmu/hw/char/exynos4210_uart.o
CC cris-softmmu/hw/cris/axis_dev88.o
CC aarch64-softmmu/hw/char/digic-uart.o
CC alpha-softmmu/hw/display/virtio-gpu.o
CC arm-softmmu/hw/char/omap_uart.o
CC aarch64-softmmu/hw/char/stm32f2xx_usart.o
CC cris-softmmu/target/cris/translate.o
CC aarch64-softmmu/hw/char/bcm2835_aux.o
CC arm-softmmu/hw/char/digic-uart.o
CC arm-softmmu/hw/char/stm32f2xx_usart.o
CC alpha-softmmu/hw/display/virtio-gpu-3d.o
CC aarch64-softmmu/hw/char/virtio-serial-bus.o
CC arm-softmmu/hw/char/bcm2835_aux.o
CC arm-softmmu/hw/char/virtio-serial-bus.o
CC alpha-softmmu/hw/display/virtio-gpu-pci.o
CC aarch64-softmmu/hw/core/generic-loader.o
CC aarch64-softmmu/hw/core/null-machine.o
CC alpha-softmmu/hw/misc/ivshmem.o
CC cris-softmmu/target/cris/op_helper.o
CC arm-softmmu/hw/core/generic-loader.o
CC aarch64-softmmu/hw/cpu/arm11mpcore.o
CC alpha-softmmu/hw/misc/mmio_interface.o
CC aarch64-softmmu/hw/cpu/realview_mpcore.o
CC arm-softmmu/hw/core/null-machine.o
CC cris-softmmu/target/cris/helper.o
CC alpha-softmmu/hw/net/virtio-net.o
CC aarch64-softmmu/hw/cpu/a9mpcore.o
CC arm-softmmu/hw/cpu/arm11mpcore.o
CC cris-softmmu/target/cris/cpu.o
CC aarch64-softmmu/hw/cpu/a15mpcore.o
CC cris-softmmu/target/cris/gdbstub.o
CC arm-softmmu/hw/cpu/realview_mpcore.o
CC aarch64-softmmu/hw/display/omap_dss.o
CC alpha-softmmu/hw/net/vhost_net.o
CC cris-softmmu/target/cris/mmu.o
CC arm-softmmu/hw/cpu/a9mpcore.o
CC alpha-softmmu/hw/scsi/virtio-scsi.o
CC arm-softmmu/hw/cpu/a15mpcore.o
CC cris-softmmu/target/cris/machine.o
CC aarch64-softmmu/hw/display/omap_lcdc.o
GEN trace/generated-helpers.c
CC arm-softmmu/hw/display/omap_dss.o
CC cris-softmmu/trace/control-target.o
CC alpha-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC aarch64-softmmu/hw/display/pxa2xx_lcd.o
CC cris-softmmu/trace/generated-helpers.o
CC arm-softmmu/hw/display/omap_lcdc.o
CC alpha-softmmu/hw/scsi/vhost-scsi-common.o
LINK cris-softmmu/qemu-system-cris
CC alpha-softmmu/hw/scsi/vhost-scsi.o
CC arm-softmmu/hw/display/pxa2xx_lcd.o
CC alpha-softmmu/hw/scsi/vhost-user-scsi.o
CC aarch64-softmmu/hw/display/bcm2835_fb.o
CC alpha-softmmu/hw/timer/mc146818rtc.o
CC arm-softmmu/hw/display/bcm2835_fb.o
CC aarch64-softmmu/hw/display/vga.o
CC arm-softmmu/hw/display/vga.o
CC alpha-softmmu/hw/vfio/pci.o
CC alpha-softmmu/hw/vfio/common.o
CC arm-softmmu/hw/display/virtio-gpu.o
CC aarch64-softmmu/hw/display/virtio-gpu.o
CC arm-softmmu/hw/display/virtio-gpu-3d.o
CC alpha-softmmu/hw/vfio/pci-quirks.o
CC arm-softmmu/hw/display/virtio-gpu-pci.o
CC arm-softmmu/hw/dma/omap_dma.o
CC alpha-softmmu/hw/vfio/platform.o
CC aarch64-softmmu/hw/display/virtio-gpu-3d.o
CC arm-softmmu/hw/dma/soc_dma.o
CC alpha-softmmu/hw/vfio/spapr.o
CC aarch64-softmmu/hw/display/virtio-gpu-pci.o
CC alpha-softmmu/hw/virtio/virtio.o
CC arm-softmmu/hw/dma/pxa2xx_dma.o
CC alpha-softmmu/hw/virtio/virtio-balloon.o
CC arm-softmmu/hw/dma/bcm2835_dma.o
CC aarch64-softmmu/hw/display/dpcd.o
CC alpha-softmmu/hw/virtio/vhost.o
CC arm-softmmu/hw/gpio/omap_gpio.o
CC aarch64-softmmu/hw/display/xlnx_dp.o
CC arm-softmmu/hw/gpio/imx_gpio.o
CC alpha-softmmu/hw/virtio/vhost-backend.o
CC aarch64-softmmu/hw/dma/xlnx_dpdma.o
CC arm-softmmu/hw/gpio/bcm2835_gpio.o
CC arm-softmmu/hw/i2c/omap_i2c.o
CC alpha-softmmu/hw/virtio/vhost-user.o
CC arm-softmmu/hw/input/pxa2xx_keypad.o
CC aarch64-softmmu/hw/dma/omap_dma.o
CC alpha-softmmu/hw/virtio/vhost-vsock.o
CC arm-softmmu/hw/input/tsc210x.o
CC alpha-softmmu/hw/virtio/virtio-crypto.o
CC aarch64-softmmu/hw/dma/soc_dma.o
CC arm-softmmu/hw/intc/armv7m_nvic.o
CC alpha-softmmu/hw/virtio/virtio-crypto-pci.o
CC aarch64-softmmu/hw/dma/pxa2xx_dma.o
GEN i386-softmmu/hmp-commands.h
GEN i386-softmmu/hmp-commands-info.h
GEN i386-softmmu/config-target.h
CC alpha-softmmu/hw/alpha/dp264.o
CC i386-softmmu/exec.o
CC aarch64-softmmu/hw/dma/bcm2835_dma.o
CC arm-softmmu/hw/intc/exynos4210_gic.o
CC aarch64-softmmu/hw/gpio/omap_gpio.o
CC arm-softmmu/hw/intc/exynos4210_combiner.o
CC alpha-softmmu/hw/alpha/pci.o
CC arm-softmmu/hw/intc/omap_intc.o
CC aarch64-softmmu/hw/gpio/imx_gpio.o
CC alpha-softmmu/hw/alpha/typhoon.o
CC aarch64-softmmu/hw/gpio/bcm2835_gpio.o
CC arm-softmmu/hw/intc/bcm2835_ic.o
CC aarch64-softmmu/hw/i2c/omap_i2c.o
CC alpha-softmmu/target/alpha/machine.o
CC arm-softmmu/hw/intc/bcm2836_control.o
CC aarch64-softmmu/hw/input/pxa2xx_keypad.o
CC arm-softmmu/hw/intc/allwinner-a10-pic.o
CC alpha-softmmu/target/alpha/translate.o
CC aarch64-softmmu/hw/input/tsc210x.o
CC i386-softmmu/tcg/tcg.o
CC arm-softmmu/hw/intc/aspeed_vic.o
CC aarch64-softmmu/hw/intc/armv7m_nvic.o
CC arm-softmmu/hw/intc/arm_gicv3_cpuif.o
CC alpha-softmmu/target/alpha/helper.o
CC aarch64-softmmu/hw/intc/exynos4210_gic.o
CC alpha-softmmu/target/alpha/cpu.o
CC aarch64-softmmu/hw/intc/exynos4210_combiner.o
CC arm-softmmu/hw/misc/ivshmem.o
CC alpha-softmmu/target/alpha/int_helper.o
CC i386-softmmu/tcg/tcg-op.o
CC aarch64-softmmu/hw/intc/omap_intc.o
CC alpha-softmmu/target/alpha/fpu_helper.o
CC arm-softmmu/hw/misc/arm_sysctl.o
CC arm-softmmu/hw/misc/cbus.o
CC aarch64-softmmu/hw/intc/bcm2835_ic.o
CC arm-softmmu/hw/misc/exynos4210_pmu.o
CC alpha-softmmu/target/alpha/vax_helper.o
CC aarch64-softmmu/hw/intc/bcm2836_control.o
CC alpha-softmmu/target/alpha/sys_helper.o
CC arm-softmmu/hw/misc/exynos4210_clk.o
CC aarch64-softmmu/hw/intc/allwinner-a10-pic.o
CC arm-softmmu/hw/misc/exynos4210_rng.o
CC alpha-softmmu/target/alpha/mem_helper.o
CC aarch64-softmmu/hw/intc/aspeed_vic.o
CC alpha-softmmu/target/alpha/gdbstub.o
CC arm-softmmu/hw/misc/imx_ccm.o
CC aarch64-softmmu/hw/intc/arm_gicv3_cpuif.o
GEN trace/generated-helpers.c
CC alpha-softmmu/trace/control-target.o
CC arm-softmmu/hw/misc/imx31_ccm.o
CC alpha-softmmu/trace/generated-helpers.o
CC i386-softmmu/tcg/optimize.o
CC arm-softmmu/hw/misc/imx25_ccm.o
LINK alpha-softmmu/qemu-system-alpha
CC arm-softmmu/hw/misc/imx6_ccm.o
CC aarch64-softmmu/hw/misc/ivshmem.o
CC i386-softmmu/tcg/tcg-common.o
CC arm-softmmu/hw/misc/imx6_src.o
CC i386-softmmu/fpu/softfloat.o
CC arm-softmmu/hw/misc/mst_fpga.o
CC aarch64-softmmu/hw/misc/arm_sysctl.o
CC arm-softmmu/hw/misc/omap_clk.o
CC aarch64-softmmu/hw/misc/cbus.o
CC arm-softmmu/hw/misc/omap_gpmc.o
CC aarch64-softmmu/hw/misc/exynos4210_pmu.o
GEN lm32-softmmu/hmp-commands.h
GEN lm32-softmmu/hmp-commands-info.h
GEN lm32-softmmu/config-target.h
CC lm32-softmmu/exec.o
CC arm-softmmu/hw/misc/omap_l4.o
CC aarch64-softmmu/hw/misc/exynos4210_clk.o
CC arm-softmmu/hw/misc/omap_sdrc.o
CC aarch64-softmmu/hw/misc/exynos4210_rng.o
CC arm-softmmu/hw/misc/omap_tap.o
CC aarch64-softmmu/hw/misc/imx_ccm.o
CC arm-softmmu/hw/misc/bcm2835_mbox.o
CC i386-softmmu/disas.o
CC aarch64-softmmu/hw/misc/imx31_ccm.o
CC arm-softmmu/hw/misc/bcm2835_property.o
GEN i386-softmmu/gdbstub-xml.c
CC aarch64-softmmu/hw/misc/imx25_ccm.o
CC aarch64-softmmu/hw/misc/imx6_ccm.o
CC i386-softmmu/arch_init.o
CC arm-softmmu/hw/misc/bcm2835_rng.o
CC aarch64-softmmu/hw/misc/imx6_src.o
CC lm32-softmmu/tcg/tcg.o
CC i386-softmmu/cpus.o
CC arm-softmmu/hw/misc/zynq_slcr.o
CC aarch64-softmmu/hw/misc/mst_fpga.o
CC arm-softmmu/hw/misc/zynq-xadc.o
CC aarch64-softmmu/hw/misc/omap_clk.o
CC i386-softmmu/monitor.o
CC arm-softmmu/hw/misc/stm32f2xx_syscfg.o
CC aarch64-softmmu/hw/misc/omap_gpmc.o
CC arm-softmmu/hw/misc/mps2-scc.o
CC aarch64-softmmu/hw/misc/omap_l4.o
CC arm-softmmu/hw/misc/aspeed_scu.o
CC aarch64-softmmu/hw/misc/omap_sdrc.o
CC lm32-softmmu/tcg/tcg-op.o
CC aarch64-softmmu/hw/misc/omap_tap.o
CC arm-softmmu/hw/misc/aspeed_sdmc.o
CC aarch64-softmmu/hw/misc/bcm2835_mbox.o
CC arm-softmmu/hw/misc/mmio_interface.o
CC i386-softmmu/gdbstub.o
CC aarch64-softmmu/hw/misc/bcm2835_property.o
CC arm-softmmu/hw/misc/msf2-sysreg.o
CC arm-softmmu/hw/net/virtio-net.o
CC i386-softmmu/balloon.o
CC aarch64-softmmu/hw/misc/bcm2835_rng.o
CC i386-softmmu/ioport.o
CC aarch64-softmmu/hw/misc/zynq_slcr.o
CC arm-softmmu/hw/net/vhost_net.o
CC arm-softmmu/hw/pcmcia/pxa2xx.o
CC aarch64-softmmu/hw/misc/zynq-xadc.o
CC i386-softmmu/numa.o
CC arm-softmmu/hw/scsi/virtio-scsi.o
CC aarch64-softmmu/hw/misc/stm32f2xx_syscfg.o
CC lm32-softmmu/tcg/optimize.o
CC aarch64-softmmu/hw/misc/mps2-scc.o
CC i386-softmmu/qtest.o
CC arm-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC aarch64-softmmu/hw/misc/auxbus.o
CC arm-softmmu/hw/scsi/vhost-scsi-common.o
CC lm32-softmmu/tcg/tcg-common.o
CC i386-softmmu/memory.o
CC aarch64-softmmu/hw/misc/aspeed_scu.o
CC arm-softmmu/hw/scsi/vhost-scsi.o
CC lm32-softmmu/fpu/softfloat.o
CC aarch64-softmmu/hw/misc/aspeed_sdmc.o
CC arm-softmmu/hw/scsi/vhost-user-scsi.o
CC arm-softmmu/hw/sd/omap_mmc.o
CC aarch64-softmmu/hw/misc/mmio_interface.o
CC i386-softmmu/memory_mapping.o
CC arm-softmmu/hw/sd/pxa2xx_mmci.o
CC aarch64-softmmu/hw/misc/msf2-sysreg.o
CC arm-softmmu/hw/sd/bcm2835_sdhost.o
CC i386-softmmu/dump.o
CC aarch64-softmmu/hw/net/virtio-net.o
CC arm-softmmu/hw/ssi/omap_spi.o
CC arm-softmmu/hw/ssi/imx_spi.o
CC i386-softmmu/migration/ram.o
CC aarch64-softmmu/hw/net/vhost_net.o
CC arm-softmmu/hw/timer/exynos4210_mct.o
CC lm32-softmmu/disas.o
CC aarch64-softmmu/hw/pcmcia/pxa2xx.o
CC aarch64-softmmu/hw/scsi/virtio-scsi.o
CC arm-softmmu/hw/timer/exynos4210_pwm.o
CC lm32-softmmu/arch_init.o
CC i386-softmmu/windbgstub.o
CC arm-softmmu/hw/timer/exynos4210_rtc.o
CC lm32-softmmu/cpus.o
CC aarch64-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC i386-softmmu/windbgstub-utils.o
CC arm-softmmu/hw/timer/omap_gptimer.o
CC aarch64-softmmu/hw/scsi/vhost-scsi-common.o
CC lm32-softmmu/monitor.o
CC i386-softmmu/accel/accel.o
CC aarch64-softmmu/hw/scsi/vhost-scsi.o
CC arm-softmmu/hw/timer/omap_synctimer.o
CC i386-softmmu/accel/stubs/hax-stub.o
CC aarch64-softmmu/hw/scsi/vhost-user-scsi.o
CC i386-softmmu/accel/stubs/kvm-stub.o
CC arm-softmmu/hw/timer/pxa2xx_timer.o
CC aarch64-softmmu/hw/sd/omap_mmc.o
CC arm-softmmu/hw/timer/digic-timer.o
CC i386-softmmu/accel/tcg/tcg-all.o
CC arm-softmmu/hw/timer/allwinner-a10-pit.o
CC i386-softmmu/accel/tcg/cputlb.o
CC aarch64-softmmu/hw/sd/pxa2xx_mmci.o
CC arm-softmmu/hw/usb/tusb6010.o
CC lm32-softmmu/gdbstub.o
CC arm-softmmu/hw/vfio/common.o
CC aarch64-softmmu/hw/sd/bcm2835_sdhost.o
CC aarch64-softmmu/hw/ssi/omap_spi.o
CC arm-softmmu/hw/vfio/pci.o
CC lm32-softmmu/balloon.o
CC i386-softmmu/accel/tcg/tcg-runtime.o
CC aarch64-softmmu/hw/ssi/imx_spi.o
CC lm32-softmmu/ioport.o
CC aarch64-softmmu/hw/timer/exynos4210_mct.o
CC i386-softmmu/accel/tcg/cpu-exec.o
CC aarch64-softmmu/hw/timer/exynos4210_pwm.o
CC lm32-softmmu/numa.o
CC i386-softmmu/accel/tcg/cpu-exec-common.o
CC arm-softmmu/hw/vfio/pci-quirks.o
CC aarch64-softmmu/hw/timer/exynos4210_rtc.o
CC i386-softmmu/accel/tcg/translate-all.o
CC lm32-softmmu/qtest.o
CC aarch64-softmmu/hw/timer/omap_gptimer.o
CC arm-softmmu/hw/vfio/platform.o
CC lm32-softmmu/memory.o
CC i386-softmmu/accel/tcg/translator.o
CC aarch64-softmmu/hw/timer/omap_synctimer.o
CC arm-softmmu/hw/vfio/calxeda-xgmac.o
CC aarch64-softmmu/hw/timer/pxa2xx_timer.o
CC i386-softmmu/hw/9pfs/virtio-9p-device.o
CC arm-softmmu/hw/vfio/amd-xgbe.o
CC i386-softmmu/hw/block/virtio-blk.o
CC aarch64-softmmu/hw/timer/digic-timer.o
CC arm-softmmu/hw/vfio/spapr.o
CC aarch64-softmmu/hw/timer/allwinner-a10-pit.o
CC lm32-softmmu/memory_mapping.o
CC i386-softmmu/hw/block/dataplane/virtio-blk.o
CC arm-softmmu/hw/virtio/virtio.o
CC lm32-softmmu/dump.o
CC aarch64-softmmu/hw/usb/tusb6010.o
CC i386-softmmu/hw/char/virtio-serial-bus.o
CC aarch64-softmmu/hw/vfio/common.o
CC i386-softmmu/hw/core/generic-loader.o
CC lm32-softmmu/migration/ram.o
CC arm-softmmu/hw/virtio/virtio-balloon.o
CC i386-softmmu/hw/core/null-machine.o
CC aarch64-softmmu/hw/vfio/pci.o
CC i386-softmmu/hw/display/vga.o
CC arm-softmmu/hw/virtio/vhost.o
CC lm32-softmmu/accel/accel.o
CC aarch64-softmmu/hw/vfio/pci-quirks.o
CC i386-softmmu/hw/display/virtio-gpu.o
CC lm32-softmmu/accel/stubs/hax-stub.o
CC arm-softmmu/hw/virtio/vhost-backend.o
CC arm-softmmu/hw/virtio/vhost-user.o
CC lm32-softmmu/accel/stubs/kvm-stub.o
CC aarch64-softmmu/hw/vfio/platform.o
CC lm32-softmmu/accel/tcg/tcg-all.o
CC i386-softmmu/hw/display/virtio-gpu-3d.o
CC arm-softmmu/hw/virtio/vhost-vsock.o
CC aarch64-softmmu/hw/vfio/calxeda-xgmac.o
CC lm32-softmmu/accel/tcg/cputlb.o
CC aarch64-softmmu/hw/vfio/amd-xgbe.o
CC arm-softmmu/hw/virtio/virtio-crypto.o
CC i386-softmmu/hw/display/virtio-gpu-pci.o
CC aarch64-softmmu/hw/vfio/spapr.o
CC arm-softmmu/hw/virtio/virtio-crypto-pci.o
CC aarch64-softmmu/hw/virtio/virtio.o
CC i386-softmmu/hw/display/virtio-vga.o
CC arm-softmmu/hw/arm/boot.o
CC lm32-softmmu/accel/tcg/tcg-runtime.o
CC i386-softmmu/hw/intc/apic.o
CC arm-softmmu/hw/arm/collie.o
CC lm32-softmmu/accel/tcg/cpu-exec.o
CC aarch64-softmmu/hw/virtio/virtio-balloon.o
CC arm-softmmu/hw/arm/exynos4_boards.o
CC lm32-softmmu/accel/tcg/cpu-exec-common.o
CC i386-softmmu/hw/intc/apic_common.o
CC aarch64-softmmu/hw/virtio/vhost.o
CC i386-softmmu/hw/intc/ioapic.o
CC lm32-softmmu/accel/tcg/translate-all.o
CC arm-softmmu/hw/arm/gumstix.o
CC i386-softmmu/hw/isa/lpc_ich9.o
CC arm-softmmu/hw/arm/highbank.o
CC lm32-softmmu/accel/tcg/translator.o
CC aarch64-softmmu/hw/virtio/vhost-backend.o
CC i386-softmmu/hw/misc/vmport.o
CC lm32-softmmu/hw/core/generic-loader.o
CC arm-softmmu/hw/arm/digic_boards.o
CC aarch64-softmmu/hw/virtio/vhost-user.o
CC lm32-softmmu/hw/core/null-machine.o
CC i386-softmmu/hw/misc/ivshmem.o
CC arm-softmmu/hw/arm/integratorcp.o
CC lm32-softmmu/hw/input/milkymist-softusb.o
CC aarch64-softmmu/hw/virtio/vhost-vsock.o
CC arm-softmmu/hw/arm/mainstone.o
CC i386-softmmu/hw/misc/pvpanic.o
CC lm32-softmmu/hw/misc/milkymist-hpdmc.o
CC aarch64-softmmu/hw/virtio/virtio-crypto.o
CC arm-softmmu/hw/arm/musicpal.o
CC i386-softmmu/hw/misc/mmio_interface.o
CC lm32-softmmu/hw/misc/milkymist-pfpu.o
CC aarch64-softmmu/hw/virtio/virtio-crypto-pci.o
CC i386-softmmu/hw/net/virtio-net.o
CC lm32-softmmu/hw/misc/mmio_interface.o
CC arm-softmmu/hw/arm/nseries.o
CC aarch64-softmmu/hw/arm/boot.o
CC lm32-softmmu/hw/net/milkymist-minimac2.o
CC i386-softmmu/hw/net/vhost_net.o
CC aarch64-softmmu/hw/arm/collie.o
CC lm32-softmmu/hw/net/vhost_net.o
CC arm-softmmu/hw/arm/omap_sx1.o
CC i386-softmmu/hw/scsi/virtio-scsi.o
CC aarch64-softmmu/hw/arm/exynos4_boards.o
CC lm32-softmmu/hw/net/rocker/qmp-norocker.o
CC arm-softmmu/hw/arm/palm.o
CC aarch64-softmmu/hw/arm/gumstix.o
CC lm32-softmmu/hw/sd/milkymist-memcard.o
CC i386-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC aarch64-softmmu/hw/arm/highbank.o
CC arm-softmmu/hw/arm/realview.o
CC lm32-softmmu/hw/vfio/common.o
CC i386-softmmu/hw/scsi/vhost-scsi-common.o
CC arm-softmmu/hw/arm/spitz.o
CC aarch64-softmmu/hw/arm/digic_boards.o
CC i386-softmmu/hw/scsi/vhost-scsi.o
CC lm32-softmmu/hw/vfio/platform.o
CC aarch64-softmmu/hw/arm/integratorcp.o
CC i386-softmmu/hw/scsi/vhost-user-scsi.o
CC arm-softmmu/hw/arm/stellaris.o
CC lm32-softmmu/hw/vfio/spapr.o
CC i386-softmmu/hw/timer/mc146818rtc.o
CC aarch64-softmmu/hw/arm/mainstone.o
CC lm32-softmmu/hw/lm32/lm32_boards.o
CC arm-softmmu/hw/arm/tosa.o
CC i386-softmmu/hw/vfio/common.o
CC aarch64-softmmu/hw/arm/musicpal.o
CC lm32-softmmu/hw/lm32/milkymist.o
CC arm-softmmu/hw/arm/versatilepb.o
CC i386-softmmu/hw/vfio/pci.o
CC lm32-softmmu/target/lm32/translate.o
CC arm-softmmu/hw/arm/vexpress.o
CC aarch64-softmmu/hw/arm/nseries.o
CC lm32-softmmu/target/lm32/op_helper.o
CC arm-softmmu/hw/arm/virt.o
CC i386-softmmu/hw/vfio/pci-quirks.o
CC aarch64-softmmu/hw/arm/omap_sx1.o
CC lm32-softmmu/target/lm32/helper.o
CC aarch64-softmmu/hw/arm/palm.o
CC arm-softmmu/hw/arm/xilinx_zynq.o
CC lm32-softmmu/target/lm32/cpu.o
CC i386-softmmu/hw/vfio/platform.o
CC aarch64-softmmu/hw/arm/realview.o
CC arm-softmmu/hw/arm/z2.o
CC lm32-softmmu/target/lm32/gdbstub.o
CC aarch64-softmmu/hw/arm/spitz.o
CC i386-softmmu/hw/vfio/spapr.o
CC lm32-softmmu/target/lm32/lm32-semi.o
CC arm-softmmu/hw/arm/virt-acpi-build.o
CC i386-softmmu/hw/virtio/virtio.o
CC lm32-softmmu/target/lm32/machine.o
CC arm-softmmu/hw/arm/netduino2.o
CC aarch64-softmmu/hw/arm/stellaris.o
GEN trace/generated-helpers.c
CC lm32-softmmu/trace/control-target.o
CC i386-softmmu/hw/virtio/virtio-balloon.o
CC arm-softmmu/hw/arm/sysbus-fdt.o
CC lm32-softmmu/trace/generated-helpers.o
CC aarch64-softmmu/hw/arm/tosa.o
CC arm-softmmu/hw/arm/armv7m.o
LINK lm32-softmmu/qemu-system-lm32
CC i386-softmmu/hw/virtio/vhost.o
CC aarch64-softmmu/hw/arm/versatilepb.o
CC arm-softmmu/hw/arm/exynos4210.o
CC aarch64-softmmu/hw/arm/vexpress.o
CC arm-softmmu/hw/arm/pxa2xx.o
CC i386-softmmu/hw/virtio/vhost-backend.o
CC aarch64-softmmu/hw/arm/virt.o
CC i386-softmmu/hw/virtio/vhost-user.o
GEN m68k-softmmu/hmp-commands.h
GEN m68k-softmmu/hmp-commands-info.h
GEN m68k-softmmu/config-target.h
CC m68k-softmmu/exec.o
CC i386-softmmu/hw/virtio/vhost-vsock.o
CC arm-softmmu/hw/arm/pxa2xx_gpio.o
CC aarch64-softmmu/hw/arm/xilinx_zynq.o
CC arm-softmmu/hw/arm/pxa2xx_pic.o
CC i386-softmmu/hw/virtio/virtio-crypto.o
CC aarch64-softmmu/hw/arm/z2.o
CC arm-softmmu/hw/arm/digic.o
CC i386-softmmu/hw/virtio/virtio-crypto-pci.o
CC arm-softmmu/hw/arm/omap1.o
CC aarch64-softmmu/hw/arm/virt-acpi-build.o
CC i386-softmmu/hw/i386/multiboot.o
CC m68k-softmmu/tcg/tcg.o
CC aarch64-softmmu/hw/arm/netduino2.o
CC i386-softmmu/hw/i386/pc.o
CC aarch64-softmmu/hw/arm/sysbus-fdt.o
CC arm-softmmu/hw/arm/omap2.o
CC aarch64-softmmu/hw/arm/armv7m.o
CC i386-softmmu/hw/i386/pc_piix.o
CC aarch64-softmmu/hw/arm/exynos4210.o
CC m68k-softmmu/tcg/tcg-op.o
CC arm-softmmu/hw/arm/strongarm.o
CC aarch64-softmmu/hw/arm/pxa2xx.o
CC i386-softmmu/hw/i386/pc_q35.o
CC arm-softmmu/hw/arm/allwinner-a10.o
CC i386-softmmu/hw/i386/pc_sysfw.o
CC arm-softmmu/hw/arm/cubieboard.o
CC i386-softmmu/hw/i386/x86-iommu.o
CC aarch64-softmmu/hw/arm/pxa2xx_gpio.o
CC arm-softmmu/hw/arm/bcm2835_peripherals.o
CC aarch64-softmmu/hw/arm/pxa2xx_pic.o
CC i386-softmmu/hw/i386/intel_iommu.o
CC aarch64-softmmu/hw/arm/digic.o
CC arm-softmmu/hw/arm/bcm2836.o
CC aarch64-softmmu/hw/arm/omap1.o
CC m68k-softmmu/tcg/optimize.o
CC arm-softmmu/hw/arm/raspi.o
CC i386-softmmu/hw/i386/amd_iommu.o
CC m68k-softmmu/tcg/tcg-common.o
CC arm-softmmu/hw/arm/stm32f205_soc.o
CC i386-softmmu/hw/i386/kvmvapic.o
CC aarch64-softmmu/hw/arm/omap2.o
CC m68k-softmmu/fpu/softfloat.o
CC arm-softmmu/hw/arm/fsl-imx25.o
CC i386-softmmu/hw/i386/acpi-build.o
CC arm-softmmu/hw/arm/imx25_pdk.o
CC aarch64-softmmu/hw/arm/strongarm.o
CC arm-softmmu/hw/arm/fsl-imx31.o
CC i386-softmmu/hw/i386/pci-assign-load-rom.o
CC aarch64-softmmu/hw/arm/allwinner-a10.o
CC arm-softmmu/hw/arm/kzm.o
CC arm-softmmu/hw/arm/fsl-imx6.o
CC aarch64-softmmu/hw/arm/cubieboard.o
CC i386-softmmu/target/i386/helper.o
CC m68k-softmmu/disas.o
CC aarch64-softmmu/hw/arm/bcm2835_peripherals.o
CC arm-softmmu/hw/arm/sabrelite.o
GEN m68k-softmmu/gdbstub-xml.c
CC aarch64-softmmu/hw/arm/bcm2836.o
CC i386-softmmu/target/i386/cpu.o
CC arm-softmmu/hw/arm/aspeed_soc.o
CC m68k-softmmu/arch_init.o
CC aarch64-softmmu/hw/arm/raspi.o
CC arm-softmmu/hw/arm/aspeed.o
CC m68k-softmmu/cpus.o
CC i386-softmmu/target/i386/gdbstub.o
CC aarch64-softmmu/hw/arm/stm32f205_soc.o
CC arm-softmmu/hw/arm/mps2.o
CC i386-softmmu/target/i386/windbgstub.o
CC aarch64-softmmu/hw/arm/xlnx-zynqmp.o
CC arm-softmmu/hw/arm/msf2-soc.o
CC m68k-softmmu/monitor.o
CC i386-softmmu/target/i386/xsave_helper.o
CC aarch64-softmmu/hw/arm/xlnx-zcu102.o
CC arm-softmmu/hw/arm/msf2-som.o
CC i386-softmmu/target/i386/translate.o
CC arm-softmmu/target/arm/arm-semi.o
CC aarch64-softmmu/hw/arm/fsl-imx25.o
CC arm-softmmu/target/arm/machine.o
CC aarch64-softmmu/hw/arm/imx25_pdk.o
CC m68k-softmmu/gdbstub.o
CC aarch64-softmmu/hw/arm/fsl-imx31.o
CC arm-softmmu/target/arm/psci.o
CC arm-softmmu/target/arm/arch_dump.o
CC aarch64-softmmu/hw/arm/kzm.o
CC m68k-softmmu/balloon.o
CC arm-softmmu/target/arm/monitor.o
CC aarch64-softmmu/hw/arm/fsl-imx6.o
CC m68k-softmmu/ioport.o
CC arm-softmmu/target/arm/kvm-stub.o
CC m68k-softmmu/numa.o
CC arm-softmmu/target/arm/translate.o
CC aarch64-softmmu/hw/arm/sabrelite.o
CC aarch64-softmmu/hw/arm/aspeed_soc.o
CC m68k-softmmu/qtest.o
CC aarch64-softmmu/hw/arm/aspeed.o
CC m68k-softmmu/memory.o
CC aarch64-softmmu/hw/arm/mps2.o
CC aarch64-softmmu/hw/arm/msf2-soc.o
CC m68k-softmmu/memory_mapping.o
CC aarch64-softmmu/hw/arm/msf2-som.o
CC m68k-softmmu/dump.o
CC aarch64-softmmu/target/arm/arm-semi.o
CC i386-softmmu/target/i386/bpt_helper.o
CC i386-softmmu/target/i386/cc_helper.o
CC aarch64-softmmu/target/arm/machine.o
CC m68k-softmmu/migration/ram.o
CC aarch64-softmmu/target/arm/psci.o
CC i386-softmmu/target/i386/excp_helper.o
CC aarch64-softmmu/target/arm/arch_dump.o
CC i386-softmmu/target/i386/fpu_helper.o
CC aarch64-softmmu/target/arm/monitor.o
CC m68k-softmmu/accel/accel.o
CC arm-softmmu/target/arm/op_helper.o
CC aarch64-softmmu/target/arm/kvm-stub.o
CC m68k-softmmu/accel/stubs/hax-stub.o
CC aarch64-softmmu/target/arm/translate.o
CC m68k-softmmu/accel/stubs/kvm-stub.o
CC m68k-softmmu/accel/tcg/tcg-all.o
CC m68k-softmmu/accel/tcg/cputlb.o
CC arm-softmmu/target/arm/helper.o
CC i386-softmmu/target/i386/int_helper.o
CC m68k-softmmu/accel/tcg/tcg-runtime.o
CC i386-softmmu/target/i386/mem_helper.o
CC m68k-softmmu/accel/tcg/cpu-exec.o
CC i386-softmmu/target/i386/misc_helper.o
CC i386-softmmu/target/i386/mpx_helper.o
CC m68k-softmmu/accel/tcg/cpu-exec-common.o
CC m68k-softmmu/accel/tcg/translate-all.o
CC i386-softmmu/target/i386/seg_helper.o
CC m68k-softmmu/accel/tcg/translator.o
CC arm-softmmu/target/arm/cpu.o
CC aarch64-softmmu/target/arm/op_helper.o
CC m68k-softmmu/hw/char/mcf_uart.o
CC arm-softmmu/target/arm/neon_helper.o
CC m68k-softmmu/hw/core/generic-loader.o
CC aarch64-softmmu/target/arm/helper.o
CC m68k-softmmu/hw/core/null-machine.o
CC m68k-softmmu/hw/misc/mmio_interface.o
CC i386-softmmu/target/i386/smm_helper.o
CC arm-softmmu/target/arm/iwmmxt_helper.o
CC i386-softmmu/target/i386/svm_helper.o
CC m68k-softmmu/hw/net/mcf_fec.o
CC m68k-softmmu/hw/net/vhost_net.o
CC i386-softmmu/target/i386/machine.o
CC arm-softmmu/target/arm/gdbstub.o
CC m68k-softmmu/hw/net/rocker/qmp-norocker.o
CC arm-softmmu/target/arm/crypto_helper.o
CC i386-softmmu/target/i386/arch_memory_mapping.o
CC m68k-softmmu/hw/vfio/common.o
CC i386-softmmu/target/i386/arch_dump.o
CC arm-softmmu/target/arm/arm-powerctl.o
CC i386-softmmu/target/i386/monitor.o
CC m68k-softmmu/hw/vfio/platform.o
GEN trace/generated-helpers.c
CC arm-softmmu/trace/control-target.o
CC i386-softmmu/target/i386/kvm-stub.o
CC m68k-softmmu/hw/vfio/spapr.o
CC arm-softmmu/gdbstub-xml.o
GEN trace/generated-helpers.c
CC aarch64-softmmu/target/arm/cpu.o
CC i386-softmmu/trace/control-target.o
CC m68k-softmmu/hw/m68k/an5206.o
CC arm-softmmu/trace/generated-helpers.o
CC i386-softmmu/gdbstub-xml.o
CC i386-softmmu/trace/generated-helpers.o
CC m68k-softmmu/hw/m68k/mcf5208.o
LINK i386-softmmu/qemu-system-i386
LINK arm-softmmu/qemu-system-arm
CC aarch64-softmmu/target/arm/neon_helper.o
CC m68k-softmmu/hw/m68k/mcf5206.o
CC m68k-softmmu/hw/m68k/mcf_intc.o
CC m68k-softmmu/target/m68k/m68k-semi.o
CC m68k-softmmu/target/m68k/translate.o
CC aarch64-softmmu/target/arm/iwmmxt_helper.o
GEN microblazeel-softmmu/hmp-commands.h
GEN microblazeel-softmmu/hmp-commands-info.h
GEN microblazeel-softmmu/config-target.h
CC aarch64-softmmu/target/arm/gdbstub.o
CC microblazeel-softmmu/exec.o
CC aarch64-softmmu/target/arm/cpu64.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 m68k-softmmu/target/m68k/op_helper.o
CC aarch64-softmmu/target/arm/translate-a64.o
CC m68k-softmmu/target/m68k/helper.o
CC m68k-softmmu/target/m68k/cpu.o
CC microblaze-softmmu/tcg/tcg.o
CC microblazeel-softmmu/tcg/tcg.o
CC m68k-softmmu/target/m68k/fpu_helper.o
CC m68k-softmmu/target/m68k/gdbstub.o
GEN trace/generated-helpers.c
CC m68k-softmmu/trace/control-target.o
CC m68k-softmmu/gdbstub-xml.o
CC microblaze-softmmu/tcg/tcg-op.o
CC microblazeel-softmmu/tcg/tcg-op.o
CC m68k-softmmu/trace/generated-helpers.o
CC aarch64-softmmu/target/arm/helper-a64.o
LINK m68k-softmmu/qemu-system-m68k
CC aarch64-softmmu/target/arm/gdbstub64.o
CC aarch64-softmmu/target/arm/crypto_helper.o
CC aarch64-softmmu/target/arm/arm-powerctl.o
CC microblazeel-softmmu/tcg/optimize.o
CC microblaze-softmmu/tcg/optimize.o
GEN trace/generated-helpers.c
GEN mips64el-softmmu/hmp-commands.h
CC aarch64-softmmu/trace/control-target.o
GEN mips64el-softmmu/hmp-commands-info.h
GEN mips64el-softmmu/config-target.h
CC mips64el-softmmu/exec.o
CC aarch64-softmmu/gdbstub-xml.o
CC microblazeel-softmmu/tcg/tcg-common.o
CC microblazeel-softmmu/fpu/softfloat.o
CC microblaze-softmmu/tcg/tcg-common.o
CC aarch64-softmmu/trace/generated-helpers.o
CC microblaze-softmmu/fpu/softfloat.o
LINK aarch64-softmmu/qemu-system-aarch64
CC mips64el-softmmu/tcg/tcg.o
CC microblazeel-softmmu/disas.o
CC mips64el-softmmu/tcg/tcg-op.o
CC microblazeel-softmmu/arch_init.o
CC microblazeel-softmmu/cpus.o
CC microblaze-softmmu/disas.o
CC microblaze-softmmu/arch_init.o
CC microblazeel-softmmu/monitor.o
CC microblaze-softmmu/cpus.o
CC microblaze-softmmu/monitor.o
GEN mips64-softmmu/hmp-commands.h
GEN mips64-softmmu/hmp-commands-info.h
GEN mips64-softmmu/config-target.h
CC mips64-softmmu/exec.o
CC microblazeel-softmmu/gdbstub.o
CC mips64el-softmmu/tcg/optimize.o
CC microblazeel-softmmu/balloon.o
CC microblazeel-softmmu/ioport.o
CC microblaze-softmmu/gdbstub.o
CC mips64el-softmmu/tcg/tcg-common.o
CC mips64el-softmmu/fpu/softfloat.o
CC microblazeel-softmmu/numa.o
CC microblaze-softmmu/balloon.o
CC mips64-softmmu/tcg/tcg.o
CC microblazeel-softmmu/qtest.o
CC microblaze-softmmu/ioport.o
CC microblazeel-softmmu/memory.o
CC microblaze-softmmu/numa.o
CC microblaze-softmmu/qtest.o
CC microblaze-softmmu/memory.o
CC microblazeel-softmmu/memory_mapping.o
CC mips64-softmmu/tcg/tcg-op.o
CC mips64el-softmmu/disas.o
CC microblazeel-softmmu/dump.o
CC mips64el-softmmu/arch_init.o
CC mips64el-softmmu/cpus.o
CC microblaze-softmmu/memory_mapping.o
CC microblazeel-softmmu/migration/ram.o
CC microblaze-softmmu/dump.o
CC mips64el-softmmu/monitor.o
CC microblaze-softmmu/migration/ram.o
CC microblazeel-softmmu/accel/accel.o
CC microblazeel-softmmu/accel/stubs/hax-stub.o
CC mips64-softmmu/tcg/optimize.o
CC microblazeel-softmmu/accel/stubs/kvm-stub.o
CC microblaze-softmmu/accel/accel.o
CC microblazeel-softmmu/accel/tcg/tcg-all.o
CC microblaze-softmmu/accel/stubs/hax-stub.o
CC mips64el-softmmu/gdbstub.o
CC microblaze-softmmu/accel/stubs/kvm-stub.o
CC microblazeel-softmmu/accel/tcg/cputlb.o
CC microblaze-softmmu/accel/tcg/tcg-all.o
CC mips64-softmmu/tcg/tcg-common.o
CC microblaze-softmmu/accel/tcg/cputlb.o
CC mips64-softmmu/fpu/softfloat.o
CC mips64el-softmmu/balloon.o
CC mips64el-softmmu/ioport.o
CC microblazeel-softmmu/accel/tcg/tcg-runtime.o
CC mips64el-softmmu/numa.o
CC microblazeel-softmmu/accel/tcg/cpu-exec.o
CC microblazeel-softmmu/accel/tcg/cpu-exec-common.o
CC mips64el-softmmu/qtest.o
CC microblaze-softmmu/accel/tcg/tcg-runtime.o
CC microblazeel-softmmu/accel/tcg/translate-all.o
CC microblaze-softmmu/accel/tcg/cpu-exec.o
CC microblazeel-softmmu/accel/tcg/translator.o
CC mips64el-softmmu/memory.o
CC microblaze-softmmu/accel/tcg/cpu-exec-common.o
CC microblazeel-softmmu/hw/core/generic-loader.o
CC mips64-softmmu/disas.o
CC microblazeel-softmmu/hw/core/null-machine.o
CC microblaze-softmmu/accel/tcg/translate-all.o
CC mips64el-softmmu/memory_mapping.o
CC microblazeel-softmmu/hw/misc/mmio_interface.o
CC mips64-softmmu/arch_init.o
CC mips64el-softmmu/dump.o
CC microblazeel-softmmu/hw/net/xilinx_ethlite.o
CC microblaze-softmmu/accel/tcg/translator.o
CC mips64-softmmu/cpus.o
CC microblazeel-softmmu/hw/net/vhost_net.o
CC microblaze-softmmu/hw/core/generic-loader.o
CC microblazeel-softmmu/hw/net/rocker/qmp-norocker.o
CC mips64el-softmmu/migration/ram.o
CC microblaze-softmmu/hw/core/null-machine.o
CC microblazeel-softmmu/hw/vfio/common.o
CC microblaze-softmmu/hw/misc/mmio_interface.o
CC mips64-softmmu/monitor.o
CC microblaze-softmmu/hw/net/xilinx_ethlite.o
CC microblazeel-softmmu/hw/vfio/platform.o
CC microblaze-softmmu/hw/net/vhost_net.o
CC mips64el-softmmu/accel/accel.o
CC microblaze-softmmu/hw/net/rocker/qmp-norocker.o
CC microblazeel-softmmu/hw/vfio/spapr.o
CC mips64el-softmmu/accel/stubs/hax-stub.o
CC microblaze-softmmu/hw/vfio/common.o
CC microblazeel-softmmu/hw/microblaze/petalogix_s3adsp1800_mmu.o
CC mips64el-softmmu/accel/stubs/kvm-stub.o
CC microblazeel-softmmu/hw/microblaze/petalogix_ml605_mmu.o
CC mips64el-softmmu/accel/tcg/tcg-all.o
CC mips64-softmmu/gdbstub.o
CC microblaze-softmmu/hw/vfio/platform.o
CC mips64el-softmmu/accel/tcg/cputlb.o
CC microblazeel-softmmu/hw/microblaze/boot.o
CC microblaze-softmmu/hw/vfio/spapr.o
CC mips64-softmmu/balloon.o
CC microblazeel-softmmu/target/microblaze/translate.o
CC microblaze-softmmu/hw/microblaze/petalogix_s3adsp1800_mmu.o
CC mips64-softmmu/ioport.o
CC microblaze-softmmu/hw/microblaze/petalogix_ml605_mmu.o
CC mips64-softmmu/numa.o
CC mips64el-softmmu/accel/tcg/tcg-runtime.o
CC microblaze-softmmu/hw/microblaze/boot.o
CC mips64el-softmmu/accel/tcg/cpu-exec.o
CC microblazeel-softmmu/target/microblaze/op_helper.o
CC mips64-softmmu/qtest.o
CC microblaze-softmmu/target/microblaze/translate.o
CC microblazeel-softmmu/target/microblaze/helper.o
CC mips64el-softmmu/accel/tcg/cpu-exec-common.o
CC mips64-softmmu/memory.o
CC mips64el-softmmu/accel/tcg/translate-all.o
CC microblazeel-softmmu/target/microblaze/cpu.o
CC microblazeel-softmmu/target/microblaze/gdbstub.o
CC mips64el-softmmu/accel/tcg/translator.o
CC microblazeel-softmmu/target/microblaze/mmu.o
CC microblaze-softmmu/target/microblaze/op_helper.o
GEN trace/generated-helpers.c
CC microblazeel-softmmu/trace/control-target.o
CC mips64-softmmu/memory_mapping.o
CC mips64el-softmmu/hw/9pfs/virtio-9p-device.o
CC microblaze-softmmu/target/microblaze/helper.o
CC mips64el-softmmu/hw/block/virtio-blk.o
CC mips64-softmmu/dump.o
CC microblaze-softmmu/target/microblaze/cpu.o
CC microblazeel-softmmu/trace/generated-helpers.o
CC microblaze-softmmu/target/microblaze/gdbstub.o
CC mips64el-softmmu/hw/block/dataplane/virtio-blk.o
LINK microblazeel-softmmu/qemu-system-microblazeel
CC microblaze-softmmu/target/microblaze/mmu.o
CC mips64-softmmu/migration/ram.o
CC mips64el-softmmu/hw/char/virtio-serial-bus.o
GEN trace/generated-helpers.c
CC microblaze-softmmu/trace/control-target.o
CC mips64el-softmmu/hw/core/generic-loader.o
CC microblaze-softmmu/trace/generated-helpers.o
CC mips64-softmmu/accel/accel.o
CC mips64el-softmmu/hw/core/null-machine.o
LINK microblaze-softmmu/qemu-system-microblaze
CC mips64-softmmu/accel/stubs/hax-stub.o
CC mips64-softmmu/accel/stubs/kvm-stub.o
CC mips64el-softmmu/hw/display/vga.o
CC mips64-softmmu/accel/tcg/tcg-all.o
CC mips64-softmmu/accel/tcg/cputlb.o
CC mips64el-softmmu/hw/display/virtio-gpu.o
CC mips64el-softmmu/hw/display/virtio-gpu-3d.o
CC mips64el-softmmu/hw/display/virtio-gpu-pci.o
GEN mipsel-softmmu/hmp-commands.h
GEN mipsel-softmmu/hmp-commands-info.h
GEN mipsel-softmmu/config-target.h
CC mipsel-softmmu/exec.o
CC mips64el-softmmu/hw/intc/mips_gic.o
CC mips64-softmmu/accel/tcg/tcg-runtime.o
CC mipsel-softmmu/tcg/tcg.o
CC mips64-softmmu/accel/tcg/cpu-exec.o
CC mips64el-softmmu/hw/misc/ivshmem.o
CC mips64-softmmu/accel/tcg/cpu-exec-common.o
CC mips64el-softmmu/hw/misc/mips_cmgcr.o
CC mips64-softmmu/accel/tcg/translate-all.o
CC mips64el-softmmu/hw/misc/mips_cpc.o
CC mips64el-softmmu/hw/misc/mips_itu.o
CC mips64-softmmu/accel/tcg/translator.o
CC mips64el-softmmu/hw/misc/mmio_interface.o
CC mips64el-softmmu/hw/net/virtio-net.o
CC mipsel-softmmu/tcg/tcg-op.o
CC mips64-softmmu/hw/9pfs/virtio-9p-device.o
CC mips64el-softmmu/hw/net/vhost_net.o
CC mips64-softmmu/hw/block/virtio-blk.o
CC mips64el-softmmu/hw/scsi/virtio-scsi.o
GEN mips-softmmu/hmp-commands.h
CC mips64-softmmu/hw/block/dataplane/virtio-blk.o
GEN mips-softmmu/hmp-commands-info.h
GEN mips-softmmu/config-target.h
CC mips-softmmu/exec.o
CC mips64el-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC mips64-softmmu/hw/char/virtio-serial-bus.o
CC mips64el-softmmu/hw/scsi/vhost-scsi-common.o
CC mips64el-softmmu/hw/scsi/vhost-scsi.o
CC mips64-softmmu/hw/core/generic-loader.o
CC mips64el-softmmu/hw/scsi/vhost-user-scsi.o
CC mipsel-softmmu/tcg/optimize.o
CC mips64-softmmu/hw/core/null-machine.o
CC mips64el-softmmu/hw/timer/mips_gictimer.o
CC mips64-softmmu/hw/display/vga.o
CC mips64el-softmmu/hw/timer/mc146818rtc.o
CC mips-softmmu/tcg/tcg.o
CC mipsel-softmmu/tcg/tcg-common.o
CC mips64el-softmmu/hw/vfio/common.o
CC mips64-softmmu/hw/display/virtio-gpu.o
CC mipsel-softmmu/fpu/softfloat.o
CC mips64el-softmmu/hw/vfio/pci.o
CC mips64-softmmu/hw/display/virtio-gpu-3d.o
CC mips-softmmu/tcg/tcg-op.o
CC mips64-softmmu/hw/display/virtio-gpu-pci.o
CC mips64el-softmmu/hw/vfio/pci-quirks.o
CC mips64-softmmu/hw/intc/mips_gic.o
CC mips64el-softmmu/hw/vfio/platform.o
CC mips64-softmmu/hw/misc/ivshmem.o
CC mips64el-softmmu/hw/vfio/spapr.o
CC mips64-softmmu/hw/misc/mips_cmgcr.o
CC mipsel-softmmu/disas.o
CC mips64el-softmmu/hw/virtio/virtio.o
CC mipsel-softmmu/arch_init.o
CC mips64-softmmu/hw/misc/mips_cpc.o
CC mipsel-softmmu/cpus.o
CC mips64-softmmu/hw/misc/mips_itu.o
CC mips-softmmu/tcg/optimize.o
CC mips64el-softmmu/hw/virtio/virtio-balloon.o
CC mips64-softmmu/hw/misc/mmio_interface.o
CC mipsel-softmmu/monitor.o
CC mips64-softmmu/hw/net/virtio-net.o
CC mips64el-softmmu/hw/virtio/vhost.o
CC mips-softmmu/tcg/tcg-common.o
CC mips64-softmmu/hw/net/vhost_net.o
CC mips64-softmmu/hw/scsi/virtio-scsi.o
CC mips-softmmu/fpu/softfloat.o
CC mipsel-softmmu/gdbstub.o
CC mips64el-softmmu/hw/virtio/vhost-backend.o
CC mips64el-softmmu/hw/virtio/vhost-user.o
CC mips64-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC mips64el-softmmu/hw/virtio/vhost-vsock.o
CC mipsel-softmmu/balloon.o
CC mips64-softmmu/hw/scsi/vhost-scsi-common.o
CC mipsel-softmmu/ioport.o
CC mips64el-softmmu/hw/virtio/virtio-crypto.o
CC mips64-softmmu/hw/scsi/vhost-scsi.o
CC mipsel-softmmu/numa.o
CC mips64-softmmu/hw/scsi/vhost-user-scsi.o
CC mips64el-softmmu/hw/virtio/virtio-crypto-pci.o
CC mipsel-softmmu/qtest.o
CC mips64-softmmu/hw/timer/mips_gictimer.o
CC mipsel-softmmu/memory.o
CC mips64el-softmmu/hw/mips/mips_r4k.o
CC mips64-softmmu/hw/timer/mc146818rtc.o
CC mips64el-softmmu/hw/mips/mips_malta.o
CC mips-softmmu/disas.o
CC mips64-softmmu/hw/vfio/common.o
CC mips64el-softmmu/hw/mips/mips_mipssim.o
CC mips-softmmu/arch_init.o
CC mips64el-softmmu/hw/mips/addr.o
CC mipsel-softmmu/memory_mapping.o
CC mipsel-softmmu/dump.o
CC mips-softmmu/cpus.o
CC mips64el-softmmu/hw/mips/mips_int.o
CC mips64-softmmu/hw/vfio/pci.o
CC mips64el-softmmu/hw/mips/mips_jazz.o
CC mips-softmmu/monitor.o
CC mipsel-softmmu/migration/ram.o
CC mips64el-softmmu/hw/mips/mips_fulong2e.o
CC mips64-softmmu/hw/vfio/pci-quirks.o
CC mips64el-softmmu/hw/mips/gt64xxx_pci.o
CC mipsel-softmmu/accel/accel.o
CC mips64el-softmmu/hw/mips/cps.o
CC mips64-softmmu/hw/vfio/platform.o
CC mipsel-softmmu/accel/stubs/hax-stub.o
CC mips64el-softmmu/hw/mips/boston.o
CC mips-softmmu/gdbstub.o
CC mipsel-softmmu/accel/stubs/kvm-stub.o
CC mips64el-softmmu/target/mips/translate.o
CC mips64-softmmu/hw/vfio/spapr.o
CC mipsel-softmmu/accel/tcg/tcg-all.o
CC mips64-softmmu/hw/virtio/virtio.o
CC mips-softmmu/balloon.o
CC mipsel-softmmu/accel/tcg/cputlb.o
CC mips-softmmu/ioport.o
CC mips-softmmu/numa.o
CC mips64-softmmu/hw/virtio/virtio-balloon.o
CC mips-softmmu/qtest.o
CC mips64-softmmu/hw/virtio/vhost.o
CC mips-softmmu/memory.o
CC mipsel-softmmu/accel/tcg/tcg-runtime.o
CC mips64-softmmu/hw/virtio/vhost-backend.o
CC mipsel-softmmu/accel/tcg/cpu-exec.o
CC mips-softmmu/memory_mapping.o
CC mips64-softmmu/hw/virtio/vhost-user.o
CC mipsel-softmmu/accel/tcg/cpu-exec-common.o
CC mips-softmmu/dump.o
CC mipsel-softmmu/accel/tcg/translate-all.o
CC mips64-softmmu/hw/virtio/vhost-vsock.o
CC mips-softmmu/migration/ram.o
CC mips64-softmmu/hw/virtio/virtio-crypto.o
CC mipsel-softmmu/accel/tcg/translator.o
CC mips64-softmmu/hw/virtio/virtio-crypto-pci.o
CC mipsel-softmmu/hw/9pfs/virtio-9p-device.o
CC mips-softmmu/accel/accel.o
CC mips64-softmmu/hw/mips/mips_r4k.o
CC mips-softmmu/accel/stubs/hax-stub.o
CC mipsel-softmmu/hw/block/virtio-blk.o
CC mips64-softmmu/hw/mips/mips_malta.o
CC mips-softmmu/accel/stubs/kvm-stub.o
CC mipsel-softmmu/hw/block/dataplane/virtio-blk.o
CC mips-softmmu/accel/tcg/tcg-all.o
CC mips64-softmmu/hw/mips/mips_mipssim.o
CC mips-softmmu/accel/tcg/cputlb.o
CC mips64-softmmu/hw/mips/addr.o
CC mipsel-softmmu/hw/char/virtio-serial-bus.o
CC mips64-softmmu/hw/mips/mips_int.o
CC mips64-softmmu/hw/mips/mips_jazz.o
CC mipsel-softmmu/hw/core/generic-loader.o
CC mipsel-softmmu/hw/core/null-machine.o
CC mips64-softmmu/hw/mips/gt64xxx_pci.o
CC mipsel-softmmu/hw/display/vga.o
CC mips64-softmmu/hw/mips/cps.o
CC mips64el-softmmu/target/mips/dsp_helper.o
CC mips-softmmu/accel/tcg/tcg-runtime.o
CC mips64-softmmu/target/mips/translate.o
CC mips-softmmu/accel/tcg/cpu-exec.o
CC mipsel-softmmu/hw/display/virtio-gpu.o
CC mips-softmmu/accel/tcg/cpu-exec-common.o
CC mips-softmmu/accel/tcg/translate-all.o
CC mips64el-softmmu/target/mips/op_helper.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 mipsel-softmmu/hw/intc/mips_gic.o
CC mips-softmmu/hw/block/virtio-blk.o
CC mipsel-softmmu/hw/misc/ivshmem.o
CC mips64el-softmmu/target/mips/lmi_helper.o
CC mips-softmmu/hw/block/dataplane/virtio-blk.o
CC mipsel-softmmu/hw/misc/mips_cmgcr.o
CC mips-softmmu/hw/char/virtio-serial-bus.o
CC mipsel-softmmu/hw/misc/mips_cpc.o
CC mips64el-softmmu/target/mips/helper.o
CC mipsel-softmmu/hw/misc/mips_itu.o
CC mips-softmmu/hw/core/generic-loader.o
CC mips64el-softmmu/target/mips/cpu.o
CC mipsel-softmmu/hw/misc/mmio_interface.o
CC mips-softmmu/hw/core/null-machine.o
CC mips64el-softmmu/target/mips/gdbstub.o
CC mips-softmmu/hw/display/vga.o
CC mipsel-softmmu/hw/net/virtio-net.o
CC mips64el-softmmu/target/mips/msa_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 mips64-softmmu/target/mips/dsp_helper.o
CC mips-softmmu/hw/display/virtio-gpu-3d.o
CC mipsel-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC mipsel-softmmu/hw/scsi/vhost-scsi-common.o
CC mipsel-softmmu/hw/scsi/vhost-scsi.o
CC mips-softmmu/hw/display/virtio-gpu-pci.o
CC mips64-softmmu/target/mips/op_helper.o
CC mipsel-softmmu/hw/scsi/vhost-user-scsi.o
CC mips-softmmu/hw/intc/mips_gic.o
CC mipsel-softmmu/hw/timer/mips_gictimer.o
CC mips-softmmu/hw/misc/ivshmem.o
CC mipsel-softmmu/hw/timer/mc146818rtc.o
CC mips64el-softmmu/target/mips/mips-semi.o
CC mips-softmmu/hw/misc/mips_cmgcr.o
CC mips64el-softmmu/target/mips/machine.o
CC mips-softmmu/hw/misc/mips_cpc.o
CC mipsel-softmmu/hw/vfio/common.o
CC mips64el-softmmu/target/mips/cp0_timer.o
CC mips-softmmu/hw/misc/mips_itu.o
GEN trace/generated-helpers.c
CC mips64el-softmmu/trace/control-target.o
CC mipsel-softmmu/hw/vfio/pci.o
CC mips-softmmu/hw/misc/mmio_interface.o
CC mips64el-softmmu/trace/generated-helpers.o
CC mips64-softmmu/target/mips/lmi_helper.o
CC mips-softmmu/hw/net/virtio-net.o
LINK mips64el-softmmu/qemu-system-mips64el
CC mips64-softmmu/target/mips/helper.o
CC mips-softmmu/hw/net/vhost_net.o
CC mips-softmmu/hw/scsi/virtio-scsi.o
CC mipsel-softmmu/hw/vfio/pci-quirks.o
CC mips64-softmmu/target/mips/cpu.o
CC mips-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC mips64-softmmu/target/mips/gdbstub.o
CC mips-softmmu/hw/scsi/vhost-scsi-common.o
CC mipsel-softmmu/hw/vfio/platform.o
CC mips-softmmu/hw/scsi/vhost-scsi.o
CC mips64-softmmu/target/mips/msa_helper.o
CC mips-softmmu/hw/scsi/vhost-user-scsi.o
CC mipsel-softmmu/hw/vfio/spapr.o
CC mips-softmmu/hw/timer/mips_gictimer.o
CC mipsel-softmmu/hw/virtio/virtio.o
CC mips-softmmu/hw/timer/mc146818rtc.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/vfio/common.o
CC mipsel-softmmu/hw/virtio/virtio-balloon.o
CC mips-softmmu/hw/vfio/pci.o
CC mipsel-softmmu/hw/virtio/vhost.o
CC mipsel-softmmu/hw/virtio/vhost-backend.o
CC mips-softmmu/hw/vfio/pci-quirks.o
CC moxie-softmmu/tcg/tcg.o
CC mipsel-softmmu/hw/virtio/vhost-user.o
CC mips64-softmmu/target/mips/mips-semi.o
CC mipsel-softmmu/hw/virtio/vhost-vsock.o
CC mips-softmmu/hw/vfio/platform.o
CC mips64-softmmu/target/mips/machine.o
CC mipsel-softmmu/hw/virtio/virtio-crypto.o
CC mips-softmmu/hw/vfio/spapr.o
CC mips64-softmmu/target/mips/cp0_timer.o
CC mipsel-softmmu/hw/virtio/virtio-crypto-pci.o
GEN trace/generated-helpers.c
CC mips64-softmmu/trace/control-target.o
CC mips-softmmu/hw/virtio/virtio.o
CC moxie-softmmu/tcg/tcg-op.o
CC mipsel-softmmu/hw/mips/mips_r4k.o
CC mips64-softmmu/trace/generated-helpers.o
CC mipsel-softmmu/hw/mips/mips_malta.o
LINK mips64-softmmu/qemu-system-mips64
CC mipsel-softmmu/hw/mips/mips_mipssim.o
CC mips-softmmu/hw/virtio/virtio-balloon.o
CC mipsel-softmmu/hw/mips/addr.o
CC mips-softmmu/hw/virtio/vhost.o
CC mipsel-softmmu/hw/mips/mips_int.o
CC mipsel-softmmu/hw/mips/gt64xxx_pci.o
CC mips-softmmu/hw/virtio/vhost-backend.o
CC mipsel-softmmu/hw/mips/cps.o
CC mips-softmmu/hw/virtio/vhost-user.o
GEN nios2-softmmu/hmp-commands.h
GEN nios2-softmmu/hmp-commands-info.h
GEN nios2-softmmu/config-target.h
CC nios2-softmmu/exec.o
CC mipsel-softmmu/target/mips/translate.o
CC moxie-softmmu/tcg/optimize.o
CC mips-softmmu/hw/virtio/vhost-vsock.o
CC mips-softmmu/hw/virtio/virtio-crypto.o
CC moxie-softmmu/tcg/tcg-common.o
CC mips-softmmu/hw/virtio/virtio-crypto-pci.o
CC moxie-softmmu/fpu/softfloat.o
CC mips-softmmu/hw/mips/mips_r4k.o
CC nios2-softmmu/tcg/tcg.o
CC mips-softmmu/hw/mips/mips_malta.o
CC mips-softmmu/hw/mips/mips_mipssim.o
CC mips-softmmu/hw/mips/addr.o
CC mips-softmmu/hw/mips/mips_int.o
CC mips-softmmu/hw/mips/gt64xxx_pci.o
CC nios2-softmmu/tcg/tcg-op.o
CC mips-softmmu/hw/mips/cps.o
CC mips-softmmu/target/mips/translate.o
CC moxie-softmmu/disas.o
CC moxie-softmmu/arch_init.o
CC moxie-softmmu/cpus.o
CC moxie-softmmu/monitor.o
CC mipsel-softmmu/target/mips/dsp_helper.o
CC nios2-softmmu/tcg/optimize.o
CC mipsel-softmmu/target/mips/op_helper.o
CC moxie-softmmu/gdbstub.o
CC nios2-softmmu/tcg/tcg-common.o
CC nios2-softmmu/fpu/softfloat.o
CC moxie-softmmu/balloon.o
CC moxie-softmmu/ioport.o
CC moxie-softmmu/numa.o
CC mipsel-softmmu/target/mips/lmi_helper.o
CC moxie-softmmu/qtest.o
CC mipsel-softmmu/target/mips/helper.o
CC moxie-softmmu/memory.o
CC mips-softmmu/target/mips/dsp_helper.o
CC mipsel-softmmu/target/mips/cpu.o
CC nios2-softmmu/disas.o
CC mipsel-softmmu/target/mips/gdbstub.o
CC nios2-softmmu/arch_init.o
CC mips-softmmu/target/mips/op_helper.o
CC moxie-softmmu/memory_mapping.o
CC mipsel-softmmu/target/mips/msa_helper.o
CC nios2-softmmu/cpus.o
CC moxie-softmmu/dump.o
CC nios2-softmmu/monitor.o
CC moxie-softmmu/migration/ram.o
CC mips-softmmu/target/mips/lmi_helper.o
CC moxie-softmmu/accel/accel.o
CC nios2-softmmu/gdbstub.o
CC moxie-softmmu/accel/stubs/hax-stub.o
CC mips-softmmu/target/mips/helper.o
CC moxie-softmmu/accel/stubs/kvm-stub.o
CC nios2-softmmu/balloon.o
CC moxie-softmmu/accel/tcg/tcg-all.o
CC mips-softmmu/target/mips/cpu.o
CC mips-softmmu/target/mips/gdbstub.o
CC moxie-softmmu/accel/tcg/cputlb.o
CC nios2-softmmu/ioport.o
CC mips-softmmu/target/mips/msa_helper.o
CC mipsel-softmmu/target/mips/mips-semi.o
CC nios2-softmmu/numa.o
CC mipsel-softmmu/target/mips/machine.o
CC nios2-softmmu/qtest.o
CC mipsel-softmmu/target/mips/cp0_timer.o
CC moxie-softmmu/accel/tcg/tcg-runtime.o
GEN trace/generated-helpers.c
CC nios2-softmmu/memory.o
CC mipsel-softmmu/trace/control-target.o
CC moxie-softmmu/accel/tcg/cpu-exec.o
CC mipsel-softmmu/trace/generated-helpers.o
CC moxie-softmmu/accel/tcg/cpu-exec-common.o
LINK mipsel-softmmu/qemu-system-mipsel
CC moxie-softmmu/accel/tcg/translate-all.o
CC nios2-softmmu/memory_mapping.o
CC moxie-softmmu/accel/tcg/translator.o
CC nios2-softmmu/dump.o
CC moxie-softmmu/hw/core/generic-loader.o
CC moxie-softmmu/hw/core/null-machine.o
CC mips-softmmu/target/mips/mips-semi.o
CC moxie-softmmu/hw/display/vga.o
CC mips-softmmu/target/mips/machine.o
CC nios2-softmmu/migration/ram.o
CC mips-softmmu/target/mips/cp0_timer.o
GEN trace/generated-helpers.c
CC mips-softmmu/trace/control-target.o
GEN or1k-softmmu/hmp-commands.h
GEN or1k-softmmu/hmp-commands-info.h
CC moxie-softmmu/hw/misc/mmio_interface.o
GEN or1k-softmmu/config-target.h
CC mips-softmmu/trace/generated-helpers.o
CC or1k-softmmu/exec.o
CC moxie-softmmu/hw/net/vhost_net.o
CC nios2-softmmu/accel/accel.o
LINK mips-softmmu/qemu-system-mips
CC moxie-softmmu/hw/net/rocker/qmp-norocker.o
CC nios2-softmmu/accel/stubs/hax-stub.o
CC nios2-softmmu/accel/stubs/kvm-stub.o
CC moxie-softmmu/hw/timer/mc146818rtc.o
CC nios2-softmmu/accel/tcg/tcg-all.o
CC moxie-softmmu/hw/vfio/common.o
CC nios2-softmmu/accel/tcg/cputlb.o
CC moxie-softmmu/hw/vfio/platform.o
CC or1k-softmmu/tcg/tcg.o
CC moxie-softmmu/hw/vfio/spapr.o
GEN ppc64-softmmu/hmp-commands.h
GEN ppc64-softmmu/hmp-commands-info.h
CC nios2-softmmu/accel/tcg/tcg-runtime.o
GEN ppc64-softmmu/config-target.h
CC ppc64-softmmu/exec.o
CC moxie-softmmu/hw/moxie/moxiesim.o
CC nios2-softmmu/accel/tcg/cpu-exec.o
CC moxie-softmmu/target/moxie/translate.o
CC nios2-softmmu/accel/tcg/cpu-exec-common.o
CC nios2-softmmu/accel/tcg/translate-all.o
CC moxie-softmmu/target/moxie/helper.o
CC or1k-softmmu/tcg/tcg-op.o
CC moxie-softmmu/target/moxie/machine.o
CC nios2-softmmu/accel/tcg/translator.o
CC moxie-softmmu/target/moxie/cpu.o
CC ppc64-softmmu/tcg/tcg.o
CC nios2-softmmu/hw/core/generic-loader.o
CC moxie-softmmu/target/moxie/mmu.o
GEN trace/generated-helpers.c
CC moxie-softmmu/trace/control-target.o
CC nios2-softmmu/hw/core/null-machine.o
CC moxie-softmmu/trace/generated-helpers.o
CC nios2-softmmu/hw/intc/nios2_iic.o
LINK moxie-softmmu/qemu-system-moxie
CC nios2-softmmu/hw/misc/mmio_interface.o
CC or1k-softmmu/tcg/optimize.o
CC nios2-softmmu/hw/net/vhost_net.o
CC nios2-softmmu/hw/net/rocker/qmp-norocker.o
CC nios2-softmmu/hw/timer/altera_timer.o
CC or1k-softmmu/tcg/tcg-common.o
CC nios2-softmmu/hw/vfio/common.o
CC ppc64-softmmu/tcg/tcg-op.o
CC or1k-softmmu/fpu/softfloat.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 nios2-softmmu/hw/vfio/platform.o
CC nios2-softmmu/hw/vfio/spapr.o
CC nios2-softmmu/hw/nios2/boot.o
CC nios2-softmmu/hw/nios2/cpu_pic.o
CC nios2-softmmu/hw/nios2/10m50_devboard.o
CC ppcemb-softmmu/tcg/tcg.o
CC or1k-softmmu/disas.o
CC ppc64-softmmu/tcg/optimize.o
CC nios2-softmmu/target/nios2/translate.o
CC or1k-softmmu/arch_init.o
CC or1k-softmmu/cpus.o
CC nios2-softmmu/target/nios2/op_helper.o
CC or1k-softmmu/monitor.o
CC ppc64-softmmu/tcg/tcg-common.o
CC nios2-softmmu/target/nios2/helper.o
CC ppcemb-softmmu/tcg/tcg-op.o
CC ppc64-softmmu/fpu/softfloat.o
CC nios2-softmmu/target/nios2/cpu.o
CC nios2-softmmu/target/nios2/mmu.o
CC nios2-softmmu/target/nios2/monitor.o
GEN trace/generated-helpers.c
CC nios2-softmmu/trace/control-target.o
CC or1k-softmmu/gdbstub.o
CC nios2-softmmu/trace/generated-helpers.o
LINK nios2-softmmu/qemu-system-nios2
CC or1k-softmmu/balloon.o
CC or1k-softmmu/ioport.o
CC ppcemb-softmmu/tcg/optimize.o
CC ppc64-softmmu/disas.o
GEN ppc64-softmmu/gdbstub-xml.c
CC or1k-softmmu/numa.o
CC or1k-softmmu/qtest.o
CC ppc64-softmmu/libdecnumber/decContext.o
CC ppcemb-softmmu/tcg/tcg-common.o
CC or1k-softmmu/memory.o
CC ppc64-softmmu/libdecnumber/decNumber.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 ppc-softmmu/exec.o
CC or1k-softmmu/memory_mapping.o
CC or1k-softmmu/dump.o
CC ppc64-softmmu/libdecnumber/dpd/decimal32.o
CC ppc64-softmmu/libdecnumber/dpd/decimal64.o
CC or1k-softmmu/migration/ram.o
CC ppc64-softmmu/libdecnumber/dpd/decimal128.o
CC ppcemb-softmmu/disas.o
CC ppc-softmmu/tcg/tcg.o
CC ppc64-softmmu/arch_init.o
GEN ppcemb-softmmu/gdbstub-xml.c
CC ppc64-softmmu/cpus.o
CC or1k-softmmu/accel/accel.o
CC ppc64-softmmu/monitor.o
CC ppcemb-softmmu/libdecnumber/decContext.o
CC or1k-softmmu/accel/stubs/hax-stub.o
CC or1k-softmmu/accel/stubs/kvm-stub.o
CC ppcemb-softmmu/libdecnumber/decNumber.o
CC or1k-softmmu/accel/tcg/tcg-all.o
CC or1k-softmmu/accel/tcg/cputlb.o
CC ppc-softmmu/tcg/tcg-op.o
CC ppc64-softmmu/gdbstub.o
CC ppcemb-softmmu/libdecnumber/dpd/decimal32.o
CC ppc64-softmmu/balloon.o
CC ppcemb-softmmu/libdecnumber/dpd/decimal64.o
CC or1k-softmmu/accel/tcg/tcg-runtime.o
CC ppc64-softmmu/ioport.o
CC or1k-softmmu/accel/tcg/cpu-exec.o
CC ppcemb-softmmu/libdecnumber/dpd/decimal128.o
CC ppcemb-softmmu/arch_init.o
CC ppc64-softmmu/numa.o
CC or1k-softmmu/accel/tcg/cpu-exec-common.o
CC ppcemb-softmmu/cpus.o
CC or1k-softmmu/accel/tcg/translate-all.o
CC ppc64-softmmu/qtest.o
CC ppc-softmmu/tcg/optimize.o
CC or1k-softmmu/accel/tcg/translator.o
CC ppcemb-softmmu/monitor.o
CC ppc64-softmmu/memory.o
CC or1k-softmmu/hw/core/generic-loader.o
CC or1k-softmmu/hw/core/null-machine.o
CC ppc-softmmu/tcg/tcg-common.o
CC or1k-softmmu/hw/misc/mmio_interface.o
CC ppcemb-softmmu/gdbstub.o
CC ppc64-softmmu/memory_mapping.o
CC ppc-softmmu/fpu/softfloat.o
CC or1k-softmmu/hw/net/vhost_net.o
CC ppc64-softmmu/dump.o
CC or1k-softmmu/hw/net/rocker/qmp-norocker.o
CC ppcemb-softmmu/balloon.o
CC or1k-softmmu/hw/vfio/common.o
CC ppcemb-softmmu/ioport.o
CC or1k-softmmu/hw/vfio/platform.o
CC ppc64-softmmu/migration/ram.o
CC ppcemb-softmmu/numa.o
CC or1k-softmmu/hw/vfio/spapr.o
CC or1k-softmmu/hw/openrisc/pic_cpu.o
CC ppcemb-softmmu/qtest.o
CC or1k-softmmu/hw/openrisc/cputimer.o
CC ppc64-softmmu/accel/accel.o
CC or1k-softmmu/hw/openrisc/openrisc_sim.o
CC ppc64-softmmu/accel/stubs/hax-stub.o
CC ppcemb-softmmu/memory.o
CC or1k-softmmu/target/openrisc/machine.o
CC ppc64-softmmu/accel/stubs/kvm-stub.o
CC ppc-softmmu/disas.o
CC ppc64-softmmu/accel/tcg/tcg-all.o
CC or1k-softmmu/target/openrisc/cpu.o
CC ppc64-softmmu/accel/tcg/cputlb.o
GEN ppc-softmmu/gdbstub-xml.c
CC or1k-softmmu/target/openrisc/exception.o
CC ppc-softmmu/libdecnumber/decContext.o
CC ppcemb-softmmu/memory_mapping.o
CC or1k-softmmu/target/openrisc/interrupt.o
CC ppc-softmmu/libdecnumber/decNumber.o
CC ppcemb-softmmu/dump.o
CC or1k-softmmu/target/openrisc/mmu.o
CC ppc64-softmmu/accel/tcg/tcg-runtime.o
CC or1k-softmmu/target/openrisc/translate.o
CC ppc64-softmmu/accel/tcg/cpu-exec.o
CC ppcemb-softmmu/migration/ram.o
CC ppc64-softmmu/accel/tcg/cpu-exec-common.o
CC or1k-softmmu/target/openrisc/exception_helper.o
CC or1k-softmmu/target/openrisc/fpu_helper.o
CC ppc64-softmmu/accel/tcg/translate-all.o
CC ppc-softmmu/libdecnumber/dpd/decimal32.o
CC ppcemb-softmmu/accel/accel.o
CC or1k-softmmu/target/openrisc/interrupt_helper.o
CC ppcemb-softmmu/accel/stubs/hax-stub.o
CC ppc-softmmu/libdecnumber/dpd/decimal64.o
CC ppcemb-softmmu/accel/stubs/kvm-stub.o
CC ppc64-softmmu/accel/tcg/translator.o
CC or1k-softmmu/target/openrisc/mmu_helper.o
CC ppcemb-softmmu/accel/tcg/tcg-all.o
CC ppc-softmmu/libdecnumber/dpd/decimal128.o
CC or1k-softmmu/target/openrisc/sys_helper.o
CC ppcemb-softmmu/accel/tcg/cputlb.o
CC ppc64-softmmu/hw/9pfs/virtio-9p-device.o
CC ppc-softmmu/arch_init.o
CC or1k-softmmu/target/openrisc/gdbstub.o
CC ppc-softmmu/cpus.o
CC ppc64-softmmu/hw/block/virtio-blk.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/dataplane/virtio-blk.o
CC ppc-softmmu/monitor.o
LINK or1k-softmmu/qemu-system-or1k
CC ppc64-softmmu/hw/char/spapr_vty.o
CC ppcemb-softmmu/accel/tcg/tcg-runtime.o
CC ppc64-softmmu/hw/char/virtio-serial-bus.o
CC ppcemb-softmmu/accel/tcg/cpu-exec.o
CC ppc64-softmmu/hw/core/generic-loader.o
CC ppc64-softmmu/hw/core/null-machine.o
CC ppcemb-softmmu/accel/tcg/cpu-exec-common.o
CC ppc-softmmu/gdbstub.o
CC ppc64-softmmu/hw/display/sm501.o
CC ppc64-softmmu/hw/display/vga.o
CC ppcemb-softmmu/accel/tcg/translate-all.o
CC ppc-softmmu/balloon.o
CC ppcemb-softmmu/accel/tcg/translator.o
CC ppc-softmmu/ioport.o
CC ppc-softmmu/numa.o
CC ppc64-softmmu/hw/display/virtio-gpu.o
CC ppcemb-softmmu/hw/9pfs/virtio-9p-device.o
CC ppc-softmmu/qtest.o
GEN s390x-softmmu/hmp-commands.h
GEN s390x-softmmu/hmp-commands-info.h
CC ppcemb-softmmu/hw/block/virtio-blk.o
CC s390x-softmmu/gen-features
GEN s390x-softmmu/config-target.h
GEN s390x-softmmu/gen-features.h
CC s390x-softmmu/exec.o
CC ppc64-softmmu/hw/display/virtio-gpu-3d.o
CC ppc-softmmu/memory.o
CC ppcemb-softmmu/hw/block/dataplane/virtio-blk.o
CC ppcemb-softmmu/hw/char/virtio-serial-bus.o
CC ppc64-softmmu/hw/display/virtio-gpu-pci.o
CC ppc-softmmu/memory_mapping.o
CC ppc64-softmmu/hw/display/virtio-vga.o
CC ppcemb-softmmu/hw/core/generic-loader.o
CC ppc-softmmu/dump.o
CC ppcemb-softmmu/hw/core/null-machine.o
CC ppc64-softmmu/hw/i2c/ppc4xx_i2c.o
CC ppcemb-softmmu/hw/display/sm501.o
CC s390x-softmmu/tcg/tcg.o
CC ppc64-softmmu/hw/intc/xics.o
CC ppc-softmmu/migration/ram.o
CC ppc64-softmmu/hw/intc/xics_spapr.o
CC ppcemb-softmmu/hw/display/vga.o
CC ppc-softmmu/accel/accel.o
CC ppc64-softmmu/hw/intc/xics_pnv.o
CC ppc-softmmu/accel/stubs/hax-stub.o
CC ppc64-softmmu/hw/misc/ivshmem.o
CC ppc-softmmu/accel/stubs/kvm-stub.o
CC s390x-softmmu/tcg/tcg-op.o
CC ppcemb-softmmu/hw/display/virtio-gpu.o
CC ppc-softmmu/accel/tcg/tcg-all.o
CC ppc64-softmmu/hw/misc/mmio_interface.o
CC ppc-softmmu/accel/tcg/cputlb.o
CC ppc64-softmmu/hw/net/spapr_llan.o
CC ppcemb-softmmu/hw/display/virtio-gpu-3d.o
CC ppc64-softmmu/hw/net/xilinx_ethlite.o
CC ppc64-softmmu/hw/net/virtio-net.o
CC ppcemb-softmmu/hw/display/virtio-gpu-pci.o
CC ppc-softmmu/accel/tcg/tcg-runtime.o
CC ppcemb-softmmu/hw/i2c/ppc4xx_i2c.o
CC ppc64-softmmu/hw/net/vhost_net.o
CC s390x-softmmu/tcg/optimize.o
CC ppc-softmmu/accel/tcg/cpu-exec.o
CC ppcemb-softmmu/hw/misc/ivshmem.o
CC ppc64-softmmu/hw/net/fsl_etsec/etsec.o
CC ppcemb-softmmu/hw/misc/mmio_interface.o
CC ppc-softmmu/accel/tcg/cpu-exec-common.o
CC ppc64-softmmu/hw/net/fsl_etsec/registers.o
CC s390x-softmmu/tcg/tcg-common.o
CC ppcemb-softmmu/hw/net/xilinx_ethlite.o
CC ppc-softmmu/accel/tcg/translate-all.o
CC ppc64-softmmu/hw/net/fsl_etsec/rings.o
CC s390x-softmmu/fpu/softfloat.o
CC ppcemb-softmmu/hw/net/virtio-net.o
CC ppc64-softmmu/hw/net/fsl_etsec/miim.o
CC ppc-softmmu/accel/tcg/translator.o
CC ppc64-softmmu/hw/nvram/spapr_nvram.o
CC ppcemb-softmmu/hw/net/vhost_net.o
CC ppcemb-softmmu/hw/scsi/virtio-scsi.o
CC ppc64-softmmu/hw/scsi/spapr_vscsi.o
CC ppc-softmmu/hw/9pfs/virtio-9p-device.o
CC ppc-softmmu/hw/block/virtio-blk.o
CC ppcemb-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC ppc64-softmmu/hw/scsi/virtio-scsi.o
CC ppcemb-softmmu/hw/scsi/vhost-scsi-common.o
CC ppc-softmmu/hw/block/dataplane/virtio-blk.o
CC ppcemb-softmmu/hw/scsi/vhost-scsi.o
CC ppc64-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC ppc-softmmu/hw/char/virtio-serial-bus.o
CC ppcemb-softmmu/hw/scsi/vhost-user-scsi.o
CC ppc64-softmmu/hw/scsi/vhost-scsi-common.o
CC s390x-softmmu/disas.o
CC ppcemb-softmmu/hw/vfio/common.o
CC ppc64-softmmu/hw/scsi/vhost-scsi.o
GEN s390x-softmmu/gdbstub-xml.c
CC ppc-softmmu/hw/core/generic-loader.o
CC ppc64-softmmu/hw/scsi/vhost-user-scsi.o
CC ppc-softmmu/hw/core/null-machine.o
CC ppc64-softmmu/hw/timer/mc146818rtc.o
CC ppcemb-softmmu/hw/vfio/pci.o
CC s390x-softmmu/arch_init.o
CC ppc-softmmu/hw/display/sm501.o
CC s390x-softmmu/cpus.o
CC ppc64-softmmu/hw/vfio/common.o
CC s390x-softmmu/monitor.o
CC ppc-softmmu/hw/display/vga.o
CC ppc64-softmmu/hw/vfio/pci.o
CC ppcemb-softmmu/hw/vfio/pci-quirks.o
CC ppcemb-softmmu/hw/vfio/platform.o
CC ppc64-softmmu/hw/vfio/pci-quirks.o
CC ppcemb-softmmu/hw/vfio/spapr.o
CC ppc-softmmu/hw/display/virtio-gpu.o
CC s390x-softmmu/gdbstub.o
CC ppcemb-softmmu/hw/virtio/virtio.o
CC ppc64-softmmu/hw/vfio/platform.o
CC s390x-softmmu/balloon.o
CC ppc-softmmu/hw/display/virtio-gpu-3d.o
CC ppc64-softmmu/hw/vfio/spapr.o
CC s390x-softmmu/ioport.o
CC ppc64-softmmu/hw/virtio/virtio.o
CC ppcemb-softmmu/hw/virtio/virtio-balloon.o
CC s390x-softmmu/numa.o
CC ppc-softmmu/hw/display/virtio-gpu-pci.o
CC s390x-softmmu/qtest.o
CC ppcemb-softmmu/hw/virtio/vhost.o
CC ppc-softmmu/hw/i2c/ppc4xx_i2c.o
CC ppc-softmmu/hw/misc/ivshmem.o
CC ppc64-softmmu/hw/virtio/virtio-balloon.o
CC s390x-softmmu/memory.o
CC ppcemb-softmmu/hw/virtio/vhost-backend.o
CC ppc64-softmmu/hw/virtio/vhost.o
CC ppc-softmmu/hw/misc/mmio_interface.o
CC ppc-softmmu/hw/net/xilinx_ethlite.o
CC ppcemb-softmmu/hw/virtio/vhost-user.o
CC ppc64-softmmu/hw/virtio/vhost-backend.o
CC ppc-softmmu/hw/net/virtio-net.o
CC ppc64-softmmu/hw/virtio/vhost-user.o
CC ppcemb-softmmu/hw/virtio/vhost-vsock.o
CC s390x-softmmu/memory_mapping.o
CC ppcemb-softmmu/hw/virtio/virtio-crypto.o
CC ppc64-softmmu/hw/virtio/vhost-vsock.o
CC s390x-softmmu/dump.o
CC ppc-softmmu/hw/net/vhost_net.o
CC ppc-softmmu/hw/net/fsl_etsec/etsec.o
CC ppc64-softmmu/hw/virtio/virtio-crypto.o
CC ppcemb-softmmu/hw/virtio/virtio-crypto-pci.o
CC s390x-softmmu/migration/ram.o
CC ppc-softmmu/hw/net/fsl_etsec/registers.o
CC ppc64-softmmu/hw/virtio/virtio-crypto-pci.o
CC ppc-softmmu/hw/net/fsl_etsec/rings.o
CC ppcemb-softmmu/hw/ppc/ppc.o
CC ppc-softmmu/hw/net/fsl_etsec/miim.o
CC ppc64-softmmu/hw/ppc/ppc.o
CC ppc-softmmu/hw/scsi/virtio-scsi.o
CC s390x-softmmu/accel/accel.o
CC ppcemb-softmmu/hw/ppc/ppc_booke.o
CC ppc64-softmmu/hw/ppc/ppc_booke.o
CC s390x-softmmu/accel/kvm/kvm-all.o
CC ppcemb-softmmu/hw/ppc/fdt.o
CC ppc-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC ppcemb-softmmu/hw/ppc/ppc405_boards.o
CC ppc64-softmmu/hw/ppc/fdt.o
CC ppc-softmmu/hw/scsi/vhost-scsi-common.o
CC ppc64-softmmu/hw/ppc/spapr.o
CC s390x-softmmu/accel/stubs/hax-stub.o
CC ppcemb-softmmu/hw/ppc/ppc4xx_devs.o
CC ppc-softmmu/hw/scsi/vhost-scsi.o
CC s390x-softmmu/accel/tcg/tcg-all.o
CC ppcemb-softmmu/hw/ppc/ppc405_uc.o
CC ppc-softmmu/hw/scsi/vhost-user-scsi.o
CC s390x-softmmu/accel/tcg/cputlb.o
CC ppc-softmmu/hw/timer/mc146818rtc.o
CC ppcemb-softmmu/hw/ppc/ppc440_bamboo.o
CC ppcemb-softmmu/hw/ppc/ppc4xx_pci.o
CC ppc64-softmmu/hw/ppc/spapr_vio.o
CC ppc-softmmu/hw/vfio/common.o
CC ppcemb-softmmu/hw/ppc/virtex_ml507.o
CC ppc64-softmmu/hw/ppc/spapr_events.o
CC ppcemb-softmmu/target/ppc/cpu-models.o
CC ppc64-softmmu/hw/ppc/spapr_hcall.o
CC ppc-softmmu/hw/vfio/pci.o
CC s390x-softmmu/accel/tcg/tcg-runtime.o
CC s390x-softmmu/accel/tcg/cpu-exec.o
CC ppc64-softmmu/hw/ppc/spapr_iommu.o
CC s390x-softmmu/accel/tcg/cpu-exec-common.o
CC ppc64-softmmu/hw/ppc/spapr_rtas.o
CC ppc-softmmu/hw/vfio/pci-quirks.o
CC ppcemb-softmmu/target/ppc/cpu.o
CC s390x-softmmu/accel/tcg/translate-all.o
CC ppcemb-softmmu/target/ppc/translate.o
CC ppc64-softmmu/hw/ppc/spapr_pci.o
CC s390x-softmmu/accel/tcg/translator.o
CC ppc-softmmu/hw/vfio/platform.o
CC ppc64-softmmu/hw/ppc/spapr_rtc.o
CC ppc-softmmu/hw/vfio/spapr.o
CC s390x-softmmu/hw/9pfs/virtio-9p-device.o
CC ppc64-softmmu/hw/ppc/spapr_drc.o
CC ppc-softmmu/hw/virtio/virtio.o
CC ppc64-softmmu/hw/ppc/spapr_rng.o
CC s390x-softmmu/hw/block/virtio-blk.o
CC ppc64-softmmu/hw/ppc/spapr_cpu_core.o
CC ppc64-softmmu/hw/ppc/spapr_ovec.o
CC s390x-softmmu/hw/block/dataplane/virtio-blk.o
CC ppc-softmmu/hw/virtio/virtio-balloon.o
CC ppc64-softmmu/hw/ppc/pnv.o
CC s390x-softmmu/hw/char/virtio-serial-bus.o
CC ppc-softmmu/hw/virtio/vhost.o
CC s390x-softmmu/hw/char/terminal3270.o
CC ppc64-softmmu/hw/ppc/pnv_xscom.o
CC s390x-softmmu/hw/core/generic-loader.o
CC ppc-softmmu/hw/virtio/vhost-backend.o
CC s390x-softmmu/hw/core/null-machine.o
CC ppc64-softmmu/hw/ppc/pnv_core.o
CC ppc-softmmu/hw/virtio/vhost-user.o
CC s390x-softmmu/hw/display/virtio-gpu.o
CC ppc64-softmmu/hw/ppc/pnv_lpc.o
CC ppc-softmmu/hw/virtio/vhost-vsock.o
CC ppc64-softmmu/hw/ppc/pnv_psi.o
CC s390x-softmmu/hw/display/virtio-gpu-3d.o
CC ppc-softmmu/hw/virtio/virtio-crypto.o
CC ppc64-softmmu/hw/ppc/pnv_occ.o
CC ppc64-softmmu/hw/ppc/pnv_bmc.o
CC ppc-softmmu/hw/virtio/virtio-crypto-pci.o
CC s390x-softmmu/hw/display/virtio-gpu-pci.o
CC ppc64-softmmu/hw/ppc/spapr_pci_vfio.o
CC ppc64-softmmu/hw/ppc/spapr_rtas_ddw.o
CC ppc-softmmu/hw/ppc/ppc.o
CC s390x-softmmu/hw/intc/s390_flic.o
CC ppc64-softmmu/hw/ppc/ppc405_boards.o
CC ppc-softmmu/hw/ppc/ppc_booke.o
CC s390x-softmmu/hw/intc/s390_flic_kvm.o
CC ppc64-softmmu/hw/ppc/ppc4xx_devs.o
CC ppc-softmmu/hw/ppc/fdt.o
CC s390x-softmmu/hw/misc/mmio_interface.o
CC ppc-softmmu/hw/ppc/ppc405_boards.o
CC ppc64-softmmu/hw/ppc/ppc405_uc.o
CC s390x-softmmu/hw/net/virtio-net.o
CC ppc-softmmu/hw/ppc/ppc4xx_devs.o
CC ppc64-softmmu/hw/ppc/ppc440_bamboo.o
CC ppc-softmmu/hw/ppc/ppc405_uc.o
CC s390x-softmmu/hw/net/vhost_net.o
CC ppc64-softmmu/hw/ppc/ppc4xx_pci.o
CC s390x-softmmu/hw/net/rocker/qmp-norocker.o
CC ppc-softmmu/hw/ppc/ppc440_bamboo.o
CC ppc64-softmmu/hw/ppc/prep.o
CC s390x-softmmu/hw/scsi/virtio-scsi.o
CC ppc-softmmu/hw/ppc/ppc4xx_pci.o
CC ppc-softmmu/hw/ppc/prep.o
CC ppc64-softmmu/hw/ppc/prep_systemio.o
CC s390x-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC ppc-softmmu/hw/ppc/prep_systemio.o
CC ppc64-softmmu/hw/ppc/rs6000_mc.o
CC s390x-softmmu/hw/scsi/vhost-scsi-common.o
CC s390x-softmmu/hw/scsi/vhost-scsi.o
CC ppc-softmmu/hw/ppc/rs6000_mc.o
CC ppc64-softmmu/hw/ppc/mac_oldworld.o
CC s390x-softmmu/hw/scsi/vhost-user-scsi.o
CC ppc-softmmu/hw/ppc/mac_oldworld.o
CC ppc64-softmmu/hw/ppc/mac_newworld.o
CC s390x-softmmu/hw/vfio/common.o
CC ppc-softmmu/hw/ppc/mac_newworld.o
CC ppc64-softmmu/hw/ppc/e500.o
CC ppc-softmmu/hw/ppc/e500.o
CC s390x-softmmu/hw/vfio/pci.o
CC ppcemb-softmmu/target/ppc/machine.o
CC ppc-softmmu/hw/ppc/mpc8544ds.o
CC ppc64-softmmu/hw/ppc/mpc8544ds.o
CC ppc-softmmu/hw/ppc/e500plat.o
CC ppcemb-softmmu/target/ppc/mmu_helper.o
CC ppc64-softmmu/hw/ppc/e500plat.o
CC ppc-softmmu/hw/ppc/mpc8544_guts.o
CC s390x-softmmu/hw/vfio/pci-quirks.o
CC ppc64-softmmu/hw/ppc/mpc8544_guts.o
CC ppc-softmmu/hw/ppc/ppce500_spin.o
CC ppcemb-softmmu/target/ppc/mmu-hash32.o
CC ppc64-softmmu/hw/ppc/ppce500_spin.o
CC ppc-softmmu/hw/ppc/virtex_ml507.o
CC s390x-softmmu/hw/vfio/ccw.o
CC ppc64-softmmu/hw/ppc/virtex_ml507.o
CC ppcemb-softmmu/target/ppc/monitor.o
CC ppc-softmmu/target/ppc/cpu-models.o
CC s390x-softmmu/hw/vfio/platform.o
CC ppc64-softmmu/target/ppc/cpu-models.o
CC ppcemb-softmmu/target/ppc/arch_dump.o
CC ppcemb-softmmu/target/ppc/kvm-stub.o
CC s390x-softmmu/hw/vfio/spapr.o
CC ppcemb-softmmu/target/ppc/dfp_helper.o
CC s390x-softmmu/hw/virtio/virtio.o
CC ppc-softmmu/target/ppc/cpu.o
CC ppcemb-softmmu/target/ppc/excp_helper.o
CC ppc64-softmmu/target/ppc/cpu.o
CC ppc-softmmu/target/ppc/translate.o
CC ppc64-softmmu/target/ppc/translate.o
CC s390x-softmmu/hw/virtio/virtio-balloon.o
CC ppcemb-softmmu/target/ppc/fpu_helper.o
CC s390x-softmmu/hw/virtio/vhost.o
CC s390x-softmmu/hw/virtio/vhost-backend.o
CC s390x-softmmu/hw/virtio/vhost-user.o
CC s390x-softmmu/hw/virtio/vhost-vsock.o
CC s390x-softmmu/hw/virtio/virtio-crypto.o
CC s390x-softmmu/hw/virtio/virtio-crypto-pci.o
CC s390x-softmmu/hw/s390x/s390-virtio-hcall.o
CC ppcemb-softmmu/target/ppc/int_helper.o
CC s390x-softmmu/hw/s390x/sclp.o
CC s390x-softmmu/hw/s390x/event-facility.o
CC s390x-softmmu/hw/s390x/sclpquiesce.o
CC s390x-softmmu/hw/s390x/sclpcpu.o
CC ppcemb-softmmu/target/ppc/timebase_helper.o
CC s390x-softmmu/hw/s390x/ipl.o
CC ppcemb-softmmu/target/ppc/misc_helper.o
CC ppcemb-softmmu/target/ppc/mem_helper.o
CC s390x-softmmu/hw/s390x/css.o
CC ppcemb-softmmu/target/ppc/gdbstub.o
CC s390x-softmmu/hw/s390x/s390-virtio-ccw.o
GEN trace/generated-helpers.c
CC ppcemb-softmmu/trace/control-target.o
CC ppcemb-softmmu/gdbstub-xml.o
CC s390x-softmmu/hw/s390x/3270-ccw.o
CC ppcemb-softmmu/trace/generated-helpers.o
CC s390x-softmmu/hw/s390x/virtio-ccw.o
LINK ppcemb-softmmu/qemu-system-ppcemb
CC s390x-softmmu/hw/s390x/css-bridge.o
CC s390x-softmmu/hw/s390x/ccw-device.o
CC s390x-softmmu/hw/s390x/s390-pci-bus.o
CC s390x-softmmu/hw/s390x/s390-pci-inst.o
GEN sh4eb-softmmu/hmp-commands.h
GEN sh4eb-softmmu/hmp-commands-info.h
GEN sh4eb-softmmu/config-target.h
CC sh4eb-softmmu/exec.o
CC s390x-softmmu/hw/s390x/s390-skeys.o
CC s390x-softmmu/hw/s390x/s390-stattrib.o
CC s390x-softmmu/hw/s390x/s390-skeys-kvm.o
CC s390x-softmmu/hw/s390x/s390-stattrib-kvm.o
CC ppc-softmmu/target/ppc/machine.o
CC s390x-softmmu/hw/s390x/s390-ccw.o
CC sh4eb-softmmu/tcg/tcg.o
CC ppc64-softmmu/target/ppc/machine.o
CC ppc-softmmu/target/ppc/mmu_helper.o
CC s390x-softmmu/target/s390x/cpu.o
CC ppc64-softmmu/target/ppc/mmu_helper.o
CC s390x-softmmu/target/s390x/cpu_models.o
CC ppc-softmmu/target/ppc/mmu-hash32.o
CC ppc64-softmmu/target/ppc/mmu-hash32.o
CC s390x-softmmu/target/s390x/cpu_features.o
CC ppc-softmmu/target/ppc/monitor.o
CC sh4eb-softmmu/tcg/tcg-op.o
CC s390x-softmmu/target/s390x/gdbstub.o
CC ppc64-softmmu/target/ppc/monitor.o
CC ppc-softmmu/target/ppc/arch_dump.o
CC ppc64-softmmu/target/ppc/arch_dump.o
CC s390x-softmmu/target/s390x/interrupt.o
CC ppc-softmmu/target/ppc/kvm-stub.o
CC ppc64-softmmu/target/ppc/mmu-hash64.o
CC s390x-softmmu/target/s390x/helper.o
CC ppc-softmmu/target/ppc/dfp_helper.o
CC s390x-softmmu/target/s390x/translate.o
CC ppc64-softmmu/target/ppc/mmu-book3s-v3.o
CC ppc64-softmmu/target/ppc/compat.o
CC ppc-softmmu/target/ppc/excp_helper.o
CC ppc64-softmmu/target/ppc/mmu-radix64.o
CC sh4eb-softmmu/tcg/optimize.o
CC ppc-softmmu/target/ppc/fpu_helper.o
CC ppc64-softmmu/target/ppc/kvm-stub.o
CC ppc64-softmmu/target/ppc/dfp_helper.o
CC sh4eb-softmmu/tcg/tcg-common.o
CC sh4eb-softmmu/fpu/softfloat.o
CC ppc64-softmmu/target/ppc/excp_helper.o
CC ppc64-softmmu/target/ppc/fpu_helper.o
CC s390x-softmmu/target/s390x/cc_helper.o
CC s390x-softmmu/target/s390x/excp_helper.o
CC s390x-softmmu/target/s390x/fpu_helper.o
CC s390x-softmmu/target/s390x/int_helper.o
CC s390x-softmmu/target/s390x/mem_helper.o
CC ppc-softmmu/target/ppc/int_helper.o
CC sh4eb-softmmu/disas.o
CC sh4eb-softmmu/arch_init.o
CC sh4eb-softmmu/cpus.o
CC sh4eb-softmmu/monitor.o
CC ppc-softmmu/target/ppc/timebase_helper.o
CC s390x-softmmu/target/s390x/misc_helper.o
CC ppc-softmmu/target/ppc/misc_helper.o
CC ppc64-softmmu/target/ppc/int_helper.o
CC s390x-softmmu/target/s390x/crypto_helper.o
CC ppc-softmmu/target/ppc/mem_helper.o
CC s390x-softmmu/target/s390x/machine.o
CC sh4eb-softmmu/gdbstub.o
CC s390x-softmmu/target/s390x/ioinst.o
CC ppc-softmmu/target/ppc/gdbstub.o
CC ppc64-softmmu/target/ppc/timebase_helper.o
CC s390x-softmmu/target/s390x/arch_dump.o
CC sh4eb-softmmu/balloon.o
GEN trace/generated-helpers.c
CC ppc-softmmu/trace/control-target.o
CC sh4eb-softmmu/ioport.o
CC s390x-softmmu/target/s390x/mmu_helper.o
CC ppc64-softmmu/target/ppc/misc_helper.o
CC ppc-softmmu/gdbstub-xml.o
CC ppc-softmmu/trace/generated-helpers.o
CC ppc64-softmmu/target/ppc/mem_helper.o
CC s390x-softmmu/target/s390x/diag.o
LINK ppc-softmmu/qemu-system-ppc
CC sh4eb-softmmu/numa.o
CC s390x-softmmu/target/s390x/kvm.o
CC sh4eb-softmmu/qtest.o
CC ppc64-softmmu/target/ppc/gdbstub.o
GEN trace/generated-helpers.c
CC ppc64-softmmu/trace/control-target.o
GEN trace/generated-helpers.c
CC sh4eb-softmmu/memory.o
CC s390x-softmmu/trace/control-target.o
CC ppc64-softmmu/gdbstub-xml.o
CC s390x-softmmu/gdbstub-xml.o
CC ppc64-softmmu/trace/generated-helpers.o
CC s390x-softmmu/trace/generated-helpers.o
LINK ppc64-softmmu/qemu-system-ppc64
LINK s390x-softmmu/qemu-system-s390x
GEN sh4-softmmu/hmp-commands.h
GEN sh4-softmmu/hmp-commands-info.h
GEN sh4-softmmu/config-target.h
CC sh4-softmmu/exec.o
CC sh4eb-softmmu/memory_mapping.o
CC sh4eb-softmmu/dump.o
CC sh4eb-softmmu/migration/ram.o
CC sh4-softmmu/tcg/tcg.o
CC sh4-softmmu/tcg/tcg-op.o
CC sh4-softmmu/tcg/optimize.o
CC sh4eb-softmmu/accel/accel.o
CC sh4eb-softmmu/accel/stubs/hax-stub.o
CC sh4eb-softmmu/accel/stubs/kvm-stub.o
GEN sparc64-softmmu/hmp-commands.h
CC sh4eb-softmmu/accel/tcg/tcg-all.o
GEN sparc64-softmmu/hmp-commands-info.h
GEN sparc64-softmmu/config-target.h
CC sh4eb-softmmu/accel/tcg/cputlb.o
CC sparc64-softmmu/exec.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 sh4-softmmu/tcg/tcg-common.o
CC sh4eb-softmmu/accel/tcg/tcg-runtime.o
CC sh4-softmmu/fpu/softfloat.o
CC sh4eb-softmmu/accel/tcg/cpu-exec.o
CC sparc64-softmmu/tcg/tcg.o
CC sh4eb-softmmu/accel/tcg/cpu-exec-common.o
CC sh4eb-softmmu/accel/tcg/translate-all.o
CC sparc-softmmu/tcg/tcg.o
CC sh4eb-softmmu/accel/tcg/translator.o
CC sh4eb-softmmu/hw/9pfs/virtio-9p-device.o
CC sparc64-softmmu/tcg/tcg-op.o
CC sh4eb-softmmu/hw/block/tc58128.o
CC sh4-softmmu/disas.o
CC sh4eb-softmmu/hw/block/virtio-blk.o
CC sh4-softmmu/arch_init.o
CC sparc-softmmu/tcg/tcg-op.o
CC sh4-softmmu/cpus.o
CC sh4eb-softmmu/hw/block/dataplane/virtio-blk.o
CC sh4eb-softmmu/hw/char/sh_serial.o
CC sh4-softmmu/monitor.o
CC sh4eb-softmmu/hw/char/virtio-serial-bus.o
CC sparc64-softmmu/tcg/optimize.o
CC sh4eb-softmmu/hw/core/generic-loader.o
CC sparc-softmmu/tcg/optimize.o
CC sh4eb-softmmu/hw/core/null-machine.o
CC sh4-softmmu/gdbstub.o
CC sparc64-softmmu/tcg/tcg-common.o
CC sh4eb-softmmu/hw/display/sm501.o
CC sparc64-softmmu/fpu/softfloat.o
CC sparc-softmmu/tcg/tcg-common.o
CC sh4-softmmu/balloon.o
CC sparc-softmmu/fpu/softfloat.o
CC sh4eb-softmmu/hw/display/vga.o
CC sh4-softmmu/ioport.o
CC sh4-softmmu/numa.o
CC sh4eb-softmmu/hw/display/virtio-gpu.o
CC sh4-softmmu/qtest.o
CC sparc64-softmmu/disas.o
CC sh4-softmmu/memory.o
CC sh4eb-softmmu/hw/display/virtio-gpu-3d.o
CC sparc64-softmmu/arch_init.o
CC sparc64-softmmu/cpus.o
CC sh4eb-softmmu/hw/display/virtio-gpu-pci.o
CC sh4-softmmu/memory_mapping.o
CC sparc-softmmu/disas.o
CC sh4eb-softmmu/hw/intc/sh_intc.o
CC sparc64-softmmu/monitor.o
CC sh4-softmmu/dump.o
CC sparc-softmmu/arch_init.o
CC sh4eb-softmmu/hw/misc/ivshmem.o
CC sparc-softmmu/cpus.o
CC sh4-softmmu/migration/ram.o
CC sh4eb-softmmu/hw/misc/mmio_interface.o
CC sparc-softmmu/monitor.o
CC sh4eb-softmmu/hw/net/virtio-net.o
CC sparc64-softmmu/gdbstub.o
CC sh4-softmmu/accel/accel.o
CC sh4eb-softmmu/hw/net/vhost_net.o
CC sparc64-softmmu/balloon.o
CC sh4-softmmu/accel/stubs/hax-stub.o
CC sh4eb-softmmu/hw/scsi/virtio-scsi.o
CC sparc-softmmu/gdbstub.o
CC sparc64-softmmu/ioport.o
CC sh4-softmmu/accel/stubs/kvm-stub.o
CC sh4eb-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC sparc64-softmmu/numa.o
CC sparc-softmmu/balloon.o
CC sh4-softmmu/accel/tcg/tcg-all.o
CC sparc-softmmu/ioport.o
CC sh4eb-softmmu/hw/scsi/vhost-scsi-common.o
CC sparc64-softmmu/qtest.o
CC sh4-softmmu/accel/tcg/cputlb.o
CC sh4eb-softmmu/hw/scsi/vhost-scsi.o
CC sparc-softmmu/numa.o
CC sparc64-softmmu/memory.o
CC sh4eb-softmmu/hw/scsi/vhost-user-scsi.o
CC sparc-softmmu/qtest.o
CC sh4eb-softmmu/hw/timer/sh_timer.o
CC sparc-softmmu/memory.o
CC sh4-softmmu/accel/tcg/tcg-runtime.o
CC sparc64-softmmu/memory_mapping.o
CC sh4eb-softmmu/hw/timer/mc146818rtc.o
CC sh4-softmmu/accel/tcg/cpu-exec.o
CC sh4eb-softmmu/hw/vfio/common.o
CC sparc64-softmmu/dump.o
CC sparc64-softmmu/migration/ram.o
CC sh4-softmmu/accel/tcg/cpu-exec-common.o
CC sh4eb-softmmu/hw/vfio/pci.o
CC sparc-softmmu/memory_mapping.o
CC sh4-softmmu/accel/tcg/translate-all.o
CC sparc-softmmu/dump.o
CC sparc64-softmmu/accel/accel.o
CC sh4eb-softmmu/hw/vfio/pci-quirks.o
CC sh4-softmmu/accel/tcg/translator.o
CC sparc-softmmu/migration/ram.o
CC sparc64-softmmu/accel/stubs/hax-stub.o
CC sh4-softmmu/hw/9pfs/virtio-9p-device.o
CC sh4-softmmu/hw/block/tc58128.o
CC sh4eb-softmmu/hw/vfio/platform.o
CC sparc64-softmmu/accel/stubs/kvm-stub.o
CC sh4-softmmu/hw/block/virtio-blk.o
CC sparc-softmmu/accel/accel.o
CC sparc64-softmmu/accel/tcg/tcg-all.o
CC sh4eb-softmmu/hw/vfio/spapr.o
CC sparc-softmmu/accel/stubs/hax-stub.o
CC sparc64-softmmu/accel/tcg/cputlb.o
CC sh4-softmmu/hw/block/dataplane/virtio-blk.o
CC sh4eb-softmmu/hw/virtio/virtio.o
CC sparc-softmmu/accel/stubs/kvm-stub.o
CC sparc-softmmu/accel/tcg/tcg-all.o
CC sh4-softmmu/hw/char/sh_serial.o
CC sparc-softmmu/accel/tcg/cputlb.o
CC sh4-softmmu/hw/char/virtio-serial-bus.o
CC sh4eb-softmmu/hw/virtio/virtio-balloon.o
CC sh4eb-softmmu/hw/virtio/vhost.o
CC sh4-softmmu/hw/core/generic-loader.o
CC sparc64-softmmu/accel/tcg/tcg-runtime.o
CC sh4-softmmu/hw/core/null-machine.o
CC sparc64-softmmu/accel/tcg/cpu-exec.o
CC sh4-softmmu/hw/display/sm501.o
CC sparc-softmmu/accel/tcg/tcg-runtime.o
CC sh4eb-softmmu/hw/virtio/vhost-backend.o
CC sparc64-softmmu/accel/tcg/cpu-exec-common.o
CC sh4eb-softmmu/hw/virtio/vhost-user.o
CC sparc-softmmu/accel/tcg/cpu-exec.o
CC sparc64-softmmu/accel/tcg/translate-all.o
CC sh4eb-softmmu/hw/virtio/vhost-vsock.o
CC sh4-softmmu/hw/display/vga.o
CC sparc-softmmu/accel/tcg/cpu-exec-common.o
CC sh4eb-softmmu/hw/virtio/virtio-crypto.o
CC sparc64-softmmu/accel/tcg/translator.o
CC sparc-softmmu/accel/tcg/translate-all.o
CC sh4eb-softmmu/hw/virtio/virtio-crypto-pci.o
CC sparc64-softmmu/hw/9pfs/virtio-9p-device.o
CC sparc-softmmu/accel/tcg/translator.o
CC sh4eb-softmmu/hw/sh4/shix.o
CC sparc64-softmmu/hw/block/virtio-blk.o
CC sh4eb-softmmu/hw/sh4/r2d.o
CC sparc-softmmu/hw/core/generic-loader.o
CC sh4-softmmu/hw/display/virtio-gpu.o
CC sparc64-softmmu/hw/block/dataplane/virtio-blk.o
CC sh4eb-softmmu/hw/sh4/sh7750.o
CC sparc-softmmu/hw/core/null-machine.o
CC sparc64-softmmu/hw/char/virtio-serial-bus.o
CC sparc-softmmu/hw/display/tcx.o
CC sh4eb-softmmu/hw/sh4/sh7750_regnames.o
CC sh4-softmmu/hw/display/virtio-gpu-3d.o
CC sh4eb-softmmu/hw/sh4/sh_pci.o
CC sparc-softmmu/hw/display/cg3.o
CC sparc64-softmmu/hw/core/generic-loader.o
CC sh4eb-softmmu/target/sh4/translate.o
CC sparc64-softmmu/hw/core/null-machine.o
CC sh4-softmmu/hw/display/virtio-gpu-pci.o
CC sparc-softmmu/hw/intc/grlib_irqmp.o
CC sparc64-softmmu/hw/display/vga.o
CC sh4-softmmu/hw/intc/sh_intc.o
CC sparc-softmmu/hw/misc/eccmemctl.o
CC sparc-softmmu/hw/misc/slavio_misc.o
CC sh4-softmmu/hw/misc/ivshmem.o
CC sparc64-softmmu/hw/display/virtio-gpu.o
CC sparc-softmmu/hw/misc/mmio_interface.o
CC sh4eb-softmmu/target/sh4/op_helper.o
CC sh4-softmmu/hw/misc/mmio_interface.o
CC sparc-softmmu/hw/net/vhost_net.o
CC sh4-softmmu/hw/net/virtio-net.o
CC sh4eb-softmmu/target/sh4/helper.o
CC sparc64-softmmu/hw/display/virtio-gpu-3d.o
CC sparc-softmmu/hw/net/rocker/qmp-norocker.o
CC sparc-softmmu/hw/vfio/common.o
CC sh4eb-softmmu/target/sh4/cpu.o
CC sparc64-softmmu/hw/display/virtio-gpu-pci.o
CC sparc64-softmmu/hw/misc/ivshmem.o
CC sh4-softmmu/hw/net/vhost_net.o
CC sh4eb-softmmu/target/sh4/monitor.o
CC sh4-softmmu/hw/scsi/virtio-scsi.o
CC sparc-softmmu/hw/vfio/platform.o
CC sh4eb-softmmu/target/sh4/gdbstub.o
CC sparc64-softmmu/hw/misc/mmio_interface.o
GEN trace/generated-helpers.c
CC sparc-softmmu/hw/vfio/spapr.o
CC sh4eb-softmmu/trace/control-target.o
CC sparc64-softmmu/hw/net/virtio-net.o
CC sh4-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC sh4eb-softmmu/trace/generated-helpers.o
CC sparc-softmmu/hw/sparc/sun4m.o
CC sh4-softmmu/hw/scsi/vhost-scsi-common.o
CC sparc64-softmmu/hw/net/vhost_net.o
LINK sh4eb-softmmu/qemu-system-sh4eb
CC sparc-softmmu/hw/sparc/leon3.o
CC sh4-softmmu/hw/scsi/vhost-scsi.o
CC sparc64-softmmu/hw/scsi/virtio-scsi.o
CC sparc-softmmu/target/sparc/machine.o
CC sh4-softmmu/hw/scsi/vhost-user-scsi.o
CC sparc64-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC sparc-softmmu/target/sparc/monitor.o
CC sh4-softmmu/hw/timer/sh_timer.o
CC sparc64-softmmu/hw/scsi/vhost-scsi-common.o
CC sparc-softmmu/target/sparc/translate.o
CC sh4-softmmu/hw/timer/mc146818rtc.o
CC sparc64-softmmu/hw/scsi/vhost-scsi.o
CC sh4-softmmu/hw/vfio/common.o
CC sparc64-softmmu/hw/scsi/vhost-user-scsi.o
GEN tricore-softmmu/hmp-commands.h
GEN tricore-softmmu/hmp-commands-info.h
GEN tricore-softmmu/config-target.h
CC tricore-softmmu/exec.o
CC sparc64-softmmu/hw/timer/mc146818rtc.o
CC sh4-softmmu/hw/vfio/pci.o
CC sparc-softmmu/target/sparc/helper.o
CC sparc64-softmmu/hw/vfio/common.o
CC sparc-softmmu/target/sparc/cpu.o
CC sparc64-softmmu/hw/vfio/pci.o
CC sparc-softmmu/target/sparc/fop_helper.o
CC sh4-softmmu/hw/vfio/pci-quirks.o
CC sparc-softmmu/target/sparc/cc_helper.o
CC tricore-softmmu/tcg/tcg.o
CC sparc-softmmu/target/sparc/win_helper.o
CC sparc64-softmmu/hw/vfio/pci-quirks.o
CC sparc-softmmu/target/sparc/mmu_helper.o
CC sh4-softmmu/hw/vfio/platform.o
CC sparc64-softmmu/hw/vfio/platform.o
CC sparc-softmmu/target/sparc/ldst_helper.o
CC sh4-softmmu/hw/vfio/spapr.o
CC sparc64-softmmu/hw/vfio/spapr.o
CC tricore-softmmu/tcg/tcg-op.o
CC sparc-softmmu/target/sparc/int32_helper.o
CC sh4-softmmu/hw/virtio/virtio.o
CC sparc64-softmmu/hw/virtio/virtio.o
CC sparc-softmmu/target/sparc/gdbstub.o
GEN trace/generated-helpers.c
CC sparc-softmmu/trace/control-target.o
CC sh4-softmmu/hw/virtio/virtio-balloon.o
CC sparc64-softmmu/hw/virtio/virtio-balloon.o
CC sparc-softmmu/trace/generated-helpers.o
CC sh4-softmmu/hw/virtio/vhost.o
CC sparc64-softmmu/hw/virtio/vhost.o
LINK sparc-softmmu/qemu-system-sparc
CC sh4-softmmu/hw/virtio/vhost-backend.o
CC tricore-softmmu/tcg/optimize.o
CC sparc64-softmmu/hw/virtio/vhost-backend.o
CC sh4-softmmu/hw/virtio/vhost-user.o
CC sparc64-softmmu/hw/virtio/vhost-user.o
CC tricore-softmmu/tcg/tcg-common.o
CC sh4-softmmu/hw/virtio/vhost-vsock.o
CC sparc64-softmmu/hw/virtio/vhost-vsock.o
GEN unicore32-softmmu/hmp-commands.h
CC tricore-softmmu/fpu/softfloat.o
GEN unicore32-softmmu/hmp-commands-info.h
GEN unicore32-softmmu/config-target.h
CC unicore32-softmmu/exec.o
CC sh4-softmmu/hw/virtio/virtio-crypto.o
CC sparc64-softmmu/hw/virtio/virtio-crypto.o
CC sparc64-softmmu/hw/virtio/virtio-crypto-pci.o
CC sh4-softmmu/hw/virtio/virtio-crypto-pci.o
CC sparc64-softmmu/hw/sparc64/sparc64.o
CC sh4-softmmu/hw/sh4/shix.o
CC sh4-softmmu/hw/sh4/r2d.o
CC sparc64-softmmu/hw/sparc64/sun4u.o
CC sh4-softmmu/hw/sh4/sh7750.o
CC unicore32-softmmu/tcg/tcg.o
CC tricore-softmmu/disas.o
CC sparc64-softmmu/hw/sparc64/niagara.o
CC tricore-softmmu/arch_init.o
CC sh4-softmmu/hw/sh4/sh7750_regnames.o
CC tricore-softmmu/cpus.o
CC sparc64-softmmu/target/sparc/machine.o
CC sh4-softmmu/hw/sh4/sh_pci.o
CC sparc64-softmmu/target/sparc/monitor.o
CC sh4-softmmu/target/sh4/translate.o
CC tricore-softmmu/monitor.o
CC sparc64-softmmu/target/sparc/translate.o
CC unicore32-softmmu/tcg/tcg-op.o
CC sh4-softmmu/target/sh4/op_helper.o
CC tricore-softmmu/gdbstub.o
CC sh4-softmmu/target/sh4/helper.o
CC tricore-softmmu/balloon.o
CC sh4-softmmu/target/sh4/cpu.o
CC unicore32-softmmu/tcg/optimize.o
CC sparc64-softmmu/target/sparc/helper.o
CC tricore-softmmu/ioport.o
CC sh4-softmmu/target/sh4/monitor.o
CC sparc64-softmmu/target/sparc/cpu.o
CC sh4-softmmu/target/sh4/gdbstub.o
CC sparc64-softmmu/target/sparc/fop_helper.o
CC tricore-softmmu/numa.o
GEN trace/generated-helpers.c
CC sh4-softmmu/trace/control-target.o
CC unicore32-softmmu/tcg/tcg-common.o
CC sparc64-softmmu/target/sparc/cc_helper.o
CC tricore-softmmu/qtest.o
CC unicore32-softmmu/fpu/softfloat.o
CC sh4-softmmu/trace/generated-helpers.o
CC sparc64-softmmu/target/sparc/win_helper.o
CC tricore-softmmu/memory.o
CC sparc64-softmmu/target/sparc/mmu_helper.o
LINK sh4-softmmu/qemu-system-sh4
CC sparc64-softmmu/target/sparc/ldst_helper.o
CC sparc64-softmmu/target/sparc/int64_helper.o
CC tricore-softmmu/memory_mapping.o
CC sparc64-softmmu/target/sparc/vis_helper.o
CC tricore-softmmu/dump.o
CC tricore-softmmu/migration/ram.o
CC sparc64-softmmu/target/sparc/gdbstub.o
CC unicore32-softmmu/disas.o
GEN trace/generated-helpers.c
CC tricore-softmmu/accel/accel.o
CC sparc64-softmmu/trace/control-target.o
CC unicore32-softmmu/arch_init.o
CC tricore-softmmu/accel/stubs/hax-stub.o
CC sparc64-softmmu/trace/generated-helpers.o
CC tricore-softmmu/accel/stubs/kvm-stub.o
GEN x86_64-softmmu/hmp-commands.h
GEN x86_64-softmmu/hmp-commands-info.h
CC unicore32-softmmu/cpus.o
GEN x86_64-softmmu/config-target.h
CC tricore-softmmu/accel/tcg/tcg-all.o
LINK sparc64-softmmu/qemu-system-sparc64
CC x86_64-softmmu/exec.o
CC tricore-softmmu/accel/tcg/cputlb.o
CC unicore32-softmmu/monitor.o
CC x86_64-softmmu/tcg/tcg.o
CC tricore-softmmu/accel/tcg/tcg-runtime.o
CC unicore32-softmmu/gdbstub.o
CC unicore32-softmmu/balloon.o
CC tricore-softmmu/accel/tcg/cpu-exec.o
CC tricore-softmmu/accel/tcg/cpu-exec-common.o
CC unicore32-softmmu/ioport.o
CC tricore-softmmu/accel/tcg/translate-all.o
GEN xtensaeb-softmmu/hmp-commands.h
GEN xtensaeb-softmmu/hmp-commands-info.h
GEN xtensaeb-softmmu/config-target.h
CC xtensaeb-softmmu/exec.o
CC unicore32-softmmu/numa.o
CC tricore-softmmu/accel/tcg/translator.o
CC unicore32-softmmu/qtest.o
CC x86_64-softmmu/tcg/tcg-op.o
CC tricore-softmmu/hw/core/generic-loader.o
CC tricore-softmmu/hw/core/null-machine.o
CC tricore-softmmu/hw/misc/mmio_interface.o
CC unicore32-softmmu/memory.o
CC tricore-softmmu/hw/net/vhost_net.o
CC tricore-softmmu/hw/net/rocker/qmp-norocker.o
CC xtensaeb-softmmu/tcg/tcg.o
CC tricore-softmmu/hw/vfio/common.o
CC unicore32-softmmu/memory_mapping.o
CC tricore-softmmu/hw/vfio/platform.o
CC unicore32-softmmu/dump.o
CC tricore-softmmu/hw/vfio/spapr.o
CC xtensaeb-softmmu/tcg/tcg-op.o
CC tricore-softmmu/hw/tricore/tricore_testboard.o
CC x86_64-softmmu/tcg/optimize.o
CC unicore32-softmmu/migration/ram.o
CC tricore-softmmu/target/tricore/translate.o
CC x86_64-softmmu/tcg/tcg-common.o
CC unicore32-softmmu/accel/accel.o
CC x86_64-softmmu/fpu/softfloat.o
CC unicore32-softmmu/accel/stubs/hax-stub.o
CC unicore32-softmmu/accel/stubs/kvm-stub.o
CC xtensaeb-softmmu/tcg/optimize.o
CC unicore32-softmmu/accel/tcg/tcg-all.o
CC unicore32-softmmu/accel/tcg/cputlb.o
CC xtensaeb-softmmu/tcg/tcg-common.o
CC xtensaeb-softmmu/fpu/softfloat.o
CC unicore32-softmmu/accel/tcg/tcg-runtime.o
CC x86_64-softmmu/disas.o
CC unicore32-softmmu/accel/tcg/cpu-exec.o
GEN x86_64-softmmu/gdbstub-xml.c
CC tricore-softmmu/target/tricore/helper.o
CC unicore32-softmmu/accel/tcg/cpu-exec-common.o
CC tricore-softmmu/target/tricore/cpu.o
CC x86_64-softmmu/arch_init.o
CC unicore32-softmmu/accel/tcg/translate-all.o
CC tricore-softmmu/target/tricore/op_helper.o
CC x86_64-softmmu/cpus.o
CC unicore32-softmmu/accel/tcg/translator.o
CC xtensaeb-softmmu/disas.o
CC x86_64-softmmu/monitor.o
CC unicore32-softmmu/hw/core/generic-loader.o
CC xtensaeb-softmmu/arch_init.o
CC unicore32-softmmu/hw/core/null-machine.o
CC xtensaeb-softmmu/cpus.o
CC unicore32-softmmu/hw/misc/mmio_interface.o
CC tricore-softmmu/target/tricore/fpu_helper.o
CC unicore32-softmmu/hw/net/vhost_net.o
CC xtensaeb-softmmu/monitor.o
GEN trace/generated-helpers.c
CC tricore-softmmu/trace/control-target.o
CC x86_64-softmmu/gdbstub.o
CC unicore32-softmmu/hw/net/rocker/qmp-norocker.o
CC unicore32-softmmu/hw/vfio/common.o
CC tricore-softmmu/trace/generated-helpers.o
CC x86_64-softmmu/balloon.o
LINK tricore-softmmu/qemu-system-tricore
CC unicore32-softmmu/hw/vfio/platform.o
CC x86_64-softmmu/ioport.o
CC xtensaeb-softmmu/gdbstub.o
CC x86_64-softmmu/numa.o
CC unicore32-softmmu/hw/vfio/spapr.o
CC xtensaeb-softmmu/balloon.o
CC unicore32-softmmu/hw/unicore32/puv3.o
CC x86_64-softmmu/qtest.o
CC xtensaeb-softmmu/ioport.o
CC unicore32-softmmu/target/unicore32/translate.o
CC x86_64-softmmu/memory.o
CC xtensaeb-softmmu/numa.o
GEN xtensa-softmmu/hmp-commands.h
GEN xtensa-softmmu/hmp-commands-info.h
GEN xtensa-softmmu/config-target.h
CC xtensaeb-softmmu/qtest.o
CC xtensa-softmmu/exec.o
CC unicore32-softmmu/target/unicore32/op_helper.o
CC x86_64-softmmu/memory_mapping.o
CC xtensaeb-softmmu/memory.o
CC x86_64-softmmu/dump.o
CC unicore32-softmmu/target/unicore32/helper.o
CC unicore32-softmmu/target/unicore32/cpu.o
CC x86_64-softmmu/migration/ram.o
CC xtensa-softmmu/tcg/tcg.o
CC unicore32-softmmu/target/unicore32/ucf64_helper.o
CC xtensaeb-softmmu/memory_mapping.o
CC unicore32-softmmu/target/unicore32/softmmu.o
CC xtensaeb-softmmu/dump.o
CC x86_64-softmmu/accel/accel.o
GEN trace/generated-helpers.c
CC unicore32-softmmu/trace/control-target.o
CC x86_64-softmmu/accel/stubs/hax-stub.o
CC unicore32-softmmu/trace/generated-helpers.o
CC xtensaeb-softmmu/migration/ram.o
CC x86_64-softmmu/accel/stubs/kvm-stub.o
LINK unicore32-softmmu/qemu-system-unicore32
CC xtensa-softmmu/tcg/tcg-op.o
CC x86_64-softmmu/accel/tcg/tcg-all.o
CC x86_64-softmmu/accel/tcg/cputlb.o
CC xtensaeb-softmmu/accel/accel.o
CC xtensaeb-softmmu/accel/stubs/hax-stub.o
CC xtensaeb-softmmu/accel/stubs/kvm-stub.o
CC xtensaeb-softmmu/accel/tcg/tcg-all.o
CC x86_64-softmmu/accel/tcg/tcg-runtime.o
CC xtensaeb-softmmu/accel/tcg/cputlb.o
CC x86_64-softmmu/accel/tcg/cpu-exec.o
CC x86_64-softmmu/accel/tcg/cpu-exec-common.o
CC xtensaeb-softmmu/accel/tcg/tcg-runtime.o
CC x86_64-softmmu/accel/tcg/translate-all.o
CC xtensa-softmmu/tcg/optimize.o
CC x86_64-softmmu/accel/tcg/translator.o
GEN aarch64-linux-user/config-target.h
CC xtensaeb-softmmu/accel/tcg/cpu-exec.o
CC aarch64-linux-user/exec.o
CC xtensa-softmmu/tcg/tcg-common.o
CC xtensaeb-softmmu/accel/tcg/cpu-exec-common.o
CC aarch64-linux-user/tcg/tcg.o
CC x86_64-softmmu/hw/9pfs/virtio-9p-device.o
CC xtensa-softmmu/fpu/softfloat.o
CC xtensaeb-softmmu/accel/tcg/translate-all.o
CC x86_64-softmmu/hw/block/virtio-blk.o
CC xtensaeb-softmmu/accel/tcg/translator.o
CC x86_64-softmmu/hw/block/dataplane/virtio-blk.o
CC xtensaeb-softmmu/hw/core/generic-loader.o
CC x86_64-softmmu/hw/char/virtio-serial-bus.o
CC aarch64-linux-user/tcg/tcg-op.o
CC xtensaeb-softmmu/hw/core/null-machine.o
CC x86_64-softmmu/hw/core/generic-loader.o
CC xtensaeb-softmmu/hw/misc/mmio_interface.o
CC xtensa-softmmu/disas.o
CC x86_64-softmmu/hw/core/null-machine.o
CC xtensaeb-softmmu/hw/net/vhost_net.o
CC x86_64-softmmu/hw/display/vga.o
CC xtensa-softmmu/arch_init.o
CC xtensaeb-softmmu/hw/net/rocker/qmp-norocker.o
CC xtensa-softmmu/cpus.o
CC xtensaeb-softmmu/hw/vfio/common.o
CC xtensa-softmmu/monitor.o
CC x86_64-softmmu/hw/display/virtio-gpu.o
CC aarch64-linux-user/tcg/optimize.o
CC xtensaeb-softmmu/hw/vfio/platform.o
CC xtensaeb-softmmu/hw/vfio/spapr.o
CC xtensa-softmmu/gdbstub.o
CC x86_64-softmmu/hw/display/virtio-gpu-3d.o
CC xtensaeb-softmmu/hw/xtensa/pic_cpu.o
CC aarch64-linux-user/tcg/tcg-common.o
CC xtensaeb-softmmu/hw/xtensa/sim.o
CC xtensaeb-softmmu/hw/xtensa/xtfpga.o
CC x86_64-softmmu/hw/display/virtio-gpu-pci.o
CC xtensa-softmmu/balloon.o
CC aarch64-linux-user/fpu/softfloat.o
CC xtensaeb-softmmu/target/xtensa/xtensa-semi.o
CC xtensa-softmmu/ioport.o
CC x86_64-softmmu/hw/display/virtio-vga.o
CC xtensaeb-softmmu/target/xtensa/core-dc232b.o
CC xtensa-softmmu/numa.o
CC x86_64-softmmu/hw/intc/apic.o
CC xtensaeb-softmmu/target/xtensa/core-dc233c.o
CC xtensa-softmmu/qtest.o
CC x86_64-softmmu/hw/intc/apic_common.o
CC xtensaeb-softmmu/target/xtensa/core-fsf.o
CC xtensa-softmmu/memory.o
CC x86_64-softmmu/hw/intc/ioapic.o
CC xtensaeb-softmmu/target/xtensa/monitor.o
CC xtensaeb-softmmu/target/xtensa/translate.o
CC x86_64-softmmu/hw/isa/lpc_ich9.o
CC aarch64-linux-user/disas.o
CC x86_64-softmmu/hw/misc/vmport.o
GEN aarch64-linux-user/gdbstub-xml.c
CC x86_64-softmmu/hw/misc/ivshmem.o
CC xtensa-softmmu/memory_mapping.o
CC aarch64-linux-user/gdbstub.o
CC xtensa-softmmu/dump.o
CC x86_64-softmmu/hw/misc/pvpanic.o
CC aarch64-linux-user/thunk.o
CC x86_64-softmmu/hw/misc/mmio_interface.o
CC xtensaeb-softmmu/target/xtensa/op_helper.o
CC aarch64-linux-user/accel/stubs/hax-stub.o
CC x86_64-softmmu/hw/net/virtio-net.o
CC xtensa-softmmu/migration/ram.o
CC aarch64-linux-user/accel/stubs/kvm-stub.o
CC aarch64-linux-user/accel/tcg/tcg-runtime.o
CC xtensaeb-softmmu/target/xtensa/helper.o
CC aarch64-linux-user/accel/tcg/cpu-exec.o
CC xtensa-softmmu/accel/accel.o
CC x86_64-softmmu/hw/net/vhost_net.o
CC xtensaeb-softmmu/target/xtensa/cpu.o
CC xtensa-softmmu/accel/stubs/hax-stub.o
CC x86_64-softmmu/hw/scsi/virtio-scsi.o
CC aarch64-linux-user/accel/tcg/cpu-exec-common.o
CC xtensaeb-softmmu/target/xtensa/gdbstub.o
CC xtensa-softmmu/accel/stubs/kvm-stub.o
CC aarch64-linux-user/accel/tcg/translate-all.o
CC xtensa-softmmu/accel/tcg/tcg-all.o
GEN trace/generated-helpers.c
CC xtensaeb-softmmu/trace/control-target.o
CC x86_64-softmmu/hw/scsi/virtio-scsi-dataplane.o
CC xtensa-softmmu/accel/tcg/cputlb.o
CC xtensaeb-softmmu/trace/generated-helpers.o
CC aarch64-linux-user/accel/tcg/translator.o
CC x86_64-softmmu/hw/scsi/vhost-scsi-common.o
CC x86_64-softmmu/hw/scsi/vhost-scsi.o
LINK xtensaeb-softmmu/qemu-system-xtensaeb
CC aarch64-linux-user/accel/tcg/user-exec.o
CC x86_64-softmmu/hw/scsi/vhost-user-scsi.o
CC aarch64-linux-user/accel/tcg/user-exec-stub.o
CC x86_64-softmmu/hw/timer/mc146818rtc.o
CC xtensa-softmmu/accel/tcg/tcg-runtime.o
CC aarch64-linux-user/linux-user/main.o
CC xtensa-softmmu/accel/tcg/cpu-exec.o
CC x86_64-softmmu/hw/vfio/common.o
CC x86_64-softmmu/hw/vfio/pci.o
CC aarch64-linux-user/linux-user/syscall.o
CC xtensa-softmmu/accel/tcg/cpu-exec-common.o
CC x86_64-softmmu/hw/vfio/pci-quirks.o
CC xtensa-softmmu/accel/tcg/translate-all.o
CC x86_64-softmmu/hw/vfio/platform.o
CC x86_64-softmmu/hw/vfio/spapr.o
GEN alpha-linux-user/config-target.h
CC xtensa-softmmu/accel/tcg/translator.o
CC alpha-linux-user/exec.o
CC x86_64-softmmu/hw/virtio/virtio.o
CC xtensa-softmmu/hw/core/generic-loader.o
CC alpha-linux-user/tcg/tcg.o
CC xtensa-softmmu/hw/core/null-machine.o
CC x86_64-softmmu/hw/virtio/virtio-balloon.o
CC xtensa-softmmu/hw/misc/mmio_interface.o
CC xtensa-softmmu/hw/net/vhost_net.o
CC x86_64-softmmu/hw/virtio/vhost.o
CC aarch64-linux-user/linux-user/strace.o
CC alpha-linux-user/tcg/tcg-op.o
CC xtensa-softmmu/hw/net/rocker/qmp-norocker.o
CC xtensa-softmmu/hw/vfio/common.o
CC x86_64-softmmu/hw/virtio/vhost-backend.o
CC aarch64-linux-user/linux-user/mmap.o
CC x86_64-softmmu/hw/virtio/vhost-user.o
CC xtensa-softmmu/hw/vfio/platform.o
CC aarch64-linux-user/linux-user/signal.o
CC x86_64-softmmu/hw/virtio/vhost-vsock.o
CC xtensa-softmmu/hw/vfio/spapr.o
CC aarch64-linux-user/linux-user/elfload.o
CC x86_64-softmmu/hw/virtio/virtio-crypto.o
CC xtensa-softmmu/hw/xtensa/pic_cpu.o
CC xtensa-softmmu/hw/xtensa/sim.o
CC alpha-linux-user/tcg/optimize.o
CC x86_64-softmmu/hw/virtio/virtio-crypto-pci.o
CC xtensa-softmmu/hw/xtensa/xtfpga.o
CC aarch64-linux-user/linux-user/linuxload.o
CC x86_64-softmmu/hw/i386/multiboot.o
CC aarch64-linux-user/linux-user/uaccess.o
CC xtensa-softmmu/target/xtensa/xtensa-semi.o
CC alpha-linux-user/tcg/tcg-common.o
CC alpha-linux-user/fpu/softfloat.o
CC x86_64-softmmu/hw/i386/pc.o
CC aarch64-linux-user/linux-user/uname.o
CC xtensa-softmmu/target/xtensa/core-dc232b.o
CCAS aarch64-linux-user/linux-user/safe-syscall.o
CC xtensa-softmmu/target/xtensa/core-dc233c.o
CC aarch64-linux-user/linux-user/flatload.o
CC xtensa-softmmu/target/xtensa/core-fsf.o
CC x86_64-softmmu/hw/i386/pc_piix.o
CC xtensa-softmmu/target/xtensa/monitor.o
CC aarch64-linux-user/target/arm/arm-semi.o
CC xtensa-softmmu/target/xtensa/translate.o
CC aarch64-linux-user/target/arm/kvm-stub.o
CC x86_64-softmmu/hw/i386/pc_q35.o
CC aarch64-linux-user/target/arm/translate.o
CC x86_64-softmmu/hw/i386/pc_sysfw.o
CC x86_64-softmmu/hw/i386/x86-iommu.o
CC alpha-linux-user/disas.o
CC x86_64-softmmu/hw/i386/intel_iommu.o
CC alpha-linux-user/gdbstub.o
CC xtensa-softmmu/target/xtensa/op_helper.o
CC alpha-linux-user/thunk.o
CC xtensa-softmmu/target/xtensa/helper.o
CC x86_64-softmmu/hw/i386/amd_iommu.o
CC alpha-linux-user/accel/stubs/hax-stub.o
CC xtensa-softmmu/target/xtensa/cpu.o
CC alpha-linux-user/accel/stubs/kvm-stub.o
CC x86_64-softmmu/hw/i386/kvmvapic.o
CC xtensa-softmmu/target/xtensa/gdbstub.o
CC alpha-linux-user/accel/tcg/tcg-runtime.o
GEN trace/generated-helpers.c
CC xtensa-softmmu/trace/control-target.o
CC x86_64-softmmu/hw/i386/acpi-build.o
CC alpha-linux-user/accel/tcg/cpu-exec.o
CC xtensa-softmmu/trace/generated-helpers.o
CC alpha-linux-user/accel/tcg/cpu-exec-common.o
LINK xtensa-softmmu/qemu-system-xtensa
CC alpha-linux-user/accel/tcg/translate-all.o
CC x86_64-softmmu/hw/i386/pci-assign-load-rom.o
CC alpha-linux-user/accel/tcg/translator.o
CC x86_64-softmmu/target/i386/helper.o
CC alpha-linux-user/accel/tcg/user-exec.o
CC aarch64-linux-user/target/arm/op_helper.o
CC aarch64-linux-user/target/arm/helper.o
CC x86_64-softmmu/target/i386/cpu.o
CC alpha-linux-user/accel/tcg/user-exec-stub.o
CC aarch64-linux-user/target/arm/cpu.o
CC x86_64-softmmu/target/i386/gdbstub.o
CC alpha-linux-user/linux-user/main.o
CC x86_64-softmmu/target/i386/windbgstub.o
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:26:2: error: #error Unsupported Architecture
#error Unsupported Architecture
^~~~~
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/cpu.h:1570:0,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/disas/disas.h:7,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/log.h:6,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:17,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c: In function ‘windbg_read_context’:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:470:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Edi’; did you mean ‘Rdi’?
stl_p(&cc->Edi, env->regs[R_EDI]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:471:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Esi’; did you mean ‘Rsi’?
stl_p(&cc->Esi, env->regs[R_ESI]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:472:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ebx’; did you mean ‘Rbx’?
stl_p(&cc->Ebx, env->regs[R_EBX]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:473:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Edx’; did you mean ‘Rdx’?
stl_p(&cc->Edx, env->regs[R_EDX]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:474:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ecx’; did you mean ‘Rcx’?
stl_p(&cc->Ecx, env->regs[R_ECX]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:475:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Eax’; did you mean ‘Rax’?
stl_p(&cc->Eax, env->regs[R_EAX]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:476:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ebp’; did you mean ‘Rbp’?
stl_p(&cc->Ebp, env->regs[R_EBP]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:477:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Esp’; did you mean ‘Rsp’?
stl_p(&cc->Esp, env->regs[R_ESP]);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:478:18: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Eip’; did you mean ‘Rip’?
stl_p(&cc->Eip, env->eip);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:498:29: error: ‘CPU_XMM_SAVE_AREA32 {aka struct _CPU_XMM_SAVE_AREA32}’ has no member named ‘Cr0NpxState’
stl_p(&cc->FloatSave.Cr0NpxState, env->xcr0);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:501:37: error: ‘CPU_XMM_SAVE_AREA32 {aka struct _CPU_XMM_SAVE_AREA32}’ has no member named ‘RegisterArea’
memcpy(PTR(cc->FloatSave.RegisterArea[i * 10]),
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:41:36: note: in definition of macro ‘UINT8_P’
#define UINT8_P(ptr) ((uint8_t *) (ptr))
^~~
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:501:20: note: in expansion of macro ‘PTR’
memcpy(PTR(cc->FloatSave.RegisterArea[i * 10]),
^~~
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:506:28: error: ‘CPU_CONTEXT_EXTENDED_REGISTERS’ undeclared (first use in this function)
if (cc->ContextFlags & CPU_CONTEXT_EXTENDED_REGISTERS) {
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:506:28: note: each undeclared identifier is reported only once for each function it appears in
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:507:26: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘ExtendedRegisters’; did you mean ‘VectorRegister’?
uint8_t *ptr = cc->ExtendedRegisters + 160;
^~
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/cpu.h:1570:0,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/disas/disas.h:7,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/log.h:6,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:17,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:514:17: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘ExtendedRegisters’; did you mean ‘VectorRegister’?
stl_p(cc->ExtendedRegisters + 24, env->mxcsr);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/cpu-all.h:144:30: note: in definition of macro ‘stl_p’
#define stl_p(p, v) stl_le_p(p, v)
^
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c: In function ‘windbg_write_context’:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:621:14: error: ‘CPU_XMM_SAVE_AREA32 {aka struct _CPU_XMM_SAVE_AREA32}’ has no member named ‘RegisterArea’
case offsetof(CPU_CONTEXT, FloatSave.RegisterArea):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:622:59: error: ‘CPU_XMM_SAVE_AREA32 {aka struct _CPU_XMM_SAVE_AREA32}’ has no member named ‘RegisterArea’
mem_size = sizeof_field(CPU_CONTEXT, FloatSave.RegisterArea);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:59: note: in definition of macro ‘sizeof_field’
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:628:14: error: ‘CPU_XMM_SAVE_AREA32 {aka struct _CPU_XMM_SAVE_AREA32}’ has no member named ‘Cr0NpxState’
case offsetof(CPU_CONTEXT, FloatSave.Cr0NpxState):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:629:59: error: ‘CPU_XMM_SAVE_AREA32 {aka struct _CPU_XMM_SAVE_AREA32}’ has no member named ‘Cr0NpxState’
mem_size = sizeof_field(CPU_CONTEXT, FloatSave.Cr0NpxState);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:59: note: in definition of macro ‘sizeof_field’
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:653:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Edi’; did you mean ‘Rdi’?
case offsetof(CPU_CONTEXT, Edi):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Edi’; did you mean ‘Rdi’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:654:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Edi);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:658:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Esi’; did you mean ‘Rsi’?
case offsetof(CPU_CONTEXT, Esi):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Esi’; did you mean ‘Rsi’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:659:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Esi);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:663:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ebx’; did you mean ‘Rbx’?
case offsetof(CPU_CONTEXT, Ebx):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ebx’; did you mean ‘Rbx’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:664:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Ebx);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:668:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Edx’; did you mean ‘Rdx’?
case offsetof(CPU_CONTEXT, Edx):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Edx’; did you mean ‘Rdx’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:669:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Edx);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:673:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ecx’; did you mean ‘Rcx’?
case offsetof(CPU_CONTEXT, Ecx):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ecx’; did you mean ‘Rcx’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:674:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Ecx);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:678:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Eax’; did you mean ‘Rax’?
case offsetof(CPU_CONTEXT, Eax):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Eax’; did you mean ‘Rax’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:679:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Eax);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:683:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ebp’; did you mean ‘Rbp’?
case offsetof(CPU_CONTEXT, Ebp):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Ebp’; did you mean ‘Rbp’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:684:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Ebp);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:688:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Eip’; did you mean ‘Rip’?
case offsetof(CPU_CONTEXT, Eip):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Eip’; did you mean ‘Rip’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:689:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Eip);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:703:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Esp’; did you mean ‘Rsp’?
case offsetof(CPU_CONTEXT, Esp):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘Esp’; did you mean ‘Rsp’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:704:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, Esp);
^~~~~~~~~~~~
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:713:14: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘ExtendedRegisters’; did you mean ‘VectorRegister’?
case offsetof(CPU_CONTEXT, ExtendedRegisters):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_CONTEXT {aka struct _CPU_CONTEXT}’ has no member named ‘ExtendedRegisters’; did you mean ‘VectorRegister’?
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:714:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_CONTEXT, ExtendedRegisters);
^~~~~~~~~~~~
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c: In function ‘windbg_read_ks_regs’:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:766:19: error: assignment to expression with array type
ckr->Gdtr.Pad = lduw_p(&env->gdt.selector);
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:767:19: error: assignment to expression with array type
ckr->Idtr.Pad = lduw_p(&env->idt.selector);
^
In file included from /usr/include/sched.h:28:0,
from /usr/include/pthread.h:23,
from /usr/include/glib-2.0/glib/deprecated/gthread.h:128,
from /usr/include/glib-2.0/glib.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/glib-compat.h:19,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/qemu/osdep.h:107,
from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:12:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c: In function ‘windbg_write_ks_regs’:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:883:14: error: ‘CPU_KSPECIAL_REGISTERS {aka struct _CPU_KSPECIAL_REGISTERS}’ has no member named ‘Reserved’
case offsetof(CPU_KSPECIAL_REGISTERS, Reserved):
^
In file included from /var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:13:0:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/include/exec/windbgstub-utils.h:45:57: error: ‘CPU_KSPECIAL_REGISTERS {aka struct _CPU_KSPECIAL_REGISTERS}’ has no member named ‘Reserved’
#define sizeof_field(type, field) sizeof(((type *) NULL)->field)
^
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:884:24: note: in expansion of macro ‘sizeof_field’
mem_size = sizeof_field(CPU_KSPECIAL_REGISTERS, Reserved);
^~~~~~~~~~~~
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c: In function ‘kd_api_read_control_space’:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:940:23: error: ‘CPU_KPROCESSOR_STATE’ undeclared (first use in this function)
if (addr < sizeof(CPU_KPROCESSOR_STATE)) {
^~~~~~~~~~~~~~~~~~~~
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c: In function ‘kd_api_write_control_space’:
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/target/i386/windbgstub.c:978:23: error: ‘CPU_KPROCESSOR_STATE’ undeclared (first use in this function)
if (addr < sizeof(CPU_KPROCESSOR_STATE)) {
^~~~~~~~~~~~~~~~~~~~
GEN armeb-linux-user/config-target.h
/var/tmp/patchew-tester-tmp-ocfdhvn7/src/rules.mak:66: recipe for target 'target/i386/windbgstub.o' failed
make[1]: *** [target/i386/windbgstub.o] Error 1
Makefile:374: recipe for target 'subdir-x86_64-softmmu' failed
make: *** [subdir-x86_64-softmmu] Error 2
make: *** Waiting for unfinished jobs....
CC aarch64-linux-user/target/arm/neon_helper.o
CC alpha-linux-user/linux-user/syscall.o
CC armeb-linux-user/exec.o
CC armeb-linux-user/tcg/tcg.o
CC aarch64-linux-user/target/arm/iwmmxt_helper.o
CC alpha-linux-user/linux-user/strace.o
CC aarch64-linux-user/target/arm/gdbstub.o
CC aarch64-linux-user/target/arm/cpu64.o
CC aarch64-linux-user/target/arm/translate-a64.o
CC alpha-linux-user/linux-user/mmap.o
CC armeb-linux-user/tcg/tcg-op.o
CC aarch64-linux-user/target/arm/helper-a64.o
CC armeb-linux-user/tcg/optimize.o
CC alpha-linux-user/linux-user/signal.o
CC alpha-linux-user/linux-user/elfload.o
CC aarch64-linux-user/target/arm/gdbstub64.o
CC alpha-linux-user/linux-user/linuxload.o
CC armeb-linux-user/tcg/tcg-common.o
CC aarch64-linux-user/target/arm/crypto_helper.o
CC alpha-linux-user/linux-user/uaccess.o
CC armeb-linux-user/fpu/softfloat.o
CC alpha-linux-user/linux-user/uname.o
GEN trace/generated-helpers.c
CCAS alpha-linux-user/linux-user/safe-syscall.o
CC aarch64-linux-user/trace/control-target.o
CC alpha-linux-user/target/alpha/translate.o
CC alpha-linux-user/target/alpha/helper.o
CC alpha-linux-user/target/alpha/cpu.o
CC aarch64-linux-user/gdbstub-xml.o
CC alpha-linux-user/target/alpha/int_helper.o
CC aarch64-linux-user/trace/generated-helpers.o
CC alpha-linux-user/target/alpha/fpu_helper.o
CC alpha-linux-user/target/alpha/vax_helper.o
LINK aarch64-linux-user/qemu-aarch64
CC alpha-linux-user/target/alpha/sys_helper.o
CC alpha-linux-user/target/alpha/mem_helper.o
CC armeb-linux-user/disas.o
CC alpha-linux-user/target/alpha/gdbstub.o
GEN armeb-linux-user/gdbstub-xml.c
GEN trace/generated-helpers.c
CC alpha-linux-user/trace/control-target.o
CC alpha-linux-user/trace/generated-helpers.o
CC armeb-linux-user/gdbstub.o
CC armeb-linux-user/thunk.o
CC armeb-linux-user/accel/stubs/hax-stub.o
LINK alpha-linux-user/qemu-alpha
CC armeb-linux-user/accel/stubs/kvm-stub.o
CC armeb-linux-user/accel/tcg/tcg-runtime.o
CC armeb-linux-user/accel/tcg/cpu-exec.o
CC armeb-linux-user/accel/tcg/cpu-exec-common.o
CC armeb-linux-user/accel/tcg/translate-all.o
CC armeb-linux-user/accel/tcg/translator.o
CC armeb-linux-user/accel/tcg/user-exec.o
CC armeb-linux-user/accel/tcg/user-exec-stub.o
CC armeb-linux-user/linux-user/main.o
CC armeb-linux-user/linux-user/syscall.o
CC armeb-linux-user/linux-user/strace.o
CC armeb-linux-user/linux-user/mmap.o
CC armeb-linux-user/linux-user/signal.o
CC armeb-linux-user/linux-user/elfload.o
CC armeb-linux-user/linux-user/linuxload.o
CC armeb-linux-user/linux-user/uname.o
CC armeb-linux-user/linux-user/uaccess.o
CCAS armeb-linux-user/linux-user/safe-syscall.o
CC armeb-linux-user/linux-user/flatload.o
CC armeb-linux-user/linux-user/arm/nwfpe/fpa11.o
CC armeb-linux-user/linux-user/arm/nwfpe/fpa11_cpdo.o
CC armeb-linux-user/linux-user/arm/nwfpe/fpa11_cpdt.o
CC armeb-linux-user/linux-user/arm/nwfpe/fpa11_cprt.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 armeb-linux-user/linux-user/arm/nwfpe/extended_cpdo.o
CC armeb-linux-user/target/arm/arm-semi.o
CC armeb-linux-user/target/arm/kvm-stub.o
CC armeb-linux-user/target/arm/translate.o
CC armeb-linux-user/target/arm/op_helper.o
CC armeb-linux-user/target/arm/helper.o
CC armeb-linux-user/target/arm/cpu.o
CC armeb-linux-user/target/arm/neon_helper.o
CC armeb-linux-user/target/arm/iwmmxt_helper.o
CC armeb-linux-user/target/arm/gdbstub.o
CC armeb-linux-user/target/arm/crypto_helper.o
GEN trace/generated-helpers.c
CC armeb-linux-user/trace/control-target.o
CC armeb-linux-user/gdbstub-xml.o
CC armeb-linux-user/trace/generated-helpers.o
LINK armeb-linux-user/qemu-armeb
=== 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] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (43 preceding siblings ...)
2017-10-17 14:11 ` [Qemu-devel] [PATCH v2 00/43] Windbg supporting no-reply
@ 2017-10-17 15:04 ` no-reply
2017-10-23 8:31 ` Ladi Prosek
45 siblings, 0 replies; 56+ messages in thread
From: no-reply @ 2017-10-17 15:04 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:
Type: series
Message-id: 150824572545.6816.5099701189660002212.stgit@Misha-PC.lan02.inno
Subject: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
=== 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
t [tag update] patchew/20171017141311.22194-1-james.hogan@imgtec.com -> patchew/20171017141311.22194-1-james.hogan@imgtec.com
* [new tag] patchew/20171017144051.8452-1-lprosek@redhat.com -> patchew/20171017144051.8452-1-lprosek@redhat.com
Switched to a new branch 'test'
781761ed55 windbg: implemented kd_api_query_memory
51254e498e windbg: implemented kd_api_fill_memory
66690a99b1 windbg: implemented kd_api_search_memory
2f6279f724 windbg: implemented kd_api_read_msr and kd_api_write_msr
ecbb8a4d90 windbg: implemented kd_api_get_version
99404b50d6 windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory
ece9ee6e85 windbg: implemented kd_api_read_io_space and kd_api_write_io_space
8dee08947b windbg: implemented kd_api_continue
319a1cfd9a windbg: debug exception subscribing
0aae01739e windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint
87f6155ccc windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove
6039691b57 windbg: implemented windbg_set_dr7
d6d36a9992 windbg: implemented windbg_set_dr
fa3991dc0d windbg: implemented windbg_set_sr
583ea26628 windbg: implemented windbg_write_ks_regs
fdf270f966 windbg: implemented windbg_read_ks_regs
05da1b9c5c windbg: implemented windbg_write_context
69df19d8e9 windbg: implemented windbg_read_context
d75b301976 windbg: implemented kd_api_read_control_space and kd_api_write_control_space
128fdb1ee0 windbg: implemented kd_api_get_context and kd_api_set_context
982f109a8f windbg: kernel's structures
cc264031d7 windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory
825443663c windbg: implemented windbg_process_manipulate_packet
3891584ec0 windbg: implemented windbg_process_data_packet
d9b0dc02f9 windbg: implemented windbg_process_control_packet
7c4948139d windbg: windbg_vm_stop
c2b182a5cc windbg: generate LoadSymbolsStateChange
e1e0fa6049 windbg: generate ExceptionStateChange
1b46d89bec windbg: sized data buffer
1e2b1312bd windbg: init DBGKD_ANY_WAIT_STATE_CHANGE
c539c2eb16 windbg: handler of parsing context
aa620f7c0f windbg: send data and control packets
ec009bb58b windbg: parsing data stream
d92166ff9c windbg: structures for parsing data stream
c5af1bfa0a windbg: handler of fs/gs register
b2913d721d windbg: hook to wrmsr operation
ea4c4d5b07 windbg: added chardev
e3dcaa4bda windbg: added WindbgState
3b4e42af9d windbg: added helper features
5193519197 windbg: added '-windbg' option
ff48de606d windbg: modified windbgkd.h
034025ddba windbg: added windbg's KD header file
0645652f63 windbg: added empty windbgstub files
=== OUTPUT BEGIN ===
Checking PATCH 1/43: windbg: added empty windbgstub files...
ERROR: do not set execute permissions for source files
#28: FILE: include/exec/windbgstub-utils.h
ERROR: do not set execute permissions for source files
#52: FILE: include/exec/windbgstub.h
ERROR: do not set execute permissions for source files
#87: FILE: stubs/windbgstub.c
ERROR: do not set execute permissions for source files
#121: FILE: target/i386/windbgstub.c
ERROR: do not set execute permissions for source files
#140: FILE: windbgstub-utils.c
ERROR: do not set execute permissions for source files
#158: FILE: windbgstub.c
total: 6 errors, 0 warnings, 120 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/43: 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/43: windbg: modified windbgkd.h...
Checking PATCH 4/43: windbg: added '-windbg' option...
Checking PATCH 5/43: windbg: added helper features...
Checking PATCH 6/43: windbg: added WindbgState...
Checking PATCH 7/43: windbg: added chardev...
Checking PATCH 8/43: windbg: hook to wrmsr operation...
Checking PATCH 9/43: windbg: handler of fs/gs register...
Checking PATCH 10/43: windbg: structures for parsing data stream...
Checking PATCH 11/43: windbg: parsing data stream...
Checking PATCH 12/43: windbg: send data and control packets...
Checking PATCH 13/43: windbg: handler of parsing context...
Checking PATCH 14/43: windbg: init DBGKD_ANY_WAIT_STATE_CHANGE...
Checking PATCH 15/43: windbg: sized data buffer...
Checking PATCH 16/43: windbg: generate ExceptionStateChange...
Checking PATCH 17/43: windbg: generate LoadSymbolsStateChange...
Checking PATCH 18/43: windbg: windbg_vm_stop...
Checking PATCH 19/43: windbg: implemented windbg_process_control_packet...
Checking PATCH 20/43: windbg: implemented windbg_process_data_packet...
Checking PATCH 21/43: windbg: implemented windbg_process_manipulate_packet...
Checking PATCH 22/43: windbg: implemented kd_api_read_virtual_memory and kd_api_write_virtual_memory...
Checking PATCH 23/43: windbg: kernel's structures...
Checking PATCH 24/43: windbg: implemented kd_api_get_context and kd_api_set_context...
Checking PATCH 25/43: windbg: implemented kd_api_read_control_space and kd_api_write_control_space...
Checking PATCH 26/43: windbg: implemented windbg_read_context...
Checking PATCH 27/43: windbg: implemented windbg_write_context...
Checking PATCH 28/43: windbg: implemented windbg_read_ks_regs...
Checking PATCH 29/43: windbg: implemented windbg_write_ks_regs...
Checking PATCH 30/43: windbg: implemented windbg_set_sr...
Checking PATCH 31/43: windbg: implemented windbg_set_dr...
Checking PATCH 32/43: windbg: implemented windbg_set_dr7...
Checking PATCH 33/43: windbg: implemented windbg_hw_breakpoint_insert and windbg_hw_breakpoint_remove...
Checking PATCH 34/43: windbg: implemented kd_api_write_breakpoint and kd_api_restore_breakpoint...
Checking PATCH 35/43: windbg: debug exception subscribing...
Checking PATCH 36/43: windbg: implemented kd_api_continue...
Checking PATCH 37/43: windbg: implemented kd_api_read_io_space and kd_api_write_io_space...
Checking PATCH 38/43: windbg: implemented kd_api_read_physical_memory and kd_api_write_physical_memory...
Checking PATCH 39/43: windbg: implemented kd_api_get_version...
Checking PATCH 40/43: windbg: implemented kd_api_read_msr and kd_api_write_msr...
Checking PATCH 41/43: windbg: implemented kd_api_search_memory...
Checking PATCH 42/43: windbg: implemented kd_api_fill_memory...
Checking PATCH 43/43: windbg: implemented kd_api_query_memory...
=== 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] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-10-17 13:08 [Qemu-devel] [PATCH v2 00/43] Windbg supporting Mihail Abakumov
` (44 preceding siblings ...)
2017-10-17 15:04 ` no-reply
@ 2017-10-23 8:31 ` Ladi Prosek
2017-11-06 15:15 ` Ladi Prosek
45 siblings, 1 reply; 56+ messages in thread
From: Ladi Prosek @ 2017-10-23 8:31 UTC (permalink / raw)
To: Mihail Abakumov
Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
On Tue, Oct 17, 2017 at 3:08 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 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)
Thank you, I am planning to take a closer look and test the changes in
a week or two.
Still wondering if it is limited to Windows hosts or if it can be used
on Linux as well, preferably with KVM.
Thanks!
Ladi
> ---
>
> Mihail Abakumov (43):
> 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
>
>
> Makefile.target | 5
> cpus.c | 18
> gdbstub.c | 4
> include/exec/windbgkd.h | 948 ++++++++++++++++++++++++++
> include/exec/windbgstub-utils.h | 122 +++
> 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 | 1443 +++++++++++++++++++++++++++++++++++++++
> vl.c | 8
> windbgstub-utils.c | 358 ++++++++++
> windbgstub.c | 490 +++++++++++++
> 16 files changed, 3455 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] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-10-23 8:31 ` Ladi Prosek
@ 2017-11-06 15:15 ` Ladi Prosek
2017-11-06 18:41 ` Andrew Baumann
2017-11-08 11:54 ` Mihail Abakumov
0 siblings, 2 replies; 56+ messages in thread
From: Ladi Prosek @ 2017-11-06 15:15 UTC (permalink / raw)
To: Mihail Abakumov
Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
On Mon, Oct 23, 2017 at 10:31 AM, Ladi Prosek <lprosek@redhat.com> wrote:
> On Tue, Oct 17, 2017 at 3:08 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 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)
>
> Thank you, I am planning to take a closer look and test the changes in
> a week or two.
>
> Still wondering if it is limited to Windows hosts or if it can be used
> on Linux as well, preferably with KVM.
I haven't been able to make this work.
I've built a 32-bit QEMU for Windows with these patches and used the
command line parameters given above:
qemu-system-i386.exe run with -windbg pipe:win7_dbg
windbg -b -k com:pipe,baud=115200,port=\\.\pipe\win7_dbg,resets=0
The guest is a fresh install of Win7 32-bit.
FS base passes all the checks in windbg_on_load() as the guest kernel
loads and it returns true. QEMU then sends some data over the pipe.
Windbg doesn't print anything, it's still showing:
Opened \\.\pipe\win7_dbg
Waiting to reconnect...
Is this expected? In regular remote kernel debugging, windbg produces
a bunch of output about the target state when it attaches.
The only thing I can reasonably do at this point is Ctrl+Break. This
results in some data exchange between QEMU and windbg but nothing
really changes -- windbg still says "Waiting to reconnect...". Hitting
Ctrl+Break for the second time kills windbg. I tried running windbg
under windbg and was able to capture this output:
Debug target initialization failed, 0x8000FFFF
Once I managed to make windbg actually attach (i.e. it generated the
target state output) but the QEMU process died shortly after that. I
don't know why because I haven't been able to reproduce it.
So, what am I doing wrong? Can you post your detailed steps please?
I'm pasting a dump of the pipe traffic as captured with IO Ninja. "<"
is windbg to QEMU, ">" is QEMU to windbg. QEMU initialized the stub at
14:57:48, the first Ctrl+Break was issued at 15:00:32 and the second
one at 15:01:10.
14:56:44 File #1: Client file opened: \win7_dbg
14:56:49 < 0000 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:56:53 < 0010 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:56:56 < 0020 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:00 < 0030 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:03 < 0040 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:07 < 0050 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:11 < 0060 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:14 < 0070 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:18 < 0080 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:22 < 0090 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:26 < 00a0 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:29 < 00b0 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:33 < 00c0 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:37 < 00d0 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:40 < 00e0 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:44 < 00f0 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:48 < 0100 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:48 < 0110 69 69 69 69 06 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 0000 30 30 30 30 07 00 f0 00 00 00 80 80 a9 0f 00 00
14:57:48 > 0010 31 30 00 00 00 00 00 00 01 00 00 00 00 00 00 00
14:57:48 > 0020 80 03 75 82 00 00 00 00 6c 2e 88 82 00 00 00 00
14:57:48 > 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 0040 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 0050 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 0060 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 0070 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 0080 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 0090 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 00a0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 00b0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 00c0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
14:57:48 > 00d0 f0 0f ff ff 00 04 00 00 10 00 03 00 c3 90 90 90
14:57:48 > 00e0 90 90 8b ff 53 56 8b f0 57 8d 46 08 08 00 23 00
14:57:48 > 00f0 23 00 30 00 02 02 20 00 00 00 00 00 00 00 00 00
14:57:48 > 0100 aa 69 69 69 69 06 00 00 00 9b 35 18 00 00 00 00
> 0110 00
15:00:32 < 0000 62
15:00:34 > 0000 30 30 30 30 07 00 f4 00 01 00 80 80 6d 10 00 00
> 0010 30 30 00 00 00 00 00 00 01 00 00 00 00 00 00 00
> 0020 98 c7 69 85 00 00 00 00 56 68 11 8c 00 00 00 00
> 0030 03 00 00 80 00 00 00 00 00 00 00 00 00 00 00 00
> 0040 56 68 11 8c 00 00 00 00 00 00 00 00 00 00 00 00
> 0050 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0060 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0070 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0080 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0090 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00a0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00b0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00c0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00d0 f0 0f ff ff 00 04 00 00 10 00 03 00 22 45 0c 3a
> 00e0 45 10 74 38 ff d3 2b 7d f8 1b 75 fc 08 00 23 00
> 00f0 23 00 30 00 46 02 00 00 00 00 00 00 00 00 00 00
15:00:34 > 0100 00 00 00 00 aa
15:01:10 < 0000 69 69 69 69 04 00 00 00 01 00 80 80 00 00 00 00
< 0010 62
15:01:10 > 0000 30 30 30 30 07 00 f4 00 00 00 80 80 6d 10 00 00
> 0010 30 30 00 00 00 00 00 00 01 00 00 00 00 00 00 00
> 0020 98 c7 69 85 00 00 00 00 56 68 11 8c 00 00 00 00
> 0030 03 00 00 80 00 00 00 00 00 00 00 00 00 00 00 00
> 0040 56 68 11 8c 00 00 00 00 00 00 00 00 00 00 00 00
> 0050 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0060 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0070 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0080 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 0090 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00a0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00b0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00c0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 00d0 f0 0f ff ff 00 04 00 00 10 00 03 00 22 45 0c 3a
> 00e0 45 10 74 38 ff d3 2b 7d f8 1b 75 fc 08 00 23 00
> 00f0 23 00 30 00 46 02 00 00 00 00 00 00 00 00 00 00
15:01:10 > 0100 00 00 00 00 aa
15:01:10 < 0000 69 69 69 69 04 00 00 00 00 00 80 80 00 00 00 00
15:01:10 < 0010 30 30 30 30 02 00 38 00 00 00 80 80 62 10 00 00
< 0020 46 31 00 00 b1 00 c7 6a 03 01 00 00 a8 fa d9 08
< 0030 00 00 00 00 01 fb d9 08 7f 43 c9 6a 78 26 ba 6a
< 0040 07 00 00 00 01 00 00 00 18 14 f0 04 68 cd b6 6a
15:01:10 < 0050 98 44 c9 6a 0c 1e 38 00 aa
15:01:10 > 0000 69 69 69 69 04 00 00 00 00 00 80 80 00 00 00 00
15:01:10 > 0010 30 30 30 30 02 00 38 00 01 00 80 80 39 18 00 00
> 0020 46 31 00 00 b1 00 c7 6a 00 00 00 00 a8 fa d9 08
> 0030 0f 00 b1 1d 06 00 03 00 4c 01 0c 03 2f 00 00 00
> 0040 00 b0 61 82 ff ff ff ff 50 58 76 82 ff ff ff ff
15:01:10 > 0050 ec bf 98 82 ff ff ff ff aa
15:01:10 < 0000 69 69 69 69 04 00 00 00 01 00 80 80 00 00 00 00
15:01:10 < 0010 30 30 30 30 02 00 38 00 01 00 80 80 c2 10 00 00
< 0020 30 31 00 00 20 00 00 00 d8 01 93 04 00 00 93 04
< 0030 ec bf 98 82 ff ff ff ff 04 00 00 00 7a 3d d0 1c
< 0040 08 fa d9 08 40 dd 10 77 38 00 00 00 00 00 00 00
15:01:10 < 0050 90 5c 7f 70 38 00 00 00 aa
15:01:10 > 0000 69 69 69 69 04 00 00 00 01 00 80 80 00 00 00 00
15:01:10 > 0010 30 30 30 30 02 00 38 00 00 00 80 80 70 0e 00 00
> 0020 30 31 00 00 20 00 00 00 01 00 00 c0 00 00 93 04
> 0030 ec bf 98 82 ff ff ff ff 04 00 00 00 00 00 00 00
> 0040 08 fa d9 08 40 dd 10 77 38 00 00 00 00 00 00 00
15:01:10 > 0050 90 5c 7f 70 38 00 00 00 aa
15:01:10 < 0000 69 69 69 69 04 00 00 00 00 00 80 80 00 00 00 00
15:01:11 File closed
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-06 15:15 ` Ladi Prosek
@ 2017-11-06 18:41 ` Andrew Baumann
2017-11-07 8:10 ` Ladi Prosek
2017-11-08 11:54 ` Mihail Abakumov
1 sibling, 1 reply; 56+ messages in thread
From: Andrew Baumann @ 2017-11-06 18:41 UTC (permalink / raw)
To: Ladi Prosek, Mihail Abakumov
Cc: sw, qemu-devel, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
Hi,
I just noticed this thread, and the problem sounded very familiar...
> From: Ladi Prosek
> Sent: Monday, 6 November 2017 07:16
[...]
> FS base passes all the checks in windbg_on_load() as the guest kernel
> loads and it returns true. QEMU then sends some data over the pipe.
> Windbg doesn't print anything, it's still showing:
>
> Opened \\.\pipe\win7_dbg
> Waiting to reconnect...
>
> Is this expected? In regular remote kernel debugging, windbg produces
> a bunch of output about the target state when it attaches.
Just a guess, but I suspect the problem you're seeing may be due to the combination of windbg's tight timing requirements for the serial debug protocol and qemu's polling-based implementation of named pipe IO. I ran into this a year or two ago when bringing up raspberry pi... I could never reliably connect windbg to the emulated serial port using a named pipe. I believe the problem is that the named pipe driver relies on receiving input through win_chr_pipe_poll(), which is called too infrequently to satisfy windbg's needs (it has a rather short timeout before it gives up and retransmits). The correct fix is to use blocking IO for the named pipes inside qemu, but I know from experience that win32 is awful in this respect -- qemu wants a single unified blocking call to wait for IO on any combination of named pipes, sockets, events, etc. and Windows appears to lack this, at least at the level of poll/select.
My workaround at the time was to kludge up a proxy between sockets and named pipes, so the connection was:
qemu <-socket-> proxy <-named pipe-> windbg
(The proxy was a fairly flaky python script, but it was good enough to tide me over until I could get kdnet working. I can probably dig it out if you're interested.)
Cheers,
Andrew
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-06 18:41 ` Andrew Baumann
@ 2017-11-07 8:10 ` Ladi Prosek
2017-11-07 17:23 ` Andrew Baumann
0 siblings, 1 reply; 56+ messages in thread
From: Ladi Prosek @ 2017-11-07 8:10 UTC (permalink / raw)
To: Andrew Baumann
Cc: Mihail Abakumov, sw, qemu-devel, Pavel Dovgalyuk, Roman Kagan,
Paolo Bonzini, Denis V. Lunev
On Mon, Nov 6, 2017 at 7:41 PM, Andrew Baumann
<Andrew.Baumann@microsoft.com> wrote:
> Hi,
>
> I just noticed this thread, and the problem sounded very familiar...
>
>> From: Ladi Prosek
>> Sent: Monday, 6 November 2017 07:16
> [...]
>> FS base passes all the checks in windbg_on_load() as the guest kernel
>> loads and it returns true. QEMU then sends some data over the pipe.
>> Windbg doesn't print anything, it's still showing:
>>
>> Opened \\.\pipe\win7_dbg
>> Waiting to reconnect...
>>
>> Is this expected? In regular remote kernel debugging, windbg produces
>> a bunch of output about the target state when it attaches.
>
> Just a guess, but I suspect the problem you're seeing may be due to the combination of windbg's tight timing requirements for the serial debug protocol and qemu's polling-based implementation of named pipe IO. I ran into this a year or two ago when bringing up raspberry pi... I could never reliably connect windbg to the emulated serial port using a named pipe. I believe the problem is that the named pipe driver relies on receiving input through win_chr_pipe_poll(), which is called too infrequently to satisfy windbg's needs (it has a rather short timeout before it gives up and retransmits). The correct fix is to use blocking IO for the named pipes inside qemu, but I know from experience that win32 is awful in this respect -- qemu wants a single unified blocking call to wait for IO on any combination of named pipes, sockets, events, etc. and Windows appears to lack this, at least at the level of poll/select.
Thanks, I don't usually set up windbg remote debugging over named
pipes so this indeed sounded plausible.
My Windows runs in a QEMU/KVM VM so to eliminate the pipe I have set
up a virtual COM port like so:
-serial tcp:127.0.0.1:8889,server,nowait
and the nested QEMU ran with:
-windbg tcp:10.0.2.2:8889
where 10.0.2.2 is the address assigned to the host with user
networking. Windbg then used the default COM1 to connect to the
target. I routinely use COMx for remote debugging between VMs with a
TCP connection on the host side acting as a null-modem cable and never
had any timing related issues.
However, the symptoms were exactly the same with this set up.
I've also run the original command lines using a pipe on a physical
Windows machine, just in case being in a VM somehow screws it up.
Again, same issue.
At this point I think it would make sense for Mihai to take a look at
the trace in my previous email and maybe compare it with what works
for him.
For completeness, in the unlikely case that it makes a difference, I'm
on Win10 (tried 1511 and 1703) and use windbg that comes with one of
the latest WDK.
Thanks!
Ladi
> My workaround at the time was to kludge up a proxy between sockets and named pipes, so the connection was:
> qemu <-socket-> proxy <-named pipe-> windbg
>
> (The proxy was a fairly flaky python script, but it was good enough to tide me over until I could get kdnet working. I can probably dig it out if you're interested.)
>
> Cheers,
> Andrew
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-07 8:10 ` Ladi Prosek
@ 2017-11-07 17:23 ` Andrew Baumann
0 siblings, 0 replies; 56+ messages in thread
From: Andrew Baumann @ 2017-11-07 17:23 UTC (permalink / raw)
To: Ladi Prosek
Cc: Mihail Abakumov, sw, qemu-devel, Pavel Dovgalyuk, Roman Kagan,
Paolo Bonzini, Denis V. Lunev
> From: Ladi Prosek [mailto:lprosek@redhat.com]
> Sent: Tuesday, 7 November 2017 00:11
>
> On Mon, Nov 6, 2017 at 7:41 PM, Andrew Baumann
> <Andrew.Baumann@microsoft.com> wrote:
> > Hi,
> >
> > I just noticed this thread, and the problem sounded very familiar...
> >
> >> From: Ladi Prosek
> >> Sent: Monday, 6 November 2017 07:16
> > [...]
> >> FS base passes all the checks in windbg_on_load() as the guest kernel
> >> loads and it returns true. QEMU then sends some data over the pipe.
> >> Windbg doesn't print anything, it's still showing:
> >>
> >> Opened \\.\pipe\win7_dbg
> >> Waiting to reconnect...
> >>
> >> Is this expected? In regular remote kernel debugging, windbg produces
> >> a bunch of output about the target state when it attaches.
> >
> > Just a guess, but I suspect the problem you're seeing may be due to the
> combination of windbg's tight timing requirements for the serial debug
> protocol and qemu's polling-based implementation of named pipe IO. I ran
> into this a year or two ago when bringing up raspberry pi... I could never
> reliably connect windbg to the emulated serial port using a named pipe. I
> believe the problem is that the named pipe driver relies on receiving input
> through win_chr_pipe_poll(), which is called too infrequently to satisfy
> windbg's needs (it has a rather short timeout before it gives up and
> retransmits). The correct fix is to use blocking IO for the named pipes inside
> qemu, but I know from experience that win32 is awful in this respect -- qemu
> wants a single unified blocking call to wait for IO on any combination of
> named pipes, sockets, events, etc. and Windows appears to lack this, at least
> at the level of poll/select.
>
> Thanks, I don't usually set up windbg remote debugging over named
> pipes so this indeed sounded plausible.
>
> My Windows runs in a QEMU/KVM VM so to eliminate the pipe I have set
> up a virtual COM port like so:
>
> -serial tcp:127.0.0.1:8889,server,nowait
>
> and the nested QEMU ran with:
>
> -windbg tcp:10.0.2.2:8889
>
> where 10.0.2.2 is the address assigned to the host with user
> networking. Windbg then used the default COM1 to connect to the
> target. I routinely use COMx for remote debugging between VMs with a
> TCP connection on the host side acting as a null-modem cable and never
> had any timing related issues.
>
> However, the symptoms were exactly the same with this set up.
Ok, then I agree this is probably not the same issue.
Andrew
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-06 15:15 ` Ladi Prosek
2017-11-06 18:41 ` Andrew Baumann
@ 2017-11-08 11:54 ` Mihail Abakumov
2017-11-08 13:43 ` Ladi Prosek
1 sibling, 1 reply; 56+ messages in thread
From: Mihail Abakumov @ 2017-11-08 11:54 UTC (permalink / raw)
To: Ladi Prosek
Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
Ladi Prosek писал 2017-11-06 18:15:
> On Mon, Oct 23, 2017 at 10:31 AM, Ladi Prosek <lprosek@redhat.com>
> wrote:
>> On Tue, Oct 17, 2017 at 3:08 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 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)
>>
>> Thank you, I am planning to take a closer look and test the changes in
>> a week or two.
>>
>> Still wondering if it is limited to Windows hosts or if it can be used
>> on Linux as well, preferably with KVM.
>
> I haven't been able to make this work.
>
> I've built a 32-bit QEMU for Windows with these patches and used the
> command line parameters given above:
>
> qemu-system-i386.exe run with -windbg pipe:win7_dbg
> windbg -b -k com:pipe,baud=115200,port=\\.\pipe\win7_dbg,resets=0
>
> The guest is a fresh install of Win7 32-bit.
>
> FS base passes all the checks in windbg_on_load() as the guest kernel
> loads and it returns true. QEMU then sends some data over the pipe.
> Windbg doesn't print anything, it's still showing:
>
> Opened \\.\pipe\win7_dbg
> Waiting to reconnect...
>
> Is this expected? In regular remote kernel debugging, windbg produces
> a bunch of output about the target state when it attaches.
>
> The only thing I can reasonably do at this point is Ctrl+Break. This
> results in some data exchange between QEMU and windbg but nothing
> really changes -- windbg still says "Waiting to reconnect...". Hitting
> Ctrl+Break for the second time kills windbg. I tried running windbg
> under windbg and was able to capture this output:
>
> Debug target initialization failed, 0x8000FFFF
>
> Once I managed to make windbg actually attach (i.e. it generated the
> target state output) but the QEMU process died shortly after that. I
> don't know why because I haven't been able to reproduce it.
>
> So, what am I doing wrong? Can you post your detailed steps please?
>
> I'm pasting a dump of the pipe traffic as captured with IO Ninja. "<"
> is windbg to QEMU, ">" is QEMU to windbg. QEMU initialized the stub at
> 14:57:48, the first Ctrl+Break was issued at 15:00:32 and the second
> one at 15:01:10.
>
This is very strange.
After reading the desired addresses (windbg_on_load()), the interaction
between the stub and windbg begins. A lot of packets are being sent.
This happens about 10 seconds. All this time "Waiting to reconnect ..."
Then the windbg connects.
In your case windbg does not send packets, more specifically, does not
continue to do it. What is your version of windbg. Also, windbg stub has
been supported only for windbg x64, yet.
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-08 11:54 ` Mihail Abakumov
@ 2017-11-08 13:43 ` Ladi Prosek
2017-11-08 14:28 ` Mihail Abakumov
0 siblings, 1 reply; 56+ messages in thread
From: Ladi Prosek @ 2017-11-08 13:43 UTC (permalink / raw)
To: Mihail Abakumov
Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
On Wed, Nov 8, 2017 at 12:54 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Ladi Prosek писал 2017-11-06 18:15:
>
>> On Mon, Oct 23, 2017 at 10:31 AM, Ladi Prosek <lprosek@redhat.com> wrote:
>>>
>>> On Tue, Oct 17, 2017 at 3:08 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 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)
>>>
>>>
>>> Thank you, I am planning to take a closer look and test the changes in
>>> a week or two.
>>>
>>> Still wondering if it is limited to Windows hosts or if it can be used
>>> on Linux as well, preferably with KVM.
>>
>>
>> I haven't been able to make this work.
>>
>> I've built a 32-bit QEMU for Windows with these patches and used the
>> command line parameters given above:
>>
>> qemu-system-i386.exe run with -windbg pipe:win7_dbg
>> windbg -b -k com:pipe,baud=115200,port=\\.\pipe\win7_dbg,resets=0
>>
>> The guest is a fresh install of Win7 32-bit.
>>
>> FS base passes all the checks in windbg_on_load() as the guest kernel
>> loads and it returns true. QEMU then sends some data over the pipe.
>> Windbg doesn't print anything, it's still showing:
>>
>> Opened \\.\pipe\win7_dbg
>> Waiting to reconnect...
>>
>> Is this expected? In regular remote kernel debugging, windbg produces
>> a bunch of output about the target state when it attaches.
>>
>> The only thing I can reasonably do at this point is Ctrl+Break. This
>> results in some data exchange between QEMU and windbg but nothing
>> really changes -- windbg still says "Waiting to reconnect...". Hitting
>> Ctrl+Break for the second time kills windbg. I tried running windbg
>> under windbg and was able to capture this output:
>>
>> Debug target initialization failed, 0x8000FFFF
>>
>> Once I managed to make windbg actually attach (i.e. it generated the
>> target state output) but the QEMU process died shortly after that. I
>> don't know why because I haven't been able to reproduce it.
>>
>> So, what am I doing wrong? Can you post your detailed steps please?
>>
>> I'm pasting a dump of the pipe traffic as captured with IO Ninja. "<"
>> is windbg to QEMU, ">" is QEMU to windbg. QEMU initialized the stub at
>> 14:57:48, the first Ctrl+Break was issued at 15:00:32 and the second
>> one at 15:01:10.
>>
>
> This is very strange.
> After reading the desired addresses (windbg_on_load()), the interaction
> between the stub and windbg begins. A lot of packets are being sent.
> This happens about 10 seconds. All this time "Waiting to reconnect ..."
> Then the windbg connects.
> In your case windbg does not send packets, more specifically, does not
> continue to do it. What is your version of windbg. Also, windbg stub has
> been supported only for windbg x64, yet.
Ah, so that's a pretty important piece of information and not very
intuitive given the "Only i386 is supported now." sentence in the
cover email.
Microsoft (R) Windows Debugger Version 10.0.15063.468 X86
Microsoft (R) Windows Debugger Version 10.0.15063.468 AMD64
Microsoft (R) Windows Debugger Version 10.0.16299.15 X86
Microsoft (R) Windows Debugger Version 10.0.16299.15 AMD64
are the versions I have tried. I don't see any difference between x86
and amd64, all versions never connect and crash after the second
break.
What guest OS are you running? Can you maybe zip up your QEMU binaries
and share them with me?
Thanks,
Ladi
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-08 13:43 ` Ladi Prosek
@ 2017-11-08 14:28 ` Mihail Abakumov
2017-11-13 12:23 ` Ladi Prosek
0 siblings, 1 reply; 56+ messages in thread
From: Mihail Abakumov @ 2017-11-08 14:28 UTC (permalink / raw)
To: Ladi Prosek
Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
Ladi Prosek писал 2017-11-08 16:43:
> On Wed, Nov 8, 2017 at 12:54 PM, Mihail Abakumov
> <mikhail.abakumov@ispras.ru> wrote:
>> Ladi Prosek писал 2017-11-06 18:15:
>>
>>> On Mon, Oct 23, 2017 at 10:31 AM, Ladi Prosek <lprosek@redhat.com>
>>> wrote:
>>>>
>>>> On Tue, Oct 17, 2017 at 3:08 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 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)
>>>>
>>>>
>>>> Thank you, I am planning to take a closer look and test the changes
>>>> in
>>>> a week or two.
>>>>
>>>> Still wondering if it is limited to Windows hosts or if it can be
>>>> used
>>>> on Linux as well, preferably with KVM.
>>>
>>>
>>> I haven't been able to make this work.
>>>
>>> I've built a 32-bit QEMU for Windows with these patches and used the
>>> command line parameters given above:
>>>
>>> qemu-system-i386.exe run with -windbg pipe:win7_dbg
>>> windbg -b -k com:pipe,baud=115200,port=\\.\pipe\win7_dbg,resets=0
>>>
>>> The guest is a fresh install of Win7 32-bit.
>>>
>>> FS base passes all the checks in windbg_on_load() as the guest kernel
>>> loads and it returns true. QEMU then sends some data over the pipe.
>>> Windbg doesn't print anything, it's still showing:
>>>
>>> Opened \\.\pipe\win7_dbg
>>> Waiting to reconnect...
>>>
>>> Is this expected? In regular remote kernel debugging, windbg produces
>>> a bunch of output about the target state when it attaches.
>>>
>>> The only thing I can reasonably do at this point is Ctrl+Break. This
>>> results in some data exchange between QEMU and windbg but nothing
>>> really changes -- windbg still says "Waiting to reconnect...".
>>> Hitting
>>> Ctrl+Break for the second time kills windbg. I tried running windbg
>>> under windbg and was able to capture this output:
>>>
>>> Debug target initialization failed, 0x8000FFFF
>>>
>>> Once I managed to make windbg actually attach (i.e. it generated the
>>> target state output) but the QEMU process died shortly after that. I
>>> don't know why because I haven't been able to reproduce it.
>>>
>>> So, what am I doing wrong? Can you post your detailed steps please?
>>>
>>> I'm pasting a dump of the pipe traffic as captured with IO Ninja. "<"
>>> is windbg to QEMU, ">" is QEMU to windbg. QEMU initialized the stub
>>> at
>>> 14:57:48, the first Ctrl+Break was issued at 15:00:32 and the second
>>> one at 15:01:10.
>>>
>>
>> This is very strange.
>> After reading the desired addresses (windbg_on_load()), the
>> interaction
>> between the stub and windbg begins. A lot of packets are being sent.
>> This happens about 10 seconds. All this time "Waiting to reconnect
>> ..."
>> Then the windbg connects.
>> In your case windbg does not send packets, more specifically, does not
>> continue to do it. What is your version of windbg. Also, windbg stub
>> has
>> been supported only for windbg x64, yet.
>
> Ah, so that's a pretty important piece of information and not very
> intuitive given the "Only i386 is supported now." sentence in the
> cover email.
>
> Microsoft (R) Windows Debugger Version 10.0.15063.468 X86
> Microsoft (R) Windows Debugger Version 10.0.15063.468 AMD64
> Microsoft (R) Windows Debugger Version 10.0.16299.15 X86
> Microsoft (R) Windows Debugger Version 10.0.16299.15 AMD64
>
> are the versions I have tried. I don't see any difference between x86
> and amd64, all versions never connect and crash after the second
> break.
>
> What guest OS are you running? Can you maybe zip up your QEMU binaries
> and share them with me?
>
> Thanks,
> Ladi
Oh, it looks like a problem in the versions. I use the Windbg from
Windows 7.
Windbg version: 6.12.0002.633 AMD64. I will try to test with your
version.
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-08 14:28 ` Mihail Abakumov
@ 2017-11-13 12:23 ` Ladi Prosek
2017-11-14 11:37 ` Mihail Abakumov
0 siblings, 1 reply; 56+ messages in thread
From: Ladi Prosek @ 2017-11-13 12:23 UTC (permalink / raw)
To: Mihail Abakumov
Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
On Wed, Nov 8, 2017 at 3:28 PM, Mihail Abakumov
<mikhail.abakumov@ispras.ru> wrote:
> Ladi Prosek писал 2017-11-08 16:43:
>
>> On Wed, Nov 8, 2017 at 12:54 PM, Mihail Abakumov
>> <mikhail.abakumov@ispras.ru> wrote:
>>>
>>> Ladi Prosek писал 2017-11-06 18:15:
>>>
>>> In your case windbg does not send packets, more specifically, does not
>>> continue to do it. What is your version of windbg. Also, windbg stub has
>>> been supported only for windbg x64, yet.
>>
>>
>> Ah, so that's a pretty important piece of information and not very
>> intuitive given the "Only i386 is supported now." sentence in the
>> cover email.
>>
>> Microsoft (R) Windows Debugger Version 10.0.15063.468 X86
>> Microsoft (R) Windows Debugger Version 10.0.15063.468 AMD64
>> Microsoft (R) Windows Debugger Version 10.0.16299.15 X86
>> Microsoft (R) Windows Debugger Version 10.0.16299.15 AMD64
>>
>> are the versions I have tried. I don't see any difference between x86
>> and amd64, all versions never connect and crash after the second
>> break.
>>
>> What guest OS are you running? Can you maybe zip up your QEMU binaries
>> and share them with me?
>>
>> Thanks,
>> Ladi
>
>
> Oh, it looks like a problem in the versions. I use the Windbg from Windows
> 7.
> Windbg version: 6.12.0002.633 AMD64. I will try to test with your version.
Looks like it's the -b switch making the difference here. It was
removed in later versions of windbg.
Windbg docs (older):
-b
(Kernel mode only) This option has two effects:
1. The debugger will break into the target computer immediately upon connection.
2. After a reboot, the debugger will break into the target computer
once the kernel is initialized. See Crashing and Rebooting the Target
Computer for details and for other methods of changing this status.
Windbg docs (newer):
-b
This option is no longer supported.
-b makes windbg send a break-in right after connecting. Apparently
there is a short time window when the break-in will work. I can
actually successfully connect with a Win10 windbg (so without -b) if I
hit Ctrl+Break shortly after the initial handshake. This also explains
why I was able to connect once during my initial testing. I was just
lucky and hit Ctrl+Break soon enough after connecting.
By initial handshake I mean this sequence (I have added a simple
logging, should be clear what it means):
Received control PACKET_TYPE_KD_RESET
Sending data 7
Sending control 6
Newer debuggers without -b will stop here. Older debuggers with -b
will continue with:
Received RESULT_BREAKIN_BYTE
Sending data 7
Received RESULT_BREAKIN_BYTE
Sending data 7
Received data PACKET_TYPE_KD_STATE_MANIPULATE (12614)
Sending control 4
Sending data 2
Received data PACKET_TYPE_KD_STATE_MANIPULATE (12592)
Sending control 4
Sending data 2
Received data PACKET_TYPE_KD_STATE_MANIPULATE (12592)
Sending control 4
Sending data 2
...
Next step, when I have time, is to find the differences between
sending the break-in early and sending it later. Also interesting
would be recording the exchange between windbg and the target when
doing regular remote kernel debugging. I would still expect to see the
"Connected to Windows 7 7601 x86 compatible target ..." output always,
even when not breaking in immediately. The handshake is likely still
missing something.
Thanks,
Ladi
^ permalink raw reply [flat|nested] 56+ messages in thread
* Re: [Qemu-devel] [PATCH v2 00/43] Windbg supporting
2017-11-13 12:23 ` Ladi Prosek
@ 2017-11-14 11:37 ` Mihail Abakumov
0 siblings, 0 replies; 56+ messages in thread
From: Mihail Abakumov @ 2017-11-14 11:37 UTC (permalink / raw)
To: Ladi Prosek
Cc: qemu-devel, sw, Pavel Dovgalyuk, Roman Kagan, Paolo Bonzini,
Denis V. Lunev
Ladi Prosek писал 2017-11-13 15:23:
> On Wed, Nov 8, 2017 at 3:28 PM, Mihail Abakumov
> <mikhail.abakumov@ispras.ru> wrote:
>> Ladi Prosek писал 2017-11-08 16:43:
>>
>>> On Wed, Nov 8, 2017 at 12:54 PM, Mihail Abakumov
>>> <mikhail.abakumov@ispras.ru> wrote:
>>>>
>>>> Ladi Prosek писал 2017-11-06 18:15:
>>>>
>>>> In your case windbg does not send packets, more specifically, does
>>>> not
>>>> continue to do it. What is your version of windbg. Also, windbg stub
>>>> has
>>>> been supported only for windbg x64, yet.
>>>
>>>
>>> Ah, so that's a pretty important piece of information and not very
>>> intuitive given the "Only i386 is supported now." sentence in the
>>> cover email.
>>>
>>> Microsoft (R) Windows Debugger Version 10.0.15063.468 X86
>>> Microsoft (R) Windows Debugger Version 10.0.15063.468 AMD64
>>> Microsoft (R) Windows Debugger Version 10.0.16299.15 X86
>>> Microsoft (R) Windows Debugger Version 10.0.16299.15 AMD64
>>>
>>> are the versions I have tried. I don't see any difference between x86
>>> and amd64, all versions never connect and crash after the second
>>> break.
>>>
>>> What guest OS are you running? Can you maybe zip up your QEMU
>>> binaries
>>> and share them with me?
>>>
>>> Thanks,
>>> Ladi
>>
>>
>> Oh, it looks like a problem in the versions. I use the Windbg from
>> Windows
>> 7.
>> Windbg version: 6.12.0002.633 AMD64. I will try to test with your
>> version.
>
> Looks like it's the -b switch making the difference here. It was
> removed in later versions of windbg.
>
>
> Windbg docs (older):
>
> -b
> (Kernel mode only) This option has two effects:
> 1. The debugger will break into the target computer immediately upon
> connection.
>
> 2. After a reboot, the debugger will break into the target computer
> once the kernel is initialized. See Crashing and Rebooting the Target
> Computer for details and for other methods of changing this status.
>
>
> Windbg docs (newer):
>
> -b
> This option is no longer supported.
>
>
> -b makes windbg send a break-in right after connecting. Apparently
> there is a short time window when the break-in will work. I can
> actually successfully connect with a Win10 windbg (so without -b) if I
> hit Ctrl+Break shortly after the initial handshake. This also explains
> why I was able to connect once during my initial testing. I was just
> lucky and hit Ctrl+Break soon enough after connecting.
>
> By initial handshake I mean this sequence (I have added a simple
> logging, should be clear what it means):
>
> Received control PACKET_TYPE_KD_RESET
> Sending data 7
> Sending control 6
>
> Newer debuggers without -b will stop here. Older debuggers with -b
> will continue with:
>
> Received RESULT_BREAKIN_BYTE
> Sending data 7
> Received RESULT_BREAKIN_BYTE
> Sending data 7
> Received data PACKET_TYPE_KD_STATE_MANIPULATE (12614)
> Sending control 4
> Sending data 2
> Received data PACKET_TYPE_KD_STATE_MANIPULATE (12592)
> Sending control 4
> Sending data 2
> Received data PACKET_TYPE_KD_STATE_MANIPULATE (12592)
> Sending control 4
> Sending data 2
> ...
>
>
> Next step, when I have time, is to find the differences between
> sending the break-in early and sending it later. Also interesting
> would be recording the exchange between windbg and the target when
> doing regular remote kernel debugging. I would still expect to see the
> "Connected to Windows 7 7601 x86 compatible target ..." output always,
> even when not breaking in immediately. The handshake is likely still
> missing something.
>
> Thanks,
> Ladi
I tested the new windbg. And as it turned out, three new api appeared in
it.
Naturally, it falls due to the fact that they are not realized. I will
try
to implement these api.
--
Thanks,
Mihail
^ permalink raw reply [flat|nested] 56+ messages in thread