Line data Source code
1 : /**
2 : * Copyright Notice:
3 : * Copyright 2021-2025 DMTF. All rights reserved.
4 : * License: BSD 3-Clause License. For full text see link: https://github.com/DMTF/libspdm/blob/main/LICENSE.md
5 : **/
6 :
7 : #include "spdm_unit_test.h"
8 : #include "internal/libspdm_requester_lib.h"
9 : #include "internal/libspdm_secured_message_lib.h"
10 :
11 : #if LIBSPDM_ENABLE_CAPABILITY_CSR_CAP
12 :
13 : #define LIBSPDM_MAX_CSR_SIZE 0x1000
14 :
15 : /*refer to https://github.com/Mbed-TLS/mbedtls/blob/3048c8c90654eb116a6b17c0d2d27c3ccbe6782c/programs/x509/cert_req.c#L119-L129*/
16 : #define LIBSPDM_MAX_REQ_INFO_BUFFER_SIZE 4096
17 :
18 : uint8_t csr_pointer[LIBSPDM_MAX_CSR_SIZE] = {0};
19 : uint8_t *csr_data_pointer = csr_pointer;
20 : size_t global_csr_len;
21 :
22 : uint8_t m_csr_opaque_data[8] = "libspdm";
23 : uint16_t m_csr_opaque_data_size = sizeof(m_csr_opaque_data);
24 :
25 : /*ECC 256 req_info(include right req_info attribute)*/
26 : uint8_t req_info_sequence[] = {0x30, 0x81, 0xBF,};
27 : uint8_t req_info_version[] = {0x02, 0x01, 0x00,};
28 : uint8_t req_info_subject[] = {
29 : 0x30, 0x45, 0x31, 0x0B, 0x30, 0x09, 0x06, 0x03, 0x55, 0x04, 0x06, 0x13, 0x02, 0x41, 0x55, 0x31,
30 : 0x13, 0x30, 0x11, 0x06, 0x03, 0x55, 0x04, 0x08, 0x0C, 0x0A, 0x53, 0x6F, 0x6D, 0x65, 0x2D, 0x53,
31 : 0x74, 0x61, 0x74, 0x65, 0x31, 0x21, 0x30, 0x1F, 0x06, 0x03, 0x55, 0x04, 0x0A, 0x0C, 0x18, 0x49,
32 : 0x6E, 0x74, 0x65, 0x72, 0x6E, 0x65, 0x74, 0x20, 0x57, 0x69, 0x64, 0x67, 0x69, 0x74, 0x73, 0x20,
33 : 0x50, 0x74, 0x79, 0x20, 0x4C, 0x74, 0x64,
34 : };
35 : uint8_t req_info_right_attributes[] = {
36 : /*[0]: attributes*/
37 : 0xA0, 0x18, 0x30, 0x16,
38 : /*OID*/
39 : 0x06, 0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x09, 0x07,
40 : /*attributes*/
41 : 0x31, 0x09, 0x0C, 0x07, 0x74, 0x65, 0x73, 0x74, 0x31, 0x32, 0x33
42 : };
43 :
44 : /*the unique attribute from right_req_info*/
45 : char right_req_info_string[] = {0x74, 0x65, 0x73, 0x74, 0x31, 0x32, 0x33};
46 :
47 : static uint8_t right_req_info[LIBSPDM_MAX_REQ_INFO_BUFFER_SIZE];
48 : static uint16_t right_req_info_size;
49 :
50 : /*gen right_req_info*/
51 1 : void libspdm_gen_req_info() {
52 : uint8_t *req_info_p;
53 : void *req_info_pkinfo;
54 : size_t req_info_pkinfo_len;
55 :
56 1 : libspdm_zero_mem(right_req_info, sizeof(right_req_info));
57 :
58 1 : req_info_p = right_req_info;
59 1 : right_req_info_size = sizeof(right_req_info);
60 :
61 1 : libspdm_read_responder_public_key(m_libspdm_use_asym_algo,
62 : &req_info_pkinfo, &req_info_pkinfo_len);
63 :
64 : /*concat right_req_info*/
65 1 : libspdm_copy_mem(req_info_p, right_req_info_size, req_info_sequence, sizeof(req_info_sequence));
66 1 : req_info_p += sizeof(req_info_sequence);
67 1 : right_req_info_size -= sizeof(req_info_sequence);
68 :
69 1 : libspdm_copy_mem(req_info_p, right_req_info_size, req_info_version, sizeof(req_info_version));
70 1 : req_info_p += sizeof(req_info_version);
71 1 : right_req_info_size -= sizeof(req_info_version);
72 :
73 1 : libspdm_copy_mem(req_info_p, right_req_info_size, req_info_subject, sizeof(req_info_subject));
74 1 : req_info_p += sizeof(req_info_subject);
75 1 : right_req_info_size -= sizeof(req_info_subject);
76 :
77 1 : libspdm_copy_mem(req_info_p, right_req_info_size, req_info_pkinfo, req_info_pkinfo_len);
78 1 : req_info_p += req_info_pkinfo_len;
79 1 : right_req_info_size = (uint16_t)(right_req_info_size - req_info_pkinfo_len);
80 :
81 1 : libspdm_copy_mem(req_info_p, right_req_info_size,
82 : req_info_right_attributes, sizeof(req_info_right_attributes));
83 1 : req_info_p += sizeof(req_info_right_attributes);
84 1 : right_req_info_size -= sizeof(req_info_right_attributes);
85 :
86 1 : right_req_info_size = sizeof(right_req_info) - right_req_info_size;
87 :
88 1 : free(req_info_pkinfo);
89 1 : }
90 :
91 5 : bool libspdm_read_requester_gen_csr(void **csr_data, size_t *csr_len)
92 : {
93 : char *file;
94 : bool res;
95 :
96 5 : file = "test_csr/cached.csr";
97 5 : res = libspdm_read_input_file(file, csr_data, csr_len);
98 5 : if (!res) {
99 0 : return res;
100 : }
101 :
102 5 : return res;
103 : }
104 :
105 : /*ensure that cached.csr exists in test_csr at the beginning*/
106 1 : void libspdm_clear_cached_csr()
107 : {
108 1 : char *new_name = "test_csr/cached.csr";
109 1 : char *file_name = "test_csr/cached.staging";
110 :
111 1 : rename(file_name, new_name);
112 1 : }
113 :
114 7 : static libspdm_return_t send_message(
115 : void *spdm_context, size_t request_size, const void *request, uint64_t timeout)
116 : {
117 : libspdm_test_context_t *spdm_test_context;
118 :
119 7 : spdm_test_context = libspdm_get_test_context();
120 7 : switch (spdm_test_context->case_id) {
121 1 : case 0x1:
122 1 : return LIBSPDM_STATUS_SEND_FAIL;
123 1 : case 0x2:
124 1 : return LIBSPDM_STATUS_SUCCESS;
125 2 : case 0x3:
126 2 : return LIBSPDM_STATUS_SUCCESS;
127 1 : case 0x4: {
128 : const spdm_get_csr_request_t *spdm_request;
129 : uint16_t requester_info_length;
130 : uint16_t opaque_data_length;
131 : uint8_t *opaque_data;
132 : uint8_t *requester_info;
133 :
134 : /* Obtain the real spdm_request */
135 1 : spdm_request =
136 : (const spdm_get_csr_request_t *)((const uint8_t *)request +
137 : sizeof(libspdm_test_message_header_t));
138 :
139 1 : requester_info_length = spdm_request->requester_info_length;
140 1 : opaque_data_length = spdm_request->opaque_data_length;
141 :
142 1 : requester_info = (void*)((size_t)(spdm_request + 1));
143 1 : assert_memory_equal(requester_info, right_req_info, requester_info_length);
144 1 : opaque_data = (void *)(requester_info + requester_info_length);
145 1 : assert_memory_equal(opaque_data, m_csr_opaque_data, opaque_data_length);
146 1 : return LIBSPDM_STATUS_SUCCESS;
147 : }
148 1 : case 0x5:
149 1 : return LIBSPDM_STATUS_SUCCESS;
150 1 : case 0x6:
151 1 : return LIBSPDM_STATUS_SUCCESS;
152 0 : case 0x7:
153 0 : assert_true(false);
154 0 : return LIBSPDM_STATUS_SUCCESS;
155 0 : default:
156 0 : return LIBSPDM_STATUS_SEND_FAIL;
157 : }
158 : }
159 :
160 6 : static libspdm_return_t receive_message(
161 : void *spdm_context, size_t *response_size, void **response, uint64_t timeout)
162 : {
163 : libspdm_test_context_t *spdm_test_context;
164 : libspdm_context_t *context;
165 :
166 6 : spdm_test_context = libspdm_get_test_context();
167 6 : switch (spdm_test_context->case_id) {
168 0 : case 0x1:
169 0 : return LIBSPDM_STATUS_RECEIVE_FAIL;
170 :
171 1 : case 0x2: {
172 : spdm_csr_response_t *spdm_response;
173 : size_t spdm_response_size;
174 : size_t transport_header_size;
175 :
176 1 : libspdm_read_requester_gen_csr((void *)&csr_data_pointer, &global_csr_len);
177 :
178 1 : spdm_response_size = sizeof(spdm_csr_response_t) + global_csr_len;
179 1 : transport_header_size = LIBSPDM_TEST_TRANSPORT_HEADER_SIZE;
180 1 : spdm_response = (void *)((uint8_t *)*response + transport_header_size);
181 :
182 1 : spdm_response->header.spdm_version = SPDM_MESSAGE_VERSION_12;
183 1 : spdm_response->header.request_response_code = SPDM_CSR;
184 1 : spdm_response->header.param1 = 0;
185 1 : spdm_response->header.param2 = 0;
186 1 : spdm_response->csr_length = (uint16_t)global_csr_len;
187 1 : spdm_response->reserved = 0;
188 :
189 1 : libspdm_copy_mem(spdm_response + 1, global_csr_len, csr_data_pointer, global_csr_len);
190 :
191 1 : libspdm_transport_test_encode_message(spdm_context, NULL, false,
192 : false, spdm_response_size,
193 : spdm_response, response_size,
194 : response);
195 : }
196 1 : return LIBSPDM_STATUS_SUCCESS;
197 :
198 2 : case 0x3: {
199 : spdm_csr_response_t *spdm_response;
200 : size_t spdm_response_size;
201 : size_t transport_header_size;
202 :
203 2 : libspdm_read_requester_gen_csr((void *)&csr_data_pointer, &global_csr_len);
204 :
205 2 : spdm_response_size = sizeof(spdm_csr_response_t) + global_csr_len;
206 2 : transport_header_size = LIBSPDM_TEST_TRANSPORT_HEADER_SIZE;
207 2 : spdm_response = (void *)((uint8_t *)*response + transport_header_size);
208 :
209 2 : spdm_response->header.spdm_version = SPDM_MESSAGE_VERSION_12;
210 2 : spdm_response->header.param2 = 0;
211 2 : spdm_response->csr_length = (uint16_t)global_csr_len;
212 2 : spdm_response->reserved = 0;
213 :
214 2 : context = spdm_context;
215 :
216 2 : if (context->connection_info.capability.flags &
217 : SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CERT_INSTALL_RESET_CAP) {
218 1 : spdm_response->header.request_response_code = SPDM_ERROR;
219 1 : spdm_response->header.param1 = SPDM_ERROR_CODE_RESET_REQUIRED;
220 : } else {
221 1 : spdm_response->header.request_response_code = SPDM_CSR;
222 1 : spdm_response->header.param1 = 0;
223 :
224 1 : libspdm_copy_mem(spdm_response + 1, global_csr_len, csr_data_pointer, global_csr_len);
225 : }
226 :
227 2 : libspdm_transport_test_encode_message(spdm_context, NULL, false,
228 : false, spdm_response_size,
229 : spdm_response, response_size,
230 : response);
231 : }
232 2 : return LIBSPDM_STATUS_SUCCESS;
233 1 : case 0x4: {
234 : spdm_csr_response_t *spdm_response;
235 : size_t spdm_response_size;
236 : size_t transport_header_size;
237 :
238 1 : libspdm_read_requester_gen_csr((void *)&csr_data_pointer, &global_csr_len);
239 1 : spdm_response_size = sizeof(spdm_csr_response_t) + global_csr_len;
240 1 : transport_header_size = LIBSPDM_TEST_TRANSPORT_HEADER_SIZE;
241 1 : spdm_response = (void *)((uint8_t *)*response + transport_header_size);
242 :
243 1 : spdm_response->header.spdm_version = SPDM_MESSAGE_VERSION_12;
244 1 : spdm_response->header.request_response_code = SPDM_CSR;
245 1 : spdm_response->header.param1 = 0;
246 1 : spdm_response->header.param2 = 0;
247 1 : spdm_response->csr_length = (uint16_t)global_csr_len;
248 1 : spdm_response->reserved = 0;
249 1 : libspdm_copy_mem(spdm_response + 1, global_csr_len, csr_data_pointer, global_csr_len);
250 :
251 1 : libspdm_transport_test_encode_message(spdm_context, NULL, false,
252 : false, spdm_response_size,
253 : spdm_response, response_size,
254 : response);
255 : }
256 1 : return LIBSPDM_STATUS_SUCCESS;
257 1 : case 0x5: {
258 : spdm_csr_response_t *spdm_response;
259 : size_t spdm_response_size;
260 : size_t transport_header_size;
261 :
262 1 : libspdm_read_requester_gen_csr((void *)&csr_data_pointer, &global_csr_len);
263 :
264 1 : spdm_response_size = sizeof(spdm_csr_response_t) + global_csr_len;
265 1 : transport_header_size = LIBSPDM_TEST_TRANSPORT_HEADER_SIZE;
266 1 : spdm_response = (void *)((uint8_t *)*response + transport_header_size);
267 :
268 1 : spdm_response->header.spdm_version = SPDM_MESSAGE_VERSION_13;
269 1 : spdm_response->header.request_response_code = SPDM_ERROR;
270 1 : spdm_response->header.param1 = SPDM_ERROR_CODE_RESET_REQUIRED;
271 1 : spdm_response->header.param2 = 1;
272 1 : spdm_response->csr_length = (uint16_t)global_csr_len;
273 1 : spdm_response->reserved = 0;
274 :
275 1 : libspdm_transport_test_encode_message(spdm_context, NULL, false,
276 : false, spdm_response_size,
277 : spdm_response, response_size,
278 : response);
279 : }
280 1 : return LIBSPDM_STATUS_SUCCESS;
281 1 : case 0x6: {
282 : spdm_error_response_t *spdm_response;
283 : size_t spdm_response_size;
284 : size_t transport_header_size;
285 :
286 1 : spdm_response_size = sizeof(spdm_error_response_t);
287 1 : transport_header_size = LIBSPDM_TEST_TRANSPORT_HEADER_SIZE;
288 1 : spdm_response = (void *)((uint8_t *)*response + transport_header_size);
289 :
290 1 : spdm_response->header.spdm_version = SPDM_MESSAGE_VERSION_13;
291 1 : spdm_response->header.request_response_code = SPDM_ERROR;
292 1 : spdm_response->header.param1 = SPDM_ERROR_CODE_RESET_REQUIRED;
293 1 : spdm_response->header.param2 = 1;
294 :
295 1 : libspdm_transport_test_encode_message(spdm_context, NULL, false,
296 : false, spdm_response_size,
297 : spdm_response, response_size,
298 : response);
299 : }
300 1 : return LIBSPDM_STATUS_SUCCESS;
301 0 : case 0x7:
302 0 : assert_true(false);
303 0 : return LIBSPDM_STATUS_SUCCESS;
304 0 : default:
305 0 : return LIBSPDM_STATUS_RECEIVE_FAIL;
306 : }
307 : }
308 :
309 : /**
310 : * Test 1: message could not be sent
311 : * Expected Behavior: get a RETURN_DEVICE_ERROR return code
312 : **/
313 1 : static void req_get_csr_case1(void **state)
314 : {
315 : libspdm_return_t status;
316 : libspdm_test_context_t *spdm_test_context;
317 : libspdm_context_t *spdm_context;
318 :
319 1 : uint8_t csr_form_get[LIBSPDM_MAX_CSR_SIZE] = {0};
320 : size_t csr_len;
321 :
322 1 : csr_len = LIBSPDM_MAX_CSR_SIZE;
323 :
324 1 : spdm_test_context = *state;
325 1 : spdm_context = spdm_test_context->spdm_context;
326 1 : spdm_test_context->case_id = 0x1;
327 1 : spdm_context->connection_info.version = SPDM_MESSAGE_VERSION_12 <<
328 : SPDM_VERSION_NUMBER_SHIFT_BIT;
329 :
330 1 : spdm_context->connection_info.connection_state =
331 : LIBSPDM_CONNECTION_STATE_NEGOTIATED;
332 1 : spdm_context->connection_info.capability.flags |=
333 : SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CSR_CAP;
334 :
335 : /*init req_info*/
336 1 : libspdm_gen_req_info();
337 :
338 1 : status = libspdm_get_csr(spdm_context, NULL, NULL, 0, NULL, 0, (void *)&csr_form_get,
339 : &csr_len);
340 :
341 1 : assert_int_equal(status, LIBSPDM_STATUS_SEND_FAIL);
342 1 : }
343 :
344 : /**
345 : * Test 2: Successful response to get csr
346 : * Expected Behavior: get a LIBSPDM_STATUS_SUCCESS return code
347 : **/
348 1 : static void req_get_csr_case2(void **state)
349 : {
350 : libspdm_return_t status;
351 : libspdm_test_context_t *spdm_test_context;
352 : libspdm_context_t *spdm_context;
353 :
354 1 : uint8_t csr_form_get[LIBSPDM_MAX_CSR_SIZE] = {0};
355 : size_t csr_len;
356 :
357 1 : csr_len = LIBSPDM_MAX_CSR_SIZE;
358 :
359 1 : spdm_test_context = *state;
360 1 : spdm_context = spdm_test_context->spdm_context;
361 1 : spdm_test_context->case_id = 0x2;
362 1 : spdm_context->connection_info.version = SPDM_MESSAGE_VERSION_12 <<
363 : SPDM_VERSION_NUMBER_SHIFT_BIT;
364 :
365 1 : spdm_context->connection_info.connection_state =
366 : LIBSPDM_CONNECTION_STATE_NEGOTIATED;
367 1 : spdm_context->connection_info.capability.flags |=
368 : SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CSR_CAP;
369 :
370 1 : status = libspdm_get_csr(spdm_context, NULL, NULL, 0, NULL, 0, (void *)&csr_form_get,
371 : &csr_len);
372 :
373 1 : assert_int_equal(status, LIBSPDM_STATUS_SUCCESS);
374 1 : assert_int_equal(csr_len, global_csr_len);
375 1 : assert_memory_equal(csr_form_get, csr_data_pointer, global_csr_len);
376 1 : }
377 :
378 : /**
379 : * Test 3: Successful response to get csr,
380 : * with a reset required
381 : * Expected Behavior: get a LIBSPDM_STATUS_SUCCESS return code
382 : **/
383 1 : static void req_get_csr_case3(void **state)
384 : {
385 : libspdm_return_t status;
386 : libspdm_test_context_t *spdm_test_context;
387 : libspdm_context_t *spdm_context;
388 :
389 1 : uint8_t csr_form_get[LIBSPDM_MAX_CSR_SIZE] = {0};
390 : size_t csr_len;
391 :
392 1 : csr_len = LIBSPDM_MAX_CSR_SIZE;
393 :
394 1 : spdm_test_context = *state;
395 1 : spdm_context = spdm_test_context->spdm_context;
396 1 : spdm_test_context->case_id = 0x3;
397 1 : spdm_context->connection_info.version = SPDM_MESSAGE_VERSION_12 <<
398 : SPDM_VERSION_NUMBER_SHIFT_BIT;
399 :
400 1 : spdm_context->connection_info.connection_state =
401 : LIBSPDM_CONNECTION_STATE_NEGOTIATED;
402 1 : spdm_context->connection_info.capability.flags |=
403 : SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CSR_CAP |
404 : SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CERT_INSTALL_RESET_CAP;
405 :
406 1 : status = libspdm_get_csr(spdm_context, NULL, NULL, 0, NULL, 0, (void *)&csr_form_get,
407 : &csr_len);
408 :
409 1 : assert_int_equal(status, LIBSPDM_STATUS_RESET_REQUIRED_PEER);
410 :
411 : /* Let's reset the responder and send the request again */
412 1 : spdm_context->connection_info.capability.flags &=
413 : ~SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CERT_INSTALL_RESET_CAP;
414 :
415 1 : status = libspdm_get_csr(spdm_context, NULL, NULL, 0, NULL, 0, (void *)&csr_form_get,
416 : &csr_len);
417 :
418 1 : assert_int_equal(status, LIBSPDM_STATUS_SUCCESS);
419 1 : assert_int_equal(csr_len, global_csr_len);
420 1 : assert_memory_equal(csr_form_get, csr_data_pointer, global_csr_len);
421 1 : }
422 :
423 : /**
424 : * Test 4: Send correct req_info and opaque_data
425 : * Expected Behavior: get a LIBSPDM_STATUS_SUCCESS return code and determine if req_info and opaque_data are correct
426 : **/
427 1 : static void req_get_csr_case4(void **state)
428 : {
429 : libspdm_return_t status;
430 : libspdm_test_context_t *spdm_test_context;
431 : libspdm_context_t *spdm_context;
432 :
433 1 : uint8_t csr_form_get[LIBSPDM_MAX_CSR_SIZE] = {0};
434 : size_t csr_len;
435 :
436 1 : csr_len = LIBSPDM_MAX_CSR_SIZE;
437 :
438 1 : spdm_test_context = *state;
439 1 : spdm_context = spdm_test_context->spdm_context;
440 1 : spdm_test_context->case_id = 0x4;
441 1 : spdm_context->connection_info.version = SPDM_MESSAGE_VERSION_12 <<
442 : SPDM_VERSION_NUMBER_SHIFT_BIT;
443 :
444 1 : spdm_context->connection_info.connection_state = LIBSPDM_CONNECTION_STATE_NEGOTIATED;
445 1 : spdm_context->local_context.capability.flags = 0;
446 1 : spdm_context->connection_info.capability.flags |= SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CSR_CAP;
447 :
448 1 : spdm_context->connection_info.algorithm.base_hash_algo = m_libspdm_use_hash_algo;
449 1 : spdm_context->connection_info.algorithm.base_asym_algo = m_libspdm_use_asym_algo;
450 :
451 1 : spdm_context->connection_info.algorithm.other_params_support =
452 : SPDM_ALGORITHMS_OPAQUE_DATA_FORMAT_0;
453 :
454 1 : status = libspdm_get_csr(spdm_context, NULL,
455 : right_req_info, right_req_info_size,
456 : m_csr_opaque_data, m_csr_opaque_data_size,
457 : (void *)&csr_form_get, &csr_len);
458 :
459 1 : assert_int_equal(status, LIBSPDM_STATUS_SUCCESS);
460 1 : assert_int_equal(csr_len, global_csr_len);
461 1 : assert_memory_equal(csr_form_get, csr_data_pointer, global_csr_len);
462 1 : }
463 :
464 : /**
465 : * Test 5: Successful response to libspdm_get_csr_ex,
466 : * with a reset required
467 : * Expected Behavior: get a LIBSPDM_STATUS_RESET_REQUIRED_PEER return code and available csr_tracking_tag
468 : **/
469 1 : static void req_get_csr_case5(void **state)
470 : {
471 : libspdm_test_context_t *spdm_test_context;
472 : libspdm_context_t *spdm_context;
473 : #if LIBSPDM_ENABLE_CAPABILITY_CSR_CAP_EX
474 : libspdm_return_t status;
475 1 : uint8_t csr_form_get[LIBSPDM_MAX_CSR_SIZE] = {0};
476 : size_t csr_len;
477 : uint8_t reset_csr_tracking_tag;
478 :
479 1 : csr_len = LIBSPDM_MAX_CSR_SIZE;
480 1 : reset_csr_tracking_tag = 0;
481 : #endif /* LIBSPDM_ENABLE_CAPABILITY_CSR_CAP_EX*/
482 1 : spdm_test_context = *state;
483 1 : spdm_context = spdm_test_context->spdm_context;
484 1 : spdm_test_context->case_id = 0x5;
485 1 : spdm_context->connection_info.version = SPDM_MESSAGE_VERSION_13 <<
486 : SPDM_VERSION_NUMBER_SHIFT_BIT;
487 :
488 1 : spdm_context->connection_info.connection_state =
489 : LIBSPDM_CONNECTION_STATE_NEGOTIATED;
490 1 : spdm_context->connection_info.capability.flags |=
491 : SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CSR_CAP |
492 : SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CERT_INSTALL_RESET_CAP;
493 :
494 : #if LIBSPDM_ENABLE_CAPABILITY_CSR_CAP_EX
495 1 : status = libspdm_get_csr_ex(spdm_context, NULL, NULL, 0, NULL, 0, (void *)&csr_form_get,
496 : &csr_len, 0, 0, &reset_csr_tracking_tag);
497 :
498 1 : assert_int_equal(status, LIBSPDM_STATUS_RESET_REQUIRED_PEER);
499 1 : assert_int_equal(reset_csr_tracking_tag, 1);
500 : #endif /*LIBSPDM_ENABLE_CAPABILITY_CSR_CAP_EX*/
501 1 : }
502 :
503 : /**
504 : * Test 6: A 1.3 Responder returns ResetRequired when its CERT_INSTALL_RESET_CAP is 0.
505 : * Expected Behavior: libspdm returns LIBSPDM_STATUS_ERROR_PEER since Responder should
506 : * not produce that error message unless CERT_INSTALL_RESET_CAP is 1.
507 : **/
508 1 : static void req_get_csr_case6(void **state)
509 : {
510 : libspdm_return_t status;
511 : libspdm_test_context_t *spdm_test_context;
512 : libspdm_context_t *spdm_context;
513 :
514 1 : uint8_t csr_form_get[LIBSPDM_MAX_CSR_SIZE] = {0};
515 : size_t csr_len;
516 :
517 1 : csr_len = LIBSPDM_MAX_CSR_SIZE;
518 :
519 1 : spdm_test_context = *state;
520 1 : spdm_context = spdm_test_context->spdm_context;
521 1 : spdm_test_context->case_id = 0x6;
522 1 : spdm_context->connection_info.version = SPDM_MESSAGE_VERSION_13 <<
523 : SPDM_VERSION_NUMBER_SHIFT_BIT;
524 :
525 1 : spdm_context->connection_info.connection_state = LIBSPDM_CONNECTION_STATE_NEGOTIATED;
526 1 : spdm_context->local_context.capability.flags = 0;
527 : /* Don't set CERT_INSTALL_RESET_CAP. */
528 1 : spdm_context->connection_info.capability.flags = SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CSR_CAP;
529 :
530 1 : spdm_context->connection_info.algorithm.base_hash_algo = m_libspdm_use_hash_algo;
531 1 : spdm_context->connection_info.algorithm.base_asym_algo = m_libspdm_use_asym_algo;
532 :
533 1 : spdm_context->connection_info.algorithm.other_params_support =
534 : SPDM_ALGORITHMS_OPAQUE_DATA_FORMAT_0;
535 :
536 1 : status = libspdm_get_csr(spdm_context, NULL,
537 : right_req_info, right_req_info_size,
538 : m_csr_opaque_data, m_csr_opaque_data_size,
539 : (void *)&csr_form_get, &csr_len);
540 :
541 1 : assert_int_equal(status, LIBSPDM_STATUS_ERROR_PEER);
542 1 : }
543 :
544 : /**
545 : * Test 7: Illegal combination of MULTI_KEY_CONN_RSP = true and CSRCertModel = 0.
546 : * Expected Behavior: returns LIBSPDM_STATUS_INVALID_PARAMETER.
547 : **/
548 1 : static void req_get_csr_case7(void **state)
549 : {
550 : #if LIBSPDM_ENABLE_CAPABILITY_CSR_CAP_EX
551 : libspdm_return_t status;
552 : libspdm_test_context_t *spdm_test_context;
553 : libspdm_context_t *spdm_context;
554 :
555 1 : uint8_t csr_form_get[LIBSPDM_MAX_CSR_SIZE] = {0};
556 : size_t csr_len;
557 : uint8_t tracking_tag;
558 :
559 1 : csr_len = LIBSPDM_MAX_CSR_SIZE;
560 :
561 1 : spdm_test_context = *state;
562 1 : spdm_context = spdm_test_context->spdm_context;
563 1 : spdm_test_context->case_id = 0x7;
564 1 : spdm_context->connection_info.version = SPDM_MESSAGE_VERSION_13 <<
565 : SPDM_VERSION_NUMBER_SHIFT_BIT;
566 :
567 1 : spdm_context->connection_info.connection_state = LIBSPDM_CONNECTION_STATE_NEGOTIATED;
568 1 : spdm_context->local_context.capability.flags = 0;
569 1 : spdm_context->connection_info.capability.flags = SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_CSR_CAP;
570 1 : spdm_context->connection_info.multi_key_conn_rsp = true;
571 :
572 1 : spdm_context->connection_info.algorithm.base_hash_algo = m_libspdm_use_hash_algo;
573 1 : spdm_context->connection_info.algorithm.base_asym_algo = m_libspdm_use_asym_algo;
574 :
575 1 : spdm_context->connection_info.algorithm.other_params_support =
576 : SPDM_ALGORITHMS_OPAQUE_DATA_FORMAT_0;
577 :
578 1 : status = libspdm_get_csr_ex(spdm_context, NULL, NULL, 0, NULL, 0, (void *)&csr_form_get,
579 : &csr_len, SPDM_CERTIFICATE_INFO_CERT_MODEL_NONE, 1, &tracking_tag);
580 :
581 1 : assert_int_equal(status, LIBSPDM_STATUS_INVALID_PARAMETER);
582 : #endif /* LIBSPDM_ENABLE_CAPABILITY_CSR_CAP_EX */
583 1 : }
584 :
585 1 : int libspdm_req_get_csr_test(void)
586 : {
587 1 : const struct CMUnitTest test_cases[] = {
588 : /* SendRequest failed*/
589 : cmocka_unit_test(req_get_csr_case1),
590 : /* Successful response to get csr*/
591 : cmocka_unit_test(req_get_csr_case2),
592 : /* Successful response to get csr with a reset required */
593 : cmocka_unit_test(req_get_csr_case3),
594 : /* Send req_info and opaque_data Successful response to get csr */
595 : cmocka_unit_test(req_get_csr_case4),
596 : /* Successful response to libspdm_get_csr_ex with a reset required */
597 : cmocka_unit_test(req_get_csr_case5),
598 : /* Illegal ResetRequired error response. */
599 : cmocka_unit_test(req_get_csr_case6),
600 : cmocka_unit_test(req_get_csr_case7),
601 : };
602 :
603 1 : libspdm_test_context_t test_context = {
604 : LIBSPDM_TEST_CONTEXT_VERSION,
605 : true,
606 : send_message,
607 : receive_message,
608 : };
609 :
610 1 : libspdm_setup_test_context(&test_context);
611 :
612 : /*ensure that cached.csr exists in test_csr at the beginning*/
613 1 : libspdm_clear_cached_csr();
614 :
615 1 : return cmocka_run_group_tests(test_cases,
616 : libspdm_unit_test_group_setup,
617 : libspdm_unit_test_group_teardown);
618 : }
619 :
620 : #endif /*LIBSPDM_ENABLE_CAPABILITY_CSR_CAP*/
|