summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Hartmeier <dhartmei@cvs.openbsd.org>2003-04-25 17:41:26 +0000
committerDaniel Hartmeier <dhartmei@cvs.openbsd.org>2003-04-25 17:41:26 +0000
commit02a4a9ac023afd32f27aafb2d4e6e6b9f3664fb8 (patch)
tree5fdc41e5c0220d4c968d158f0287340f1c3a9d08
parente078e59bedd770f9a3abc3b710fc764b68254d73 (diff)
Fix nat proxy port allocation. In case a range was manually specified,
ports outside that range could be used with a probability inversely proportional to the size of the specified range (occured often with very small, rarely with larger ranges). Reported by Gopakumar Pillai, ok henning@
-rw-r--r--sys/net/pf.c33
1 files changed, 14 insertions, 19 deletions
diff --git a/sys/net/pf.c b/sys/net/pf.c
index a735b475f4f..a21a7383277 100644
--- a/sys/net/pf.c
+++ b/sys/net/pf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pf.c,v 1.337 2003/04/11 14:40:57 henning Exp $ */
+/* $OpenBSD: pf.c,v 1.338 2003/04/25 17:41:25 dhartmei Exp $ */
/*
* Copyright (c) 2001 Daniel Hartmeier
@@ -1550,7 +1550,6 @@ pf_get_sport(sa_family_t af, u_int8_t proto, struct pf_pool *rpool,
{
struct pf_tree_node key;
struct pf_addr init_addr;
- int step;
u_int16_t cut;
bzero(&init_addr, sizeof(init_addr));
@@ -1589,30 +1588,26 @@ pf_get_sport(sa_family_t af, u_int8_t proto, struct pf_pool *rpool,
return (0);
}
} else {
- if (low < high) {
- step = 1;
- cut = arc4random() % (1 + high - low) + low;
- } else {
- step = -1;
- cut = arc4random() % (1 + low - high) + high;
- }
+ if (low > high) {
+ u_int16_t tmp;
- *nport = cut - step;
- do {
- *nport += step;
+ tmp = low;
+ low = high;
+ high = tmp;
+ }
+ /* low < high */
+ cut = arc4random() % (1 + high - low) + low;
+ /* low <= cut <= high */
+ for (*nport = cut; *nport <= high; ++(*nport)) {
key.port[1] = htons(*nport);
if (pf_find_state(&tree_ext_gwy, &key) == NULL)
return (0);
- } while (*nport != low && *nport != high);
-
- step = -step;
- *nport = cut;
- do {
- *nport += step;
+ }
+ for (*nport = cut - 1; *nport >= low; --(*nport)) {
key.port[1] = htons(*nport);
if (pf_find_state(&tree_ext_gwy, &key) == NULL)
return (0);
- } while (*nport != low && *nport != high);
+ }
}
switch (rpool->opts & PF_POOL_TYPEMASK) {