summaryrefslogtreecommitdiff
path: root/src/common/address.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2010-02-09 12:32:10 -0500
committerNick Mathewson <nickm@torproject.org>2010-02-09 12:32:10 -0500
commitc0d682686ad8df66b1f6680b1185853532f24429 (patch)
tree5f2bc651108569b0b1c034fd326ee958e62c4a39 /src/common/address.c
parent080e8f50f87fb7c0c099b1341173fa05c82a42e8 (diff)
downloadtor-c0d682686ad8df66b1f6680b1185853532f24429.tar.gz
tor-c0d682686ad8df66b1f6680b1185853532f24429.zip
Make tor_addr_copy() conform to memcpy requirements
The src and dest of a memcpy() call aren't supposed to overlap, but we were sometimes calling tor_addr_copy() as a no-op. Also, tor_addr_assign was a redundant copy of tor_addr_copy(); this patch removes it.
Diffstat (limited to 'src/common/address.c')
-rw-r--r--src/common/address.c9
1 files changed, 2 insertions, 7 deletions
diff --git a/src/common/address.c b/src/common/address.c
index 2fe013a2cd..7729f29147 100644
--- a/src/common/address.c
+++ b/src/common/address.c
@@ -760,6 +760,8 @@ tor_addr_from_in6(tor_addr_t *dest, const struct in6_addr *in6)
void
tor_addr_copy(tor_addr_t *dest, const tor_addr_t *src)
{
+ if (src == dest)
+ return;
tor_assert(src);
tor_assert(dest);
memcpy(dest, src, sizeof(tor_addr_t));
@@ -912,13 +914,6 @@ tor_dup_addr(const tor_addr_t *addr)
return tor_strdup(buf);
}
-/** Copy the address in <b>src</b> to <b>dest</b> */
-void
-tor_addr_assign(tor_addr_t *dest, const tor_addr_t *src)
-{
- memcpy(dest, src, sizeof(tor_addr_t));
-}
-
/** Return a string representing the address <b>addr</b>. This string is
* statically allocated, and must not be freed. Each call to
* <b>fmt_addr</b> invalidates the last result of the function. This