diff options
author | Nick Mathewson <nickm@torproject.org> | 2006-09-19 22:20:09 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2006-09-19 22:20:09 +0000 |
commit | 7b0ec744bc8afa691873f97cfb6a3b7822376d7b (patch) | |
tree | 36879b2af44a9c2aabc7906816493d2a6993c692 /src | |
parent | e9abe750ea68099e73064a84dab1e17bbb606c03 (diff) | |
download | tor-7b0ec744bc8afa691873f97cfb6a3b7822376d7b.tar.gz tor-7b0ec744bc8afa691873f97cfb6a3b7822376d7b.zip |
Switch routerlist.c to using memcmp on digests rather than crypto_pk_cmp_keys(); speed up find_whitespace a lot (8x for me) by using a switch statement. This should speed parsing a lot of routers at once by a lot.
svn:r8430
Diffstat (limited to 'src')
-rw-r--r-- | src/common/util.c | 19 | ||||
-rw-r--r-- | src/or/routerlist.c | 3 |
2 files changed, 16 insertions, 6 deletions
diff --git a/src/common/util.c b/src/common/util.c index 8bd1f2aec0..264bd0b74f 100644 --- a/src/common/util.c +++ b/src/common/util.c @@ -434,11 +434,20 @@ const char * find_whitespace(const char *s) { /* tor_assert(s); */ - - while (*s && !TOR_ISSPACE(*s) && *s != '#') - s++; - - return s; + while (1) { + switch (*s) + { + case '\0': + case '#': + case ' ': + case '\r': + case '\n': + case '\t': + return s; + default: + ++s; + } + } } /** Return true iff the 'len' bytes at 'mem' are all zero. */ diff --git a/src/or/routerlist.c b/src/or/routerlist.c index 4bc26b13a1..1d067667b9 100644 --- a/src/or/routerlist.c +++ b/src/or/routerlist.c @@ -1674,7 +1674,8 @@ router_add_to_routerlist(routerinfo_t *router, const char **msg, routerinfo_t *old_router = smartlist_get(routerlist->routers, i); /* XXXX This might be a slow point; can't we just look up in one of the * digestmaps? -NM */ - if (!crypto_pk_cmp_keys(router->identity_pkey,old_router->identity_pkey)) { + if (!memcmp(router->cache_info.identity_digest, + old_router->cache_info.identity_digest, DIGEST_LEN)) { if (router->cache_info.published_on <= old_router->cache_info.published_on) { /* Same key, but old */ |