summaryrefslogtreecommitdiff
path: root/lib/libssl/d1_both.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/libssl/d1_both.c')
-rw-r--r--lib/libssl/d1_both.c10
1 files changed, 3 insertions, 7 deletions
diff --git a/lib/libssl/d1_both.c b/lib/libssl/d1_both.c
index db57bf9d3d5..10b62cd4104 100644
--- a/lib/libssl/d1_both.c
+++ b/lib/libssl/d1_both.c
@@ -618,7 +618,7 @@ dtls1_reassemble_fragment(SSL *s, struct hm_header_st* msg_hdr, int *ok)
frag->msg_header.frag_len = frag->msg_header.msg_len;
frag->msg_header.frag_off = 0;
} else
- frag = (hm_fragment*) item->data;
+ frag = (hm_fragment*)item->data;
/* If message is already reassembled, this must be a
* retransmit and can be dropped.
@@ -671,10 +671,8 @@ dtls1_reassemble_fragment(SSL *s, struct hm_header_st* msg_hdr, int *ok)
return DTLS1_HM_FRAGMENT_RETRY;
err:
- if (frag != NULL)
+ if (item == NULL && frag != NULL)
dtls1_hm_fragment_free(frag);
- if (item != NULL)
- free(item);
*ok = 0;
return i;
}
@@ -755,10 +753,8 @@ dtls1_process_out_of_seq_message(SSL *s, struct hm_header_st* msg_hdr, int *ok)
return DTLS1_HM_FRAGMENT_RETRY;
err:
- if (frag != NULL)
+ if (item == NULL && frag != NULL)
dtls1_hm_fragment_free(frag);
- if (item != NULL)
- free(item);
*ok = 0;
return i;
}