[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] Re: [PATCH] Fix incoming migration
From: |
Juan Quintela |
Subject: |
[Qemu-devel] Re: [PATCH] Fix incoming migration |
Date: |
Tue, 10 Nov 2009 19:55:12 +0100 |
User-agent: |
Gnus/5.13 (Gnus v5.13) Emacs/23.1 (gnu/linux) |
Mark McLoughlin <address@hidden> wrote:
> On Tue, 2009-11-10 at 18:03 +0100, Juan Quintela wrote:
>> Mark McLoughlin <address@hidden> wrote:
>> > On Fri, 2009-11-06 at 15:58 +0100, Juan Quintela wrote:
>> >> commit b04c4134d6de28c249277de19e523bfbe4aebbd6
>> >> broke incoming migration. After talking with Gleb, code was intended
>> >> to be the way is in this fix. This fixes migration here.
>> >
>> > Tried to reproduce and it works fine for me. More details?
>> >
>> >> Signed-off-by: Juan Quintela <address@hidden>
>> >> ---
>> >> savevm.c | 7 ++++++-
>> >> 1 files changed, 6 insertions(+), 1 deletions(-)
>> >>
>> >> diff --git a/savevm.c b/savevm.c
>> >> index b7abf43..fd98ccd 100644
>> >> --- a/savevm.c
>> >> +++ b/savevm.c
>> >> @@ -126,6 +126,8 @@ static int announce_self_create(uint8_t *buf,
>> >> static void qemu_announce_self_once(void *opaque)
>> >> {
>> >> int i, len;
>> >> + VLANState *vlan;
>> >> + VLANClientState *vc;
>> >> uint8_t buf[60];
>> >> static int count = SELF_ANNOUNCE_ROUNDS;
>> >> QEMUTimer *timer = *(QEMUTimer **)opaque;
>> >> @@ -134,7 +136,10 @@ static void qemu_announce_self_once(void *opaque)
>> >> if (!nd_table[i].used)
>> >> continue;
>> >> len = announce_self_create(buf, nd_table[i].macaddr);
>> >> - qemu_send_packet_raw(nd_table[i].vc, buf, len);
>> >> + vlan = nd_table[i].vlan;
>> >> + QTAILQ_FOREACH(vc, &vlan->clients, next) {
>> >> + qemu_send_packet_raw(vc, buf, len);
>> >> + }
>> >
>> > A NIC isn't necessarily connected to a vlan any more, which is why the
>> > change was made.
>> >
>> > With your patch, I'd expect it to crash if you used -netdev rather than
>> > -net
>>
>> Without this patch, migration don't work at all. nd_table[i].vc is NULL
>> at this point. Any better idea?
>
> Right, I can't reproduce that. Exactly what command line did you use?
/scratch/qemu/x86_64-softmmu/qemu-system-x86_64 -M pc -m 512 -smp 1
-name test -drive file=/scratch/tmp/f11b.img,if=ide -drive
file=/scratch/tmp/temp.img,if=virtio -net
nic,macaddr=54:52:00:53:7e:5b,vlan=0,model=virtio -net
tap,script=/etc/kvm-ifup,vlan=0,ifname=vnet1,downscript=no --monitor
stdio --serial telnet:0:5553,server --virtioconsole telnet:0:5554,server
--enable-kvm -usbdevice tablet -soundhw ac97 -loadvm virtio
virtio is an image saved with the same command line.
(I am rebasing to upstream, but I am getting a different error)
qemu)
Program received signal SIGSEGV, Segmentation fault.
0x00000000004ddb53 in qdev_reset (opaque=0xd32cc0)
at /scratch/qemu/hw/qdev.c:228
228 if (dev->info->reset)
(gdb) bt
#0 0x00000000004ddb53 in qdev_reset (opaque=0xd32cc0)
at /scratch/qemu/hw/qdev.c:228
#1 0x000000000040ce9d in qemu_system_reset () at /scratch/qemu/vl.c:3240
#2 0x000000000040da71 in main_loop () at /scratch/qemu/vl.c:4047
#3 0x0000000000411452 in main (argc=30, argv=0x7fffffffe388,
envp=0x7fffffffe480) at /scratch/qemu/vl.c:5909
(gdb) p *dev
$1 = {id = 0x0,
state = DEV_STATE_INITIALIZED, opts = 0x0, hotplugged = 0,
info = 0x10000007f7ee2a0, parent_bus = 0x137f80, num_gpio_out = 0,
gpio_out = 0x0, num_gpio_in = 0, gpio_in = 0x0, child_bus = {
lh_first = 0x0}, num_child_bus = 0, sibling = {le_next = 0xd0a8d0,
le_prev = 0xcf6400}}
(gdb)
Will try again once that I have fixed that one.
Later, Juan.