diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-06-05 01:50:35 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-06-05 01:50:35 +0000 |
commit | 17b5b3685f5f2f27b05d4e7f5b1dc78939a9f5e8 (patch) | |
tree | a98d7127db6e9a733e0978668f539d211b2638c5 /src/or | |
parent | 42569ffd0fc659d81093bc1d7b0fe5171e5738cf (diff) | |
download | tor-17b5b3685f5f2f27b05d4e7f5b1dc78939a9f5e8.tar.gz tor-17b5b3685f5f2f27b05d4e7f5b1dc78939a9f5e8.zip |
Make tor build on win32 again; handle locking for server
svn:r1948
Diffstat (limited to 'src/or')
-rw-r--r-- | src/or/connection.c | 2 | ||||
-rw-r--r-- | src/or/cpuworker.c | 5 | ||||
-rw-r--r-- | src/or/or.h | 1 | ||||
-rw-r--r-- | src/or/router.c | 24 |
4 files changed, 24 insertions, 8 deletions
diff --git a/src/or/connection.c b/src/or/connection.c index b7d2c52e04..aaafbe3068 100644 --- a/src/or/connection.c +++ b/src/or/connection.c @@ -333,7 +333,7 @@ static int connection_create_listener(const char *bindaddress, uint16_t bindport memset(&bindaddr,0,sizeof(struct sockaddr_in)); bindaddr.sin_family = AF_INET; - bindaddr.sin_port = htons(usePort); + bindaddr.sin_port = htons((uint16_t) usePort); if(tor_lookup_hostname(hostname, &(bindaddr.sin_addr.s_addr)) != 0) { log_fn(LOG_WARN,"Can't resolve BindAddress %s",hostname); tor_free(hostname); diff --git a/src/or/cpuworker.c b/src/or/cpuworker.c index 94a2238b62..1b55822a5f 100644 --- a/src/or/cpuworker.c +++ b/src/or/cpuworker.c @@ -202,10 +202,7 @@ static int cpuworker_main(void *data) { connection_free_all(); /* so the child doesn't hold the parent's fd's open */ #endif - /* XXXX WINDOWS lock here. */ - onion_key = crypto_pk_dup_key(get_onion_key()); - if (get_previous_onion_key()) - last_onion_key = crypto_pk_dup_key(get_previous_onion_key()); + dup_onion_keys(&onion_key, &last_onion_key); for(;;) { diff --git a/src/or/or.h b/src/or/or.h index 7eee5a789b..e121266bd5 100644 --- a/src/or/or.h +++ b/src/or/or.h @@ -1279,6 +1279,7 @@ crypto_pk_env_t *get_previous_onion_key(void); time_t get_onion_key_set_at(void); void set_identity_key(crypto_pk_env_t *k); crypto_pk_env_t *get_identity_key(void); +void dup_onion_keys(crypto_pk_env_t **key, crypto_pk_env_t **last); int init_keys(void); crypto_pk_env_t *init_key_from_file(const char *fname); void rotate_onion_key(void); diff --git a/src/or/router.c b/src/or/router.c index dc91797101..9c263ecd2e 100644 --- a/src/or/router.c +++ b/src/or/router.c @@ -22,6 +22,7 @@ extern or_options_t options; /* command-line and config-file options */ /** Private keys for this OR. There is also an SSL key managed by tortls.c. */ +static tor_mutex_t *key_lock=NULL; static time_t onionkey_set_at=0; /* When was onionkey last changed? */ static crypto_pk_env_t *onionkey=NULL; static crypto_pk_env_t *lastonionkey=NULL; @@ -31,8 +32,10 @@ static crypto_pk_env_t *identitykey=NULL; * to update onionkey correctly, call rotate_onion_key(). */ void set_onion_key(crypto_pk_env_t *k) { + tor_mutex_acquire(key_lock); onionkey = k; onionkey_set_at = time(NULL); + tor_mutex_release(key_lock); } /** Return the current onion key. Requires that the onion key has been @@ -50,6 +53,18 @@ crypto_pk_env_t *get_previous_onion_key(void) { return lastonionkey; } +void dup_onion_keys(crypto_pk_env_t **key, crypto_pk_env_t **last) +{ + tor_assert(key && last); + tor_mutex_acquire(key_lock); + *key = crypto_pk_dup_key(onionkey); + if (lastonionkey) + *last = crypto_pk_dup_key(lastonionkey); + else + *last = NULL; + tor_mutex_release(key_lock); +} + /** Return the time when the onion key was last set. This is either the time * when the process launched, or the time of the most recent key rotation since * the process launched. @@ -96,13 +111,13 @@ void rotate_onion_key(void) log(LOG_ERR, "Couldn't write generated key to %s.", fname); goto error; } + tor_mutex_acquire(key_lock); if (lastonionkey) crypto_free_pk_env(lastonionkey); - /* XXXX WINDOWS on windows, we need to protect this next bit with a lock. - */ log_fn(LOG_INFO, "Rotating onion key"); lastonionkey = onionkey; set_onion_key(prkey); + tor_mutex_release(key_lock); return; error: log_fn(LOG_WARN, "Couldn't rotate onion key."); @@ -171,6 +186,9 @@ int init_keys(void) { const char *tmp, *mydesc; crypto_pk_env_t *prkey; + if (!key_lock) + key_lock = tor_mutex_new(); + /* OP's don't need keys. Just initialize the TLS context.*/ if (!options.ORPort) { tor_assert(!options.DirPort); @@ -418,7 +436,7 @@ int router_rebuild_descriptor(void) { ri->socks_port = options.SocksPort; ri->dir_port = options.DirPort; ri->published_on = time(NULL); - ri->onion_pkey = crypto_pk_dup_key(get_onion_key()); + ri->onion_pkey = crypto_pk_dup_key(get_onion_key()); /* must invoke from main thread */ ri->identity_pkey = crypto_pk_dup_key(get_identity_key()); get_platform_str(platform, sizeof(platform)); ri->platform = tor_strdup(platform); |