summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHenning Brauer <henning@cvs.openbsd.org>2002-11-07 17:47:34 +0000
committerHenning Brauer <henning@cvs.openbsd.org>2002-11-07 17:47:34 +0000
commit506b0703f01d3988bb192476b167947af1d35407 (patch)
treed177b5f0b8099c0f4f78e3d0a4132f71ab6ecc55
parent921ebf7436ec0e7de1b52b155b6769cc8ea581fb (diff)
move the ifa_exists block a bit up in host()
inspired by mpech@ pointing out a missing free(buf). so handle the it-is-an-interface case where we don't need the buf before allocating memory.
-rw-r--r--sbin/pfctl/parse.y18
1 files changed, 9 insertions, 9 deletions
diff --git a/sbin/pfctl/parse.y b/sbin/pfctl/parse.y
index 8c5075ada68..cca8648869a 100644
--- a/sbin/pfctl/parse.y
+++ b/sbin/pfctl/parse.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: parse.y,v 1.181 2002/11/04 22:46:28 henning Exp $ */
+/* $OpenBSD: parse.y,v 1.182 2002/11/07 17:47:33 henning Exp $ */
/*
* Copyright (c) 2001 Markus Friedl. All rights reserved.
@@ -2916,6 +2916,14 @@ host(char *s, int mask)
int bits, error, v4mask, v6mask;
char *buf;
+ if (ifa_exists(s) || !strncmp(s, "self", IFNAMSIZ)) {
+ /* interface with this name exists */
+ h = ifa_lookup(s, PFCTL_IFLOOKUP_HOST);
+ if (h != NULL && mask > -1)
+ set_ipmask(h, mask);
+ return (h);
+ }
+
if (mask == -1) {
if (asprintf(&buf, "%s", s) == -1)
err(1, "host: malloc");
@@ -2930,14 +2938,6 @@ host(char *s, int mask)
return (NULL);
}
- if (ifa_exists(s) || !strncmp(s, "self", IFNAMSIZ)) {
- /* interface with this name exists */
- h = ifa_lookup(s, PFCTL_IFLOOKUP_HOST);
- if (h != NULL && mask > -1)
- set_ipmask(h, mask);
- return (h);
- }
-
memset(&ina, 0, sizeof(struct in_addr));
if ((bits = inet_net_pton(AF_INET, buf, &ina, sizeof(&ina))) > -1) {
h = calloc(1, sizeof(struct node_host));