mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-04-05 16:20:20 +00:00
PSA PBKDF2: add new input function
Note on naming: previously considered input_numeric but then thought the other two input function are "input <name>" not "input <adjective>" so decided to follow that pattern. input_int would be shorter but sounds too much like the C type, which could be confusing as that's not the type of the parameter; IMO "integer" avoids that problem. Signed-off-by: Manuel Pégourié-Gonnard <manuel.pegourie-gonnard@arm.com>
This commit is contained in:
parent
5a67992a61
commit
22f08bcc00
@ -3290,6 +3290,48 @@ psa_status_t psa_key_derivation_input_bytes(
|
|||||||
const uint8_t *data,
|
const uint8_t *data,
|
||||||
size_t data_length);
|
size_t data_length);
|
||||||
|
|
||||||
|
/** Provide a numeric input for key derivation or key agreement.
|
||||||
|
*
|
||||||
|
* Which inputs are required and in what order depends on the algorithm.
|
||||||
|
* Refer to the documentation of each key derivation or key agreement
|
||||||
|
* algorithm for information.
|
||||||
|
*
|
||||||
|
* This function is used for inputs which are small non-negative integers.
|
||||||
|
*
|
||||||
|
* If this function returns an error status, the operation enters an error
|
||||||
|
* state and must be aborted by calling psa_key_derivation_abort().
|
||||||
|
*
|
||||||
|
* \param[in,out] operation The key derivation operation object to use.
|
||||||
|
* It must have been set up with
|
||||||
|
* psa_key_derivation_setup() and must not
|
||||||
|
* have produced any output yet.
|
||||||
|
* \param step Which step the input data is for.
|
||||||
|
* \param[in] data Input data to use.
|
||||||
|
* \param data_length Size of the \p data buffer in bytes.
|
||||||
|
*
|
||||||
|
* \retval #PSA_SUCCESS
|
||||||
|
* Success.
|
||||||
|
* \retval #PSA_ERROR_INVALID_ARGUMENT
|
||||||
|
* \c step is not compatible with the operation's algorithm.
|
||||||
|
* \retval #PSA_ERROR_INVALID_ARGUMENT
|
||||||
|
* \c step does not allow numeric inputs.
|
||||||
|
* \retval #PSA_ERROR_INSUFFICIENT_MEMORY
|
||||||
|
* \retval #PSA_ERROR_COMMUNICATION_FAILURE
|
||||||
|
* \retval #PSA_ERROR_HARDWARE_FAILURE
|
||||||
|
* \retval #PSA_ERROR_CORRUPTION_DETECTED
|
||||||
|
* \retval #PSA_ERROR_STORAGE_FAILURE
|
||||||
|
* \retval #PSA_ERROR_BAD_STATE
|
||||||
|
* The operation state is not valid for this input \p step.
|
||||||
|
* \retval #PSA_ERROR_BAD_STATE
|
||||||
|
* The library has not been previously initialized by psa_crypto_init().
|
||||||
|
* It is implementation-dependent whether a failure to initialize
|
||||||
|
* results in this error code.
|
||||||
|
*/
|
||||||
|
psa_status_t psa_key_derivation_input_integer(
|
||||||
|
psa_key_derivation_operation_t *operation,
|
||||||
|
psa_key_derivation_step_t step,
|
||||||
|
uint64_t value);
|
||||||
|
|
||||||
/** Provide an input for key derivation in the form of a key.
|
/** Provide an input for key derivation in the form of a key.
|
||||||
*
|
*
|
||||||
* Which inputs are required and in what order depends on the algorithm.
|
* Which inputs are required and in what order depends on the algorithm.
|
||||||
|
@ -2194,7 +2194,7 @@ static inline int mbedtls_svc_key_id_is_null( mbedtls_svc_key_id_t key )
|
|||||||
|
|
||||||
/** A cost parameter for password hashing / key stretching.
|
/** A cost parameter for password hashing / key stretching.
|
||||||
*
|
*
|
||||||
* This must be a direct input, passed to psa_key_derivation_input_numeric().
|
* This must be a direct input, passed to psa_key_derivation_input_integer().
|
||||||
*/
|
*/
|
||||||
#define PSA_KEY_DERIVATION_INPUT_COST ((psa_key_derivation_step_t)0x0205)
|
#define PSA_KEY_DERIVATION_INPUT_COST ((psa_key_derivation_step_t)0x0205)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user