On Thu, 2009-10-15 at 09:33 +0200, Gleb Natapov wrote: > On Thu, Oct 15, 2009 at 08:04:45AM +0100, Mark McLoughlin wrote: > > Hi Gleb, > > > > On Tue, 2009-05-26 at 13:03 +0300, Gleb Natapov wrote: > > > It gets packet without virtio header and adds it if needed. Allows to > > > inject packets to vlan from outside. To send gracious arp for instance. > > ... > > > diff --git a/net.h b/net.h > > > index 931133b..3d0b6f2 100644 > > > --- a/net.h > > > +++ b/net.h > > > ... > > > @@ -63,6 +64,7 @@ int qemu_can_send_packet(VLANClientState *vc); > > > ssize_t qemu_sendv_packet(VLANClientState *vc, const struct iovec *iov, > > > int iovcnt); > > > int qemu_send_packet(VLANClientState *vc, const uint8_t *buf, int size); > > > +void qemu_send_packet_raw(VLANClientState *vc, const uint8_t *buf, int size); > > > void qemu_format_nic_info_str(VLANClientState *vc, uint8_t macaddr[6]); > > > void qemu_check_nic_model(NICInfo *nd, const char *model); > > > void qemu_check_nic_model_list(NICInfo *nd, const char * const *models, > > > > I've only just now noticed that we never actually made announce_self() > > use this ... care to do that? > > > Something like this: > > --- > Use qemu_send_packet_raw to send gracious arp. This will ensure that > vnet header is handled properly. > > Signed-off-by: Gleb Natapov <gleb@xxxxxxxxxx> Acked-by: Mark McLoughlin <markmc@xxxxxxxxxx> > diff --git a/savevm.c b/savevm.c > index 7a363b6..8ea2daf 100644 > --- a/savevm.c > +++ b/savevm.c > @@ -132,7 +132,7 @@ static void qemu_announce_self_once(void *opaque) > len = announce_self_create(buf, nd_table[i].macaddr); > vlan = nd_table[i].vlan; > for(vc = vlan->first_client; vc != NULL; vc = vc->next) { > - vc->receive(vc, buf, len); > + qemu_send_packet_raw(vc, buf, len); This makes things even more gratuitous because we're making every net client send the packet rather than receive it, but it works fine in practice. Cheers, Mark. -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html