From b060e08c9dd701b56b5163321b5e9a79f90b1f23 Mon Sep 17 00:00:00 2001 From: Lorenz Schori Date: Tue, 25 Jul 2017 14:21:06 +0200 Subject: Add support for IPv6 AUTO_LINKLOCAL flag on bridge interfaces --- src/etc/inc/interfaces.inc | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'src/etc/inc') diff --git a/src/etc/inc/interfaces.inc b/src/etc/inc/interfaces.inc index 0787110..51668b4 100644 --- a/src/etc/inc/interfaces.inc +++ b/src/etc/inc/interfaces.inc @@ -560,6 +560,8 @@ function interface_bridge_configure(&$bridge, $checkmember = 0) { interface_bridge_configure_advanced($bridge); + interface_bridge_configure_ip6linklocal($bridge); + if ($bridge['bridgeif']) { interfaces_bring_up($bridge['bridgeif']); } else { @@ -686,6 +688,25 @@ function interface_bridge_configure_advanced($bridge) { } } +function interface_bridge_configure_ip6linklocal($bridge) { + $bridgeif = $bridge['bridgeif']; + + $members = explode(',', $bridge['members']); + if (!count($members)) { + return; + } + + $auto_linklocal = isset($bridge['ip6linklocal']); + $bridgeop = $auto_linklocal ? '' : '-'; + $memberop = $auto_linklocal ? '-' : ''; + + mwexec("/usr/sbin/ndp -i {$bridgeif} -- {$bridgeop}auto_linklocal"); + foreach ($members as $member) { + $realif = get_real_interface($member); + mwexec("/usr/sbin/ndp -i {$realif} -- {$memberop}auto_linklocal"); + } +} + function interface_bridge_add_member($bridgeif, $interface, $flagsapplied = false) { global $config; -- cgit v1.1