diff options
author | Henning Brauer <henning@cvs.openbsd.org> | 2003-03-10 14:48:39 +0000 |
---|---|---|
committer | Henning Brauer <henning@cvs.openbsd.org> | 2003-03-10 14:48:39 +0000 |
commit | 306c561d3259fb60173a34e4717cb03d1e7a86d5 (patch) | |
tree | 78eeaa5691c07d4bca72864d180a703729a086a9 | |
parent | 450ca21c568c3bc80fc580709a8b9cab8142c6ad (diff) |
rework error handling in eval_pfqueue().
instead of using errx, print the error message and return. This is
consistent with what we do everywhere in pfctl.
ok dhartmei@ pb@ (as part of a monsterdiff)
-rw-r--r-- | sbin/pfctl/pfctl_altq.c | 37 |
1 files changed, 23 insertions, 14 deletions
diff --git a/sbin/pfctl/pfctl_altq.c b/sbin/pfctl/pfctl_altq.c index 19049ee642d..f36d2a6561c 100644 --- a/sbin/pfctl/pfctl_altq.c +++ b/sbin/pfctl/pfctl_altq.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pfctl_altq.c,v 1.43 2003/03/08 14:40:03 henning Exp $ */ +/* $OpenBSD: pfctl_altq.c,v 1.44 2003/03/10 14:48:38 henning Exp $ */ /* * Copyright (C) 2002 @@ -317,9 +317,10 @@ eval_pfqueue(struct pfctl *pf, struct pf_altq *pa, u_int32_t bw_absolute, int error = 0; /* find the corresponding interface and copy fields used by queues */ - if_pa = pfaltq_lookup(pa->ifname); - if (if_pa == NULL) - errx(1, "altq not defined on %s", pa->ifname); + if ((if_pa = pfaltq_lookup(pa->ifname)) == NULL) { + fprintf(stderr, "altq not defined on %s\n", pa->ifname); + return (1); + } pa->scheduler = if_pa->scheduler; pa->ifbandwidth = if_pa->ifbandwidth; pa->qid = qname_to_qid(pa->qname); @@ -327,9 +328,11 @@ eval_pfqueue(struct pfctl *pf, struct pf_altq *pa, u_int32_t bw_absolute, parent = NULL; if (pa->parent[0] != 0) { parent = qname_to_pfaltq(pa->parent, pa->ifname); - if (parent == NULL) - errx(1, "parent %s not found for %s", + if (parent == NULL) { + fprintf(stderr, "parent %s not found for %s\n", pa->parent, pa->qname); + return (1); + } pa->parent_qid = parent->qid; } if (pa->qlimit == 0) @@ -340,16 +343,22 @@ eval_pfqueue(struct pfctl *pf, struct pf_altq *pa, u_int32_t bw_absolute, pa->bandwidth = bw_absolute; else if (bw_percent > 0 && parent != NULL) pa->bandwidth = parent->bandwidth / 100 * bw_percent; - else - errx(1, "bandwidth for %s invalid (%d / %d)", pa->qname, - bw_absolute, bw_percent); + else { + fprintf(stderr, "bandwidth for %s invalid (%d / %d)\n", + pa->qname, bw_absolute, bw_percent); + return (1); + } - if (pa->bandwidth > pa->ifbandwidth) - errx(1, "bandwidth for %s higher than interface", - pa->qname); - if (parent != NULL && pa->bandwidth > parent->bandwidth) - errx(1, "bandwidth for %s higher than parent", + if (pa->bandwidth > pa->ifbandwidth) { + fprintf(stderr, "bandwidth for %s higher than " + "interface\n", pa->qname); + return (1); + } + if (parent != NULL && pa->bandwidth > parent->bandwidth) { + fprintf(stderr, "bandwidth for %s higher than parent\n", pa->qname); + return (1); + } } switch (pa->scheduler) { |