blob: 23a5649f2fc66055ec9eb4acc54c4677cfca7900 [file] [log] [blame]
rjw1f884582022-01-06 17:20:42 +08001/*****************************************************************************
2* Copyright Statement:
3* --------------------
4* This software is protected by Copyright and the information contained
5* herein is confidential. The software may not be copied and the information
6* contained herein may not be used or disclosed except with the written
7* permission of MediaTek Inc. (C) 2011
8*
9* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
10* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
11* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
12* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
13* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
14* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
15* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
16* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
17* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
18* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
19* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
20* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
21*
22* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
23* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
24* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
25* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
26* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
27*
28* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
29* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
30* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
31* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
32* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
33*
34*****************************************************************************/
35
36#ifndef TRUSTZONE_H
37#define TRUSTZONE_H
38
39#include "typedefs.h"
40
41#define BL31 0x43001000UL
42#define BL33 0x43a00000UL
43#define BL31_BASE 0x43000000UL
44#define BL31_SIZE 0x00030000UL /* default is 192K Bytes */
45
46#define ATF_BOOT_ARG_ADDR (0x40000000)
47#define TEE_BOOT_ARG_ADDR (0x40001000)
48#define ATF_BOOTCFG_MAGIC (0x4D415446) // String MATF in little-endian
49
50#define DEVINFO_SIZE 4
51
52/* bootarg for ATF */
53typedef struct {
54 u64 bootarg_loc;
55 u64 bootarg_size;
56 u64 bl33_start_addr;
57 u64 tee_info_addr;
58} mtk_bl_param_t;
59
60typedef struct {
61 u32 atf_magic;
62 u32 tee_support;
63 u32 tee_entry;
64 u32 tee_boot_arg_addr;
65 u32 hwuid[4]; // HW Unique id for t-base used
66 u32 atf_hrid_size;
67 u32 HRID[8]; // HW random id for t-base used
68 u32 atf_log_port;
69 u32 atf_log_baudrate;
70 u32 atf_log_buf_start;
71 u32 atf_log_buf_size;
72 u32 atf_irq_num;
73 u32 devinfo[DEVINFO_SIZE];
74 u32 atf_aee_debug_buf_start;
75 u32 atf_aee_debug_buf_size;
76#if CFG_TEE_SUPPORT
77 u32 tee_rpmb_size;
78#endif
79} atf_arg_t, *atf_arg_t_ptr;
80
81#endif /* TRUSTZONE_H */
82