2011-12-08 08:04:38 -05:00
|
|
|
$OpenBSD: patch-cache_c,v 1.2 2011/12/08 13:04:38 sthen Exp $
|
|
|
|
--- cache.c.orig Wed Nov 7 06:34:18 2007
|
|
|
|
+++ cache.c Thu Dec 8 13:02:56 2011
|
2008-06-12 20:38:12 -04:00
|
|
|
@@ -118,12 +118,17 @@ add_state(pf_state_t *st)
|
|
|
|
|
|
|
|
cache_size--;
|
|
|
|
|
|
|
|
+#ifdef HAVE_PFSYNC_STATE
|
2011-12-08 08:04:38 -05:00
|
|
|
+ ent->id = st->id;
|
|
|
|
+ ent->creatorid = st->creatorid;
|
2008-06-12 20:38:12 -04:00
|
|
|
+#else
|
|
|
|
ent->addr[0] = st->lan.addr;
|
|
|
|
ent->port[0] = st->lan.port;
|
|
|
|
ent->addr[1] = st->ext.addr;
|
|
|
|
ent->port[1] = st->ext.port;
|
|
|
|
ent->af = st->af;
|
|
|
|
ent->proto = st->proto;
|
|
|
|
+#endif
|
|
|
|
#ifdef HAVE_INOUT_COUNT
|
|
|
|
ent->bytes = COUNTER(st->bytes[0]) + COUNTER(st->bytes[1]);
|
|
|
|
#else
|
|
|
|
@@ -147,13 +152,17 @@ cache_state(pf_state_t *st)
|
|
|
|
if (cache_max == 0)
|
|
|
|
return (NULL);
|
|
|
|
|
|
|
|
+#ifdef HAVE_PFSYNC_STATE
|
2011-12-08 08:04:38 -05:00
|
|
|
+ ent.id = st->id;
|
|
|
|
+ ent.creatorid = st->creatorid;
|
2008-06-12 20:38:12 -04:00
|
|
|
+#else
|
|
|
|
ent.addr[0] = st->lan.addr;
|
|
|
|
ent.port[0] = st->lan.port;
|
|
|
|
ent.addr[1] = st->ext.addr;
|
|
|
|
ent.port[1] = st->ext.port;
|
|
|
|
ent.af = st->af;
|
|
|
|
ent.proto = st->proto;
|
|
|
|
-
|
|
|
|
+#endif
|
|
|
|
old = RB_FIND(sc_tree, &sctree, &ent);
|
|
|
|
|
|
|
|
if (old == NULL) {
|
|
|
|
@@ -210,8 +219,18 @@ cache_endupdate(void)
|
|
|
|
static __inline int
|
|
|
|
sc_cmp(struct sc_ent *a, struct sc_ent *b)
|
|
|
|
{
|
|
|
|
+#ifdef HAVE_PFSYNC_STATE
|
2011-12-08 08:04:38 -05:00
|
|
|
+ if (a->id > b->id)
|
2008-06-12 20:38:12 -04:00
|
|
|
+ return (1);
|
2011-12-08 08:04:38 -05:00
|
|
|
+ if (a->id < b->id)
|
2008-06-12 20:38:12 -04:00
|
|
|
+ return (-1);
|
2011-12-08 08:04:38 -05:00
|
|
|
+ if (a->creatorid > b->creatorid)
|
2008-06-12 20:38:12 -04:00
|
|
|
+ return (1);
|
2011-12-08 08:04:38 -05:00
|
|
|
+ if (a->creatorid < b->creatorid)
|
2008-06-12 20:38:12 -04:00
|
|
|
+ return (-1);
|
|
|
|
+#else
|
|
|
|
int diff;
|
|
|
|
-
|
|
|
|
+
|
|
|
|
if ((diff = a->proto - b->proto) != 0)
|
|
|
|
return (diff);
|
|
|
|
if ((diff = a->af - b->af) != 0)
|
|
|
|
@@ -269,6 +288,6 @@ sc_cmp(struct sc_ent *a, struct sc_ent *b)
|
|
|
|
return (diff);
|
|
|
|
if ((diff = a->port[1] - b->port[1]) != 0)
|
|
|
|
return (diff);
|
|
|
|
-
|
|
|
|
+#endif
|
|
|
|
return (0);
|
|
|
|
}
|