summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-04-11 10:48:46 -0400
committerNick Mathewson <nickm@torproject.org>2018-04-11 10:48:46 -0400
commit0c8f901ee7c3cfd2351e7f6e723998226fabe190 (patch)
tree57a5e659ec646857bed9c741d8d1fc4a3cea2122 /src/or
parent6bdfaa8b244ca3e10e57f6d99616af1d5f68fa67 (diff)
parentf9ba0c65467fe80f65b3789365cfac874198a337 (diff)
downloadtor-0c8f901ee7c3cfd2351e7f6e723998226fabe190.tar.gz
tor-0c8f901ee7c3cfd2351e7f6e723998226fabe190.zip
Merge branch 'maint-0.3.3'
Diffstat (limited to 'src/or')
-rw-r--r--src/or/circuituse.c2
-rw-r--r--src/or/or.h8
2 files changed, 9 insertions, 1 deletions
diff --git a/src/or/circuituse.c b/src/or/circuituse.c
index 8d388cc2c6..fe28dd9a1a 100644
--- a/src/or/circuituse.c
+++ b/src/or/circuituse.c
@@ -383,7 +383,7 @@ count_pending_general_client_circuits(void)
SMARTLIST_FOREACH_BEGIN(circuit_get_global_list(), circuit_t *, circ) {
if (circ->marked_for_close ||
circ->state == CIRCUIT_STATE_OPEN ||
- circ->purpose != CIRCUIT_PURPOSE_C_GENERAL ||
+ !CIRCUIT_PURPOSE_COUNTS_TOWARDS_MAXPENDING(circ->purpose) ||
!CIRCUIT_IS_ORIGIN(circ))
continue;
diff --git a/src/or/or.h b/src/or/or.h
index 541b709d89..b845443947 100644
--- a/src/or/or.h
+++ b/src/or/or.h
@@ -586,6 +586,14 @@ typedef enum {
/** True iff the circuit_t c is actually an or_circuit_t */
#define CIRCUIT_IS_ORCIRC(c) (((circuit_t *)(c))->magic == OR_CIRCUIT_MAGIC)
+/** True iff this circuit purpose should count towards the global
+ * pending rate limit (set by MaxClientCircuitsPending). We count all
+ * general purpose circuits, as well as the first step of client onion
+ * service connections (HSDir gets). */
+#define CIRCUIT_PURPOSE_COUNTS_TOWARDS_MAXPENDING(p) \
+ ((p) == CIRCUIT_PURPOSE_C_GENERAL || \
+ (p) == CIRCUIT_PURPOSE_C_HSDIR_GET)
+
/** How many circuits do we want simultaneously in-progress to handle
* a given stream? */
#define MIN_CIRCUITS_HANDLING_STREAM 2