aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuca Deri <deri@ntop.org>2023-12-23 08:07:28 +0100
committerLuca Deri <deri@ntop.org>2023-12-23 08:07:28 +0100
commit5c7200f2bb763bfcd4e0636aebb88573e97bbcf3 (patch)
tree7559d49717f1a74164bcd33869817200098796c6
parent7c4be6d07779034711d5b4a1d08b537be18932e4 (diff)
Buffer overflow fix
-rw-r--r--src/lib/protocols/tls.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/lib/protocols/tls.c b/src/lib/protocols/tls.c
index 71f6eb0be..e3e103307 100644
--- a/src/lib/protocols/tls.c
+++ b/src/lib/protocols/tls.c
@@ -2383,13 +2383,14 @@ int processClientServerHello(struct ndpi_detection_module_struct *ndpi_struct,
#endif
ja.client.num_signature_algorithms = ndpi_min(sa_size, MAX_NUM_JA);
-
+ for(i=0, id=0; i<tot_signature_algorithms_len && s_offset+i<total_len; i += 2) {
+ ja.client.signature_algorithms[id++] = ntohs(*(u_int16_t*)&packet->payload[s_offset+i]);
+ }
+
for(i=0, id=0; i<tot_signature_algorithms_len && s_offset+i<total_len; i++) {
int rc = ndpi_snprintf(&ja.client.signature_algorithms_str[i*2],
sizeof(ja.client.signature_algorithms_str)-i*2,
"%02X", packet->payload[s_offset+i]);
- ja.client.signature_algorithms[id++] = ntohs(*(u_int16_t*)&packet->payload[s_offset+i*2]);
-
if(rc < 0) break;
}