diff --git a/controller/pinctrl.c b/controller/pinctrl.c index 07cd140e02..92ba34f047 100644 --- a/controller/pinctrl.c +++ b/controller/pinctrl.c @@ -4301,7 +4301,8 @@ ipv6_ra_update_config(const struct sbrec_port_binding *pb) } const char *prefixes = smap_get(&pb->options, "ipv6_ra_prefixes"); - if (prefixes && !extract_ip_addresses(prefixes, &config->prefixes)) { + if (prefixes && *prefixes != '\0' && + !extract_ip_addresses(prefixes, &config->prefixes)) { VLOG_WARN("Invalid IPv6 prefixes: %s", prefixes); goto fail; } diff --git a/tests/ovn.at b/tests/ovn.at index 94be3f7477..5469a8daa6 100644 --- a/tests/ovn.at +++ b/tests/ovn.at @@ -16712,7 +16712,7 @@ ovs-vsctl add-br br-phys ovn_attach n1 br-phys 192.168.0.3 ovn-nbctl lr-add ro -ovn-nbctl lrp-add ro ro-sw 00:00:00:00:00:01 aef0:0:0:0:0:0:0:1/64 +ovn-nbctl lrp-add ro ro-sw 00:00:00:00:00:01 20.0.0.1/24 ovn-nbctl ls-add sw ovn-nbctl lsp-add sw sw-ro @@ -16818,6 +16818,11 @@ ra_test() { rm -f expected } +echo "Baseline test with no ipv6" +ra_test 0 00 0 0 0 c0 + +ovn-nbctl --wait=hv set Logical_Router_port ro-sw networks='aef0\:\:1/64' + echo "Baseline test with no MTU" ra_test 0 00 0 0 0 c0 40 aef00000000000000000000000000000 @@ -16963,7 +16968,7 @@ check ovs-vsctl set open . external-ids:ovn-bridge-mappings=phys:br-phys ovn_attach n1 br-phys 192.168.0.3 check ovn-nbctl lr-add ro -check ovn-nbctl lrp-add ro ro-sw 00:00:00:00:00:01 aef0:0:0:0:0:0:0:1/64 +check ovn-nbctl lrp-add ro ro-sw 00:00:00:00:00:01 20.0.0.1/24 check ovn-nbctl ls-add sw check ovn-nbctl lsp-add sw ln @@ -17078,8 +17083,13 @@ ra_test() { rm -f expected } + +echo "Baseline test with no ipv6" +check ra_test 0 00 0 0 0 c0 +ovn-nbctl --wait=hv set Logical_Router_port ro-sw networks='aef0\:\:1/64' + # check that RAs are sent to vifs -ra_test 0 00 0 0 0 c0 40 aef00000000000000000000000000000 +check ra_test 0 00 0 0 0 c0 40 aef00000000000000000000000000000 # check that RAs don't leak into provider networks for i in hv1 hv2 ; do