mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-26 04:31:07 +00:00
Pass a writable pointer to the persistent data when needed
Most driver methods are not allowed to modify the persistent data, so the driver context structure contains a const pointer to it. Pass a non-const pointer to the persstent data to the driver methods that need it: init, allocate, destroy.
This commit is contained in:
parent
f2223c868d
commit
94cc42c28f
|
@ -97,6 +97,8 @@ typedef struct {
|
||||||
/** \brief A driver initialization function.
|
/** \brief A driver initialization function.
|
||||||
*
|
*
|
||||||
* \param[in,out] drv_context The driver context structure.
|
* \param[in,out] drv_context The driver context structure.
|
||||||
|
* \param[in,out] persistent_data A pointer to the persistent data
|
||||||
|
* that allows writing.
|
||||||
* \param lifetime The lifetime value for which this driver
|
* \param lifetime The lifetime value for which this driver
|
||||||
* is registered.
|
* is registered.
|
||||||
*
|
*
|
||||||
|
@ -109,6 +111,7 @@ typedef struct {
|
||||||
* The core will NOT update the persistent data in storage.
|
* The core will NOT update the persistent data in storage.
|
||||||
*/
|
*/
|
||||||
typedef psa_status_t (*psa_drv_se_init_t)(psa_drv_se_context_t *drv_context,
|
typedef psa_status_t (*psa_drv_se_init_t)(psa_drv_se_context_t *drv_context,
|
||||||
|
void *persistent_data,
|
||||||
psa_key_lifetime_t lifetime);
|
psa_key_lifetime_t lifetime);
|
||||||
|
|
||||||
/** An internal designation of a key slot between the core part of the
|
/** An internal designation of a key slot between the core part of the
|
||||||
|
@ -787,6 +790,8 @@ typedef struct psa_key_attributes_s psa_key_attributes_t;
|
||||||
/** \brief A function that allocates a slot for a key.
|
/** \brief A function that allocates a slot for a key.
|
||||||
*
|
*
|
||||||
* \param[in,out] drv_context The driver context structure.
|
* \param[in,out] drv_context The driver context structure.
|
||||||
|
* \param[in,out] persistent_data A pointer to the persistent data
|
||||||
|
* that allows writing.
|
||||||
* \param[in] attributes Attributes of the key.
|
* \param[in] attributes Attributes of the key.
|
||||||
* \param[out] key_slot Slot where the key will be stored.
|
* \param[out] key_slot Slot where the key will be stored.
|
||||||
* This must be a valid slot for a key of the
|
* This must be a valid slot for a key of the
|
||||||
|
@ -801,6 +806,7 @@ typedef struct psa_key_attributes_s psa_key_attributes_t;
|
||||||
*/
|
*/
|
||||||
typedef psa_status_t (*psa_drv_se_allocate_key_t)(
|
typedef psa_status_t (*psa_drv_se_allocate_key_t)(
|
||||||
psa_drv_se_context_t *drv_context,
|
psa_drv_se_context_t *drv_context,
|
||||||
|
void *persistent_data,
|
||||||
const psa_key_attributes_t *attributes,
|
const psa_key_attributes_t *attributes,
|
||||||
psa_key_slot_number_t *key_slot);
|
psa_key_slot_number_t *key_slot);
|
||||||
|
|
||||||
|
@ -843,6 +849,8 @@ typedef psa_status_t (*psa_drv_se_import_key_t)(psa_drv_se_context_t *drv_contex
|
||||||
* This function returns the specified slot to its default state.
|
* This function returns the specified slot to its default state.
|
||||||
*
|
*
|
||||||
* \param[in,out] drv_context The driver context structure.
|
* \param[in,out] drv_context The driver context structure.
|
||||||
|
* \param[in,out] persistent_data A pointer to the persistent data
|
||||||
|
* that allows writing.
|
||||||
* \param key_slot The key slot to erase.
|
* \param key_slot The key slot to erase.
|
||||||
*
|
*
|
||||||
* \retval #PSA_SUCCESS
|
* \retval #PSA_SUCCESS
|
||||||
|
@ -850,6 +858,7 @@ typedef psa_status_t (*psa_drv_se_import_key_t)(psa_drv_se_context_t *drv_contex
|
||||||
*/
|
*/
|
||||||
typedef psa_status_t (*psa_drv_se_destroy_key_t)(
|
typedef psa_status_t (*psa_drv_se_destroy_key_t)(
|
||||||
psa_drv_se_context_t *drv_context,
|
psa_drv_se_context_t *drv_context,
|
||||||
|
void *persistent_data,
|
||||||
psa_key_slot_number_t key_slot);
|
psa_key_slot_number_t key_slot);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue