提交 8cb06b7f 编写于 作者: J Jason Baron 提交者: Michal Privoznik

qemu: handle multicast overflow on macvtap NIC_RX_FILTER_CHANGED

Guest network devices can set 'overflow' when there are a number of multicast
ips configured. For virtio_net, the limit is only 64. In this case, the list
of mac addresses is empty and the 'overflow' condition is set. Thus, the guest
will currently receive no multicast traffic in this state.

When 'overflow' is set in the guest, let's turn this into ALLMULTI on the host.
Signed-off-by: NJason Baron <jbaron@akamai.com>
Acked-by: NMichael S. Tsirkin <mst@redhat.com>
Acked-by: NMichal Privoznik <mprivozn@redhat.com>
上级 47647bda
...@@ -4443,11 +4443,12 @@ static void ...@@ -4443,11 +4443,12 @@ static void
syncNicRxFilterMultiMode(char *ifname, virNetDevRxFilterPtr guestFilter, syncNicRxFilterMultiMode(char *ifname, virNetDevRxFilterPtr guestFilter,
virNetDevRxFilterPtr hostFilter) virNetDevRxFilterPtr hostFilter)
{ {
if (hostFilter->multicast.mode != guestFilter->multicast.mode) { if (hostFilter->multicast.mode != guestFilter->multicast.mode ||
(guestFilter->multicast.overflow &&
guestFilter->multicast.mode == VIR_NETDEV_RX_FILTER_MODE_NORMAL)) {
switch (guestFilter->multicast.mode) { switch (guestFilter->multicast.mode) {
case VIR_NETDEV_RX_FILTER_MODE_ALL: case VIR_NETDEV_RX_FILTER_MODE_ALL:
if (virNetDevSetRcvAllMulti(ifname, true)) { if (virNetDevSetRcvAllMulti(ifname, true)) {
VIR_WARN("Couldn't set allmulticast flag to 'on' for " VIR_WARN("Couldn't set allmulticast flag to 'on' for "
"device %s while responding to " "device %s while responding to "
"NIC_RX_FILTER_CHANGED", ifname); "NIC_RX_FILTER_CHANGED", ifname);
...@@ -4455,17 +4456,24 @@ syncNicRxFilterMultiMode(char *ifname, virNetDevRxFilterPtr guestFilter, ...@@ -4455,17 +4456,24 @@ syncNicRxFilterMultiMode(char *ifname, virNetDevRxFilterPtr guestFilter,
break; break;
case VIR_NETDEV_RX_FILTER_MODE_NORMAL: case VIR_NETDEV_RX_FILTER_MODE_NORMAL:
if (virNetDevSetRcvMulti(ifname, true)) { if (guestFilter->multicast.overflow &&
(hostFilter->multicast.mode == VIR_NETDEV_RX_FILTER_MODE_ALL)) {
break;
}
if (virNetDevSetRcvMulti(ifname, true)) {
VIR_WARN("Couldn't set multicast flag to 'on' for " VIR_WARN("Couldn't set multicast flag to 'on' for "
"device %s while responding to " "device %s while responding to "
"NIC_RX_FILTER_CHANGED", ifname); "NIC_RX_FILTER_CHANGED", ifname);
} }
if (virNetDevSetRcvAllMulti(ifname, false)) { if (virNetDevSetRcvAllMulti(ifname,
VIR_WARN("Couldn't set allmulticast flag to 'off' for " guestFilter->multicast.overflow) < 0) {
"device %s while responding to " VIR_WARN("Couldn't set allmulticast flag to '%s' for "
"NIC_RX_FILTER_CHANGED", ifname); "device %s while responding to "
"NIC_RX_FILTER_CHANGED",
virTristateSwitchTypeToString(virTristateSwitchFromBool(guestFilter->multicast.overflow)),
ifname);
} }
break; break;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册