LCOV - code coverage report
Current view: top level - library/spdm_responder_lib - libspdm_rsp_measurements.c (source / functions) Coverage Total Hit
Test: coverage.info Lines: 84.1 % 214 180
Test Date: 2026-03-15 08:15:47 Functions: 66.7 % 3 2

            Line data    Source code
       1              : /**
       2              :  *  Copyright Notice:
       3              :  *  Copyright 2021-2026 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 "internal/libspdm_responder_lib.h"
       8              : 
       9              : #if LIBSPDM_ENABLE_CAPABILITY_MEAS_CAP
      10              : 
      11            0 : libspdm_return_t libspdm_register_meas_log_reset_callback(
      12              :     void *spdm_context, libspdm_meas_log_reset_callback_func spdm_meas_log_reset_callback)
      13              : {
      14            0 :     libspdm_context_t *context = (libspdm_context_t *)spdm_context;
      15            0 :     context->spdm_meas_log_reset_callback = spdm_meas_log_reset_callback;
      16            0 :     return LIBSPDM_STATUS_SUCCESS;
      17              : }
      18              : 
      19           16 : bool libspdm_generate_measurement_signature(libspdm_context_t *spdm_context,
      20              :                                             libspdm_session_info_t *session_info,
      21              :                                             uint8_t slot_id,
      22              :                                             uint8_t *signature)
      23              : {
      24              :     size_t signature_size;
      25              :     bool result;
      26              : #if LIBSPDM_RECORD_TRANSCRIPT_DATA_SUPPORT
      27              :     libspdm_l1l2_managed_buffer_t l1l2;
      28              :     uint8_t *l1l2_buffer;
      29              :     size_t l1l2_buffer_size;
      30              : #else
      31              :     uint8_t l1l2_hash[LIBSPDM_MAX_HASH_SIZE];
      32              :     size_t l1l2_hash_size;
      33              : #endif
      34              : 
      35              : #if LIBSPDM_RECORD_TRANSCRIPT_DATA_SUPPORT
      36              :     result = libspdm_calculate_l1l2(spdm_context, session_info, &l1l2);
      37              : #else
      38           16 :     l1l2_hash_size = sizeof(l1l2_hash);
      39           16 :     result = libspdm_calculate_l1l2_hash(spdm_context, session_info, &l1l2_hash_size, l1l2_hash);
      40              : #endif
      41           16 :     libspdm_reset_message_m(spdm_context, session_info);
      42           16 :     if (!result) {
      43            0 :         return false;
      44              :     }
      45              : 
      46           16 :     if (spdm_context->connection_info.algorithm.pqc_asym_algo != 0) {
      47            0 :         signature_size = libspdm_get_pqc_asym_signature_size(
      48              :             spdm_context->connection_info.algorithm.pqc_asym_algo);
      49              :     } else {
      50           16 :         signature_size = libspdm_get_asym_signature_size(
      51              :             spdm_context->connection_info.algorithm.base_asym_algo);
      52              :     }
      53              : #if LIBSPDM_RECORD_TRANSCRIPT_DATA_SUPPORT
      54              :     l1l2_buffer = libspdm_get_managed_buffer(&l1l2);
      55              :     l1l2_buffer_size = libspdm_get_managed_buffer_size(&l1l2);
      56              : 
      57              :     result = libspdm_responder_data_sign(
      58              :         spdm_context,
      59              :         spdm_context->connection_info.version,
      60              :         libspdm_slot_id_to_key_pair_id(spdm_context, slot_id, false),
      61              :         SPDM_MEASUREMENTS,
      62              :         spdm_context->connection_info.algorithm.base_asym_algo,
      63              :         spdm_context->connection_info.algorithm.pqc_asym_algo,
      64              :         spdm_context->connection_info.algorithm.base_hash_algo,
      65              :         false, l1l2_buffer, l1l2_buffer_size, signature, &signature_size);
      66              : #else
      67           32 :     result = libspdm_responder_data_sign(
      68              :         spdm_context,
      69           16 :         spdm_context->connection_info.version,
      70           16 :         libspdm_slot_id_to_key_pair_id(spdm_context, slot_id, false),
      71              :         SPDM_MEASUREMENTS,
      72              :         spdm_context->connection_info.algorithm.base_asym_algo,
      73              :         spdm_context->connection_info.algorithm.pqc_asym_algo,
      74              :         spdm_context->connection_info.algorithm.base_hash_algo,
      75              :         true, l1l2_hash, l1l2_hash_size, signature, &signature_size);
      76              : #endif
      77           16 :     return result;
      78              : }
      79          137 : libspdm_return_t libspdm_get_response_measurements(libspdm_context_t *spdm_context,
      80              :                                                    size_t request_size,
      81              :                                                    const void *request,
      82              :                                                    size_t *response_size,
      83              :                                                    void *response)
      84              : {
      85              :     const spdm_get_measurements_request_t *spdm_request;
      86              :     size_t spdm_request_size;
      87              :     spdm_measurements_response_t *spdm_response;
      88              :     size_t spdm_response_size;
      89              :     libspdm_return_t status;
      90              :     size_t signature_size;
      91              :     uint8_t slot_id_param;
      92              :     uint8_t measurements_index;
      93              :     uint8_t measurements_count;
      94              :     uint8_t *measurements;
      95              :     size_t measurements_size;
      96              :     uint8_t *opaque_data;
      97              :     size_t opaque_data_size;
      98              :     size_t meas_opaque_buffer_size;
      99              :     bool ret;
     100              :     libspdm_session_info_t *session_info;
     101              :     libspdm_session_state_t session_state;
     102              :     uint8_t content_changed;
     103              :     uint8_t *fill_response_ptr;
     104              :     size_t request_context_size;
     105              :     const void *request_context;
     106              :     const uint32_t *session_id_ptr;
     107              : 
     108          137 :     spdm_request = request;
     109              : 
     110              :     /* -=[Check Parameters Phase]=- */
     111          137 :     LIBSPDM_ASSERT(spdm_request->header.request_response_code == SPDM_GET_MEASUREMENTS);
     112              : 
     113          137 :     if (!spdm_context->last_spdm_request_session_id_valid) {
     114          136 :         session_info = NULL;
     115          136 :         session_id_ptr = NULL;
     116              :     } else {
     117            1 :         session_id_ptr = &spdm_context->last_spdm_request_session_id;
     118            1 :         session_info = libspdm_get_session_info_via_session_id(
     119              :             spdm_context,
     120              :             spdm_context->last_spdm_request_session_id);
     121            1 :         if (session_info == NULL) {
     122              :             /* do not reset message_m because it is unclear which context it should be used. */
     123            0 :             return libspdm_generate_error_response(
     124              :                 spdm_context,
     125              :                 SPDM_ERROR_CODE_UNEXPECTED_REQUEST, 0,
     126              :                 response_size, response);
     127              :         }
     128            1 :         session_state = libspdm_secured_message_get_session_state(
     129              :             session_info->secured_message_context);
     130            1 :         if (session_state != LIBSPDM_SESSION_STATE_ESTABLISHED) {
     131            0 :             libspdm_reset_message_m(spdm_context, session_info);
     132            0 :             return libspdm_generate_error_response(
     133              :                 spdm_context,
     134              :                 SPDM_ERROR_CODE_UNEXPECTED_REQUEST, 0,
     135              :                 response_size, response);
     136              :         }
     137              :     }
     138              : 
     139          137 :     if (spdm_request->header.spdm_version != libspdm_get_connection_version(spdm_context)) {
     140            0 :         libspdm_reset_message_m(spdm_context, session_info);
     141            0 :         return libspdm_generate_error_response(spdm_context,
     142              :                                                SPDM_ERROR_CODE_VERSION_MISMATCH, 0,
     143              :                                                response_size, response);
     144              :     }
     145          137 :     if (spdm_context->response_state != LIBSPDM_RESPONSE_STATE_NORMAL) {
     146              : #if LIBSPDM_RESPOND_IF_READY_SUPPORT
     147            3 :         if (spdm_context->response_state != LIBSPDM_RESPONSE_STATE_NOT_READY) {
     148              : #endif
     149            2 :         libspdm_reset_message_m(spdm_context, session_info);
     150              : #if LIBSPDM_RESPOND_IF_READY_SUPPORT
     151              :     }
     152              : #endif
     153            3 :         return libspdm_responder_handle_response_state(
     154              :             spdm_context,
     155            3 :             spdm_request->header.request_response_code,
     156              :             response_size, response);
     157              :     }
     158              :     /* check local context here, because meas_cap is reserved for requester.*/
     159          134 :     if (!libspdm_is_capabilities_flag_supported(
     160              :             spdm_context, false, 0,
     161              :             SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_MEAS_CAP)) {
     162            1 :         libspdm_reset_message_m(spdm_context, session_info);
     163            1 :         return libspdm_generate_error_response(
     164              :             spdm_context, SPDM_ERROR_CODE_UNSUPPORTED_REQUEST,
     165              :             SPDM_GET_MEASUREMENTS, response_size, response);
     166              :     }
     167          133 :     if ((spdm_context->connection_info.algorithm.measurement_spec == 0) ||
     168          133 :         (spdm_context->connection_info.algorithm.measurement_hash_algo == 0) ) {
     169            0 :         libspdm_reset_message_m(spdm_context, session_info);
     170            0 :         return libspdm_generate_error_response(
     171              :             spdm_context, SPDM_ERROR_CODE_UNEXPECTED_REQUEST,
     172              :             0, response_size, response);
     173              :     }
     174          133 :     if (spdm_context->connection_info.connection_state <
     175              :         LIBSPDM_CONNECTION_STATE_NEGOTIATED) {
     176            1 :         libspdm_reset_message_m(spdm_context, session_info);
     177            1 :         return libspdm_generate_error_response(
     178              :             spdm_context,
     179              :             SPDM_ERROR_CODE_UNEXPECTED_REQUEST, 0,
     180              :             response_size, response);
     181              :     }
     182              : 
     183          132 :     if ((spdm_request->header.param1 &
     184              :          SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) != 0) {
     185           24 :         if (spdm_request->header.spdm_version >= SPDM_MESSAGE_VERSION_11) {
     186           13 :             if (request_size < sizeof(spdm_get_measurements_request_t)) {
     187            4 :                 libspdm_reset_message_m(spdm_context, session_info);
     188            4 :                 return libspdm_generate_error_response(
     189              :                     spdm_context,
     190              :                     SPDM_ERROR_CODE_INVALID_REQUEST, 0,
     191              :                     response_size, response);
     192              :             }
     193            9 :             spdm_request_size = sizeof(spdm_get_measurements_request_t);
     194              :         } else {
     195           11 :             if (request_size <
     196              :                 sizeof(spdm_get_measurements_request_t) -
     197              :                 sizeof(spdm_request->slot_id_param)) {
     198            1 :                 libspdm_reset_message_m(spdm_context, session_info);
     199            1 :                 return libspdm_generate_error_response(
     200              :                     spdm_context,
     201              :                     SPDM_ERROR_CODE_INVALID_REQUEST, 0,
     202              :                     response_size, response);
     203              :             }
     204           10 :             spdm_request_size = sizeof(spdm_get_measurements_request_t) -
     205              :                                 sizeof(spdm_request->slot_id_param);
     206              :         }
     207              :     } else {
     208          108 :         if (request_size < sizeof(spdm_message_header_t)) {
     209            0 :             libspdm_reset_message_m(spdm_context, session_info);
     210            0 :             return libspdm_generate_error_response(
     211              :                 spdm_context, SPDM_ERROR_CODE_INVALID_REQUEST,
     212              :                 0, response_size, response);
     213              :         }
     214          108 :         spdm_request_size = sizeof(spdm_message_header_t);
     215              :     }
     216          127 :     if (spdm_request->header.spdm_version >= SPDM_MESSAGE_VERSION_13) {
     217            2 :         if (request_size < spdm_request_size + SPDM_REQ_CONTEXT_SIZE) {
     218            0 :             libspdm_reset_message_m(spdm_context, session_info);
     219            0 :             return libspdm_generate_error_response(
     220              :                 spdm_context, SPDM_ERROR_CODE_INVALID_REQUEST,
     221              :                 0, response_size, response);
     222              :         }
     223            2 :         spdm_request_size += SPDM_REQ_CONTEXT_SIZE;
     224              :     }
     225              : 
     226          127 :     if ((spdm_request->header.param1 &
     227              :          SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) != 0) {
     228           19 :         if (!libspdm_is_capabilities_flag_supported(
     229              :                 spdm_context, false, 0,
     230              :                 SPDM_GET_CAPABILITIES_RESPONSE_FLAGS_MEAS_CAP_SIG)) {
     231            1 :             libspdm_reset_message_m(spdm_context, session_info);
     232            1 :             return libspdm_generate_error_response(
     233              :                 spdm_context, SPDM_ERROR_CODE_INVALID_REQUEST,
     234              :                 0, response_size, response);
     235              :         }
     236              :     }
     237              : 
     238          126 :     if ((spdm_request->header.param1 &
     239              :          SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) == 0) {
     240          108 :         signature_size = 0;
     241              :     } else {
     242           18 :         if (spdm_context->connection_info.algorithm.pqc_asym_algo != 0) {
     243            0 :             signature_size = libspdm_get_pqc_asym_signature_size(
     244              :                 spdm_context->connection_info.algorithm.pqc_asym_algo);
     245              :         } else {
     246           18 :             signature_size = libspdm_get_asym_signature_size(
     247              :                 spdm_context->connection_info.algorithm.base_asym_algo);
     248              :         }
     249              :     }
     250              : 
     251          126 :     if (spdm_request->header.spdm_version >= SPDM_MESSAGE_VERSION_13) {
     252            2 :         request_context_size = SPDM_REQ_CONTEXT_SIZE;
     253              : 
     254            2 :         if ((spdm_request->header.param1 &
     255              :              SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) == 0) {
     256            1 :             request_context = (const uint8_t *)spdm_request + sizeof(spdm_message_header_t);
     257              :         } else {
     258            1 :             request_context = spdm_request + 1;
     259              :         }
     260              :     } else {
     261          124 :         request_context_size = 0;
     262          124 :         request_context = NULL;
     263              :     }
     264              : 
     265              :     /* response_size should be large enough to hold a MEASUREMENTS response without
     266              :      * measurements or opaque data. */
     267          126 :     LIBSPDM_ASSERT(*response_size >= (sizeof(spdm_measurements_response_t) +
     268              :                                       SPDM_NONCE_SIZE + sizeof(uint16_t) + signature_size));
     269              : 
     270          126 :     meas_opaque_buffer_size = *response_size - (sizeof(spdm_measurements_response_t) +
     271              :                                                 SPDM_NONCE_SIZE + sizeof(uint16_t) +
     272              :                                                 signature_size);
     273              : 
     274          126 :     libspdm_zero_mem(response, *response_size);
     275              : 
     276          126 :     measurements_index = spdm_request->header.param2;
     277          126 :     measurements_count = 0;
     278          126 :     measurements = (uint8_t*)response + sizeof(spdm_measurements_response_t);
     279          126 :     measurements_size = meas_opaque_buffer_size;
     280              : 
     281          244 :     status = libspdm_measurement_collection(
     282              :         spdm_context,
     283              :         session_id_ptr,
     284          126 :         spdm_context->connection_info.version,
     285          126 :         spdm_context->connection_info.algorithm.measurement_spec,
     286              :         spdm_context->connection_info.algorithm.measurement_hash_algo,
     287              :         measurements_index,
     288          126 :         spdm_request->header.param1,
     289          126 :         ((spdm_request->header.param1 &
     290              :           SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) != 0) ?
     291              :         spdm_request->nonce : NULL,
     292          126 :         ((spdm_request->header.param1 &
     293           18 :           SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) != 0 &&
     294           18 :          spdm_request->header.spdm_version >= SPDM_MESSAGE_VERSION_11) ?
     295            8 :         (spdm_request->slot_id_param & SPDM_GET_MEASUREMENTS_REQUEST_SLOT_ID_MASK) : 0,
     296              :         request_context_size,
     297              :         request_context,
     298              :         &content_changed,
     299              :         &measurements_count,
     300              :         measurements,
     301              :         &measurements_size);
     302              : 
     303          126 :     if (LIBSPDM_STATUS_IS_ERROR(status)) {
     304            1 :         if (status == LIBSPDM_STATUS_MEAS_INVALID_INDEX) {
     305            1 :             libspdm_reset_message_m(spdm_context, session_info);
     306            1 :             return libspdm_generate_error_response(
     307              :                 spdm_context, SPDM_ERROR_CODE_INVALID_REQUEST,
     308              :                 0, response_size, response);
     309              :         } else {
     310            0 :             libspdm_reset_message_m(spdm_context, session_info);
     311            0 :             return libspdm_generate_error_response(
     312              :                 spdm_context, SPDM_ERROR_CODE_UNSPECIFIED,
     313              :                 0, response_size, response);
     314              :         }
     315              :     }
     316              : 
     317          125 :     LIBSPDM_ASSERT(measurements_count != 0);
     318          125 :     LIBSPDM_ASSERT((measurements_index == 0) || (measurements_size > 0));
     319          125 :     LIBSPDM_ASSERT(measurements_size <= SPDM_MAX_MEASUREMENT_RECORD_LENGTH);
     320          125 :     LIBSPDM_ASSERT(measurements_size <= meas_opaque_buffer_size);
     321              : 
     322          125 :     if (measurements_index == 0) {
     323           11 :         measurements_size = 0;
     324              :     }
     325              : 
     326          125 :     opaque_data =
     327              :         (uint8_t*)response + sizeof(spdm_measurements_response_t) + measurements_size +
     328          125 :         SPDM_NONCE_SIZE + sizeof(uint16_t);
     329              : 
     330          125 :     if ((libspdm_get_connection_version(spdm_context) >= SPDM_MESSAGE_VERSION_12) &&
     331            8 :         ((spdm_context->connection_info.algorithm.other_params_support &
     332              :           SPDM_ALGORITHMS_OPAQUE_DATA_FORMAT_MASK) == SPDM_ALGORITHMS_OPAQUE_DATA_FORMAT_NONE)) {
     333            4 :         opaque_data_size = 0;
     334              :     } else {
     335          121 :         opaque_data_size = meas_opaque_buffer_size - measurements_size;
     336              : 
     337          121 :         ret = libspdm_measurement_opaque_data(
     338              :             spdm_context,
     339              :             session_id_ptr,
     340          121 :             spdm_context->connection_info.version,
     341          121 :             spdm_context->connection_info.algorithm.measurement_spec,
     342              :             spdm_context->connection_info.algorithm.measurement_hash_algo,
     343              :             measurements_index,
     344          121 :             spdm_request->header.param1,
     345              :             request_context_size,
     346              :             request_context,
     347              :             opaque_data,
     348              :             &opaque_data_size);
     349              : 
     350          121 :         if (!ret) {
     351            0 :             libspdm_reset_message_m(spdm_context, session_info);
     352            0 :             return libspdm_generate_error_response(
     353              :                 spdm_context, SPDM_ERROR_CODE_UNSPECIFIED,
     354              :                 0, response_size, response);
     355              :         }
     356              :     }
     357              : 
     358          125 :     LIBSPDM_ASSERT(opaque_data_size <= (meas_opaque_buffer_size - measurements_size));
     359              : 
     360          125 :     spdm_response_size =
     361              :         sizeof(spdm_measurements_response_t) + measurements_size + SPDM_NONCE_SIZE +
     362          125 :         sizeof(uint16_t) + opaque_data_size + signature_size;
     363          125 :     if (spdm_request->header.spdm_version >= SPDM_MESSAGE_VERSION_13) {
     364            2 :         spdm_response_size += SPDM_REQ_CONTEXT_SIZE;
     365              :     }
     366              : 
     367          125 :     LIBSPDM_ASSERT(*response_size >= spdm_response_size);
     368              : 
     369          125 :     *response_size = spdm_response_size;
     370          125 :     spdm_response = response;
     371              : 
     372          125 :     switch (spdm_request->header.param2) {
     373           11 :     case SPDM_GET_MEASUREMENTS_REQUEST_MEASUREMENT_OPERATION_TOTAL_NUMBER_OF_MEASUREMENTS:
     374           11 :         spdm_response->header.spdm_version = spdm_request->header.spdm_version;
     375           11 :         spdm_response->header.request_response_code = SPDM_MEASUREMENTS;
     376           11 :         spdm_response->header.param1 = measurements_count;
     377           11 :         spdm_response->header.param2 = 0;
     378           11 :         spdm_response->number_of_blocks = 0;
     379           11 :         libspdm_write_uint24(spdm_response->measurement_record_length, 0);
     380           11 :         break;
     381            5 :     case SPDM_GET_MEASUREMENTS_REQUEST_MEASUREMENT_OPERATION_ALL_MEASUREMENTS:
     382           45 :         LIBSPDM_DEBUG_CODE(
     383              :             uint8_t index;
     384              :             size_t debug_measurements_record_size;
     385              :             size_t debug_measurements_block_size;
     386              :             spdm_measurement_block_dmtf_t *debug_measurement_block;
     387              : 
     388              :             debug_measurements_record_size = 0;
     389              :             debug_measurement_block = (void *)measurements;
     390              :             for (index = 0; index < measurements_count; index++) {
     391              :             debug_measurements_block_size =
     392              :                 sizeof(spdm_measurement_block_dmtf_t) +
     393              :                 debug_measurement_block->measurement_block_dmtf_header
     394              :                 .dmtf_spec_measurement_value_size;
     395              :             debug_measurements_record_size += debug_measurements_block_size;
     396              :             debug_measurement_block =
     397              :                 (void *)((size_t)debug_measurement_block + debug_measurements_block_size);
     398              :         }
     399              :             LIBSPDM_ASSERT(debug_measurements_record_size == measurements_size);
     400              :             );
     401              : 
     402            5 :         spdm_response->header.spdm_version = spdm_request->header.spdm_version;
     403            5 :         spdm_response->header.request_response_code = SPDM_MEASUREMENTS;
     404            5 :         spdm_response->header.param1 = 0;
     405            5 :         spdm_response->header.param2 = 0;
     406            5 :         spdm_response->number_of_blocks = measurements_count;
     407            5 :         libspdm_write_uint24(spdm_response->measurement_record_length, (uint32_t)measurements_size);
     408            5 :         break;
     409          109 :     default:
     410          109 :         LIBSPDM_ASSERT(measurements_count == 1);
     411              : 
     412          109 :         spdm_response->header.spdm_version = spdm_request->header.spdm_version;
     413          109 :         spdm_response->header.request_response_code = SPDM_MEASUREMENTS;
     414          109 :         spdm_response->header.param1 = 0;
     415          109 :         spdm_response->header.param2 = 0;
     416          109 :         spdm_response->number_of_blocks = 1;
     417          109 :         libspdm_write_uint24(spdm_response->measurement_record_length, (uint32_t)measurements_size);
     418          109 :         break;
     419              :     }
     420              : 
     421          125 :     if ((spdm_request->header.param1 &
     422              :          SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) != 0) {
     423           18 :         if (spdm_response->header.spdm_version >= SPDM_MESSAGE_VERSION_11) {
     424            8 :             slot_id_param = spdm_request->slot_id_param &
     425              :                             SPDM_GET_MEASUREMENTS_REQUEST_SLOT_ID_MASK;
     426            8 :             if ((slot_id_param != 0xF) && (slot_id_param >= SPDM_MAX_SLOT_COUNT)) {
     427            1 :                 libspdm_reset_message_m(spdm_context, session_info);
     428            1 :                 return libspdm_generate_error_response(
     429              :                     spdm_context,
     430              :                     SPDM_ERROR_CODE_INVALID_REQUEST, 0,
     431              :                     response_size, response);
     432              :             }
     433            7 :             if (slot_id_param != 0xF) {
     434            6 :                 if (spdm_context->local_context
     435            6 :                     .local_cert_chain_provision[slot_id_param] == NULL) {
     436            0 :                     libspdm_reset_message_m(spdm_context, session_info);
     437            0 :                     return libspdm_generate_error_response(
     438              :                         spdm_context, SPDM_ERROR_CODE_INVALID_REQUEST,
     439              :                         0, response_size, response);
     440              :                 }
     441              :             } else {
     442            1 :                 if (spdm_context->local_context
     443            1 :                     .local_public_key_provision == NULL) {
     444            0 :                     libspdm_reset_message_m(spdm_context, session_info);
     445            0 :                     return libspdm_generate_error_response(
     446              :                         spdm_context, SPDM_ERROR_CODE_INVALID_REQUEST,
     447              :                         0, response_size, response);
     448              :                 }
     449              :             }
     450              : 
     451            7 :             if ((spdm_request->header.spdm_version >= SPDM_MESSAGE_VERSION_13) &&
     452            1 :                 spdm_context->connection_info.multi_key_conn_rsp &&
     453              :                 (slot_id_param != 0xF)) {
     454            1 :                 if ((spdm_context->local_context.local_key_usage_bit_mask[slot_id_param] &
     455              :                      SPDM_KEY_USAGE_BIT_MASK_MEASUREMENT_USE) == 0) {
     456            1 :                     return libspdm_generate_error_response(
     457              :                         spdm_context, SPDM_ERROR_CODE_INVALID_REQUEST,
     458              :                         0, response_size, response);
     459              :                 }
     460              :             }
     461              : 
     462            6 :             spdm_response->header.param2 = slot_id_param;
     463            6 :             if (spdm_response->header.spdm_version >= SPDM_MESSAGE_VERSION_12) {
     464            5 :                 spdm_response->header.param2 = slot_id_param |
     465            5 :                                                (content_changed &
     466              :                                                 SPDM_MEASUREMENTS_RESPONSE_CONTENT_CHANGE_MASK);
     467              :             }
     468              :         }
     469              :     }
     470              : 
     471          123 :     fill_response_ptr =
     472          123 :         (uint8_t*)response + sizeof(spdm_measurements_response_t) + measurements_size;
     473              : 
     474          123 :     if (!libspdm_get_random_number(SPDM_NONCE_SIZE, fill_response_ptr)) {
     475            0 :         libspdm_reset_message_m(spdm_context, session_info);
     476            0 :         return libspdm_generate_error_response(spdm_context,
     477              :                                                SPDM_ERROR_CODE_UNSPECIFIED, 0,
     478              :                                                response_size, response);
     479              :     }
     480          123 :     fill_response_ptr += SPDM_NONCE_SIZE;
     481              : 
     482          123 :     libspdm_write_uint16(fill_response_ptr, (uint16_t)opaque_data_size);
     483          123 :     fill_response_ptr += sizeof(uint16_t);
     484              : 
     485          123 :     fill_response_ptr += opaque_data_size;
     486              : 
     487          123 :     if (spdm_request->header.spdm_version >= SPDM_MESSAGE_VERSION_13) {
     488            1 :         libspdm_copy_mem(fill_response_ptr, SPDM_REQ_CONTEXT_SIZE,
     489            1 :                          (const uint8_t *)spdm_request + spdm_request_size - SPDM_REQ_CONTEXT_SIZE,
     490              :                          SPDM_REQ_CONTEXT_SIZE);
     491            1 :         fill_response_ptr += SPDM_REQ_CONTEXT_SIZE;
     492              :     }
     493              : 
     494          123 :     libspdm_reset_message_buffer_via_request_code(spdm_context, session_info,
     495          123 :                                                   spdm_request->header.request_response_code);
     496              : 
     497          123 :     status = libspdm_append_message_m(spdm_context, session_info, spdm_request, spdm_request_size);
     498          123 :     if (LIBSPDM_STATUS_IS_ERROR(status)) {
     499            0 :         libspdm_reset_message_m(spdm_context, session_info);
     500            0 :         return libspdm_generate_error_response(spdm_context,
     501              :                                                SPDM_ERROR_CODE_UNSPECIFIED, 0,
     502              :                                                response_size, response);
     503              :     }
     504              : 
     505          123 :     status = libspdm_append_message_m(spdm_context, session_info,
     506          123 :                                       spdm_response, *response_size - signature_size);
     507          123 :     if (LIBSPDM_STATUS_IS_ERROR(status)) {
     508            0 :         libspdm_reset_message_m(spdm_context, session_info);
     509            0 :         return libspdm_generate_error_response(spdm_context,
     510              :                                                SPDM_ERROR_CODE_UNSPECIFIED, 0,
     511              :                                                response_size, response);
     512              :     }
     513              : 
     514          123 :     if ((spdm_request->header.param1 &
     515              :          SPDM_GET_MEASUREMENTS_REQUEST_ATTRIBUTES_GENERATE_SIGNATURE) != 0) {
     516              : 
     517           16 :         ret = libspdm_generate_measurement_signature(
     518              :             spdm_context, session_info, slot_id_param, fill_response_ptr);
     519              : 
     520           16 :         if (!ret) {
     521            0 :             libspdm_reset_message_m(spdm_context, session_info);
     522            0 :             return libspdm_generate_error_response(
     523              :                 spdm_context,
     524              :                 SPDM_ERROR_CODE_UNSPECIFIED,
     525              :                 0,
     526              :                 response_size, response);
     527              :         }
     528              :         /*reset*/
     529           16 :         libspdm_reset_message_m(spdm_context, session_info);
     530              :     }
     531              : 
     532          123 :     return LIBSPDM_STATUS_SUCCESS;
     533              : }
     534              : 
     535              : #endif /* LIBSPDM_ENABLE_CAPABILITY_MEAS_CAP*/
        

Generated by: LCOV version 2.0-1