2018-08-01 08:07:41 +02:00
|
|
|
/** @file
|
|
|
|
OP-TEE specific header file.
|
|
|
|
|
|
|
|
Copyright (c) 2018, Linaro Ltd. All rights reserved.<BR>
|
2021-01-08 15:07:51 +01:00
|
|
|
Copyright (c) 2021, Arm Limited. All rights reserved.<BR>
|
2018-08-01 08:07:41 +02:00
|
|
|
|
2019-04-04 01:03:18 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2018-08-01 08:07:41 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
2021-04-20 13:00:23 +02:00
|
|
|
#ifndef OPTEE_LIB_H_
|
|
|
|
#define OPTEE_LIB_H_
|
2018-08-01 08:07:41 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The 'Trusted OS Call UID' is supposed to return the following UUID for
|
|
|
|
* OP-TEE OS. This is a 128-bit value.
|
|
|
|
*/
|
2021-12-05 23:53:50 +01:00
|
|
|
#define OPTEE_OS_UID0 0x384fb3e0
|
|
|
|
#define OPTEE_OS_UID1 0xe7f811e3
|
|
|
|
#define OPTEE_OS_UID2 0xaf630002
|
|
|
|
#define OPTEE_OS_UID3 0xa5d5c51b
|
2018-08-01 08:07:41 +02:00
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_NONE 0x0
|
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_VALUE_INPUT 0x1
|
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_VALUE_OUTPUT 0x2
|
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_VALUE_INOUT 0x3
|
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MEMORY_INPUT 0x9
|
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MEMORY_OUTPUT 0xa
|
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MEMORY_INOUT 0xb
|
2018-10-22 08:29:36 +02:00
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
#define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MASK 0xff
|
2018-10-22 08:29:36 +02:00
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
#define OPTEE_SUCCESS 0x00000000
|
|
|
|
#define OPTEE_ORIGIN_COMMUNICATION 0x00000002
|
|
|
|
#define OPTEE_ERROR_COMMUNICATION 0xFFFF000E
|
2018-10-22 08:29:36 +02:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT64 BufferAddress;
|
|
|
|
UINT64 Size;
|
|
|
|
UINT64 SharedMemoryReference;
|
|
|
|
} OPTEE_MESSAGE_PARAM_MEMORY;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT64 A;
|
|
|
|
UINT64 B;
|
|
|
|
UINT64 C;
|
|
|
|
} OPTEE_MESSAGE_PARAM_VALUE;
|
|
|
|
|
2021-01-08 15:07:51 +01:00
|
|
|
typedef union {
|
2021-12-05 23:53:50 +01:00
|
|
|
OPTEE_MESSAGE_PARAM_MEMORY Memory;
|
|
|
|
OPTEE_MESSAGE_PARAM_VALUE Value;
|
2021-01-08 15:07:51 +01:00
|
|
|
} OPTEE_MESSAGE_PARAM_UNION;
|
|
|
|
|
2018-10-22 08:29:36 +02:00
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT64 Attribute;
|
|
|
|
OPTEE_MESSAGE_PARAM_UNION Union;
|
2018-10-22 08:29:36 +02:00
|
|
|
} OPTEE_MESSAGE_PARAM;
|
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
#define OPTEE_MAX_CALL_PARAMS 4
|
2018-10-22 08:29:36 +02:00
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT32 Command;
|
|
|
|
UINT32 Function;
|
|
|
|
UINT32 Session;
|
|
|
|
UINT32 CancelId;
|
|
|
|
UINT32 Pad;
|
|
|
|
UINT32 Return;
|
|
|
|
UINT32 ReturnOrigin;
|
|
|
|
UINT32 NumParams;
|
2018-10-22 08:29:36 +02:00
|
|
|
|
|
|
|
// NumParams tells the actual number of element in Params
|
2021-12-05 23:53:50 +01:00
|
|
|
OPTEE_MESSAGE_PARAM Params[OPTEE_MAX_CALL_PARAMS];
|
2018-10-22 08:29:36 +02:00
|
|
|
} OPTEE_MESSAGE_ARG;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
EFI_GUID Uuid; // [in] GUID/UUID of the Trusted Application
|
|
|
|
UINT32 Session; // [out] Session id
|
|
|
|
UINT32 Return; // [out] Return value
|
|
|
|
UINT32 ReturnOrigin; // [out] Origin of the return value
|
2018-10-22 08:29:36 +02:00
|
|
|
} OPTEE_OPEN_SESSION_ARG;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT32 Function; // [in] Trusted Application function, specific to the TA
|
|
|
|
UINT32 Session; // [in] Session id
|
|
|
|
UINT32 Return; // [out] Return value
|
|
|
|
UINT32 ReturnOrigin; // [out] Origin of the return value
|
|
|
|
OPTEE_MESSAGE_PARAM Params[OPTEE_MAX_CALL_PARAMS]; // Params for function to be invoked
|
2018-10-22 08:29:36 +02:00
|
|
|
} OPTEE_INVOKE_FUNCTION_ARG;
|
|
|
|
|
2018-08-01 08:07:41 +02:00
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
IsOpteePresent (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
2018-10-22 08:29:36 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
OpteeInit (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
OpteeOpenSession (
|
2021-12-05 23:53:50 +01:00
|
|
|
IN OUT OPTEE_OPEN_SESSION_ARG *OpenSessionArg
|
2018-10-22 08:29:36 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
OpteeCloseSession (
|
2021-12-05 23:53:50 +01:00
|
|
|
IN UINT32 Session
|
2018-10-22 08:29:36 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
OpteeInvokeFunction (
|
2021-12-05 23:53:50 +01:00
|
|
|
IN OUT OPTEE_INVOKE_FUNCTION_ARG *InvokeFunctionArg
|
2018-10-22 08:29:36 +02:00
|
|
|
);
|
|
|
|
|
2021-04-20 13:00:23 +02:00
|
|
|
#endif // OPTEE_LIB_H_
|