Commit 2a3a6a1d authored by Ad Schellevis's avatar Ad Schellevis

(legacy) cleanup system_advanced_network.php and add switch for vlanhwfilter...

(legacy) cleanup system_advanced_network.php and add switch for vlanhwfilter disable ( https://github.com/opnsense/core/issues/252 )
parent 640e37f6
...@@ -3004,12 +3004,13 @@ function interface_configure($interface = 'wan', $reloadall = false, $linkupeven ...@@ -3004,12 +3004,13 @@ function interface_configure($interface = 'wan', $reloadall = false, $linkupeven
/* skip vlans for checksumming and polling */ /* skip vlans for checksumming and polling */
if (!stristr($realif, "_vlan") && is_array($options)) { if (!stristr($realif, "_vlan") && is_array($options)) {
legacy_interface_flags($realhwif, sprintf( legacy_interface_flags($realhwif, sprintf(
'%stxcsum %srxcsum %stso %slro %spolling', '%stxcsum %srxcsum %stso %slro %spolling %svlanhwfilter',
isset($config['system']['disablechecksumoffloading']) ? '-' : '', isset($config['system']['disablechecksumoffloading']) ? '-' : '',
isset($config['system']['disablechecksumoffloading']) ? '-' : '', isset($config['system']['disablechecksumoffloading']) ? '-' : '',
isset($config['system']['disablesegmentationoffloading']) ? '-' : '', isset($config['system']['disablesegmentationoffloading']) ? '-' : '',
isset($config['system']['disablelargereceiveoffloading']) ? '-' : '', isset($config['system']['disablelargereceiveoffloading']) ? '-' : '',
isset($config['system']['polling']) ? '' : '-' isset($config['system']['polling']) ? '' : '-',
isset($config['system']['disablevlanhwfilter']) ? '-' : ''
)); ));
} }
......
...@@ -42,85 +42,77 @@ function system_enable_arp_wrong_if() ...@@ -42,85 +42,77 @@ function system_enable_arp_wrong_if()
} }
$pconfig['ipv6nat_enable'] = isset($config['diag']['ipv6nat']['enable']); if (isset($_POST) && count($_POST) > 0) {
$pconfig['ipv6nat_ipaddr'] = $config['diag']['ipv6nat']['ipaddr']; $input_errors = array();
$pconfig['ipv6allow'] = isset($config['system']['ipv6allow']);
$pconfig['prefer_ipv4'] = isset($config['system']['prefer_ipv4']); if (isset($_POST['ipv6nat_enable']) && !is_ipaddr($_POST['ipv6nat_ipaddr'])) {
$pconfig['polling_enable'] = isset($config['system']['polling']);
$pconfig['sharednet'] = $config['system']['sharednet'];
$pconfig['disablechecksumoffloading'] = isset($config['system']['disablechecksumoffloading']);
$pconfig['disablesegmentationoffloading'] = isset($config['system']['disablesegmentationoffloading']);
$pconfig['disablelargereceiveoffloading'] = isset($config['system']['disablelargereceiveoffloading']);
if ($_POST) {
unset($input_errors);
$pconfig = $_POST;
if ($_POST['ipv6nat_enable'] && !is_ipaddr($_POST['ipv6nat_ipaddr'])) {
$input_errors[] = gettext("You must specify an IP address to NAT IPv6 packets."); $input_errors[] = gettext("You must specify an IP address to NAT IPv6 packets.");
} }
ob_flush(); if (isset($_POST['ipv6nat_enable']) && $_POST['ipv6nat_enable'] == "yes") {
flush();
if (!$input_errors) {
if ($_POST['ipv6nat_enable'] == "yes") {
$config['diag']['ipv6nat']['enable'] = true; $config['diag']['ipv6nat']['enable'] = true;
$config['diag']['ipv6nat']['ipaddr'] = $_POST['ipv6nat_ipaddr']; $config['diag']['ipv6nat']['ipaddr'] = $_POST['ipv6nat_ipaddr'];
} else { } elseif (isset($config['diag']['ipv6nat'])) {
if ($config['diag']) {
if ($config['diag']['ipv6nat']) {
unset($config['diag']['ipv6nat']['enable']); unset($config['diag']['ipv6nat']['enable']);
unset($config['diag']['ipv6nat']['ipaddr']); unset($config['diag']['ipv6nat']['ipaddr']);
} }
}
}
if ($_POST['ipv6allow'] == "yes") { if (isset($_POST['ipv6allow']) && $_POST['ipv6allow'] == "yes") {
$config['system']['ipv6allow'] = true; $config['system']['ipv6allow'] = true;
} else { } else {
unset($config['system']['ipv6allow']); unset($config['system']['ipv6allow']);
} }
if ($_POST['prefer_ipv4'] == "yes") { if (isset($_POST['prefer_ipv4']) && $_POST['prefer_ipv4'] == "yes") {
$config['system']['prefer_ipv4'] = true; $config['system']['prefer_ipv4'] = true;
} else { } else {
unset($config['system']['prefer_ipv4']); unset($config['system']['prefer_ipv4']);
} }
if ($_POST['sharednet'] == "yes") { if (isset($_POST['sharednet']) && $_POST['sharednet'] == "yes") {
$config['system']['sharednet'] = true; $config['system']['sharednet'] = true;
system_disable_arp_wrong_if();
} else { } else {
unset($config['system']['sharednet']); unset($config['system']['sharednet']);
system_enable_arp_wrong_if();
} }
if ($_POST['polling_enable'] == "yes") { if (isset($_POST['polling_enable']) && $_POST['polling_enable'] == "yes") {
$config['system']['polling'] = true; $config['system']['polling'] = true;
setup_polling();
} else { } else {
unset($config['system']['polling']); unset($config['system']['polling']);
setup_polling();
} }
if ($_POST['disablechecksumoffloading'] == "yes") { if (isset($_POST['disablechecksumoffloading']) && $_POST['disablechecksumoffloading'] == "yes") {
$config['system']['disablechecksumoffloading'] = true; $config['system']['disablechecksumoffloading'] = true;
} else { } else {
unset($config['system']['disablechecksumoffloading']); unset($config['system']['disablechecksumoffloading']);
} }
if ($_POST['disablesegmentationoffloading'] == "yes") { if (isset($_POST['disablesegmentationoffloading']) && $_POST['disablesegmentationoffloading'] == "yes") {
$config['system']['disablesegmentationoffloading'] = true; $config['system']['disablesegmentationoffloading'] = true;
} else { } else {
unset($config['system']['disablesegmentationoffloading']); unset($config['system']['disablesegmentationoffloading']);
} }
if ($_POST['disablelargereceiveoffloading'] == "yes") { if (isset($_POST['disablelargereceiveoffloading']) && $_POST['disablelargereceiveoffloading'] == "yes") {
$config['system']['disablelargereceiveoffloading'] = true; $config['system']['disablelargereceiveoffloading'] = true;
} else { } else {
unset($config['system']['disablelargereceiveoffloading']); unset($config['system']['disablelargereceiveoffloading']);
} }
if (isset($_POST['disablevlanhwfilter']) && $_POST['disablevlanhwfilter'] == "yes") {
$config['system']['disablevlanhwfilter'] = true;
} else {
unset($config['system']['disablevlanhwfilter']);
}
// save when no errors are found
if (count($input_errors) == 0) {
setup_polling();
if (isset($config['system']['sharednet'])) {
system_disable_arp_wrong_if();
} else {
system_enable_arp_wrong_if();
}
setup_microcode(); setup_microcode();
// Write out configuration (config.xml) // Write out configuration (config.xml)
...@@ -187,7 +179,7 @@ include("head.inc"); ...@@ -187,7 +179,7 @@ include("head.inc");
<tr> <tr>
<td width="22%" valign="top" class="vncell"><?=gettext("Allow IPv6"); ?></td> <td width="22%" valign="top" class="vncell"><?=gettext("Allow IPv6"); ?></td>
<td width="78%" class="vtable"> <td width="78%" class="vtable">
<input name="ipv6allow" type="checkbox" id="ipv6allow" value="yes" <?php if ($pconfig['ipv6allow']) { <input name="ipv6allow" type="checkbox" id="ipv6allow" value="yes" <?php if (isset($config['system']['ipv6allow'])) {
echo "checked=\"checked\""; echo "checked=\"checked\"";
} ?> onclick="enable_change(false)" /> } ?> onclick="enable_change(false)" />
<strong><?=gettext("Allow IPv6"); ?></strong><br /> <strong><?=gettext("Allow IPv6"); ?></strong><br />
...@@ -199,7 +191,7 @@ include("head.inc"); ...@@ -199,7 +191,7 @@ include("head.inc");
<tr> <tr>
<td width="22%" valign="top" class="vncell"><?=gettext("IPv6 over IPv4 Tunneling"); ?></td> <td width="22%" valign="top" class="vncell"><?=gettext("IPv6 over IPv4 Tunneling"); ?></td>
<td width="78%" class="vtable"> <td width="78%" class="vtable">
<input name="ipv6nat_enable" type="checkbox" id="ipv6nat_enable" value="yes" <?php if ($pconfig['ipv6nat_enable']) { <input name="ipv6nat_enable" type="checkbox" id="ipv6nat_enable" value="yes" <?php if (isset($config['diag']['ipv6nat']['enable'])) {
echo "checked=\"checked\""; echo "checked=\"checked\"";
} ?> onclick="enable_change(false)" /> } ?> onclick="enable_change(false)" />
<strong><?=gettext("Enable IPv4 NAT encapsulation of IPv6 packets"); ?></strong><br /> <strong><?=gettext("Enable IPv4 NAT encapsulation of IPv6 packets"); ?></strong><br />
...@@ -209,13 +201,13 @@ include("head.inc"); ...@@ -209,13 +201,13 @@ include("head.inc");
"add a firewall rule to permit IPv6 packets."); ?><br /> "add a firewall rule to permit IPv6 packets."); ?><br />
<br /> <br />
<?=gettext("IP address"); ?>&nbsp;:&nbsp; <?=gettext("IP address"); ?>&nbsp;:&nbsp;
<input name="ipv6nat_ipaddr" type="text" class="formfld unknown" id="ipv6nat_ipaddr" size="20" value="<?=htmlspecialchars($pconfig['ipv6nat_ipaddr']);?>" /> <input name="ipv6nat_ipaddr" type="text" class="formfld unknown" id="ipv6nat_ipaddr" size="20" value="<?=htmlspecialchars(isset($config['diag']['ipv6nat']['ipaddr']) ? $config['diag']['ipv6nat']['ipaddr']:"");?>" />
</td> </td>
</tr> </tr>
<tr> <tr>
<td width="22%" valign="top" class="vncell"><?=gettext("Prefer IPv4 over IPv6"); ?></td> <td width="22%" valign="top" class="vncell"><?=gettext("Prefer IPv4 over IPv6"); ?></td>
<td width="78%" class="vtable"> <td width="78%" class="vtable">
<input name="prefer_ipv4" type="checkbox" id="prefer_ipv4" value="yes" <?php if ($pconfig['prefer_ipv4']) { <input name="prefer_ipv4" type="checkbox" id="prefer_ipv4" value="yes" <?php if (isset($config['system']['prefer_ipv4'])) {
echo "checked=\"checked\""; echo "checked=\"checked\"";
} ?> /> } ?> />
<strong><?=gettext("Prefer to use IPv4 even if IPv6 is available"); ?></strong><br /> <strong><?=gettext("Prefer to use IPv4 even if IPv6 is available"); ?></strong><br />
...@@ -230,7 +222,7 @@ include("head.inc"); ...@@ -230,7 +222,7 @@ include("head.inc");
<tr> <tr>
<td width="22%" valign="top" class="vncell"><?=gettext("Device polling"); ?></td> <td width="22%" valign="top" class="vncell"><?=gettext("Device polling"); ?></td>
<td width="78%" class="vtable"> <td width="78%" class="vtable">
<input name="polling_enable" type="checkbox" id="polling_enable" value="yes" <?php if ($pconfig['polling_enable']) { <input name="polling_enable" type="checkbox" id="polling_enable" value="yes" <?php if (isset($config['system']['polling'])) {
echo "checked=\"checked\""; echo "checked=\"checked\"";
} ?> /> } ?> />
<strong><?=gettext("Enable device polling"); ?></strong><br /> <strong><?=gettext("Enable device polling"); ?></strong><br />
...@@ -276,10 +268,23 @@ include("head.inc"); ...@@ -276,10 +268,23 @@ include("head.inc");
<?=gettext("This will take effect after you reboot the machine or re-configure each interface.");?> <?=gettext("This will take effect after you reboot the machine or re-configure each interface.");?>
</td> </td>
</tr> </tr>
<tr>
<td width="22%" valign="top" class="vncell"><?=gettext("VLAN Hardware Filtering"); ?></td>
<td width="78%" class="vtable">
<input name="disablevlanhwfilter" type="checkbox" id="disablevlanhwfilter" value="yes" <?php if (isset($config['system']['disablevlanhwfilter'])) {
echo "checked=\"checked\"";
} ?> />
<strong><?=gettext("Disable VLAN Hardware Filtering"); ?></strong><br />
<?=gettext("Checking this option will disable VLAN hardware filtering. This offloading is broken in some hardware drivers, and may impact performance with some specific NICs."); ?>
<br />
<span class="red"><strong><?=gettext("Note:");?>&nbsp;</strong></span>
<?=gettext("This will take effect after you reboot the machine or re-configure each interface.");?>
</td>
</tr>
<tr> <tr>
<td width="22%" valign="top" class="vncell"><?=gettext("ARP Handling"); ?></td> <td width="22%" valign="top" class="vncell"><?=gettext("ARP Handling"); ?></td>
<td width="78%" class="vtable"> <td width="78%" class="vtable">
<input name="sharednet" type="checkbox" id="sharednet" value="yes" <?php if (isset($pconfig['sharednet'])) { <input name="sharednet" type="checkbox" id="sharednet" value="yes" <?php if (isset($config['system']['sharednet'])) {
echo "checked=\"checked\""; echo "checked=\"checked\"";
} ?> /> } ?> />
<strong><?=gettext("Suppress ARP messages"); ?></strong><br /> <strong><?=gettext("Suppress ARP messages"); ?></strong><br />
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment