summaryrefslogtreecommitdiff
path: root/sbin/pfctl
diff options
context:
space:
mode:
authorHenning Brauer <henning@cvs.openbsd.org>2003-04-13 21:51:11 +0000
committerHenning Brauer <henning@cvs.openbsd.org>2003-04-13 21:51:11 +0000
commit68cb6142751da64bac56dce8d7b1fc0951f58000 (patch)
tree7c30b40ba22227d7c8c6ff730bf25d0b91a9bd83 /sbin/pfctl
parentddf3e868aca953bf1ded456f6deb7ac8a9f343d6 (diff)
say bye bye to hfscflags_list and hfscflags_item
welcome hfscopts_list and hfscopts_item, returning a full struct node_hfsc_opt instead of just an int for the flags. needed because of all the opts hfsc knows
Diffstat (limited to 'sbin/pfctl')
-rw-r--r--sbin/pfctl/parse.y27
1 files changed, 16 insertions, 11 deletions
diff --git a/sbin/pfctl/parse.y b/sbin/pfctl/parse.y
index 9619257e19d..d74e51bcc04 100644
--- a/sbin/pfctl/parse.y
+++ b/sbin/pfctl/parse.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: parse.y,v 1.360 2003/04/13 20:41:37 henning Exp $ */
+/* $OpenBSD: parse.y,v 1.361 2003/04/13 21:51:10 henning Exp $ */
/*
* Copyright (c) 2001 Markus Friedl. All rights reserved.
@@ -315,6 +315,7 @@ typedef struct {
struct queue_opts queue_opts;
struct scrub_opts scrub_opts;
struct table_opts table_opts;
+ struct node_hfsc_opts hfsc_opts;
} v;
int lineno;
} YYSTYPE;
@@ -380,7 +381,7 @@ typedef struct {
%type <v.queue_options> scheduler
%type <v.number> cbqflags_list cbqflags_item
%type <v.number> priqflags_list priqflags_item
-%type <v.number> hfscflags_list hfscflags_item
+%type <v.hfsc_opts> hfscopts_list hfscopts_item
%type <v.queue_bwspec> bandwidth
%type <v.filter_opts> filter_opts filter_opt filter_opts_l
%type <v.queue_opts> queue_opts queue_opt queue_opts_l
@@ -985,9 +986,10 @@ scheduler : CBQ {
bzero(&$$.data.hfsc_opts,
sizeof(struct node_hfsc_opts));
}
- | HFSC '(' hfscflags_list ')' {
+ | HFSC '(' hfscopts_list ')' {
$$.qtype = ALTQT_HFSC;
- $$.data.hfsc_opts.flags = $3;
+ memcpy(&$$.data.hfsc_opts, &$3,
+ sizeof(struct node_hfsc_opts));
}
;
@@ -1033,19 +1035,22 @@ priqflags_item : STRING {
}
;
-hfscflags_list : hfscflags_item { $$ |= $1; }
- | hfscflags_list comma hfscflags_item { $$ |= $3; }
+hfscopts_list : hfscopts_item {
+ $$.flags |= $1.flags;
+ }
+ | hfscopts_list comma hfscopts_item {
+ $$.flags |= $3.flags;
;
-hfscflags_item : STRING {
+hfscopts_item : STRING {
if (!strcmp($1, "default"))
- $$ = HFCF_DEFAULTCLASS;
+ $$.flags = HFCF_DEFAULTCLASS;
else if (!strcmp($1, "red"))
- $$ = HFCF_RED;
+ $$.flags = HFCF_RED;
else if (!strcmp($1, "ecn"))
- $$ = HFCF_RED|HFCF_ECN;
+ $$.flags = HFCF_RED|HFCF_ECN;
else if (!strcmp($1, "rio"))
- $$ = HFCF_RIO;
+ $$.flags = HFCF_RIO;
else {
yyerror("unknown hfsc flag \"%s\"", $1);
YYERROR;