blob: a26f565abf9ceb9b21d61d59e5db489c7c52fa87 [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +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) 2005
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/*****************************************************************************
37 *
38 * Filename:
39 * ---------
40 *
41 *
42 * Project:
43 * --------
44 * MAUI
45 *
46 * Description:
47 * ------------
48 *
49 *
50 * Author:
51 * -------
52 *
53 *
54 *============================================================================
55 ****************************************************************************/
56#ifndef __SIM_NVRAM_DEF_H__
57#define __SIM_NVRAM_DEF_H__
58
59#ifdef __cplusplus
60extern "C"
61{
62#endif /* __cplusplus */
63
64
65#include "nvram_defs.h"
66#include "nvram_enums.h"
67#include "ps_public_enum.h"
68#include "device.h"
69#include "sim_public_enum.h"
70
71// LID Enums
72
73typedef enum
74{
75 NVRAM_EF_SIM_ASSERT_LID = NVRAM_LID_GRP_SIM(0), // __REL10__: t3346
76 NVRAM_EF_TEST_SIM_LID = NVRAM_LID_GRP_SIM(1),
77 NVRAM_EF_REGISTRATION_MODE_LID = NVRAM_LID_GRP_SIM(2), /* ERMODE */
78 NVRAM_EF_SIM_PROFILE_LID = NVRAM_LID_GRP_SIM(3),
79 NVRAM_EF_SIM_DISABLE_SLOT_BITMASK_LID = NVRAM_LID_GRP_SIM(4),
80 NVRAM_EF_SIM_DISABLE_ICCID_LIST_LID = NVRAM_LID_GRP_SIM(5),
81 NVRAM_EF_SIM_FAKE_IMSI_LID = NVRAM_LID_GRP_SIM(6),
82#ifdef __SIM_TERMINAL_CAP__
83 NVRAM_EF_SIM_TERMINAL_CAPABILITY_LID = NVRAM_LID_GRP_SIM(7),
84#endif
85#ifdef __SIM_RECOVERY_SWITCH__
86 NVRAM_EF_SIM_HOTSWAPOFF_RECOVEROFF_LID = NVRAM_LID_GRP_SIM(9),
87#endif
88 NVRAM_EF_SIM_RESTRICT_CARD_TYPE_LID = NVRAM_LID_GRP_SIM(11),
89 NVRAM_EF_SIM_LAST_LID = NVRAM_LID_GRP_SIM(63)
90}nvram_lid_sim_enum;
91
92/* NVRAM_EF_SIM_ASSERT_LID */
93#define NVRAM_EF_SIM_ASSERT_LID_VERNO "000"
94#define NVRAM_EF_SIM_ASSERT_LID_HASH 0xF18F3E9C
95
96/* NVRAM_EF_TEST_SIM_LID */
97#define NVRAM_EF_TEST_SIM_LID_VERNO "001"
98#define NVRAM_EF_TEST_SIM_LID_HASH 0x29F3CB9C
99
100/* NVRAM_EF_REGISTRATION_MODE_LID, for SBP_KOR_CUSTOMIZATION */
101#define NVRAM_EF_REGISTRATION_MODE_LID_VERNO "000"
102#define NVRAM_EF_REGISTRATION_MODE_LID_HASH 0x7871C9B3
103
104/* NVRAM_EF_SIM_PROFILE_LID */
105#define NVRAM_EF_SIM_PROFILE_LID_VERNO "003"
106#define NVRAM_EF_SIM_PROFILE_LID_HASH 0x47EF6F87
107
108/* NVRAM_EF_SIM_DISABLE_SLOT_BITMASK_LID */
109#define NVRAM_EF_SIM_DISABLE_ICCID_LIST_LID_VERNO "000"
110#define NVRAM_EF_SIM_DISABLE_SLOT_BITMASK_LID_HASH 0xC1F0B496
111
112/* NVRAM_EF_SIM_DISABLE_ICCID_LIST_LID */
113#define NVRAM_EF_SIM_DISABLE_SLOT_BITMASK_LID_VERNO "000"
114#define NVRAM_EF_SIM_DISABLE_ICCID_LIST_LID_HASH 0x2D1F758B
115
116#ifdef __FAKEID_SUPPORT__
117/* NVRAM_EF_SIM_FAKE_IMSI_LID */
118#define NVRAM_EF_SIM_FAKE_IMSI_LID_VERNO "000"
119#define NVRAM_EF_SIM_FAKE_IMSI_LID_HASH 0xB62EE911
120#endif
121
122#ifdef __SIM_TERMINAL_CAP__
123// Size and Total
124/* NVRAM_EF_SIM_TERMINAL_CAPABILITY_LID */
125#define NVRAM_EF_SIM_TERMINAL_CAPABILITY_LID_VERNO "000"
126#define NVRAM_EF_SIM_TERMINAL_CAPABILITY_LID_HASH 0xB9055DE6
127#endif
128
129#ifdef __SIM_RECOVERY_SWITCH__
130// Size and Total
131/* NVRAM_EF_SIM_HOTSWAPOFF_RECOVEROFF_LID */
132#define NVRAM_EF_SIM_HOTSWAPOFF_RECOVEROFF_LID_VERNO "000"
133#define NVRAM_EF_SIM_HOTSWAPOFF_RECOVEROFF_LID_HASH 0x599F4618
134#endif
135// Size and Total
136#define NVRAM_EF_SIM_RESTRICT_CARD_TYPE_LID_VERNO "000"
137#define NVRAM_EF_SIM_RESTRICT_CARD_TYPE_LID_HASH 0x8730A2AC
138
139/*
140 * SIM log
141 */
142#define NVRAM_EF_SIM_ASSERT_SIZE 16
143#define NVRAM_EF_SIM_ASSERT_TOTAL 80
144
145
146typedef struct{
147 kal_uint8 test_sim;
148}nvram_test_sim_struct;
149
150#define NVRAM_EF_TEST_SIM_TOTAL 1
151#define NVRAM_EF_TEST_SIM_SIZE sizeof(nvram_test_sim_struct)
152
153
154typedef struct{
155 kal_uint8 nvram_sim_profile[MAX_SIM_PROFILE_LEN];
156}nvram_ef_sim_profile_struct;
157
158#define NVRAM_EF_SIM_PROFILE_TOTAL (1 * NVRAM_DUAL_RECORD)
159#define NVRAM_EF_SIM_PROFILE_SIZE sizeof(nvram_ef_sim_profile_struct)
160
161
162/* ERMODE */
163typedef struct
164{
165 kal_uint8 registration_mode;
166}nvram_ef_registration_mode_struct;
167#define NVRAM_EF_REGISTRATION_MODE_TOTAL (1 * NVRAM_DUAL_RECORD)
168#define NVRAM_EF_REGISTRATION_MODE_SIZE sizeof(nvram_ef_registration_mode_struct)
169
170
171typedef struct{
172 kal_uint8 off_slot_bitmask;
173}nvram_disable_slot_bitmask_struct;
174
175#define NVRAM_EF_SIM_DISABLE_SLOT_BITMASK_TOTAL 1
176#define NVRAM_EF_SIM_DISABLE_SLOT_BITMASK_SIZE sizeof(nvram_disable_slot_bitmask_struct)
177
178#define SIM_MAX_DISABLED_ICCID_REC_NUM 20
179
180
181typedef struct{
182 kal_uint8 iccid_list[10*SIM_MAX_DISABLED_ICCID_REC_NUM]; /* ciphered ICCID */
183} nvram_disable_iccid_list_struct;
184
185#define NVRAM_EF_SIM_DISABLE_ICCID_LIST_TOTAL 1
186#define NVRAM_EF_SIM_DISABLE_ICCID_LIST_SIZE sizeof(nvram_disable_iccid_list_struct)
187
188
189#ifdef __FAKEID_SUPPORT__
190typedef struct
191{
192 kal_uint8 fake_mnc_length;
193 kal_uint8 fake_imsi[9];
194} nvram_fake_imsi_struct;
195
196#define NVRAM_EF_FAKE_IMSI_TOTAL (1 * NVRAM_DUAL_RECORD)
197#define NVRAM_EF_FAKE_IMSI_SIZE sizeof(nvram_fake_imsi_struct)
198#endif
199#ifdef __SIM_TERMINAL_CAP__
200typedef struct{
201 kal_uint8 tlv_list_length;
202 kal_uint8 tlv_objects[255];
203}nvram_terminal_capability_objects_struct;
204
205#define NVRAM_EF_SIM_TERMINAL_CAPABILITY_TOTAL (1 * NVRAM_DUAL_RECORD)
206#define NVRAM_EF_SIM_TERMINAL_CAPABILITY_SIZE sizeof(nvram_terminal_capability_objects_struct)
207#endif
208
209#ifdef __SIM_RECOVERY_SWITCH__
210typedef struct{
211 kal_uint8 sim_hotswapoff;
212 kal_uint8 sim_recoveroff;
213}nvram_hotswapoff_recoveroff_objects_struct;
214
215#define NVRAM_EF_SIM_HOTSWAPOFF_RECOVEROFF_TOTAL (1 * NVRAM_DUAL_RECORD)
216#define NVRAM_EF_SIM_HOTSWAPOFF_RECOVEROFF_SIZE sizeof(nvram_hotswapoff_recoveroff_objects_struct)
217#endif
218
219typedef struct
220{
221 kal_uint8 control;
222 sim_restrict_card_type_enum card_type;
223} nvram_sim_restrict_card_type_object_struct;
224
225#define NVRAM_EF_SIM_RESTRICT_CARD_TYPE_TOTAL 1
226#define NVRAM_EF_SIM_RESTRICT_CARD_TYPE_SIZE sizeof(nvram_sim_restrict_card_type_object_struct)
227
228#ifdef __cplusplus
229}
230#endif
231
232#endif /* __SIM_NVRAM_DEF_H__ */