blob: 0ceb5902896173b95d7f0705f943789535369772 [file] [log] [blame]
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Copyright (c) 2019 Amlogic, Inc. All rights reserved.
*/
#ifndef __TEE_H__
#define __TEE_H__
/* memory align used by tee_protect_mem_by_type() */
#define TEE_MEM_ALIGN_SIZE 0x10000
/* memory type used by tee_protect_mem_by_type() */
#define TEE_MEM_TYPE_STREAM_INPUT 0x4
#define TEE_MEM_TYPE_STREAM_OUTPUT 0x5
#define TEE_MEM_TYPE_GPU 0x6
#define TEE_MEM_TYPE_VDIN 0x7
#define TEE_MEM_TYPE_HCODEC 0x8
#define TEE_MEM_TYPE_GE2D 0x9
#define TEE_MEM_TYPE_DEMUX 0xa
#define TEE_MEM_TYPE_TCON 0xb
#define TEE_MEM_TYPE_PCIE 0xc
#define TEE_MEM_TYPE_FRC 0xd
#define TEE_MEM_TYPE_KERNEL 0xe
#define TEE_MEM_TYPE_INVALID 0xff
/* device ID used by tee_config_device_state() */
#define DMC_DEV_ID_GPU 1
#define DMC_DEV_ID_HEVC 4
#define DMC_DEV_ID_PARSER 7
#define DMC_DEV_ID_VPU 8
#define DMC_DEV_ID_VDIN 9
#define DMC_DEV_ID_VDEC 13
#define DMC_DEV_ID_HCODEC 14
#define DMC_DEV_ID_GE2D 15
#define DMC_DEV_ID_DI_PRE 16
#define DMC_DEV_ID_DI_POST 17
#define DMC_DEV_ID_GDC 18
/* TEE error codes */
#define TEEC_SUCCESS 0x00000000
bool tee_enabled(void);
int is_secload_get(void);
int tee_load_video_fw(u32 index, u32 vdec);
int tee_load_video_fw_swap(u32 index, u32 vdec, bool is_swap);
int tee_config_device_state(int dev_id, int secure);
void tee_demux_config_pipeline(int tsn_in, int tsn_out);
int tee_demux_config_pad(int reg, int val);
int tee_read_reg_bits(u32 reg, u32 *val, u32 offset, u32 length);
int tee_write_reg_bits(u32 reg, u32 val, u32 offset, u32 length);
u32 tee_protect_mem(u32 type, u32 level,
phys_addr_t start, size_t size, u32 *handle);
void tee_unprotect_mem(u32 handle);
int tee_check_in_mem(phys_addr_t pa, size_t size);
int tee_check_out_mem(phys_addr_t pa, size_t size);
u32 tee_register_mem(u32 type, phys_addr_t pa, size_t size);
int tee_vp9_prob_process(u32 cur_frame_type, u32 prev_frame_type,
u32 prob_status, u32 prob_addr);
int tee_vp9_prob_malloc(u32 *prob_addr);
int tee_vp9_prob_free(u32 prob_addr);
/* All of the following apis will be deprecated */
u32 tee_protect_tvp_mem(phys_addr_t start, size_t size, u32 *handle);
void tee_unprotect_tvp_mem(u32 handle);
u32 tee_protect_mem_by_type(u32 type,
phys_addr_t start, size_t size, u32 *handle);
#endif /* __TEE_H__ */