1
10
13
14
20
21
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
116
117
118
119
...
...
...
#define NX_SECURE_SOURCE_CODE
#include "nx_secure_tls.h"
#include "nx_secure_x509.h"
...
...
UINT _nx_secure_tls_remote_certificate_allocate(NX_SECURE_TLS_SESSION *tls_session,
NX_SECURE_X509_CERT *certificate,
UCHAR *raw_certificate_buffer, UINT buffer_size)
{
UINT status;
tx_mutex_get(&_nx_secure_tls_protection, TX_WAIT_FOREVER);
certificate -> nx_secure_x509_certificate_raw_data = raw_certificate_buffer;
certificate -> nx_secure_x509_certificate_raw_buffer_size = buffer_size;
certificate->nx_secure_x509_user_allocated_cert = NX_TRUE;
status = _nx_secure_x509_store_certificate_add(certificate, &tls_session -> nx_secure_tls_credentials.nx_secure_tls_certificate_store,
NX_SECURE_X509_CERT_LOCATION_FREE);
tx_mutex_put(&_nx_secure_tls_protection);
if (status == NX_SECURE_X509_CERT_ID_DUPLICATE)
{
return(NX_SECURE_TLS_CERT_ID_DUPLICATE);
}if (status == NX_SECURE_X509_CERT_ID_DUPLICATE) { ... }
return(status);
}{ ... }