summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Goulet <dgoulet@torproject.org>2019-04-24 13:38:47 -0400
committerDavid Goulet <dgoulet@torproject.org>2019-04-29 12:17:57 -0400
commitc7385b5b14b30774c1768798c4495465da4d995d (patch)
tree8e339c489377cd562bc44101f9d0f87b677b9c79
parent805c81efed9bc2c474d3f10675846ee445a908d5 (diff)
downloadtor-c7385b5b14b30774c1768798c4495465da4d995d.tar.gz
tor-c7385b5b14b30774c1768798c4495465da4d995d.zip
sendme: Keep cell digest only if a SENDME is next
This way, we reduce the load by only hashing when we absolutely must. Part of #26288 Signed-off-by: David Goulet <dgoulet@torproject.org>
-rw-r--r--src/core/crypto/relay_crypto.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/src/core/crypto/relay_crypto.c b/src/core/crypto/relay_crypto.c
index 94e9060651..eddc4298e2 100644
--- a/src/core/crypto/relay_crypto.c
+++ b/src/core/crypto/relay_crypto.c
@@ -12,6 +12,7 @@
#include "core/crypto/hs_ntor.h" // for HS_NTOR_KEY_EXPANSION_KDF_OUT_LEN
#include "core/or/relay.h"
#include "core/crypto/relay_crypto.h"
+#include "core/or/sendme.h"
#include "core/or/cell_st.h"
#include "core/or/or_circuit_st.h"
@@ -142,10 +143,11 @@ relay_decrypt_cell(circuit_t *circ, cell_t *cell,
if (relay_digest_matches(thishop->crypto.b_digest, cell)) {
*recognized = 1;
*layer_hint = thishop;
- /* Keep current digest of this cell for the possible SENDME. */
- crypto_digest_get_digest(thishop->crypto.b_digest,
- (char *) thishop->crypto.sendme_digest,
- sizeof(thishop->crypto.sendme_digest));
+ /* This cell is for us. Keep a record of this cell because we will
+ * use it in the next SENDME cell. */
+ if (sendme_circuit_is_next_cell(thishop->deliver_window)) {
+ sendme_circuit_note_inbound_cell(thishop);
+ }
return 0;
}
}
@@ -216,10 +218,13 @@ relay_encrypt_cell_inbound(cell_t *cell,
or_circuit_t *or_circ)
{
relay_set_digest(or_circ->crypto.b_digest, cell);
- /* Keep a record of this cell, we might use it for validating the SENDME. */
- crypto_digest_get_digest(or_circ->crypto.b_digest,
- (char *) or_circ->crypto.sendme_digest,
- sizeof(or_circ->crypto.sendme_digest));
+
+ /* We are about to send this cell outbound on the circuit. Keep a record of
+ * this cell if we are expecting that the next cell is a SENDME. */
+ if (sendme_circuit_is_next_cell(TO_CIRCUIT(or_circ)->package_window)) {
+ sendme_circuit_note_outbound_cell(or_circ);
+ }
+
/* encrypt one layer */
relay_crypt_one_payload(or_circ->crypto.b_crypto, cell->payload);
}