| /** |
| * Copyright (c) 2011 Trusted Logic S.A. |
| * All Rights Reserved. |
| * |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License |
| * version 2 as published by the Free Software Foundation. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License |
| * along with this program; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
| * MA 02111-1307 USA |
| */ |
| |
| /* |
| * This header file corresponds to V1.0 of the GlobalPlatform |
| * TEE Client API Specification |
| */ |
| #ifndef __TEE_CLIENT_API_H__ |
| #define __TEE_CLIENT_API_H__ |
| |
| #include <linux/types.h> |
| |
| #ifndef TEEC_EXPORT |
| #define TEEC_EXPORT |
| #endif |
| |
| /* The header tee_client_api_imp.h must define implementation-dependent |
| types, constants and macros. |
| |
| The implementation-dependent types are: |
| - TEEC_Context_IMP |
| - TEEC_Session_IMP |
| - TEEC_SharedMemory_IMP |
| - TEEC_Operation_IMP |
| |
| The implementation-dependent constants are: |
| - TEEC_CONFIG_SHAREDMEM_MAX_SIZE |
| The implementation-dependent macros are: |
| - TEEC_PARAM_TYPES |
| */ |
| #include "tee_client_api_imp.h" |
| |
| /* Type definitions */ |
| typedef struct TEEC_Context |
| { |
| TEEC_Context_IMP imp; |
| } TEEC_Context; |
| |
| typedef struct TEEC_Session |
| { |
| TEEC_Session_IMP imp; |
| } TEEC_Session; |
| |
| typedef struct TEEC_SharedMemory |
| { |
| void* buffer; |
| size_t size; |
| uint32_t flags; |
| TEEC_SharedMemory_IMP imp; |
| } TEEC_SharedMemory; |
| |
| typedef struct |
| { |
| void* buffer; |
| size_t size; |
| } TEEC_TempMemoryReference; |
| |
| typedef struct |
| { |
| TEEC_SharedMemory * parent; |
| size_t size; |
| size_t offset; |
| } TEEC_RegisteredMemoryReference; |
| |
| typedef struct |
| { |
| uint32_t a; |
| uint32_t b; |
| } TEEC_Value; |
| |
| typedef union |
| { |
| TEEC_TempMemoryReference tmpref; |
| TEEC_RegisteredMemoryReference memref; |
| TEEC_Value value; |
| } TEEC_Parameter; |
| |
| typedef struct TEEC_Operation |
| { |
| volatile uint32_t started; |
| uint32_t paramTypes; |
| TEEC_Parameter params[4]; |
| TEEC_Operation_IMP imp; |
| } TEEC_Operation; |
| |
| #define TEEC_SUCCESS ((TEEC_Result)0x00000000) |
| #define TEEC_ERROR_GENERIC ((TEEC_Result)0xFFFF0000) |
| #define TEEC_ERROR_ACCESS_DENIED ((TEEC_Result)0xFFFF0001) |
| #define TEEC_ERROR_CANCEL ((TEEC_Result)0xFFFF0002) |
| #define TEEC_ERROR_ACCESS_CONFLICT ((TEEC_Result)0xFFFF0003) |
| #define TEEC_ERROR_EXCESS_DATA ((TEEC_Result)0xFFFF0004) |
| #define TEEC_ERROR_BAD_FORMAT ((TEEC_Result)0xFFFF0005) |
| #define TEEC_ERROR_BAD_PARAMETERS ((TEEC_Result)0xFFFF0006) |
| #define TEEC_ERROR_BAD_STATE ((TEEC_Result)0xFFFF0007) |
| #define TEEC_ERROR_ITEM_NOT_FOUND ((TEEC_Result)0xFFFF0008) |
| #define TEEC_ERROR_NOT_IMPLEMENTED ((TEEC_Result)0xFFFF0009) |
| #define TEEC_ERROR_NOT_SUPPORTED ((TEEC_Result)0xFFFF000A) |
| #define TEEC_ERROR_NO_DATA ((TEEC_Result)0xFFFF000B) |
| #define TEEC_ERROR_OUT_OF_MEMORY ((TEEC_Result)0xFFFF000C) |
| #define TEEC_ERROR_BUSY ((TEEC_Result)0xFFFF000D) |
| #define TEEC_ERROR_COMMUNICATION ((TEEC_Result)0xFFFF000E) |
| #define TEEC_ERROR_SECURITY ((TEEC_Result)0xFFFF000F) |
| #define TEEC_ERROR_SHORT_BUFFER ((TEEC_Result)0xFFFF0010) |
| |
| #define TEEC_ORIGIN_API 0x00000001 |
| #define TEEC_ORIGIN_COMMS 0x00000002 |
| #define TEEC_ORIGIN_TEE 0x00000003 |
| #define TEEC_ORIGIN_TRUSTED_APP 0x00000004 |
| |
| #define TEEC_MEM_INPUT 0x00000001 |
| #define TEEC_MEM_OUTPUT 0x00000002 |
| |
| #define TEEC_NONE 0x0 |
| #define TEEC_VALUE_INPUT 0x1 |
| #define TEEC_VALUE_OUTPUT 0x2 |
| #define TEEC_VALUE_INOUT 0x3 |
| #define TEEC_MEMREF_TEMP_INPUT 0x5 |
| #define TEEC_MEMREF_TEMP_OUTPUT 0x6 |
| #define TEEC_MEMREF_TEMP_INOUT 0x7 |
| #define TEEC_MEMREF_WHOLE 0xC |
| #define TEEC_MEMREF_PARTIAL_INPUT 0xD |
| #define TEEC_MEMREF_PARTIAL_OUTPUT 0xE |
| #define TEEC_MEMREF_PARTIAL_INOUT 0xF |
| |
| #define TEEC_LOGIN_PUBLIC 0x00000000 |
| #define TEEC_LOGIN_USER 0x00000001 |
| #define TEEC_LOGIN_GROUP 0x00000002 |
| #define TEEC_LOGIN_APPLICATION 0x00000004 |
| #define TEEC_LOGIN_USER_APPLICATION 0x00000005 |
| #define TEEC_LOGIN_GROUP_APPLICATION 0x00000006 |
| |
| TEEC_Result TEEC_EXPORT TEEC_InitializeContext( |
| const char* name, |
| TEEC_Context* context); |
| |
| void TEEC_EXPORT TEEC_FinalizeContext( |
| TEEC_Context* context); |
| |
| TEEC_Result TEEC_EXPORT TEEC_RegisterSharedMemory( |
| TEEC_Context* context, |
| TEEC_SharedMemory* sharedMem); |
| |
| TEEC_Result TEEC_EXPORT TEEC_AllocateSharedMemory( |
| TEEC_Context* context, |
| TEEC_SharedMemory* sharedMem); |
| |
| void TEEC_EXPORT TEEC_ReleaseSharedMemory ( |
| TEEC_SharedMemory* sharedMem); |
| |
| TEEC_Result TEEC_EXPORT TEEC_OpenSession ( |
| TEEC_Context* context, |
| TEEC_Session* session, |
| const TEEC_UUID* destination, |
| uint32_t connectionMethod, |
| void* connectionData, |
| TEEC_Operation* operation, |
| uint32_t* errorOrigin); |
| |
| void TEEC_EXPORT TEEC_CloseSession ( |
| TEEC_Session* session); |
| |
| TEEC_Result TEEC_EXPORT TEEC_InvokeCommand( |
| TEEC_Session* session, |
| uint32_t commandID, |
| TEEC_Operation* operation, |
| uint32_t* errorOrigin); |
| |
| void TEEC_EXPORT TEEC_RequestCancellation( |
| TEEC_Operation* operation); |
| |
| #include "tee_client_api_ex.h" |
| |
| #endif /* __TEE_CLIENT_API_H__ */ |