[Freeswitch-svn] [commit] r13920 - in freeswitch/trunk/libs/sofia-sip: . libsofia-sip-ua/sresolv
FreeSWITCH SVN
mikej at freeswitch.org
Tue Jun 23 12:47:59 PDT 2009
Author: mikej
Date: Tue Jun 23 14:47:59 2009
New Revision: 13920
Log:
Tue Jun 23 08:38:48 CDT 2009 Mikhail Zabaluev <mikhail.zabaluev at nokia.com>
* sresolv/sres.c: Refactored the query ID generation
Modified:
freeswitch/trunk/libs/sofia-sip/.update
freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/sresolv/sres.c
Modified: freeswitch/trunk/libs/sofia-sip/.update
==============================================================================
--- freeswitch/trunk/libs/sofia-sip/.update (original)
+++ freeswitch/trunk/libs/sofia-sip/.update Tue Jun 23 14:47:59 2009
@@ -1 +1 @@
-Tue Jun 23 14:46:33 CDT 2009
+Tue Jun 23 14:47:05 CDT 2009
Modified: freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/sresolv/sres.c
==============================================================================
--- freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/sresolv/sres.c (original)
+++ freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/sresolv/sres.c Tue Jun 23 14:47:59 2009
@@ -74,6 +74,12 @@
#include <iphlpapi.h>
#endif
+#if HAVE_IP_RECVERR || HAVE_IPV6_RECVERR
+#include <linux/types.h>
+#include <linux/errqueue.h>
+#include <sys/uio.h>
+#endif
+
#include <time.h>
#include "sofia-resolv/sres.h"
@@ -184,6 +190,13 @@
#define va_copy(dst, src) (memcpy(&(dst), &(src), sizeof (va_list)))
#endif
+/*
+ * 3571 is a prime =>
+ * we hash successive id values to different parts of hash tables
+ */
+#define Q_PRIME 3571
+#define SRES_QUERY_HASH(q) ((q)->q_hash)
+
/**
* How often to recheck nameserver information (seconds).
*/
@@ -393,10 +406,14 @@
sres_config_t const *c);
/** Generate new 16-bit identifier for DNS query. */
-static uint16_t
-sres_new_id(sres_resolver_t *res)
+static void
+sres_gen_id(sres_resolver_t *res, sres_query_t *query)
{
- return res->res_id ? res->res_id++ : (res->res_id = 2, 1);
+ if (res->res_id == 0) {
+ res->res_id = 1;
+ }
+ query->q_id = res->res_id++;
+ query->q_hash = query->q_id * Q_PRIME;
}
/** Return true if we have a search list or a local domain name. */
@@ -1688,13 +1705,6 @@
res->res_updcb(res->res_async, INVALID_SOCKET, INVALID_SOCKET);
}
-/*
- * 3571 is a prime =>
- * we hash successive id values to different parts of hash tables
- */
-#define Q_PRIME 3571
-#define SRES_QUERY_HASH(q) ((q)->q_hash)
-
HTABLE_BODIES_WITH(sres_qtable, qt, sres_query_t, SRES_QUERY_HASH,
unsigned, size_t);
@@ -1726,10 +1736,11 @@
query->q_timestamp = res->res_now;
query->q_name = strcpy((char *)(query + 1), domain);
- query->q_id = sres_new_id(res); assert(query->q_id);
+ sres_gen_id(res, query);
+ assert(query->q_id);
+
query->q_i_server = res->res_i_server;
query->q_n_servers = res->res_n_servers;
- query->q_hash = query->q_id * Q_PRIME /* + query->q_i_server */;
sres_qtable_append(res->res_queries, query);
@@ -3138,12 +3149,6 @@
}
}
-#if HAVE_IP_RECVERR || HAVE_IPV6_RECVERR
-#include <linux/types.h>
-#include <linux/errqueue.h>
-#include <sys/uio.h>
-#endif
-
static
int sres_no_update(sres_async_t *async,
sres_socket_t new_socket,
@@ -3462,8 +3467,7 @@
dns->dns_edns = edns_not_supported;
assert(query->q_id);
sres_remove_query(res, query, 0);
- query->q_id = sres_new_id(res);
- query->q_hash = query->q_id * Q_PRIME;
+ sres_gen_id(res, query);
sres_qtable_append(res->res_queries, query);
sres_send_dns_query(res, query);
query->q_retry_count++;
More information about the Freeswitch-svn
mailing list