summaryrefslogtreecommitdiffstats
path: root/etc/inc
diff options
context:
space:
mode:
authorScott Ullrich <sullrich@pfsense.org>2006-02-26 00:27:08 +0000
committerScott Ullrich <sullrich@pfsense.org>2006-02-26 00:27:08 +0000
commite295675f8ff89e9555722b8825282972e1a72e74 (patch)
tree5539708daa59fa566c1c6ad2fbc0d767abc0b496 /etc/inc
parent59f6fb8ed81682fa614bd5c33154b3a854a34bec (diff)
downloadpfsense-e295675f8ff89e9555722b8825282972e1a72e74.zip
pfsense-e295675f8ff89e9555722b8825282972e1a72e74.tar.gz
MFC
Shaper fixes from BillM
Diffstat (limited to 'etc/inc')
-rw-r--r--etc/inc/config.inc10
-rw-r--r--etc/inc/globals.inc2
-rw-r--r--etc/inc/shaper.inc43
3 files changed, 41 insertions, 14 deletions
diff --git a/etc/inc/config.inc b/etc/inc/config.inc
index f7b750b..a77e30a 100644
--- a/etc/inc/config.inc
+++ b/etc/inc/config.inc
@@ -744,6 +744,14 @@ function convert_config() {
$config['interfaces']['wan']['gateway'] = $config['system']['gateway'];
$config['version'] = "2.2";
}
+ /* Convert 2.2 -> 2.3 */
+ if ($config['version'] == "2.2") {
+ if(isset($config['shaper'])) {
+ /* wipe previous shaper configuration */
+ unset($config['shaper']);
+ }
+ $config['version'] = "2.3";
+ }
if ($prev_version != $config['version'])
write_config("Upgraded config version level from {$prev_version} to {$config['version']}");
@@ -1434,4 +1442,4 @@ function start_devd() {
exec("/sbin/devd");
}
-?> \ No newline at end of file
+?>
diff --git a/etc/inc/globals.inc b/etc/inc/globals.inc
index eb597ee..7e03f42 100644
--- a/etc/inc/globals.inc
+++ b/etc/inc/globals.inc
@@ -52,7 +52,7 @@ $g = array(
"n_pppoe_units" => 16, /* this value can be overriden in pppoe->n_pppoe_units */
"pppoe_subnet" => 28, /* this value can be overriden in pppoe->pppoe_subnet */
"debug" => false,
- "latest_config" => "2.2",
+ "latest_config" => "2.3",
"nopkg_platforms" => array("cdrom"),
"nopccard_platforms" => array("wrap", "net48xx"),
"xmlrpcbaseurl" => "www.pfsense.com",
diff --git a/etc/inc/shaper.inc b/etc/inc/shaper.inc
index 6dd40e6..f043aac 100644
--- a/etc/inc/shaper.inc
+++ b/etc/inc/shaper.inc
@@ -113,13 +113,22 @@ function filter_generate_altq_queues($altq_ints) {
if(isset($rule['defaultqueue']) and $rule['defaultqueue'] <> "")
$options .= " default";
if(isset($rule['upperlimit']) and $rule['upperlimit'] <> "") {
- $options .= " upperlimit({$rule['upperlimit1']} {$rule['upperlimit2']} {$rule['upperlimit3']})";
+ if ($rule['upperlimit1'] <> "")
+ $options .= " upperlimit({$rule['upperlimit1']} {$rule['upperlimit2']} {$rule['upperlimit3']})";
+ else
+ $options .= " upperlimit {$rule['upperlimit3']}";
}
if(isset($rule['linkshare']) and $rule['linkshare'] <> "") {
- $options .= " linkshare({$rule['linkshare1']} {$rule['linkshare2']} {$rule['linkshare3']})";
+ if ($rule['linkshare1'] <> "")
+ $options .= " linkshare({$rule['linkshare1']} {$rule['linkshare2']} {$rule['linkshare3']})";
+ else
+ $options .= " linkshare {$rule['linkshare3']}";
}
if(isset($rule['realtime']) and $rule['realtime'] <> "") {
- $options .= " realtime({$rule['realtime1']} {$rule['realtime2']} {$rule['realtime3']})";
+ if ($rule['realtime1'] <> "")
+ $options .= " realtime({$rule['realtime1']} {$rule['realtime2']} {$rule['realtime3']})";
+ else
+ $options .= " realtime {$rule['realtime3']}";
}
$scheduler_type = $config['shaper']['schedulertype'];
$altq_rules .= "{$scheduler_type} ";
@@ -176,7 +185,7 @@ function filter_is_queue_being_used_on_interface($queuename, $interface) {
if(!is_array($lconfig['shaper']['rule'])) return null;
foreach($lconfig['shaper']['rule'] as $rule) {
- if(($rule['inqueue'] == $queuename && $rule['interface'] == $interface))
+ if(($rule['inqueue'] == $queuename && $rule['in-interface'] == $interface))
return $interface;
}
return null;
@@ -267,7 +276,7 @@ function queue_interface_recursive($queuename) {
}
foreach($config['shaper']['rule'] as $rule) {
if($rule['inqueue'] == $queuename)
- return $rule['interface'];
+ return $rule['in-interface'];
}
}
@@ -341,7 +350,7 @@ function filter_generate_pf_altq_rules() {
continue;
}
- switch($rule['interface']) {
+ switch($rule['in-interface']) {
case "pptp": /* does the rule deal with a PPTP interface? */
if ($pptpdcfg['mode'] != "server") {
if (($rule['source']['network'] == "pptp") ||
@@ -374,8 +383,8 @@ function filter_generate_pf_altq_rules() {
$ispppoe = true;
break;
default:
- if (strstr($rule['interface'], "opt")) {
- if (!array_key_exists($rule['interface'], $optcfg)) {
+ if (strstr($rule['in-interface'], "opt")) {
+ if (!array_key_exists($rule['in-interface'], $optcfg)) {
$i++;
continue;
}
@@ -419,17 +428,17 @@ function filter_generate_pf_altq_rules() {
if($ispppoe) {
$line .= " ng" . ($iif+1);
} else {
- $if = $config['interfaces'][$rule['interface']]['if'];
+ $if = $config['interfaces'][$rule['in-interface']]['if'];
}
- if ($rule['interface'] == "wan") {
+ if ($rule['in-interface'] == "wan") {
if($direction=="in") {
$if = $wanif;
} else {
$if = $lanif;
}
} else {
- if($rule['interface'] == "lan") {
+ if($rule['in-interface'] == "lan") {
if($direction=="in") {
$if = $lanif;
} else {
@@ -587,6 +596,16 @@ function filter_generate_pf_altq_rules() {
$line .= "\n";
$shaperrules .= $line;
+ /* setup the outbound queue on the other interface */
+ switch($direction) {
+ case 'in':
+ $qouttag = "outqueue";
+ break;
+ case 'out':
+ $qouttag = "inqueue";
+ break;
+ }
+ $shaperrules .= "pass out on {$rule['out-interface']} all keep state tagged {$rule[$qtag]} tag {$rule[$qouttag]}";
}
}
@@ -596,4 +615,4 @@ function filter_generate_pf_altq_rules() {
return $shaperrules;
}
-?> \ No newline at end of file
+?>
OpenPOWER on IntegriCloud