Blame SOURCES/rsyslog-8.24.0-rhbz1512551-caching-sockaddr.patch

f656cf
From 5f828658a317c86095fc2b982801b58bf8b8ee6f Mon Sep 17 00:00:00 2001
f656cf
From: mosvald <mosvald@redhat.com>
f656cf
Date: Mon, 4 Dec 2017 08:10:37 +0100
f656cf
Subject: [PATCH] cache sin_addr instead of the whole sockaddr structure
f656cf
f656cf
---
f656cf
 runtime/dnscache.c | 41 +++++++++++++++++++++++++++++++----------
f656cf
 1 file changed, 31 insertions(+), 10 deletions(-)
f656cf
f656cf
diff --git a/runtime/dnscache.c b/runtime/dnscache.c
f656cf
index 388a64f5e..d1d6e10a1 100644
f656cf
--- a/runtime/dnscache.c
f656cf
+++ b/runtime/dnscache.c
f656cf
@@ -79,22 +79,43 @@ static prop_t *staticErrValue;
f656cf
 static unsigned int
f656cf
 hash_from_key_fn(void *k) 
f656cf
 {
f656cf
-    int len;
f656cf
-    uchar *rkey = (uchar*) k; /* we treat this as opaque bytes */
f656cf
-    unsigned hashval = 1;
f656cf
-
f656cf
-    len = SALEN((struct sockaddr*)k);
f656cf
-    while(len--)
f656cf
-        hashval = hashval * 33 + *rkey++;
f656cf
+	int len = 0;
f656cf
+	uchar *rkey; /* we treat this as opaque bytes */
f656cf
+	unsigned hashval = 1;
f656cf
+
f656cf
+	switch (((struct sockaddr *)k)->sa_family) {
f656cf
+		case AF_INET:
f656cf
+			len = sizeof (struct in_addr);
f656cf
+			rkey = (uchar*) &(((struct sockaddr_in *)k)->sin_addr);
f656cf
+			break;
f656cf
+		case AF_INET6:
f656cf
+			len = sizeof (struct in6_addr);
f656cf
+			rkey = (uchar*) &(((struct sockaddr_in6 *)k)->sin6_addr);
f656cf
+			break;
f656cf
+	}
f656cf
+	while(len--)
f656cf
+		hashval = hashval * 33 + *rkey++;
f656cf
 
f656cf
-    return hashval;
f656cf
+	return hashval;
f656cf
 }
f656cf
 
f656cf
 static int
f656cf
 key_equals_fn(void *key1, void *key2)
f656cf
 {
f656cf
-	return (SALEN((struct sockaddr*)key1) == SALEN((struct sockaddr*) key2) 
f656cf
-		   && !memcmp(key1, key2, SALEN((struct sockaddr*) key1)));
f656cf
+	int RetVal = 0;
f656cf
+
f656cf
+	if (((struct sockaddr *)key1)->sa_family != ((struct sockaddr *)key2)->sa_family)
f656cf
+		return 0;
f656cf
+	 switch (((struct sockaddr *)key1)->sa_family) {
f656cf
+		case AF_INET:
f656cf
+			RetVal = !memcmp(&((struct sockaddr_in *)key1)->sin_addr, &((struct sockaddr_in *)key2)->sin_addr, sizeof (struct in_addr));
f656cf
+			break;
f656cf
+		case AF_INET6:
f656cf
+			RetVal = !memcmp(&((struct sockaddr_in6 *)key1)->sin6_addr, &((struct sockaddr_in6 *)key2)->sin6_addr, sizeof (struct in6_addr));
f656cf
+			break;
f656cf
+	}
f656cf
+
f656cf
+	return RetVal;
f656cf
 }
f656cf
 
f656cf
 /* destruct a cache entry.
f656cf
-- 
f656cf
2.14.3
f656cf