From: Avi Kivity Date: Sun, 13 Nov 2011 10:00:55 +0000 (+0200) Subject: memory: fix 'info mtree' segfaults X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=88365e47dd19da8776252a94ed5fa0b7242ea9e9;p=qmiga%2Fqemu.git memory: fix 'info mtree' segfaults 'info mtree' accesses invalid memory in two cases, both due to incorrect (and unsafe) usage of QTAILQ_FOREACH_SAFE(). Reported-by: Andreas Färber Signed-off-by: Avi Kivity --- diff --git a/memory.c b/memory.c index c0c1d12d79..7c20a0703f 100644 --- a/memory.c +++ b/memory.c @@ -1401,7 +1401,7 @@ static void mtree_print_mr(fprintf_function mon_printf, void *f, alias_print_queue); } - QTAILQ_FOREACH_SAFE(next_ml, &submr_print_queue, queue, ml) { + QTAILQ_FOREACH_SAFE(ml, &submr_print_queue, queue, next_ml) { g_free(ml); } } @@ -1425,7 +1425,7 @@ void mtree_info(fprintf_function mon_printf, void *f) } QTAILQ_FOREACH_SAFE(ml, &ml_head, queue, ml2) { - g_free(ml2); + g_free(ml); } if (address_space_io.root &&