aboutsummaryrefslogtreecommitdiff
path: root/src/or/connection_or.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-11-05 23:34:39 +0000
committerNick Mathewson <nickm@torproject.org>2007-11-05 23:34:39 +0000
commit6fcda5299fe7c0a40d3bff06ac4dcfe13d02d476 (patch)
treeeb42e117ce2b35dab8ae718df80c77946eae6040 /src/or/connection_or.c
parent9a20a64b62b149b102a487b6dc099fa310553f3c (diff)
downloadtor-6fcda5299fe7c0a40d3bff06ac4dcfe13d02d476.tar
tor-6fcda5299fe7c0a40d3bff06ac4dcfe13d02d476.tar.gz
r14727@31-33-67: nickm | 2007-11-05 18:34:35 -0500
Make VERSIONS variable-length. svn:r12391
Diffstat (limited to 'src/or/connection_or.c')
-rw-r--r--src/or/connection_or.c44
1 files changed, 34 insertions, 10 deletions
diff --git a/src/or/connection_or.c b/src/or/connection_or.c
index 0645e3eb4..7842d8da9 100644
--- a/src/or/connection_or.c
+++ b/src/or/connection_or.c
@@ -149,13 +149,24 @@ cell_unpack(cell_t *dest, const char *src)
/** DOCDOC */
void
-var_cell_pack_header(var_cell_t *cell, char *hdr_out)
+var_cell_pack_header(const var_cell_t *cell, char *hdr_out)
{
*(uint16_t*)(hdr_out) = htons(cell->circ_id);
*(uint8_t*)(hdr_out+2) = cell->command;
set_uint16(hdr_out+3, htons(cell->payload_len));
}
+/* DOCDOC*/
+var_cell_t *
+var_cell_new(uint16_t payload_len)
+{
+ var_cell_t *cell = tor_malloc(sizeof(var_cell_t)+payload_len-1);
+ cell->payload_len = payload_len;
+ cell->command = 0;
+ cell->circ_id = 0;
+ return cell;
+}
+
/** DOCDOC */
void
var_cell_free(var_cell_t *cell)
@@ -841,6 +852,19 @@ connection_or_write_cell_to_buf(const cell_t *cell, or_connection_t *conn)
connection_write_to_buf(networkcell.body, CELL_NETWORK_SIZE, TO_CONN(conn));
}
+/**DOCDOC*/
+void
+connection_or_write_var_cell_to_buf(const var_cell_t *cell,
+ or_connection_t *conn)
+{
+ char hdr[VAR_CELL_HEADER_SIZE];
+ tor_assert(cell);
+ tor_assert(conn);
+ var_cell_pack_header(cell, hdr);
+ connection_write_to_buf(hdr, sizeof(hdr), TO_CONN(conn));
+ connection_write_to_buf(cell->payload, cell->payload_len, TO_CONN(conn));
+}
+
/** DOCDOC */
static int
connection_fetch_var_cell_from_buf(or_connection_t *conn, var_cell_t **out)
@@ -924,22 +948,21 @@ connection_or_send_destroy(uint16_t circ_id, or_connection_t *conn, int reason)
static int
connection_or_send_versions(or_connection_t *conn)
{
- cell_t cell;
- uint8_t versions[] = { 1 };
+ var_cell_t *cell;
+ uint16_t versions[] = { 1, 2 };
int n_versions = sizeof(versions) / sizeof(uint8_t);
int i;
tor_assert(conn->handshake_state &&
!conn->handshake_state->sent_versions_at);
- memset(&cell, 0, sizeof(cell_t));
- cell.command = CELL_VERSIONS;
- set_uint16(cell.payload, htons(n_versions));
+ /*XXXX020 docdoc 2-byte versions */
+ cell = var_cell_new(n_versions * 2);
+ cell->command = CELL_VERSIONS;
for (i = 0; i < n_versions; ++i) {
- uint8_t v = versions[i];
- tor_assert(v > 0 && v < 128);
- cell.payload[2+i] = v;
+ uint16_t v = versions[i];
+ set_uint16(cell->payload+(2*i), htons(v));
}
- connection_or_write_cell_to_buf(&cell, conn);
+ connection_or_write_var_cell_to_buf(cell, conn);
conn->handshake_state->sent_versions_at = time(NULL);
return 0;
@@ -1054,3 +1077,4 @@ connection_or_send_link_auth(or_connection_t *conn)
* authenticated. */
return 0;
}
+