blob: 535001bd666a2499a518a20b14c9a7f4cb35c77c [file] [log] [blame]
/*
* Copyright (c) 2023, Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: BSD-3-Clause
*
*/
#ifndef RSE_PLATFORM_API_H
#define RSE_PLATFORM_API_H
#include <stdint.h>
#include "psa/error.h"
#include <rse_crypto_defs.h>
#define RSE_PLATFORM_API_ID_NV_READ (1010)
#define RSE_PLATFORM_API_ID_NV_INCREMENT (1011)
/*
* Increments the given non-volatile (NV) counter by one
*
* counter_id NV counter ID.
*
* PSA_SUCCESS if the value is read correctly. Otherwise,
* it returns a PSA_ERROR.
*/
psa_status_t
rse_platform_nv_counter_increment(uint32_t counter_id);
/*
* Reads the given non-volatile (NV) counter
*
* counter_id NV counter ID.
* size Size of the buffer to store NV counter value
* in bytes.
* val Pointer to store the current NV counter value.
*
* PSA_SUCCESS if the value is read correctly. Otherwise,
* it returns a PSA_ERROR.
*/
psa_status_t
rse_platform_nv_counter_read(uint32_t counter_id,
uint32_t size, uint8_t *val);
/*
* Reads the public key or the public part of a key pair in binary format.
*
* key Identifier of the key to export.
* data Buffer where the key data is to be written.
* data_size Size of the data buffer in bytes.
* data_length On success, the number of bytes that make up the key data.
*
* PSA_SUCCESS if the value is read correctly. Otherwise,
* it returns a PSA_ERROR.
*/
psa_status_t
rse_platform_key_read(enum rse_key_id_builtin_t key, uint8_t *data,
size_t data_size, size_t *data_length);
#endif /* RSE_PLATFORM_API_H */