* [Qemu-devel] [PULL 0/3] hmp queue
@ 2017-02-21 18:55 Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 1/3] hmp: fix block_set_io_throttle Dr. David Alan Gilbert (git)
` (3 more replies)
0 siblings, 4 replies; 7+ messages in thread
From: Dr. David Alan Gilbert (git) @ 2017-02-21 18:55 UTC (permalink / raw)
To: qemu-devel; +Cc: eblake, phrdina, thuth
From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
The following changes since commit 796b288f7be875045670f963ce99991b3c8e96ac:
Merge remote-tracking branch 'remotes/cody/tags/block-pull-request' into staging (2017-02-21 15:48:22 +0000)
are available in the git repository at:
git://github.com/dagrh/qemu.git tags/pull-hmp-20170221
for you to fetch changes up to 854e67fea6a6f181163a5467fc9ba04de8d181bb:
monitor: Fix crashes when using HMP commands without CPU (2017-02-21 18:29:01 +0000)
----------------------------------------------------------------
HMP pull
Note, I had seen a fail in the vhost-user/flags-mismatch on one
host in one build, but not others with the same patches; and these patches
go nowhere near that, so I think that's a separate vhost-user issue.
----------------------------------------------------------------
Eric Blake (1):
hmp: fix block_set_io_throttle
Pavel Hrdina (1):
monitor: add poll-* properties into query-iothreads result
Thomas Huth (1):
monitor: Fix crashes when using HMP commands without CPU
hmp.c | 18 +++++++++++++++---
iothread.c | 3 +++
monitor.c | 42 ++++++++++++++++++++++++++++++++++--------
qapi-schema.json | 15 ++++++++++++++-
target/i386/monitor.c | 16 +++++++++++++++-
target/ppc/monitor.c | 4 ++++
target/sh4/monitor.c | 5 +++++
target/sparc/monitor.c | 4 ++++
target/xtensa/monitor.c | 4 ++++
9 files changed, 98 insertions(+), 13 deletions(-)
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Qemu-devel] [PULL 1/3] hmp: fix block_set_io_throttle
2017-02-21 18:55 [Qemu-devel] [PULL 0/3] hmp queue Dr. David Alan Gilbert (git)
@ 2017-02-21 18:55 ` Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 2/3] monitor: add poll-* properties into query-iothreads result Dr. David Alan Gilbert (git)
` (2 subsequent siblings)
3 siblings, 0 replies; 7+ messages in thread
From: Dr. David Alan Gilbert (git) @ 2017-02-21 18:55 UTC (permalink / raw)
To: qemu-devel; +Cc: eblake, phrdina, thuth
From: Eric Blake <eblake@redhat.com>
Commit 7a9877a made the 'device' parameter to BlockIOThrottle
optional, favoring 'id' instead. But it forgot to update the
HMP usage to set has_device, which makes all attempts to change
throttling via HMP fail with "Need exactly one of 'device' and 'id'"
CC: qemu-stable@nongnu.org
Signed-off-by: Eric Blake <eblake@redhat.com>
Message-Id: <20170120230359.4244-1-eblake@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
---
hmp.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/hmp.c b/hmp.c
index 2bc4f06..0c80596 100644
--- a/hmp.c
+++ b/hmp.c
@@ -1552,6 +1552,7 @@ void hmp_block_set_io_throttle(Monitor *mon, const QDict *qdict)
{
Error *err = NULL;
BlockIOThrottle throttle = {
+ .has_device = true,
.device = (char *) qdict_get_str(qdict, "device"),
.bps = qdict_get_int(qdict, "bps"),
.bps_rd = qdict_get_int(qdict, "bps_rd"),
--
2.9.3
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [Qemu-devel] [PULL 2/3] monitor: add poll-* properties into query-iothreads result
2017-02-21 18:55 [Qemu-devel] [PULL 0/3] hmp queue Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 1/3] hmp: fix block_set_io_throttle Dr. David Alan Gilbert (git)
@ 2017-02-21 18:55 ` Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 3/3] monitor: Fix crashes when using HMP commands without CPU Dr. David Alan Gilbert (git)
2017-02-23 9:59 ` [Qemu-devel] [PULL 0/3] hmp queue Peter Maydell
3 siblings, 0 replies; 7+ messages in thread
From: Dr. David Alan Gilbert (git) @ 2017-02-21 18:55 UTC (permalink / raw)
To: qemu-devel; +Cc: eblake, phrdina, thuth
From: Pavel Hrdina <phrdina@redhat.com>
IOthreads were recently extended by new properties that can
enable/disable and configure aio polling. This will also allow
other tools that uses QEMU to probe for existence of those new
properties via query-qmp-schema.
Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
Message-Id: <3163c16d6ab4257f7be9ad44fe9cc0ce8c359e5a.1486718555.git.phrdina@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
---
hmp.c | 9 +++++++--
iothread.c | 3 +++
qapi-schema.json | 15 ++++++++++++++-
3 files changed, 24 insertions(+), 3 deletions(-)
diff --git a/hmp.c b/hmp.c
index 0c80596..8b0c2b0 100644
--- a/hmp.c
+++ b/hmp.c
@@ -2149,10 +2149,15 @@ void hmp_info_iothreads(Monitor *mon, const QDict *qdict)
{
IOThreadInfoList *info_list = qmp_query_iothreads(NULL);
IOThreadInfoList *info;
+ IOThreadInfo *value;
for (info = info_list; info; info = info->next) {
- monitor_printf(mon, "%s: thread_id=%" PRId64 "\n",
- info->value->id, info->value->thread_id);
+ value = info->value;
+ monitor_printf(mon, "%s:\n", value->id);
+ monitor_printf(mon, " thread_id=%" PRId64 "\n", value->thread_id);
+ monitor_printf(mon, " poll-max-ns=%" PRId64 "\n", value->poll_max_ns);
+ monitor_printf(mon, " poll-grow=%" PRId64 "\n", value->poll_grow);
+ monitor_printf(mon, " poll-shrink=%" PRId64 "\n", value->poll_shrink);
}
qapi_free_IOThreadInfoList(info_list);
diff --git a/iothread.c b/iothread.c
index 257b01d..beeb870 100644
--- a/iothread.c
+++ b/iothread.c
@@ -268,6 +268,9 @@ static int query_one_iothread(Object *object, void *opaque)
info = g_new0(IOThreadInfo, 1);
info->id = iothread_get_id(iothread);
info->thread_id = iothread->thread_id;
+ info->poll_max_ns = iothread->poll_max_ns;
+ info->poll_grow = iothread->poll_grow;
+ info->poll_shrink = iothread->poll_shrink;
elem = g_new0(IOThreadInfoList, 1);
elem->value = info;
diff --git a/qapi-schema.json b/qapi-schema.json
index e9a6364..f6ca18c 100644
--- a/qapi-schema.json
+++ b/qapi-schema.json
@@ -1427,10 +1427,23 @@
#
# @thread-id: ID of the underlying host thread
#
+# @poll-max-ns: maximum polling time in ns, 0 means polling is disabled
+# (since 2.9)
+#
+# @poll-grow: how many ns will be added to polling time, 0 means that it's not
+# configured (since 2.9)
+#
+# @poll-shrink: how many ns will be removed from polling time, 0 means that
+# it's not configured (since 2.9)
+#
# Since: 2.0
##
{ 'struct': 'IOThreadInfo',
- 'data': {'id': 'str', 'thread-id': 'int'} }
+ 'data': {'id': 'str',
+ 'thread-id': 'int',
+ 'poll-max-ns': 'int',
+ 'poll-grow': 'int',
+ 'poll-shrink': 'int' } }
##
# @query-iothreads:
--
2.9.3
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [Qemu-devel] [PULL 3/3] monitor: Fix crashes when using HMP commands without CPU
2017-02-21 18:55 [Qemu-devel] [PULL 0/3] hmp queue Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 1/3] hmp: fix block_set_io_throttle Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 2/3] monitor: add poll-* properties into query-iothreads result Dr. David Alan Gilbert (git)
@ 2017-02-21 18:55 ` Dr. David Alan Gilbert (git)
2017-02-23 9:59 ` [Qemu-devel] [PULL 0/3] hmp queue Peter Maydell
3 siblings, 0 replies; 7+ messages in thread
From: Dr. David Alan Gilbert (git) @ 2017-02-21 18:55 UTC (permalink / raw)
To: qemu-devel; +Cc: eblake, phrdina, thuth
From: Thomas Huth <thuth@redhat.com>
When running certain HMP commands ("info registers", "info cpustats",
"info tlb", "nmi", "memsave" or dumping virtual memory) with the "none"
machine, QEMU crashes with a segmentation fault. This happens because the
"none" machine does not have any CPUs by default, but these HMP commands
did not check for a valid CPU pointer yet. Add such checks now, so we get
an error message about the missing CPU instead.
Signed-off-by: Thomas Huth <thuth@redhat.com>
Message-Id: <1484309555-1935-1-git-send-email-thuth@redhat.com>
Reviewed-by: Markus Armbruster <armbru@redhat.com>
Acked-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
---
hmp.c | 8 +++++++-
monitor.c | 42 ++++++++++++++++++++++++++++++++++--------
target/i386/monitor.c | 16 +++++++++++++++-
target/ppc/monitor.c | 4 ++++
target/sh4/monitor.c | 5 +++++
target/sparc/monitor.c | 4 ++++
target/xtensa/monitor.c | 4 ++++
7 files changed, 73 insertions(+), 10 deletions(-)
diff --git a/hmp.c b/hmp.c
index 8b0c2b0..aba728f 100644
--- a/hmp.c
+++ b/hmp.c
@@ -1014,8 +1014,14 @@ void hmp_memsave(Monitor *mon, const QDict *qdict)
const char *filename = qdict_get_str(qdict, "filename");
uint64_t addr = qdict_get_int(qdict, "val");
Error *err = NULL;
+ int cpu_index = monitor_get_cpu_index();
- qmp_memsave(addr, size, filename, true, monitor_get_cpu_index(), &err);
+ if (cpu_index < 0) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
+
+ qmp_memsave(addr, size, filename, true, cpu_index, &err);
hmp_handle_error(mon, &err);
}
diff --git a/monitor.c b/monitor.c
index 3cd72a9..5953fc9 100644
--- a/monitor.c
+++ b/monitor.c
@@ -1026,6 +1026,9 @@ int monitor_set_cpu(int cpu_index)
CPUState *mon_get_cpu(void)
{
if (!cur_mon->mon_cpu) {
+ if (!first_cpu) {
+ return NULL;
+ }
monitor_set_cpu(first_cpu->cpu_index);
}
cpu_synchronize_state(cur_mon->mon_cpu);
@@ -1034,17 +1037,27 @@ CPUState *mon_get_cpu(void)
CPUArchState *mon_get_cpu_env(void)
{
- return mon_get_cpu()->env_ptr;
+ CPUState *cs = mon_get_cpu();
+
+ return cs ? cs->env_ptr : NULL;
}
int monitor_get_cpu_index(void)
{
- return mon_get_cpu()->cpu_index;
+ CPUState *cs = mon_get_cpu();
+
+ return cs ? cs->cpu_index : UNASSIGNED_CPU_INDEX;
}
static void hmp_info_registers(Monitor *mon, const QDict *qdict)
{
- cpu_dump_state(mon_get_cpu(), (FILE *)mon, monitor_fprintf, CPU_DUMP_FPU);
+ CPUState *cs = mon_get_cpu();
+
+ if (!cs) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
+ cpu_dump_state(cs, (FILE *)mon, monitor_fprintf, CPU_DUMP_FPU);
}
static void hmp_info_jit(Monitor *mon, const QDict *qdict)
@@ -1077,7 +1090,13 @@ static void hmp_info_history(Monitor *mon, const QDict *qdict)
static void hmp_info_cpustats(Monitor *mon, const QDict *qdict)
{
- cpu_dump_statistics(mon_get_cpu(), (FILE *)mon, &monitor_fprintf, 0);
+ CPUState *cs = mon_get_cpu();
+
+ if (!cs) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
+ cpu_dump_statistics(cs, (FILE *)mon, &monitor_fprintf, 0);
}
static void hmp_info_trace_events(Monitor *mon, const QDict *qdict)
@@ -1236,6 +1255,12 @@ static void memory_dump(Monitor *mon, int count, int format, int wsize,
int l, line_size, i, max_digits, len;
uint8_t buf[16];
uint64_t v;
+ CPUState *cs = mon_get_cpu();
+
+ if (!cs && (format == 'i' || !is_physical)) {
+ monitor_printf(mon, "Can not dump without CPU\n");
+ return;
+ }
if (format == 'i') {
int flags = 0;
@@ -1265,7 +1290,7 @@ static void memory_dump(Monitor *mon, int count, int format, int wsize,
flags = msr_le << 16;
flags |= env->bfd_mach;
#endif
- monitor_disas(mon, mon_get_cpu(), addr, count, is_physical, flags);
+ monitor_disas(mon, cs, addr, count, is_physical, flags);
return;
}
@@ -1304,7 +1329,7 @@ static void memory_dump(Monitor *mon, int count, int format, int wsize,
if (is_physical) {
cpu_physical_memory_read(addr, buf, l);
} else {
- if (cpu_memory_rw_debug(mon_get_cpu(), addr, buf, l, 0) < 0) {
+ if (cpu_memory_rw_debug(cs, addr, buf, l, 0) < 0) {
monitor_printf(mon, " Cannot access memory\n");
break;
}
@@ -2189,11 +2214,12 @@ expr_error(Monitor *mon, const char *fmt, ...)
static int get_monitor_def(target_long *pval, const char *name)
{
const MonitorDef *md = target_monitor_defs();
+ CPUState *cs = mon_get_cpu();
void *ptr;
uint64_t tmp = 0;
int ret;
- if (md == NULL) {
+ if (cs == NULL || md == NULL) {
return -1;
}
@@ -2220,7 +2246,7 @@ static int get_monitor_def(target_long *pval, const char *name)
}
}
- ret = target_get_monitor_def(mon_get_cpu(), name, &tmp);
+ ret = target_get_monitor_def(cs, name, &tmp);
if (!ret) {
*pval = (target_long) tmp;
}
diff --git a/target/i386/monitor.c b/target/i386/monitor.c
index 468aa07..77ead60 100644
--- a/target/i386/monitor.c
+++ b/target/i386/monitor.c
@@ -210,6 +210,10 @@ void hmp_info_tlb(Monitor *mon, const QDict *qdict)
CPUArchState *env;
env = mon_get_cpu_env();
+ if (!env) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
if (!(env->cr[0] & CR0_PG_MASK)) {
monitor_printf(mon, "PG disabled\n");
@@ -529,6 +533,10 @@ void hmp_info_mem(Monitor *mon, const QDict *qdict)
CPUArchState *env;
env = mon_get_cpu_env();
+ if (!env) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
if (!(env->cr[0] & CR0_PG_MASK)) {
monitor_printf(mon, "PG disabled\n");
@@ -624,7 +632,13 @@ const MonitorDef *target_monitor_defs(void)
void hmp_info_local_apic(Monitor *mon, const QDict *qdict)
{
- x86_cpu_dump_local_apic_state(mon_get_cpu(), (FILE *)mon, monitor_fprintf,
+ CPUState *cs = mon_get_cpu();
+
+ if (!cs) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
+ x86_cpu_dump_local_apic_state(cs, (FILE *)mon, monitor_fprintf,
CPU_DUMP_FPU);
}
diff --git a/target/ppc/monitor.c b/target/ppc/monitor.c
index c2d0806..b8f30e9 100644
--- a/target/ppc/monitor.c
+++ b/target/ppc/monitor.c
@@ -62,6 +62,10 @@ void hmp_info_tlb(Monitor *mon, const QDict *qdict)
{
CPUArchState *env1 = mon_get_cpu_env();
+ if (!env1) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
dump_mmu((FILE*)mon, (fprintf_function)monitor_printf, env1);
}
diff --git a/target/sh4/monitor.c b/target/sh4/monitor.c
index 426e5d4..4c7f36c 100644
--- a/target/sh4/monitor.c
+++ b/target/sh4/monitor.c
@@ -44,6 +44,11 @@ void hmp_info_tlb(Monitor *mon, const QDict *qdict)
CPUArchState *env = mon_get_cpu_env();
int i;
+ if (!env) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
+
monitor_printf (mon, "ITLB:\n");
for (i = 0 ; i < ITLB_SIZE ; i++)
print_tlb (mon, i, &env->itlb[i]);
diff --git a/target/sparc/monitor.c b/target/sparc/monitor.c
index 7cc1b0f..f3ca524 100644
--- a/target/sparc/monitor.c
+++ b/target/sparc/monitor.c
@@ -32,6 +32,10 @@ void hmp_info_tlb(Monitor *mon, const QDict *qdict)
{
CPUArchState *env1 = mon_get_cpu_env();
+ if (!env1) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
dump_mmu((FILE*)mon, (fprintf_function)monitor_printf, env1);
}
diff --git a/target/xtensa/monitor.c b/target/xtensa/monitor.c
index f3fa4cd..2ee2b5b 100644
--- a/target/xtensa/monitor.c
+++ b/target/xtensa/monitor.c
@@ -31,5 +31,9 @@ void hmp_info_tlb(Monitor *mon, const QDict *qdict)
{
CPUArchState *env1 = mon_get_cpu_env();
+ if (!env1) {
+ monitor_printf(mon, "No CPU available\n");
+ return;
+ }
dump_mmu((FILE*)mon, (fprintf_function)monitor_printf, env1);
}
--
2.9.3
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [Qemu-devel] [PULL 0/3] hmp queue
2017-02-21 18:55 [Qemu-devel] [PULL 0/3] hmp queue Dr. David Alan Gilbert (git)
` (2 preceding siblings ...)
2017-02-21 18:55 ` [Qemu-devel] [PULL 3/3] monitor: Fix crashes when using HMP commands without CPU Dr. David Alan Gilbert (git)
@ 2017-02-23 9:59 ` Peter Maydell
3 siblings, 0 replies; 7+ messages in thread
From: Peter Maydell @ 2017-02-23 9:59 UTC (permalink / raw)
To: Dr. David Alan Gilbert (git); +Cc: QEMU Developers, Thomas Huth, phrdina
On 21 February 2017 at 18:55, Dr. David Alan Gilbert (git)
<dgilbert@redhat.com> wrote:
> From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
>
> The following changes since commit 796b288f7be875045670f963ce99991b3c8e96ac:
>
> Merge remote-tracking branch 'remotes/cody/tags/block-pull-request' into staging (2017-02-21 15:48:22 +0000)
>
> are available in the git repository at:
>
> git://github.com/dagrh/qemu.git tags/pull-hmp-20170221
>
> for you to fetch changes up to 854e67fea6a6f181163a5467fc9ba04de8d181bb:
>
> monitor: Fix crashes when using HMP commands without CPU (2017-02-21 18:29:01 +0000)
>
> ----------------------------------------------------------------
> HMP pull
>
> Note, I had seen a fail in the vhost-user/flags-mismatch on one
> host in one build, but not others with the same patches; and these patches
> go nowhere near that, so I think that's a separate vhost-user issue.
Applied, thanks.
-- PMM
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Qemu-devel] [PULL 0/3] hmp queue
@ 2017-05-17 18:07 Dr. David Alan Gilbert (git)
2017-05-18 9:31 ` Stefan Hajnoczi
0 siblings, 1 reply; 7+ messages in thread
From: Dr. David Alan Gilbert (git) @ 2017-05-17 18:07 UTC (permalink / raw)
To: qemu-devel; +Cc: peterx
From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
The following changes since commit cdece0467c00007cf8e3f4b3c3f0b13bf2c4fea9:
block/win32: fix 'ret not initialized' warning (2017-05-16 15:34:18 +0100)
are available in the git repository at:
git://github.com/dagrh/qemu.git tags/pull-hmp-20170517
for you to fetch changes up to be9b23c4a539090da30b482015ee660850e8bb5f:
ramblock: add new hmp command "info ramblock" (2017-05-17 17:31:16 +0100)
----------------------------------------------------------------
HMP pull
----------------------------------------------------------------
Peter Xu (3):
ramblock: add RAMBLOCK_FOREACH()
utils: provide size_to_str()
ramblock: add new hmp command "info ramblock"
exec.c | 44 +++++++++++++++++++++++++++++++++-----------
hmp-commands-info.hx | 14 ++++++++++++++
hmp.c | 6 ++++++
hmp.h | 1 +
include/exec/ramlist.h | 6 ++++++
include/qemu-common.h | 1 +
migration/ram.c | 13 +++++++------
qapi/string-output-visitor.c | 22 ++++++----------------
util/cutils.c | 25 +++++++++++++++++++++++++
9 files changed, 99 insertions(+), 33 deletions(-)
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [Qemu-devel] [PULL 0/3] hmp queue
2017-05-17 18:07 Dr. David Alan Gilbert (git)
@ 2017-05-18 9:31 ` Stefan Hajnoczi
0 siblings, 0 replies; 7+ messages in thread
From: Stefan Hajnoczi @ 2017-05-18 9:31 UTC (permalink / raw)
To: Dr. David Alan Gilbert (git); +Cc: qemu-devel, peterx
[-- Attachment #1: Type: text/plain, Size: 1652 bytes --]
On Wed, May 17, 2017 at 07:07:51PM +0100, Dr. David Alan Gilbert (git) wrote:
> From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
>
> The following changes since commit cdece0467c00007cf8e3f4b3c3f0b13bf2c4fea9:
>
> block/win32: fix 'ret not initialized' warning (2017-05-16 15:34:18 +0100)
>
> are available in the git repository at:
>
> git://github.com/dagrh/qemu.git tags/pull-hmp-20170517
>
> for you to fetch changes up to be9b23c4a539090da30b482015ee660850e8bb5f:
>
> ramblock: add new hmp command "info ramblock" (2017-05-17 17:31:16 +0100)
>
> ----------------------------------------------------------------
> HMP pull
>
> ----------------------------------------------------------------
> Peter Xu (3):
> ramblock: add RAMBLOCK_FOREACH()
> utils: provide size_to_str()
> ramblock: add new hmp command "info ramblock"
>
> exec.c | 44 +++++++++++++++++++++++++++++++++-----------
> hmp-commands-info.hx | 14 ++++++++++++++
> hmp.c | 6 ++++++
> hmp.h | 1 +
> include/exec/ramlist.h | 6 ++++++
> include/qemu-common.h | 1 +
> migration/ram.c | 13 +++++++------
> qapi/string-output-visitor.c | 22 ++++++----------------
> util/cutils.c | 25 +++++++++++++++++++++++++
> 9 files changed, 99 insertions(+), 33 deletions(-)
>
Peter has already merged pull requests from your RH2 PGP key. I will
merge it even though gpg doesn't trust the key.
Thanks, applied to my staging tree:
https://github.com/stefanha/qemu/commits/staging
Stefan
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 455 bytes --]
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2017-05-18 9:31 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-02-21 18:55 [Qemu-devel] [PULL 0/3] hmp queue Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 1/3] hmp: fix block_set_io_throttle Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 2/3] monitor: add poll-* properties into query-iothreads result Dr. David Alan Gilbert (git)
2017-02-21 18:55 ` [Qemu-devel] [PULL 3/3] monitor: Fix crashes when using HMP commands without CPU Dr. David Alan Gilbert (git)
2017-02-23 9:59 ` [Qemu-devel] [PULL 0/3] hmp queue Peter Maydell
-- strict thread matches above, loose matches on Subject: below --
2017-05-17 18:07 Dr. David Alan Gilbert (git)
2017-05-18 9:31 ` Stefan Hajnoczi
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).