summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-06-05 12:01:27 -0400
committerNick Mathewson <nickm@torproject.org>2017-06-05 12:01:27 -0400
commit33b500851c3476298f4a243374216258a4cf56e8 (patch)
treefec0da47efa42213847fa8a4b7a438648f7fb51e
parentdf842d84a8879a976401ea57bc435497ef6d234e (diff)
parent33fcc0f61d1feb2fbdf3153c7c64780dcdce6767 (diff)
downloadtor-33b500851c3476298f4a243374216258a4cf56e8.tar.gz
tor-33b500851c3476298f4a243374216258a4cf56e8.zip
Merge branch 'maint-0.2.8' into release-0.2.8
-rw-r--r--changes/bug224903
-rw-r--r--src/or/geoip.c2
2 files changed, 4 insertions, 1 deletions
diff --git a/changes/bug22490 b/changes/bug22490
new file mode 100644
index 0000000000..244dd50b36
--- /dev/null
+++ b/changes/bug22490
@@ -0,0 +1,3 @@
+ o Minor bugfixes (correctness):
+ - Avoid undefined behavior when parsing IPv6 entries from the geoip6
+ file. Fixes bug 22490; bugfix on 0.2.4.6-alpha.
diff --git a/src/or/geoip.c b/src/or/geoip.c
index b563db0418..681cb900f2 100644
--- a/src/or/geoip.c
+++ b/src/or/geoip.c
@@ -144,6 +144,7 @@ geoip_parse_entry(const char *line, sa_family_t family)
if (*line == '#')
return 0;
+ char buf[512];
if (family == AF_INET) {
unsigned int low, high;
if (tor_sscanf(line,"%u,%u,%2s", &low, &high, c) == 3 ||
@@ -154,7 +155,6 @@ geoip_parse_entry(const char *line, sa_family_t family)
goto fail;
country = c;
} else { /* AF_INET6 */
- char buf[512];
char *low_str, *high_str;
struct in6_addr low, high;
char *strtok_state;