All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Loading...
Searching...
No Matches
Secure Element Message Authentication Codes

Detailed Description

Generation and authentication of Message Authentication Codes (MACs) using a secure element can be done either as a single function call (via the psa_drv_se_mac_generate_t or psa_drv_se_mac_verify_t functions), or in parts using the following sequence:

If a previously started secure element MAC operation needs to be terminated, it should be done so by the psa_drv_se_mac_abort_t. Failure to do so may result in allocated resources not being freed or in other undefined behavior.

Data Structures

struct  psa_drv_se_mac_t
 A struct containing all of the function pointers needed to perform secure element MAC operations. More...
 

Typedefs

typedef psa_status_t(* psa_drv_se_mac_setup_t) (psa_drv_se_context_t *drv_context, void *op_context, psa_key_slot_number_t key_slot, psa_algorithm_t algorithm)
 A function that starts a secure element MAC operation for a PSA Crypto Driver implementation.
 
typedef psa_status_t(* psa_drv_se_mac_update_t) (void *op_context, const uint8_t *p_input, size_t input_length)
 A function that continues a previously started secure element MAC operation.
 
typedef psa_status_t(* psa_drv_se_mac_finish_t) (void *op_context, uint8_t *p_mac, size_t mac_size, size_t *p_mac_length)
 A function that completes a previously started secure element MAC operation by returning the resulting MAC.
 
typedef psa_status_t(* psa_drv_se_mac_finish_verify_t) (void *op_context, const uint8_t *p_mac, size_t mac_length)
 A function that completes a previously started secure element MAC operation by comparing the resulting MAC against a provided value.
 
typedef psa_status_t(* psa_drv_se_mac_abort_t) (void *op_context)
 A function that aborts a previous started secure element MAC operation.
 
typedef psa_status_t(* psa_drv_se_mac_generate_t) (psa_drv_se_context_t *drv_context, const uint8_t *p_input, size_t input_length, psa_key_slot_number_t key_slot, psa_algorithm_t alg, uint8_t *p_mac, size_t mac_size, size_t *p_mac_length)
 A function that performs a secure element MAC operation in one command and returns the calculated MAC.
 
typedef psa_status_t(* psa_drv_se_mac_verify_t) (psa_drv_se_context_t *drv_context, const uint8_t *p_input, size_t input_length, psa_key_slot_number_t key_slot, psa_algorithm_t alg, const uint8_t *p_mac, size_t mac_length)
 A function that performs a secure element MAC operation in one command and compares the resulting MAC against a provided value.
 

Typedef Documentation

◆ psa_drv_se_mac_abort_t

typedef psa_status_t(* psa_drv_se_mac_abort_t) (void *op_context)

A function that aborts a previous started secure element MAC operation.

Parameters
op_contextA hardware-specific structure for the previously started MAC operation to be aborted

Definition at line 263 of file psa_crypto_se_driver.h.

◆ psa_drv_se_mac_finish_t

typedef psa_status_t(* psa_drv_se_mac_finish_t) (void *op_context, uint8_t *p_mac, size_t mac_size, size_t *p_mac_length)

A function that completes a previously started secure element MAC operation by returning the resulting MAC.

Parameters
op_contextA hardware-specific structure for the previously started MAC operation to be finished
p_macA buffer where the generated MAC will be placed
mac_sizeThe size in bytes of the buffer that has been allocated for the output buffer
p_mac_lengthAfter completion, will contain the number of bytes placed in the p_mac buffer
Returns
PSA_SUCCESS Success.

Definition at line 233 of file psa_crypto_se_driver.h.

◆ psa_drv_se_mac_finish_verify_t

typedef psa_status_t(* psa_drv_se_mac_finish_verify_t) (void *op_context, const uint8_t *p_mac, size_t mac_length)

A function that completes a previously started secure element MAC operation by comparing the resulting MAC against a provided value.

Parameters
op_contextA hardware-specific structure for the previously started MAC operation to be fiinished
p_macThe MAC value against which the resulting MAC will be compared against
mac_lengthThe size in bytes of the value stored in p_mac
Returns
PSA_SUCCESS The operation completed successfully and the MACs matched each other PSA_ERROR_INVALID_SIGNATURE The operation completed successfully, but the calculated MAC did not match the provided MAC

Definition at line 253 of file psa_crypto_se_driver.h.

◆ psa_drv_se_mac_generate_t

typedef psa_status_t(* psa_drv_se_mac_generate_t) (psa_drv_se_context_t *drv_context, const uint8_t *p_input, size_t input_length, psa_key_slot_number_t key_slot, psa_algorithm_t alg, uint8_t *p_mac, size_t mac_size, size_t *p_mac_length)

A function that performs a secure element MAC operation in one command and returns the calculated MAC.

Parameters
drv_contextThe driver context structure.
p_inputA buffer containing the message to be MACed
input_lengthThe size in bytes of p_input
key_slotThe slot of the key to be used
algThe algorithm to be used to underlie the MAC operation
p_macA buffer where the generated MAC will be placed
mac_sizeThe size in bytes of the p_mac buffer
p_mac_lengthAfter completion, will contain the number of bytes placed in the output buffer
Returns
PSA_SUCCESS Success.

Definition at line 283 of file psa_crypto_se_driver.h.

◆ psa_drv_se_mac_setup_t

typedef psa_status_t(* psa_drv_se_mac_setup_t) (psa_drv_se_context_t *drv_context, void *op_context, psa_key_slot_number_t key_slot, psa_algorithm_t algorithm)

A function that starts a secure element MAC operation for a PSA Crypto Driver implementation.

Parameters
drv_contextThe driver context structure.
op_contextA structure that will contain the hardware-specific MAC context
key_slotThe slot of the key to be used for the operation
algorithmThe algorithm to be used to underly the MAC operation
Returns
PSA_SUCCESS Success.

Definition at line 197 of file psa_crypto_se_driver.h.

◆ psa_drv_se_mac_update_t

typedef psa_status_t(* psa_drv_se_mac_update_t) (void *op_context, const uint8_t *p_input, size_t input_length)

A function that continues a previously started secure element MAC operation.

Parameters
op_contextA hardware-specific structure for the previously-established MAC operation to be updated
p_inputA buffer containing the message to be appended to the MAC operation
input_lengthThe size in bytes of the input message buffer

Definition at line 213 of file psa_crypto_se_driver.h.

◆ psa_drv_se_mac_verify_t

typedef psa_status_t(* psa_drv_se_mac_verify_t) (psa_drv_se_context_t *drv_context, const uint8_t *p_input, size_t input_length, psa_key_slot_number_t key_slot, psa_algorithm_t alg, const uint8_t *p_mac, size_t mac_length)

A function that performs a secure element MAC operation in one command and compares the resulting MAC against a provided value.

Parameters
drv_contextThe driver context structure.
p_inputA buffer containing the message to be MACed
input_lengthThe size in bytes of input
key_slotThe slot of the key to be used
algThe algorithm to be used to underlie the MAC operation
p_macThe MAC value against which the resulting MAC will be compared against
mac_lengthThe size in bytes of p_mac
Returns
PSA_SUCCESS The operation completed successfully and the MACs matched each other PSA_ERROR_INVALID_SIGNATURE The operation completed successfully, but the calculated MAC did not match the provided MAC

Definition at line 311 of file psa_crypto_se_driver.h.