diff options
Diffstat (limited to 'src/libknot/quic/tls_common.c')
-rw-r--r-- | src/libknot/quic/tls_common.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/src/libknot/quic/tls_common.c b/src/libknot/quic/tls_common.c index a1158e5ed..45f02bc72 100644 --- a/src/libknot/quic/tls_common.c +++ b/src/libknot/quic/tls_common.c @@ -196,7 +196,7 @@ struct knot_creds *knot_creds_init_peer(const struct knot_creds *local_creds, if (local_creds != NULL) { creds->peer = true; - creds->cert_creds = ATOMIC_GET(local_creds->cert_creds); + ATOMIC_INIT(creds->cert_creds, ATOMIC_GET(local_creds->cert_creds)); } else { gnutls_certificate_credentials_t new_creds; int ret = gnutls_certificate_allocate_credentials(&new_creds); @@ -204,7 +204,7 @@ struct knot_creds *knot_creds_init_peer(const struct knot_creds *local_creds, free(creds); return NULL; } - creds->cert_creds = new_creds; + ATOMIC_INIT(creds->cert_creds, new_creds); } if (peer_pin_len > 0 && peer_pin != NULL) { @@ -345,8 +345,9 @@ void knot_creds_free(struct knot_creds *creds) return; } - if (!creds->peer && creds->cert_creds != NULL) { - gnutls_certificate_free_credentials(creds->cert_creds); + if (!creds->peer && ATOMIC_GET(creds->cert_creds) != NULL) { + gnutls_certificate_free_credentials(ATOMIC_GET(creds->cert_creds)); + ATOMIC_DEINIT(creds->cert_creds); if (creds->cert_creds_prev != NULL) { gnutls_certificate_free_credentials(creds->cert_creds_prev); } |