mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-10 21:23:58 +01:00
Merge commit 'nickm/strtok' into mp-voting-final
This commit is contained in:
commit
cb477f9cc0
@ -773,7 +773,7 @@
|
|||||||
Same as passing 'EXTENDED' to SETEVENTS; this is the preferred way to
|
Same as passing 'EXTENDED' to SETEVENTS; this is the preferred way to
|
||||||
request the extended event syntax.
|
request the extended event syntax.
|
||||||
|
|
||||||
This feaure was first used in 0.1.2.3-alpha. It is always-on in
|
This feature was first used in 0.1.2.3-alpha. It is always-on in
|
||||||
Tor 0.2.2.1-alpha and later.
|
Tor 0.2.2.1-alpha and later.
|
||||||
|
|
||||||
VERBOSE_NAMES
|
VERBOSE_NAMES
|
||||||
|
@ -42,31 +42,25 @@ Status: Open
|
|||||||
slices of 50 nodes each, grouped according to advertised node bandwidth.
|
slices of 50 nodes each, grouped according to advertised node bandwidth.
|
||||||
|
|
||||||
Two hop circuits are built using nodes from the same slice, and a large
|
Two hop circuits are built using nodes from the same slice, and a large
|
||||||
file is downloaded via these circuits. For nodes in the first 15% of the
|
file is downloaded via these circuits. The file sizes are set based
|
||||||
network, a 500K file will be used. For nodes in the next 15%, a 250K file
|
on node percentile rank as follows:
|
||||||
will be used. For nodes in next 15%, a 100K file will be used. The
|
|
||||||
remainder of the nodes will fetch a 75K file.[1]
|
|
||||||
|
|
||||||
This process is repeated 250 times, and average stream capacities are
|
0-10: 2M
|
||||||
assigned to each node from these results.
|
10-20: 1M
|
||||||
|
20-30: 512k
|
||||||
|
30-50: 256k
|
||||||
|
50-100: 128k
|
||||||
|
|
||||||
In the future, a node generator type can be created to ensure that
|
These sizes are based on measurements performed during test scans.
|
||||||
each node is chosen to participate in an equal number of circuits,
|
|
||||||
and the selection will continue until every live node is chosen
|
This process is repeated until each node has been chosen to participate
|
||||||
to participate in at least 7 circuits.
|
in at least 5 circuits.
|
||||||
|
|
||||||
|
|
||||||
4. Ratio Calculation Options
|
4. Ratio Calculation
|
||||||
|
|
||||||
There are two options for deriving the ratios themselves. They can
|
The ratios are calculated by dividing each measured value by the
|
||||||
be obtained by dividing each nodes' average stream capacity by
|
network-wide average.
|
||||||
either the average for the slice, or the average for the network as a
|
|
||||||
whole.
|
|
||||||
|
|
||||||
Dividing by the network-wide average has the advantage that it will
|
|
||||||
account for issues related to unbalancing between higher vs lower
|
|
||||||
capacity, such as Steven Murdoch's queuing theory weighting result.
|
|
||||||
For this reason, we will opt for network-wide averages.
|
|
||||||
|
|
||||||
|
|
||||||
5. Ratio Filtering
|
5. Ratio Filtering
|
||||||
@ -77,10 +71,8 @@ Status: Open
|
|||||||
with capacity of one standard deviation below a node's average
|
with capacity of one standard deviation below a node's average
|
||||||
are also removed.
|
are also removed.
|
||||||
|
|
||||||
The final ratio result will be calculated as the maximum of
|
The final ratio result will be greater of the unfiltered ratio
|
||||||
these two resulting ratios if both are less than 1.0, the minimum
|
and the filtered ratio.
|
||||||
if both are greater than 1.0, and the mean if one is greater
|
|
||||||
and one is less than 1.0.
|
|
||||||
|
|
||||||
|
|
||||||
6. Pseudocode for Ratio Calculation Algorithm
|
6. Pseudocode for Ratio Calculation Algorithm
|
||||||
@ -95,11 +87,8 @@ Status: Open
|
|||||||
BW_measured(N) = MEAN(b | b is bandwidth of a stream through N)
|
BW_measured(N) = MEAN(b | b is bandwidth of a stream through N)
|
||||||
Bw_stddev(N) = STDDEV(b | b is bandwidth of a stream through N)
|
Bw_stddev(N) = STDDEV(b | b is bandwidth of a stream through N)
|
||||||
Bw_avg(S) = MEAN(b | b = BW_measured(N) for all N in S)
|
Bw_avg(S) = MEAN(b | b = BW_measured(N) for all N in S)
|
||||||
Normal_Routers(S) = {N | Bw_measured(N)/Bw_avg(S) > 0.5 }
|
|
||||||
for N in S:
|
for N in S:
|
||||||
Normal_Streams(N) =
|
Normal_Streams(N) = {stream via N | bandwidth >= BW_measured(N)}
|
||||||
{stream via N | all nodes in stream not in {Normal_Routers(S)-N}
|
|
||||||
and bandwidth > BW_measured(N)-Bw_stddev(N)}
|
|
||||||
BW_Norm_measured(N) = MEAN(b | b is a bandwidth of Normal_Streams(N))
|
BW_Norm_measured(N) = MEAN(b | b is a bandwidth of Normal_Streams(N))
|
||||||
|
|
||||||
Bw_net_avg(Slices) = MEAN(BW_measured(N) for all N in Slices)
|
Bw_net_avg(Slices) = MEAN(BW_measured(N) for all N in Slices)
|
||||||
@ -107,14 +96,9 @@ Status: Open
|
|||||||
|
|
||||||
for N in all Slices:
|
for N in all Slices:
|
||||||
Bw_net_ratio(N) = Bw_measured(N)/Bw_net_avg(Slices)
|
Bw_net_ratio(N) = Bw_measured(N)/Bw_net_avg(Slices)
|
||||||
Bw_Norm_net_ratio(N) = Bw_measured2(N)/Bw_Norm_net_avg(Slices)
|
Bw_Norm_net_ratio(N) = BW_Norm_measured(N)/Bw_Norm_net_avg(Slices)
|
||||||
|
|
||||||
if Bw_net_ratio(N) < 1.0 and Bw_Norm_net_ratio(N) < 1.0:
|
|
||||||
ResultRatio(N) = MAX(Bw_net_ratio(N), Bw_Norm_net_ratio(N))
|
ResultRatio(N) = MAX(Bw_net_ratio(N), Bw_Norm_net_ratio(N))
|
||||||
else if Bw_net_ratio(N) > 1.0 and Bw_Norm_net_ratio(N) > 1.0:
|
|
||||||
ResultRatio(N) = MIN(Bw_net_ratio(N), Bw_Norm_net_ratio(N))
|
|
||||||
else:
|
|
||||||
ResultRatio(N) = MEAN(Bw_net_ratio(N), Bw_Norm_net_ratio(N))
|
|
||||||
|
|
||||||
|
|
||||||
7. Security implications
|
7. Security implications
|
||||||
@ -126,13 +110,13 @@ Status: Open
|
|||||||
|
|
||||||
This scheme will not address nodes that try to game the system by
|
This scheme will not address nodes that try to game the system by
|
||||||
providing better service to scanners. The scanners can be detected
|
providing better service to scanners. The scanners can be detected
|
||||||
at the entry by IP address, and at the exit by the destination fetch.
|
at the entry by IP address, and at the exit by the destination fetch
|
||||||
|
IP.
|
||||||
|
|
||||||
Measures can be taken to obfuscate and separate the scanners' source
|
Measures can be taken to obfuscate and separate the scanners' source
|
||||||
IP address from the directory authority IP address. For instance,
|
IP address from the directory authority IP address. For instance,
|
||||||
scans can happen offsite and the results can be rsynced into the
|
scans can happen offsite and the results can be rsynced into the
|
||||||
authorities. The destination fetch can also be obscured by using SSL
|
authorities. The destination server IP can also change.
|
||||||
and periodically changing the large document that is fetched.
|
|
||||||
|
|
||||||
Neither of these methods are foolproof, but such nodes can already
|
Neither of these methods are foolproof, but such nodes can already
|
||||||
lie about their bandwidth to attract more traffic, so this solution
|
lie about their bandwidth to attract more traffic, so this solution
|
||||||
@ -148,14 +132,14 @@ Status: Open
|
|||||||
over a portion of the network, outputting files of the form:
|
over a portion of the network, outputting files of the form:
|
||||||
|
|
||||||
node_id=<idhex> SP strm_bw=<BW_measured(N)> SP
|
node_id=<idhex> SP strm_bw=<BW_measured(N)> SP
|
||||||
filt_bw=<BW_Norm_measured(N)> NL
|
filt_bw=<BW_Norm_measured(N)> ns_bw=<CurrentConsensusBw(N)> NL
|
||||||
|
|
||||||
The most recent file from each scanner will be periodically gathered
|
The most recent file from each scanner will be periodically gathered
|
||||||
by another script that uses them to produce network-wide averages
|
by another script that uses them to produce network-wide averages
|
||||||
and calculate ratios as per the algorithm in section 6. Because nodes
|
and calculate ratios as per the algorithm in section 6. Because nodes
|
||||||
may shift in capacity, they may appear in more than one slice and/or
|
may shift in capacity, they may appear in more than one slice and/or
|
||||||
appear more than once in the file set. The line that yields a ratio
|
appear more than once in the file set. The most recently measured
|
||||||
closest to 1.0 will be chosen in this case.
|
line will be chosen in this case.
|
||||||
|
|
||||||
|
|
||||||
9. Integration with Proposal 160
|
9. Integration with Proposal 160
|
||||||
@ -166,10 +150,15 @@ Status: Open
|
|||||||
scan, and taking the weighted average with the previous consensus
|
scan, and taking the weighted average with the previous consensus
|
||||||
bandwidth:
|
bandwidth:
|
||||||
|
|
||||||
Bw_new = (Bw_current * Alpha + Bw_scan_avg*Bw_ratio)/(Alpha + 1)
|
Bw_new = Round((Bw_current * Alpha + Bw_scan_avg*Bw_ratio)/(Alpha + 1))
|
||||||
|
|
||||||
The Alpha parameter is a smoothing parameter intended to prevent
|
The Alpha parameter is a smoothing parameter intended to prevent
|
||||||
rapid oscillation between loaded and unloaded conditions.
|
rapid oscillation between loaded and unloaded conditions. It is
|
||||||
|
currently fixed at 0.333.
|
||||||
|
|
||||||
|
The Round() step consists of rounding to the 3 most significant figures
|
||||||
|
in base10, and then rounding that result to the nearest 1000, with
|
||||||
|
a minimum value of 1000.
|
||||||
|
|
||||||
This will produce a new bandwidth value that will be output into a
|
This will produce a new bandwidth value that will be output into a
|
||||||
file consisting of lines of the form:
|
file consisting of lines of the form:
|
||||||
@ -183,6 +172,3 @@ Status: Open
|
|||||||
This file can be either copied or rsynced into a directory readable
|
This file can be either copied or rsynced into a directory readable
|
||||||
by the directory authority.
|
by the directory authority.
|
||||||
|
|
||||||
|
|
||||||
1. Exact values for each segment are still being determined via
|
|
||||||
test scans.
|
|
||||||
|
@ -398,6 +398,37 @@ const char TOR_TOLOWER_TABLE[256] = {
|
|||||||
240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,
|
240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/** Implementation of strtok_r for platforms whose coders haven't figured out
|
||||||
|
* how to write one. Hey guys! You can use this code here for free! */
|
||||||
|
char *
|
||||||
|
tor_strtok_r_impl(char *str, const char *sep, char **lasts)
|
||||||
|
{
|
||||||
|
char *cp, *start;
|
||||||
|
if (str)
|
||||||
|
start = cp = *lasts = str;
|
||||||
|
else if (!*lasts)
|
||||||
|
return NULL;
|
||||||
|
else
|
||||||
|
start = cp = *lasts;
|
||||||
|
|
||||||
|
tor_assert(*sep);
|
||||||
|
if (sep[1]) {
|
||||||
|
while (*cp && !strchr(sep, *cp))
|
||||||
|
++cp;
|
||||||
|
} else {
|
||||||
|
tor_assert(strlen(sep) == 1);
|
||||||
|
cp = strchr(cp, *sep);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!cp || !*cp) {
|
||||||
|
*lasts = NULL;
|
||||||
|
} else {
|
||||||
|
*cp++ = '\0';
|
||||||
|
*lasts = cp;
|
||||||
|
}
|
||||||
|
return start;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef MS_WINDOWS
|
#ifdef MS_WINDOWS
|
||||||
/** Take a filename and return a pointer to its final element. This
|
/** Take a filename and return a pointer to its final element. This
|
||||||
* function is called on __FILE__ to fix a MSVC nit where __FILE__
|
* function is called on __FILE__ to fix a MSVC nit where __FILE__
|
||||||
|
@ -267,6 +267,13 @@ extern const char TOR_TOLOWER_TABLE[];
|
|||||||
#define TOR_TOLOWER(c) (TOR_TOLOWER_TABLE[(uint8_t)c])
|
#define TOR_TOLOWER(c) (TOR_TOLOWER_TABLE[(uint8_t)c])
|
||||||
#define TOR_TOUPPER(c) (TOR_TOUPPER_TABLE[(uint8_t)c])
|
#define TOR_TOUPPER(c) (TOR_TOUPPER_TABLE[(uint8_t)c])
|
||||||
|
|
||||||
|
char *tor_strtok_r_impl(char *str, const char *sep, char **lasts);
|
||||||
|
#ifdef HAVE_STRTOK_R
|
||||||
|
#define tor_strok_r(str, sep, lasts) strtok_r(str, sep, lasts)
|
||||||
|
#else
|
||||||
|
#define tor_strok_r(str, sep, lasts) tor_strtok_r_impl(str, sep, lasts)
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef MS_WINDOWS
|
#ifdef MS_WINDOWS
|
||||||
#define _SHORT_FILE_ (tor_fix_source_file(__FILE__))
|
#define _SHORT_FILE_ (tor_fix_source_file(__FILE__))
|
||||||
const char *tor_fix_source_file(const char *fname);
|
const char *tor_fix_source_file(const char *fname);
|
||||||
|
@ -4361,6 +4361,39 @@ test_util_datadir(void)
|
|||||||
tor_free(f);
|
tor_free(f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_util_strtok(void)
|
||||||
|
{
|
||||||
|
char buf[128];
|
||||||
|
char buf2[128];
|
||||||
|
char *cp1, *cp2;
|
||||||
|
strlcpy(buf, "Graved on the dark in gestures of descent", sizeof(buf));
|
||||||
|
strlcpy(buf2, "they.seemed;their!own;most.perfect;monument", sizeof(buf2));
|
||||||
|
/* -- "Year's End", Richard Wilbur */
|
||||||
|
|
||||||
|
test_streq("Graved", tor_strtok_r_impl(buf, " ", &cp1));
|
||||||
|
test_streq("they", tor_strtok_r_impl(buf2, ".!..;!", &cp2));
|
||||||
|
#define S1() tor_strtok_r_impl(NULL, " ", &cp1)
|
||||||
|
#define S2() tor_strtok_r_impl(NULL, ".!..;!", &cp2)
|
||||||
|
test_streq("on", S1());
|
||||||
|
test_streq("the", S1());
|
||||||
|
test_streq("dark", S1());
|
||||||
|
test_streq("seemed", S2());
|
||||||
|
test_streq("their", S2());
|
||||||
|
test_streq("own", S2());
|
||||||
|
test_streq("in", S1());
|
||||||
|
test_streq("gestures", S1());
|
||||||
|
test_streq("of", S1());
|
||||||
|
test_streq("most", S2());
|
||||||
|
test_streq("perfect", S2());
|
||||||
|
test_streq("descent", S1());
|
||||||
|
test_streq("monument", S2());
|
||||||
|
test_assert(NULL == S1());
|
||||||
|
test_assert(NULL == S2());
|
||||||
|
done:
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
/** Test AES-CTR encryption and decryption with IV. */
|
/** Test AES-CTR encryption and decryption with IV. */
|
||||||
static void
|
static void
|
||||||
test_crypto_aes_iv(void)
|
test_crypto_aes_iv(void)
|
||||||
@ -4769,6 +4802,7 @@ static struct {
|
|||||||
SUBENT(util, threads),
|
SUBENT(util, threads),
|
||||||
SUBENT(util, order_functions),
|
SUBENT(util, order_functions),
|
||||||
SUBENT(util, sscanf),
|
SUBENT(util, sscanf),
|
||||||
|
SUBENT(util, strtok),
|
||||||
ENT(onion_handshake),
|
ENT(onion_handshake),
|
||||||
ENT(dir_format),
|
ENT(dir_format),
|
||||||
ENT(dirutil),
|
ENT(dirutil),
|
||||||
|
Loading…
Reference in New Issue
Block a user