1*1c60b9acSAndroid Build Coastguard Worker /*
2*1c60b9acSAndroid Build Coastguard Worker * libwebsockets - small server side websockets and web server implementation
3*1c60b9acSAndroid Build Coastguard Worker *
4*1c60b9acSAndroid Build Coastguard Worker * Copyright (C) 2010 - 2021 Andy Green <[email protected]>
5*1c60b9acSAndroid Build Coastguard Worker *
6*1c60b9acSAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a copy
7*1c60b9acSAndroid Build Coastguard Worker * of this software and associated documentation files (the "Software"), to
8*1c60b9acSAndroid Build Coastguard Worker * deal in the Software without restriction, including without limitation the
9*1c60b9acSAndroid Build Coastguard Worker * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10*1c60b9acSAndroid Build Coastguard Worker * sell copies of the Software, and to permit persons to whom the Software is
11*1c60b9acSAndroid Build Coastguard Worker * furnished to do so, subject to the following conditions:
12*1c60b9acSAndroid Build Coastguard Worker *
13*1c60b9acSAndroid Build Coastguard Worker * The above copyright notice and this permission notice shall be included in
14*1c60b9acSAndroid Build Coastguard Worker * all copies or substantial portions of the Software.
15*1c60b9acSAndroid Build Coastguard Worker *
16*1c60b9acSAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*1c60b9acSAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*1c60b9acSAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*1c60b9acSAndroid Build Coastguard Worker * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*1c60b9acSAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21*1c60b9acSAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
22*1c60b9acSAndroid Build Coastguard Worker * IN THE SOFTWARE.
23*1c60b9acSAndroid Build Coastguard Worker */
24*1c60b9acSAndroid Build Coastguard Worker
25*1c60b9acSAndroid Build Coastguard Worker #include "private-lib-core.h"
26*1c60b9acSAndroid Build Coastguard Worker #include "private-lib-cose.h"
27*1c60b9acSAndroid Build Coastguard Worker
28*1c60b9acSAndroid Build Coastguard Worker lws_cose_sig_alg_t *
lws_cose_sign_alg_create(struct lws_context * cx,const lws_cose_key_t * ck,cose_param_t cose_alg,int op)29*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_create(struct lws_context *cx, const lws_cose_key_t *ck,
30*1c60b9acSAndroid Build Coastguard Worker cose_param_t cose_alg, int op)
31*1c60b9acSAndroid Build Coastguard Worker {
32*1c60b9acSAndroid Build Coastguard Worker lws_cose_sig_alg_t *alg = lws_zalloc(sizeof(*alg), __func__);
33*1c60b9acSAndroid Build Coastguard Worker const struct lws_gencrypto_keyelem *ke;
34*1c60b9acSAndroid Build Coastguard Worker enum lws_genhmac_types ghm;
35*1c60b9acSAndroid Build Coastguard Worker enum lws_genhash_types gh;
36*1c60b9acSAndroid Build Coastguard Worker const char *crv;
37*1c60b9acSAndroid Build Coastguard Worker
38*1c60b9acSAndroid Build Coastguard Worker if (!alg)
39*1c60b9acSAndroid Build Coastguard Worker return NULL;
40*1c60b9acSAndroid Build Coastguard Worker
41*1c60b9acSAndroid Build Coastguard Worker alg->cose_alg = cose_alg;
42*1c60b9acSAndroid Build Coastguard Worker alg->cose_key = ck;
43*1c60b9acSAndroid Build Coastguard Worker
44*1c60b9acSAndroid Build Coastguard Worker switch (cose_alg) {
45*1c60b9acSAndroid Build Coastguard Worker
46*1c60b9acSAndroid Build Coastguard Worker /* ECDSA algs */
47*1c60b9acSAndroid Build Coastguard Worker
48*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAECDSA_ALG_ES256: /* ECDSA w/ SHA-256 */
49*1c60b9acSAndroid Build Coastguard Worker crv = "P-256";
50*1c60b9acSAndroid Build Coastguard Worker gh = LWS_GENHASH_TYPE_SHA256;
51*1c60b9acSAndroid Build Coastguard Worker alg->keybits = 256;
52*1c60b9acSAndroid Build Coastguard Worker goto ecdsa;
53*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAECDSA_ALG_ES384: /* ECDSA w/ SHA-384 */
54*1c60b9acSAndroid Build Coastguard Worker crv = "P-384";
55*1c60b9acSAndroid Build Coastguard Worker gh = LWS_GENHASH_TYPE_SHA384;
56*1c60b9acSAndroid Build Coastguard Worker alg->keybits = 384;
57*1c60b9acSAndroid Build Coastguard Worker goto ecdsa;
58*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAECDSA_ALG_ES512: /* ECDSA w/ SHA-512 */
59*1c60b9acSAndroid Build Coastguard Worker crv = "P-521";
60*1c60b9acSAndroid Build Coastguard Worker gh = LWS_GENHASH_TYPE_SHA512;
61*1c60b9acSAndroid Build Coastguard Worker alg->keybits = 521;
62*1c60b9acSAndroid Build Coastguard Worker ecdsa:
63*1c60b9acSAndroid Build Coastguard Worker
64*1c60b9acSAndroid Build Coastguard Worker /* the key is good for this? */
65*1c60b9acSAndroid Build Coastguard Worker
66*1c60b9acSAndroid Build Coastguard Worker if (lws_cose_key_checks(ck, LWSCOSE_WKKTV_EC2, cose_alg,
67*1c60b9acSAndroid Build Coastguard Worker op, crv))
68*1c60b9acSAndroid Build Coastguard Worker goto bail_ecdsa;
69*1c60b9acSAndroid Build Coastguard Worker
70*1c60b9acSAndroid Build Coastguard Worker if (lws_genhash_init(&alg->hash_ctx, gh))
71*1c60b9acSAndroid Build Coastguard Worker goto bail_ecdsa;
72*1c60b9acSAndroid Build Coastguard Worker
73*1c60b9acSAndroid Build Coastguard Worker if (lws_genecdsa_create(&alg->u.ecdsactx, cx, lws_ec_curves)) {
74*1c60b9acSAndroid Build Coastguard Worker lwsl_notice("%s: lws_genrsa_public_decrypt_create\n",
75*1c60b9acSAndroid Build Coastguard Worker __func__);
76*1c60b9acSAndroid Build Coastguard Worker goto bail_ecdsa1;
77*1c60b9acSAndroid Build Coastguard Worker }
78*1c60b9acSAndroid Build Coastguard Worker
79*1c60b9acSAndroid Build Coastguard Worker if (lws_genecdsa_set_key(&alg->u.ecdsactx, ck->e)) {
80*1c60b9acSAndroid Build Coastguard Worker lwsl_notice("%s: ec key import fail\n", __func__);
81*1c60b9acSAndroid Build Coastguard Worker goto bail_ecdsa2;
82*1c60b9acSAndroid Build Coastguard Worker }
83*1c60b9acSAndroid Build Coastguard Worker
84*1c60b9acSAndroid Build Coastguard Worker break;
85*1c60b9acSAndroid Build Coastguard Worker
86*1c60b9acSAndroid Build Coastguard Worker /* HMAC algs */
87*1c60b9acSAndroid Build Coastguard Worker
88*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_256_64:
89*1c60b9acSAndroid Build Coastguard Worker ghm = LWS_GENHMAC_TYPE_SHA256;
90*1c60b9acSAndroid Build Coastguard Worker alg->keybits = 64;
91*1c60b9acSAndroid Build Coastguard Worker goto hmac;
92*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_256_256:
93*1c60b9acSAndroid Build Coastguard Worker ghm = LWS_GENHMAC_TYPE_SHA256;
94*1c60b9acSAndroid Build Coastguard Worker alg->keybits = 256;
95*1c60b9acSAndroid Build Coastguard Worker goto hmac;
96*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_384_384:
97*1c60b9acSAndroid Build Coastguard Worker ghm = LWS_GENHMAC_TYPE_SHA384;
98*1c60b9acSAndroid Build Coastguard Worker alg->keybits = 384;
99*1c60b9acSAndroid Build Coastguard Worker goto hmac;
100*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_512_512:
101*1c60b9acSAndroid Build Coastguard Worker ghm = LWS_GENHMAC_TYPE_SHA512;
102*1c60b9acSAndroid Build Coastguard Worker alg->keybits = 512;
103*1c60b9acSAndroid Build Coastguard Worker
104*1c60b9acSAndroid Build Coastguard Worker hmac:
105*1c60b9acSAndroid Build Coastguard Worker if (lws_cose_key_checks(ck, LWSCOSE_WKKTV_SYMMETRIC,
106*1c60b9acSAndroid Build Coastguard Worker cose_alg, op, NULL))
107*1c60b9acSAndroid Build Coastguard Worker goto bail_hmac;
108*1c60b9acSAndroid Build Coastguard Worker
109*1c60b9acSAndroid Build Coastguard Worker ke = &ck->e[LWS_GENCRYPTO_OCT_KEYEL_K];
110*1c60b9acSAndroid Build Coastguard Worker if (lws_genhmac_init(&alg->u.hmacctx, ghm, ke->buf, ke->len))
111*1c60b9acSAndroid Build Coastguard Worker goto bail_hmac;
112*1c60b9acSAndroid Build Coastguard Worker
113*1c60b9acSAndroid Build Coastguard Worker break;
114*1c60b9acSAndroid Build Coastguard Worker
115*1c60b9acSAndroid Build Coastguard Worker /* RSASSA algs */
116*1c60b9acSAndroid Build Coastguard Worker
117*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKARSA_ALG_RS256:
118*1c60b9acSAndroid Build Coastguard Worker gh = LWS_GENHASH_TYPE_SHA256;
119*1c60b9acSAndroid Build Coastguard Worker goto rsassa;
120*1c60b9acSAndroid Build Coastguard Worker
121*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKARSA_ALG_RS384:
122*1c60b9acSAndroid Build Coastguard Worker gh = LWS_GENHASH_TYPE_SHA384;
123*1c60b9acSAndroid Build Coastguard Worker goto rsassa;
124*1c60b9acSAndroid Build Coastguard Worker
125*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKARSA_ALG_RS512:
126*1c60b9acSAndroid Build Coastguard Worker gh = LWS_GENHASH_TYPE_SHA512;
127*1c60b9acSAndroid Build Coastguard Worker
128*1c60b9acSAndroid Build Coastguard Worker rsassa:
129*1c60b9acSAndroid Build Coastguard Worker if (lws_cose_key_checks(ck, LWSCOSE_WKKTV_RSA, cose_alg,
130*1c60b9acSAndroid Build Coastguard Worker op, NULL))
131*1c60b9acSAndroid Build Coastguard Worker goto bail_hmac;
132*1c60b9acSAndroid Build Coastguard Worker
133*1c60b9acSAndroid Build Coastguard Worker alg->keybits = (int)ck->e[LWS_GENCRYPTO_RSA_KEYEL_N].len * 8;
134*1c60b9acSAndroid Build Coastguard Worker
135*1c60b9acSAndroid Build Coastguard Worker if (lws_genhash_init(&alg->hash_ctx, gh))
136*1c60b9acSAndroid Build Coastguard Worker goto bail_hmac;
137*1c60b9acSAndroid Build Coastguard Worker
138*1c60b9acSAndroid Build Coastguard Worker if (lws_genrsa_create(&alg->u.rsactx, ck->e, cx,
139*1c60b9acSAndroid Build Coastguard Worker LGRSAM_PKCS1_1_5, gh)) {
140*1c60b9acSAndroid Build Coastguard Worker lwsl_notice("%s: lws_genrsa_create fail\n", __func__);
141*1c60b9acSAndroid Build Coastguard Worker goto bail_hmac;
142*1c60b9acSAndroid Build Coastguard Worker }
143*1c60b9acSAndroid Build Coastguard Worker break;
144*1c60b9acSAndroid Build Coastguard Worker
145*1c60b9acSAndroid Build Coastguard Worker default:
146*1c60b9acSAndroid Build Coastguard Worker lwsl_warn("%s: unsupported alg %lld\n", __func__,
147*1c60b9acSAndroid Build Coastguard Worker (long long)cose_alg);
148*1c60b9acSAndroid Build Coastguard Worker goto bail_hmac;
149*1c60b9acSAndroid Build Coastguard Worker }
150*1c60b9acSAndroid Build Coastguard Worker
151*1c60b9acSAndroid Build Coastguard Worker return alg;
152*1c60b9acSAndroid Build Coastguard Worker
153*1c60b9acSAndroid Build Coastguard Worker bail_ecdsa2:
154*1c60b9acSAndroid Build Coastguard Worker lws_genec_destroy(&alg->u.ecdsactx);
155*1c60b9acSAndroid Build Coastguard Worker bail_ecdsa1:
156*1c60b9acSAndroid Build Coastguard Worker lws_genhash_destroy(&alg->hash_ctx, NULL);
157*1c60b9acSAndroid Build Coastguard Worker bail_ecdsa:
158*1c60b9acSAndroid Build Coastguard Worker lws_free(alg);
159*1c60b9acSAndroid Build Coastguard Worker
160*1c60b9acSAndroid Build Coastguard Worker return NULL;
161*1c60b9acSAndroid Build Coastguard Worker
162*1c60b9acSAndroid Build Coastguard Worker bail_hmac:
163*1c60b9acSAndroid Build Coastguard Worker lws_free(alg);
164*1c60b9acSAndroid Build Coastguard Worker
165*1c60b9acSAndroid Build Coastguard Worker return NULL;
166*1c60b9acSAndroid Build Coastguard Worker }
167*1c60b9acSAndroid Build Coastguard Worker
168*1c60b9acSAndroid Build Coastguard Worker int
lws_cose_sign_alg_hash(lws_cose_sig_alg_t * alg,const uint8_t * in,size_t in_len)169*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_hash(lws_cose_sig_alg_t *alg, const uint8_t *in, size_t in_len)
170*1c60b9acSAndroid Build Coastguard Worker {
171*1c60b9acSAndroid Build Coastguard Worker #if defined(VERBOSE)
172*1c60b9acSAndroid Build Coastguard Worker lwsl_hexdump_warn(in, in_len);
173*1c60b9acSAndroid Build Coastguard Worker #endif
174*1c60b9acSAndroid Build Coastguard Worker
175*1c60b9acSAndroid Build Coastguard Worker switch (alg->cose_alg) {
176*1c60b9acSAndroid Build Coastguard Worker
177*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_256_64:
178*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_256_256:
179*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_384_384:
180*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_512_512:
181*1c60b9acSAndroid Build Coastguard Worker return lws_genhmac_update(&alg->u.hmacctx, in, in_len);
182*1c60b9acSAndroid Build Coastguard Worker }
183*1c60b9acSAndroid Build Coastguard Worker
184*1c60b9acSAndroid Build Coastguard Worker /* EC, rsa are just making the hash before signing */
185*1c60b9acSAndroid Build Coastguard Worker
186*1c60b9acSAndroid Build Coastguard Worker return lws_genhash_update(&alg->hash_ctx, in, in_len);
187*1c60b9acSAndroid Build Coastguard Worker }
188*1c60b9acSAndroid Build Coastguard Worker
189*1c60b9acSAndroid Build Coastguard Worker /*
190*1c60b9acSAndroid Build Coastguard Worker * We fill up alg-> rhash and rhash_len with the results, and destroy the
191*1c60b9acSAndroid Build Coastguard Worker * crypto pieces cleanly. Call lws_cose_sign_alg_destroy() afterwards to
192*1c60b9acSAndroid Build Coastguard Worker * clean up the alg itself.
193*1c60b9acSAndroid Build Coastguard Worker */
194*1c60b9acSAndroid Build Coastguard Worker
195*1c60b9acSAndroid Build Coastguard Worker void
lws_cose_sign_alg_complete(lws_cose_sig_alg_t * alg)196*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_complete(lws_cose_sig_alg_t *alg)
197*1c60b9acSAndroid Build Coastguard Worker {
198*1c60b9acSAndroid Build Coastguard Worker uint8_t digest[LWS_GENHASH_LARGEST];
199*1c60b9acSAndroid Build Coastguard Worker unsigned int bytes;
200*1c60b9acSAndroid Build Coastguard Worker uint8_t htype;
201*1c60b9acSAndroid Build Coastguard Worker size_t hs;
202*1c60b9acSAndroid Build Coastguard Worker
203*1c60b9acSAndroid Build Coastguard Worker if (alg->completed)
204*1c60b9acSAndroid Build Coastguard Worker return;
205*1c60b9acSAndroid Build Coastguard Worker
206*1c60b9acSAndroid Build Coastguard Worker switch (alg->cose_alg) {
207*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAECDSA_ALG_ES256: /* ECDSA w/ SHA-256 */
208*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAECDSA_ALG_ES384: /* ECDSA w/ SHA-384 */
209*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAECDSA_ALG_ES512: /* ECDSA w/ SHA-512 */
210*1c60b9acSAndroid Build Coastguard Worker hs = lws_genhash_size(alg->hash_ctx.type);
211*1c60b9acSAndroid Build Coastguard Worker bytes = (unsigned int)lws_gencrypto_bits_to_bytes(alg->keybits);
212*1c60b9acSAndroid Build Coastguard Worker lws_genhash_destroy(&alg->hash_ctx, digest);
213*1c60b9acSAndroid Build Coastguard Worker alg->rhash_len = 0;
214*1c60b9acSAndroid Build Coastguard Worker lwsl_notice("alg keybits %d hs %d\n", (int)alg->keybits, (int)hs);
215*1c60b9acSAndroid Build Coastguard Worker if (!alg->failed &&
216*1c60b9acSAndroid Build Coastguard Worker lws_genecdsa_hash_sign_jws(&alg->u.ecdsactx, digest,
217*1c60b9acSAndroid Build Coastguard Worker alg->hash_ctx.type,
218*1c60b9acSAndroid Build Coastguard Worker (int)alg->keybits, alg->rhash,
219*1c60b9acSAndroid Build Coastguard Worker 2u * bytes) >= 0)
220*1c60b9acSAndroid Build Coastguard Worker alg->rhash_len = (int)(2 * bytes);
221*1c60b9acSAndroid Build Coastguard Worker else
222*1c60b9acSAndroid Build Coastguard Worker alg->failed = 1;
223*1c60b9acSAndroid Build Coastguard Worker
224*1c60b9acSAndroid Build Coastguard Worker lws_genec_destroy(&alg->u.ecdsactx);
225*1c60b9acSAndroid Build Coastguard Worker break;
226*1c60b9acSAndroid Build Coastguard Worker
227*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_256_64:
228*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_256_256:
229*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_384_384:
230*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKAHMAC_512_512:
231*1c60b9acSAndroid Build Coastguard Worker alg->rhash_len = (int)lws_genhmac_size(alg->u.hmacctx.type);
232*1c60b9acSAndroid Build Coastguard Worker if (alg->cose_alg == LWSCOSE_WKAHMAC_256_64)
233*1c60b9acSAndroid Build Coastguard Worker alg->rhash_len = 8;
234*1c60b9acSAndroid Build Coastguard Worker
235*1c60b9acSAndroid Build Coastguard Worker if (lws_genhmac_destroy(&alg->u.hmacctx, alg->rhash)) {
236*1c60b9acSAndroid Build Coastguard Worker lwsl_err("%s: destroy failed\n", __func__);
237*1c60b9acSAndroid Build Coastguard Worker break;
238*1c60b9acSAndroid Build Coastguard Worker }
239*1c60b9acSAndroid Build Coastguard Worker break;
240*1c60b9acSAndroid Build Coastguard Worker
241*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKARSA_ALG_RS256:
242*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKARSA_ALG_RS384:
243*1c60b9acSAndroid Build Coastguard Worker case LWSCOSE_WKARSA_ALG_RS512:
244*1c60b9acSAndroid Build Coastguard Worker bytes = (unsigned int)lws_gencrypto_bits_to_bytes(alg->keybits);
245*1c60b9acSAndroid Build Coastguard Worker htype = alg->hash_ctx.type;
246*1c60b9acSAndroid Build Coastguard Worker
247*1c60b9acSAndroid Build Coastguard Worker if (!lws_genhash_destroy(&alg->hash_ctx, digest) &&
248*1c60b9acSAndroid Build Coastguard Worker !alg->failed &&
249*1c60b9acSAndroid Build Coastguard Worker lws_genrsa_hash_sign(&alg->u.rsactx, digest, htype,
250*1c60b9acSAndroid Build Coastguard Worker alg->rhash, bytes) >= 0)
251*1c60b9acSAndroid Build Coastguard Worker alg->rhash_len = (int)bytes;
252*1c60b9acSAndroid Build Coastguard Worker else
253*1c60b9acSAndroid Build Coastguard Worker lwsl_err("%s: lws_genrsa_hash_sign\n", __func__);
254*1c60b9acSAndroid Build Coastguard Worker
255*1c60b9acSAndroid Build Coastguard Worker lws_genrsa_destroy(&alg->u.rsactx);
256*1c60b9acSAndroid Build Coastguard Worker break;
257*1c60b9acSAndroid Build Coastguard Worker
258*1c60b9acSAndroid Build Coastguard Worker default:
259*1c60b9acSAndroid Build Coastguard Worker break;
260*1c60b9acSAndroid Build Coastguard Worker }
261*1c60b9acSAndroid Build Coastguard Worker
262*1c60b9acSAndroid Build Coastguard Worker alg->completed = 1;
263*1c60b9acSAndroid Build Coastguard Worker }
264*1c60b9acSAndroid Build Coastguard Worker
265*1c60b9acSAndroid Build Coastguard Worker void
lws_cose_sign_alg_destroy(lws_cose_sig_alg_t ** _alg)266*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_destroy(lws_cose_sig_alg_t **_alg)
267*1c60b9acSAndroid Build Coastguard Worker {
268*1c60b9acSAndroid Build Coastguard Worker lws_dll2_remove(&(*_alg)->list);
269*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_complete(*_alg);
270*1c60b9acSAndroid Build Coastguard Worker lws_free_set_NULL(*_alg);
271*1c60b9acSAndroid Build Coastguard Worker }
272