summaryrefslogtreecommitdiffstats
path: root/src/etc
diff options
context:
space:
mode:
authorLorenz Schori <lo@znerol.ch>2017-07-25 14:21:06 +0200
committerLorenz Schori <lo@znerol.ch>2017-07-25 16:53:53 +0200
commitb060e08c9dd701b56b5163321b5e9a79f90b1f23 (patch)
treeb81795af7138be98343dd2a4e8b13c4295c93457 /src/etc
parenteb0a2a9466ceba7777a7ad1bcabee06e4c4ba92b (diff)
downloadpfsense-b060e08c9dd701b56b5163321b5e9a79f90b1f23.zip
pfsense-b060e08c9dd701b56b5163321b5e9a79f90b1f23.tar.gz
Add support for IPv6 AUTO_LINKLOCAL flag on bridge interfaces
Diffstat (limited to 'src/etc')
-rw-r--r--src/etc/inc/interfaces.inc21
1 files changed, 21 insertions, 0 deletions
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;
OpenPOWER on IntegriCloud