| /* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */ |
| /* |
| * include/linux/amlogic/tee.h |
| * |
| * Copyright (C) 2017 Amlogic, Inc. 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 as published by |
| * the Free Software Foundation; either version 2 of the License, or |
| * (at your option) any later version. |
| * |
| * 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. |
| * |
| */ |
| |
| #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 |
| |
| 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); |
| u32 tee_protect_tvp_mem(u32 start, u32 size, |
| u32 *handle); |
| void tee_unprotect_tvp_mem(u32 handle); |
| u32 tee_protect_mem_by_type(u32 type, |
| u32 start, u32 size, |
| u32 *handle); |
| void tee_unprotect_mem(u32 handle); |
| |
| 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, |
| u32 start, u32 size, u32 *handle); |
| |
| int tee_check_in_mem(u32 pa, u32 size); |
| |
| int tee_check_out_mem(u32 pa, u32 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); |
| |
| #endif /* __TEE_H__ */ |
| |