aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2013-03-18 15:29:32 -0400
committerNick Mathewson <nickm@torproject.org>2013-03-18 15:29:32 -0400
commita88f3e24eaf2180ac2f374df81b0261661774c5f (patch)
treea2da83c98d63104d5fc165aa201232f0cadd8c8e
parent67709398b6bb1cea68b8c2a0060b251e8dfa86ee (diff)
parent2ac66e59f7b32bb7f975803c9d483848e755a08f (diff)
downloadtor-a88f3e24eaf2180ac2f374df81b0261661774c5f.tar.gz
tor-a88f3e24eaf2180ac2f374df81b0261661774c5f.zip
Merge remote-tracking branch 'origin/maint-0.2.4'
Conflicts: src/test/test_addr.c
-rw-r--r--changes/bug83773
-rw-r--r--src/common/address.c3
-rw-r--r--src/test/test_addr.c36
3 files changed, 41 insertions, 1 deletions
diff --git a/changes/bug8377 b/changes/bug8377
new file mode 100644
index 0000000000..c9ad151bc9
--- /dev/null
+++ b/changes/bug8377
@@ -0,0 +1,3 @@
+ o Minor bugfixes:
+ - Correctly recognize that [::1] is a loopback address. Fixes bug #8377;
+ bugfix on 0.2.1.3-alpha.
diff --git a/src/common/address.c b/src/common/address.c
index 69e7f68103..227b4fbaee 100644
--- a/src/common/address.c
+++ b/src/common/address.c
@@ -817,7 +817,8 @@ tor_addr_is_loopback(const tor_addr_t *addr)
case AF_INET6: {
/* ::1 */
uint32_t *a32 = tor_addr_to_in6_addr32(addr);
- return (a32[0] == 0) && (a32[1] == 0) && (a32[2] == 0) && (a32[3] == 1);
+ return (a32[0] == 0) && (a32[1] == 0) && (a32[2] == 0) &&
+ (ntohl(a32[3]) == 1);
}
case AF_INET:
/* 127.0.0.1 */
diff --git a/src/test/test_addr.c b/src/test/test_addr.c
index f182bca195..106f921c5d 100644
--- a/src/test/test_addr.c
+++ b/src/test/test_addr.c
@@ -937,6 +937,41 @@ test_addr_sockaddr_to_str(void *arg)
tor_free(v);
}
+static void
+test_addr_is_loopback(void *data)
+{
+ static const struct loopback_item {
+ const char *name;
+ int is_loopback;
+ } loopback_items[] = {
+ { "::1", 1 },
+ { "127.0.0.1", 1 },
+ { "127.99.100.101", 1 },
+ { "128.99.100.101", 0 },
+ { "8.8.8.8", 0 },
+ { "0.0.0.0", 0 },
+ { "::2", 0 },
+ { "::", 0 },
+ { "::1.0.0.0", 0 },
+ { NULL, 0 }
+ };
+
+ int i;
+ tor_addr_t addr;
+ (void)data;
+
+ for (i=0; loopback_items[i].name; ++i) {
+ tt_int_op(tor_addr_parse(&addr, loopback_items[i].name), >=, 0);
+ tt_int_op(tor_addr_is_loopback(&addr), ==, loopback_items[i].is_loopback);
+ }
+
+ tor_addr_make_unspec(&addr);
+ tt_int_op(tor_addr_is_loopback(&addr), ==, 0);
+
+ done:
+ ;
+}
+
#define ADDR_LEGACY(name) \
{ #name, legacy_test_helper, 0, &legacy_setup, test_addr_ ## name }
@@ -948,6 +983,7 @@ struct testcase_t addr_tests[] = {
{ "localname", test_addr_localname, 0, NULL, NULL },
{ "dup_ip", test_addr_dup_ip, 0, NULL, NULL },
{ "sockaddr_to_str", test_addr_sockaddr_to_str, 0, NULL, NULL },
+ { "is_loopback", test_addr_is_loopback, 0, NULL, NULL },
END_OF_TESTCASES
};