summaryrefslogtreecommitdiff
path: root/src/or/or.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/or/or.h')
-rw-r--r--src/or/or.h32
1 files changed, 26 insertions, 6 deletions
diff --git a/src/or/or.h b/src/or/or.h
index 83c80a36b0..53033f0fcd 100644
--- a/src/or/or.h
+++ b/src/or/or.h
@@ -114,12 +114,20 @@
#define CONN_TYPE_DIR_LISTENER 8
#define CONN_TYPE_DIR 9
#define CONN_TYPE_DNSWORKER 10
+#define CONN_TYPE_CPUWORKER 11
#define LISTENER_STATE_READY 0
#define DNSWORKER_STATE_IDLE 0
#define DNSWORKER_STATE_BUSY 1
+#define CPUWORKER_STATE_IDLE 0
+#define CPUWORKER_STATE_BUSY_ONION 1
+#define CPUWORKER_STATE_BUSY_HANDSHAKE 2
+
+#define CPUWORKER_TASK_ONION CPUWORKER_STATE_BUSY_ONION
+#define CPUWORKER_TASK_HANDSHAKE CPUWORKER_STATE_BUSY_HANDSHAKE
+
/* how to read these states:
* foo_CONN_STATE_bar_baz:
* "I am acting as a bar, currently in stage baz of talking with a foo."
@@ -328,8 +336,8 @@ struct connection_t {
char nonce[8];
/* Used by worker connections */
- int num_processed;
-
+ int num_processed; /* statistics kept by dns worker */
+ struct circuit_t *circ; /* by cpu worker to know who he's working for */
};
typedef struct connection_t connection_t;
@@ -399,7 +407,7 @@ struct crypt_path_t {
typedef struct crypt_path_t crypt_path_t;
/* struct for a path (circuit) through the network */
-typedef struct {
+struct circuit_t {
uint32_t n_addr;
uint16_t n_port;
connection_t *p_conn;
@@ -428,7 +436,9 @@ typedef struct {
// uint32_t recvlen; /* length of the onion so far */
void *next;
-} circuit_t;
+};
+
+typedef struct circuit_t circuit_t;
struct onion_queue_t {
circuit_t *circ;
@@ -678,6 +688,15 @@ connection_t *connection_or_connect(routerinfo_t *router);
int connection_or_create_listener(struct sockaddr_in *bindaddr);
int connection_or_handle_listener_read(connection_t *conn);
+/********************************* cpuworker.c *****************************/
+
+void cpu_init(void);
+int connection_cpu_finished_flushing(connection_t *conn);
+int connection_cpu_process_inbuf(connection_t *conn);
+int cpuworker_main(void *data);
+int assign_to_cpuworker(connection_t *cpuworker, unsigned char question_type,
+ void *task);
+
/********************************* directory.c ***************************/
void directory_initiate_fetch(routerinfo_t *router);
@@ -737,10 +756,11 @@ int decide_aci_type(uint32_t local_addr, uint16_t local_port,
uint32_t remote_addr, uint16_t remote_port);
int onion_pending_add(circuit_t *circ);
-int onion_pending_check(void);
-void onion_pending_process_one(void);
+circuit_t *onion_next_task(void);
void onion_pending_remove(circuit_t *circ);
+int onionskin_process(circuit_t *circ, unsigned char *payload, unsigned char *keys);
+
/* uses a weighted coin with weight cw to choose a route length */
int chooselen(double cw);