blob: 1dbbab1169c76f63e5e06beaa737156c91d8ea06 [file] [log] [blame]
/**
* 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__ */