diff options
author | Nick Mathewson <nickm@torproject.org> | 2006-07-23 05:32:35 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2006-07-23 05:32:35 +0000 |
commit | 35960e11620d70c3ea48cac1d17cca9f02eabfbe (patch) | |
tree | 99919c66f38a3316d5633587d6faca7181208664 /src/common | |
parent | 1c266c33525f817cd6a1a55be1e83b0cd6eedae6 (diff) | |
download | tor-35960e11620d70c3ea48cac1d17cca9f02eabfbe.tar.gz tor-35960e11620d70c3ea48cac1d17cca9f02eabfbe.zip |
Add a mem_is_zero function (I think we will need this) and a STRUCT_OFFSET macro (we already need this).
svn:r6810
Diffstat (limited to 'src/common')
-rw-r--r-- | src/common/util.c | 23 | ||||
-rw-r--r-- | src/common/util.h | 5 |
2 files changed, 25 insertions, 3 deletions
diff --git a/src/common/util.c b/src/common/util.c index e80a15c649..39efee9cd2 100644 --- a/src/common/util.c +++ b/src/common/util.c @@ -428,13 +428,30 @@ find_whitespace(const char *s) return s; } +/** Return true iff the 'len' bytes at 'mem' are all zero. */ +int tor_mem_is_zero(const char *mem, size_t len) +{ + static const char ZERO[] = { + 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, + }; + while (len >= sizeof(ZERO)) { + if (memcmp(mem, ZERO, sizeof(ZERO))) + return 0; + len -= sizeof(ZERO); + mem += sizeof(ZERO); + } + /* Deal with leftover bytes. */ + if (len) + return ! memcmp(mem, ZERO, len); + + return 1; +} + /** Return true iff the DIGEST_LEN bytes in digest are all zero. */ int tor_digest_is_zero(const char *digest) { - static char ZERO_DIGEST[] = { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }; - - return !memcmp(digest, ZERO_DIGEST, DIGEST_LEN); + return tor_mem_is_zero(digest, DIGEST_LEN); } #define CHECK_STRTOX_RESULT() \ diff --git a/src/common/util.h b/src/common/util.h index b61b399dec..bc21d2051f 100644 --- a/src/common/util.h +++ b/src/common/util.h @@ -88,6 +88,10 @@ extern int dmalloc_free(const char *file, const int line, void *pnt, #define tor_strndup(s, n) _tor_strndup(s, n DMALLOC_ARGS) #define tor_memdup(s, n) _tor_memdup(s, n DMALLOC_ARGS) +/** Return the offset of <b>member</b> within the type <b>tp</b>, in bytes */ +#define STRUCT_OFFSET(tp, member) \ + ((off_t) (((char*)&((tp*)0)->member)-(char*)0)) + /* String manipulation */ #define HEX_CHARACTERS "0123456789ABCDEFabcdef" void tor_strlower(char *s); @@ -114,6 +118,7 @@ const char *hex_str(const char *from, size_t fromlen); const char *eat_whitespace(const char *s); const char *eat_whitespace_no_nl(const char *s); const char *find_whitespace(const char *s); +int tor_mem_is_zero(const char *mem, size_t len); int tor_digest_is_zero(const char *digest); char *esc_for_log(const char *string); const char *escaped(const char *string); |