Files
kernel_common_drivers/include/linux/amlogic/tee.h
T
lele xiang 575834ee6b tee: CB0 Playback failed of 4K HLS128 streams. [1/2]
PD#SWPL-233214

Problem:
In the secure playback context, the newly allocated TVP_POOL
was not granted access permissions for vdec/hevc.

Solution:
After allocating a new TVP_POOL, the TEE module checks and
synchronizes the current vdec/hevc access permissions,
add interface with lock

depends on CL:
600559

Verify:
S905X5

Change-Id: Iffa38ffabbb5b8edcf5f54dc88c18e21495b568b
Signed-off-by: lele xiang <lele.xiang@amlogic.com>
2025-10-28 02:30:44 -07:00

112 lines
3.6 KiB
C

/* 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
#define DMC_DEV_ID_HEVC_B 19
/* TEE error codes */
#define TEEC_SUCCESS 0x00000000
struct tee_sectbl_info {
u32 tbl0_en;
u64 tbl0_sta;
u64 tbl0_size;
u32 tbl0_blk_size;
u32 tbl1_en;
u64 tbl1_sta;
u64 tbl1_size;
u32 tbl1_blk_size;
u32 tbl1_offset;
u32 secure_bits;
u32 sectbl_crc;
};
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);
int tee_config_device_state_lock(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);
u32 tee_sectbl_mem_map(phys_addr_t tbl0_sta, size_t tbl0_size, u32 tbl0_blk_size,
phys_addr_t tbl1_sta, size_t tbl1_size, u32 tbl1_blk_size);
u32 tee_sectbl_get_info(struct tee_sectbl_info *sectbl_info);
u32 tee_sectbl_secmem_set(phys_addr_t start, size_t size, u32 secure);
#endif /* __TEE_H__ */