mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-01-26 03:35:35 +00:00
66fb1c17ff
The goal is to keep psasim as simple as possible: - do not build a separate lib for psa-ff; build those source files as part of server or client - do not have lot of different makefiles: just 1 that does all we need - do not have several subfolders for headers: only 1 is enough for this kind of project Signed-off-by: Valerio Setti <valerio.setti@nordicsemi.no>
76 lines
1.7 KiB
C
76 lines
1.7 KiB
C
/* PSA Firmware Framework client header for psasim. */
|
|
|
|
/*
|
|
* Copyright The Mbed TLS Contributors
|
|
* SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
|
|
*/
|
|
|
|
#ifndef __PSA_CLIENT_H__
|
|
#define __PSA_CLIENT_H__
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdint.h>
|
|
#include <stddef.h>
|
|
|
|
#include "psa/crypto.h"
|
|
|
|
#include "error_ext.h"
|
|
/*********************** PSA Client Macros and Types *************************/
|
|
|
|
#define PSA_FRAMEWORK_VERSION (0x0100)
|
|
|
|
#define PSA_VERSION_NONE (0)
|
|
|
|
/* PSA response types */
|
|
#define PSA_CONNECTION_REFUSED PSA_ERROR_CONNECTION_REFUSED
|
|
#define PSA_CONNECTION_BUSY PSA_ERROR_CONNECTION_BUSY
|
|
#define PSA_DROP_CONNECTION PSA_ERROR_PROGRAMMER_ERROR
|
|
|
|
/* PSA message handles */
|
|
#define PSA_NULL_HANDLE ((psa_handle_t) 0)
|
|
|
|
#define PSA_HANDLE_IS_VALID(handle) ((psa_handle_t) (handle) > 0)
|
|
#define PSA_HANDLE_TO_ERROR(handle) ((psa_status_t) (handle))
|
|
|
|
/**
|
|
* A read-only input memory region provided to an RoT Service.
|
|
*/
|
|
typedef struct psa_invec {
|
|
const void *base;
|
|
size_t len;
|
|
} psa_invec;
|
|
|
|
/**
|
|
* A writable output memory region provided to an RoT Service.
|
|
*/
|
|
typedef struct psa_outvec {
|
|
void *base;
|
|
size_t len;
|
|
} psa_outvec;
|
|
|
|
/*************************** PSA Client API **********************************/
|
|
|
|
uint32_t psa_framework_version(void);
|
|
|
|
uint32_t psa_version(uint32_t sid);
|
|
|
|
psa_handle_t psa_connect(uint32_t sid, uint32_t version);
|
|
|
|
psa_status_t psa_call(psa_handle_t handle,
|
|
int32_t type,
|
|
const psa_invec *in_vec,
|
|
size_t in_len,
|
|
psa_outvec *out_vec,
|
|
size_t out_len);
|
|
|
|
void psa_close(psa_handle_t handle);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __PSA_CLIENT_H__ */
|