[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] Make clients use CREATE_FAST cells. add an option to disabl...
Update of /home/or/cvsroot/tor/src/or
In directory moria:/tmp/cvs-serv16546/src/or
Modified Files:
circuitbuild.c config.c or.h
Log Message:
Make clients use CREATE_FAST cells. add an option to disable this.
Index: circuitbuild.c
===================================================================
RCS file: /home/or/cvsroot/tor/src/or/circuitbuild.c,v
retrieving revision 1.167
retrieving revision 1.168
diff -u -d -r1.167 -r1.168
--- circuitbuild.c 7 Dec 2005 04:43:39 -0000 1.167
+++ circuitbuild.c 7 Dec 2005 22:09:02 -0000 1.168
@@ -437,7 +437,8 @@
});
}
-/** Find a new circid that isn't currently in use by the outgoing
+/** Find a new circid that isn't currently in use on the circ->n_conn
+ * for the outgoing
* circuit <b>circ</b>, and deliver a cell of type <b>cell_type</b>
* (either CELL_CREATE or CELL_CREATE_FAST) with payload <b>payload</b>
* to this circuit.
@@ -492,6 +493,23 @@
return 1;
}
+/** Return true iff we should send a create_fast cell to build a circuit
+ * starting at <b>router</b>. (If <b>router</b> is NULL, we don't have
+ * information on the router. */
+static INLINE int
+should_use_create_fast_for_router(routerinfo_t *router)
+{
+ or_options_t *options = get_options();
+
+ if (!options->FastFirstHopPK || options->ORPort)
+ return 0;
+ else if (!router || !router->platform ||
+ !tor_version_as_new_as(router->platform, "0.1.0.6-rc"))
+ return 0;
+ else
+ return 1;
+}
+
extern int has_completed_circuit;
/** This is the backbone function for building circuits.
@@ -517,14 +535,13 @@
tor_assert(CIRCUIT_IS_ORIGIN(circ));
if (circ->cpath->state == CPATH_STATE_CLOSED) {
+ int fast;
uint8_t cell_type;
debug(LD_CIRC,"First skin; sending create cell.");
router = router_get_by_digest(circ->n_conn->identity_digest);
-
- if (1 || /* Disable this '1' once we believe CREATE_FAST works. XXXX */
- (get_options()->ORPort || !router || !router->platform ||
- !tor_version_as_new_as(router->platform, "0.1.0.6-rc"))) {
+ fast = should_use_create_fast_for_router(router);
+ if (! fast) {
/* We are an OR, or we are connecting to an old Tor: we should
* send an old slow create cell.
*/
@@ -551,7 +568,8 @@
circ->cpath->state = CPATH_STATE_AWAITING_KEYS;
circuit_set_state(circ, CIRCUIT_STATE_BUILDING);
- debug(LD_CIRC,"first skin; finished sending create cell.");
+ info(LD_CIRC,"First hop: finished sending %s cell to '%s'",
+ fast ? "CREATE_FAST" : "CREATE", router->nickname);
} else {
tor_assert(circ->cpath->state == CPATH_STATE_OPEN);
tor_assert(circ->state == CIRCUIT_STATE_BUILDING);
@@ -809,7 +827,8 @@
}
hop->state = CPATH_STATE_OPEN;
- info(LD_CIRC,"Finished building circuit hop:");
+ info(LD_CIRC,"Finished building %scircuit hop:",
+ (reply_type == CELL_CREATED_FAST) ? "fast " : "");
circuit_log_path(LOG_INFO,LD_CIRC,circ);
control_event_circuit_status(circ, CIRC_EVENT_EXTENDED);
Index: config.c
===================================================================
RCS file: /home/or/cvsroot/tor/src/or/config.c,v
retrieving revision 1.449
retrieving revision 1.450
diff -u -d -r1.449 -r1.450
--- config.c 19 Nov 2005 10:12:10 -0000 1.449
+++ config.c 7 Dec 2005 22:09:02 -0000 1.450
@@ -131,6 +131,7 @@
VAR("ExitPolicy", LINELIST, ExitPolicy, NULL),
VAR("FascistFirewall", BOOL, FascistFirewall, "0"),
VAR("FirewallPorts", CSV, FirewallPorts, ""),
+ VAR("FastFirstHopPK", BOOL, FastFirstHopPK, "1"),
VAR("Group", STRING, Group, NULL),
VAR("HardwareAccel", BOOL, HardwareAccel, "1"),
VAR("HashedControlPassword",STRING, HashedControlPassword, NULL),
Index: or.h
===================================================================
RCS file: /home/or/cvsroot/tor/src/or/or.h,v
retrieving revision 1.750
retrieving revision 1.751
diff -u -d -r1.750 -r1.751
--- or.h 6 Dec 2005 06:55:43 -0000 1.750
+++ or.h 7 Dec 2005 22:09:02 -0000 1.751
@@ -1321,6 +1321,8 @@
* of fixed nodes? */
int NumHelperNodes; /**< How many helper nodes do we try to establish? */
int RephistTrackTime; /**< How many seconds do we keep rephist info? */
+ int FastFirstHopPK; /**< If Tor believes it is safe, should we save a third
+ * of our PK time by sending CREATE_FAST cells? */
addr_policy_t *reachable_addr_policy; /**< Parsed from ReachableAddresses */
} or_options_t;