1
10
13
14
20
21
27
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
101
102
103
104
105
106
107
110
113
116
119
120
127
128
129
130
134
135
136
137
138
139
140
...
...
...
#define NX_SECURE_SOURCE_CODE
#include "nx_secure_x509.h"
...
...
UINT _nx_secure_x509_store_certificate_remove(NX_SECURE_X509_CERTIFICATE_STORE *store,
NX_SECURE_X509_DISTINGUISHED_NAME *name,
UINT location, UINT cert_id)
{
UINT status;
NX_SECURE_X509_CERT **store_ptr = NX_CRYPTO_NULL;
if (store == NX_CRYPTO_NULL)
{
#ifdef NX_CRYPTO_STANDALONE_ENABLE
return(NX_CRYPTO_PTR_ERROR);
#else
return(NX_PTR_ERROR);
#endif
}if (store == NX_CRYPTO_NULL) { ... }
status = NX_SECURE_X509_SUCCESS;
switch (location)
{
case NX_SECURE_X509_CERT_LOCATION_LOCAL:
store_ptr = &store -> nx_secure_x509_local_certificates;
break;case NX_SECURE_X509_CERT_LOCATION_LOCAL:
case NX_SECURE_X509_CERT_LOCATION_REMOTE:
store_ptr = &store -> nx_secure_x509_remote_certificates;
break;case NX_SECURE_X509_CERT_LOCATION_REMOTE:
case NX_SECURE_X509_CERT_LOCATION_TRUSTED:
store_ptr = &store -> nx_secure_x509_trusted_certificates;
break;case NX_SECURE_X509_CERT_LOCATION_TRUSTED:
case NX_SECURE_X509_CERT_LOCATION_EXCEPTIONS:
store_ptr = &store -> nx_secure_x509_certificate_exceptions;
break;case NX_SECURE_X509_CERT_LOCATION_EXCEPTIONS:
case NX_SECURE_X509_CERT_LOCATION_NONE:
default:
#ifdef NX_CRYPTO_STANDALONE_ENABLE
status = NX_CRYPTO_INVALID_PARAMETER;
#else
status = NX_INVALID_PARAMETERS;
#endif
break;default
}switch (location) { ... }
if (status)
{
return(status);
}if (status) { ... }
status = _nx_secure_x509_certificate_list_remove(store_ptr, name, cert_id);
return(status);
}{ ... }