[tor-commits] [tor/master] Update the limits in max_dl_per_request for IPv6 address length
nickm at torproject.org
nickm at torproject.org
Fri Jan 15 15:52:27 UTC 2016
commit 91077d3aca2ea027816f4ea733bb8193dd60a2f2
Author: Fergus Dall <fergus at beware.dropbear.id.au>
Date: Wed Jan 13 06:49:56 2016 +1030
Update the limits in max_dl_per_request for IPv6 address length
---
changes/17573 | 3 +++
src/or/routerlist.c | 13 ++++++++++---
2 files changed, 13 insertions(+), 3 deletions(-)
diff --git a/changes/17573 b/changes/17573
new file mode 100644
index 0000000..fe1fd1c
--- /dev/null
+++ b/changes/17573
@@ -0,0 +1,3 @@
+ o Minor bigfixes (IPv6):
+ - Update the limits in max_dl_per_request for IPv6 address
+ length. Closes ticket 17573.
diff --git a/src/or/routerlist.c b/src/or/routerlist.c
index 853c07d..8edab2c 100644
--- a/src/or/routerlist.c
+++ b/src/or/routerlist.c
@@ -4440,13 +4440,20 @@ static int
max_dl_per_request(const or_options_t *options, int purpose)
{
/* Since squid does not like URLs >= 4096 bytes we limit it to 96.
- * 4096 - strlen(http://255.255.255.255/tor/server/d/.z) == 4058
- * 4058/41 (40 for the hash and 1 for the + that separates them) => 98
+ * 4096 - strlen(http://ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
+ * /tor/server/d/.z) == 4034
+ * 4034/41 (40 for the hash and 1 for the + that separates them) => 98
* So use 96 because it's a nice number.
+ *
+ * For microdescriptors, the calculation is
+ * 4096 - strlen(http://ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
+ * /tor/micro/d/.z) == 4035
+ * 4035/44 (43 for the hash and 1 for the - that separates them) => 91
+ * So use 90 because it's a nice number.
*/
int max = 96;
if (purpose == DIR_PURPOSE_FETCH_MICRODESC) {
- max = 92;
+ max = 90;
}
/* If we're going to tunnel our connections, we can ask for a lot more
* in a request. */
More information about the tor-commits
mailing list