blob: d16f50fad7a99c9f4033bf36540af6e7d04c8882 [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) 2012
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 * Filename:
38 * ---------
39 * l4c_el1_struct.h
40 *
41 * Project:
42 * --------
43 * MOLY
44 *
45 * Description:
46 * ------------
47 * message and common structure definition between L4C and EL1 modules.
48 *
49 * Author:
50 * -------
51 * -------
52 *
53 * ==========================================================================
54 * $Log$
55 *
56 * 06 02 2021 titi.wu
57 * [MOLY00609450] [FM350][HP][Kaixuan.Zhang]LTE«D«H¥OTx©MRxªºAT©R¥O»Ý¨D
58 *
59 * .
60 *
61 * 04 09 2021 titi.wu
62 * [MOLY00609450] [FM350][HP][Kaixuan.Zhang]LTE«D«H¥OTx©MRxªºAT©R¥O»Ý¨D
63 * .
64 *
65 * 07 03 2020 wade.chen
66 * [MOLY00534567] LTE B38 ©M B41ªº «ü¥OAT+ERFTX=6,0,1,41,2,26825,1,1,4,0,25,0,23,1,1 ?¤£¥X?¥\²v
67 *
68 * [EWSP0000125300][R3]add rx ant state for ERFTX test
69 *
70 * 05 26 2020 chun-yu.chien
71 * [MOLY00516314] [CAYMAN][SPR] OMADM node to control ./LTE/QAM/Downlink ./LTE/QAM/Uplink ./LTE/TDD/TM9: ./LTE/FDD/TM9: ./LTE/B25/4x4MIMO:./LTE/B41/4x4MIMO:
72 *
73 * AT+EGDM extension : GET/SET omadm 4x4 MIMO interface
74 * R3.MP
75 *
76 * 09 25 2019 wade.chen
77 * [MOLY00347940] [Gen97][MT6297] tstm_meta development
78 *
79 * [VMOLY]ERFTX error handle enhancement (code sync)
80 *
81 * 01 29 2019 wade.chen
82 * [MOLY00347940] [Gen97][MT6297] tstm_meta development
83 *
84 * [ERS00028822][EVB.SEPT.DEV][code sync] RF De-sense modification
85 *
86 * 06 06 2018 vend_mtb_mobiveil012
87 * [MOLY00331680] [CODE SYNC] Looking for TAS AT comamnd while target execte RF test by AT+ERFTX
88 * Added two antenna parameters to AT+ERFTX=6.
89 *
90 * 05 22 2018 aki.hietala
91 * [MOLY00260136] [MT6295] EL1C TX development
92 * -SAR update for Gen95, EL1C part
93 *
94 * 12 04 2017 bart.liang
95 * [MOLY00293238] [GEN93] EM Power Detector - error handling
96 *
97 * 12 01 2017 bart.liang
98 * [MOLY00293238] [GEN93] EM Power Detector - error handling
99 *
100 * 12 01 2017 bart.liang
101 * [MOLY00293238] [GEN93] EM Power Detector - error handling
102 * Rollback for V-list sync fail
103 *
104 * 07 10 2017 jung-ching.hsieh
105 * [MOLY00262750] [PH1 VZW] Regarding Antenna Testing interface modify
106 *
107 * 12 19 2016 gary.liu
108 * [MOLY00207413] EL1C 6293 development
109 * [EL1 CH] change lte band from uint8 to uint16
110 *
111 * 11 16 2016 popcafa.shih
112 * [MOLY00196065] [MT6293][folder structure] Move EL1/EL2 files from LTE domain to SWRD domain
113 * modify MOLY00173949 & MOLY00172964 for IS_EL1_ANDROID_M_LCE_REPORT_SUPPORT 0.
114 *
115 * 01 15 2016 ty.shen
116 * [MOLY00159734] TX power detector support on Jade
117 * L4C/EL1 Interface.
118 *
119 * 07 09 2014 yr.chiang
120 * [MOLY00071851] [MT6290E2][EL1TX] ROME DSDA support for AT+EB3INFO
121 * .
122 *
123 * 05 20 2014 yr.chiang
124 * [MOLY00066106] [MT6290E2][EL1] EL1 support for EM forceTx function
125 * .
126 *
127 ****************************************************************************/
128
129
130#ifndef _L4C_EL1_STRUCT_H_
131#define _L4C_EL1_STRUCT_H_
132
133#include "kal_general_types.h"
134#include "kal_public_defs.h"
135#include "el1_comm_inter_category_public.h"
136
137#if (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__)))
138#include "l3_inc_enums.h"
139#include "l4c_common_enum.h"
140#endif
141
142//#include "ps_public_enum.h"
143
144#define LTE_MAX_TX_PWR_REQ_ANT_NUM 16 // LTE_MAX_TX_PWR_REQ_ANT_NUM >= LTE_SAR_ENABLE_MAX_ANT_TABLE_NUM
145/* MSG_ID_EL1_LTE_MAX_TX_PWR_RED_REQ */
146typedef struct
147{
148 LOCAL_PARA_HDR
149 // op 1: for all band, op 3,5: only for band, op 4: reset, n = 1
150 // op 9: for all band (2 antennas), op 10: one band (2 antennas), n = 2
151 // op 11: for all band (n antennas), op 12: one band (n antennas), 1 < n <= LTE_MAX_TX_PWR_REQ_ANT_NUM
152 kal_uint8 op;
153 kal_uint16 band; // Band in integer format (1 - 255)
154 // note: para1, para2 and para3 to be removed
155 kal_uint8 para1; // 0~255, unit: 1/8 dB, (0~32 dB)
156 kal_uint8 para2; // reserved
157 kal_uint8 para3; // reserved
158 kal_uint8 n; // 1~LTE_MAX_TX_PWR_REQ_ANT_NUM, number of valid parameters in param[]
159 kal_uint8 param[LTE_MAX_TX_PWR_REQ_ANT_NUM]; // 0~255, unit: 1/8 dB, (0~32 dB)
160} el1_lte_max_tx_pwr_red_req_struct;
161
162
163typedef enum
164{
165 EL1_EM_TST_CMD_FORCE_TX_PWR,
166 EL1_EM_TST_CMD_END,
167 EL1_EM_TST_CMD_TX_REPORT,
168} EL1_EM_TSTCmdType;
169
170typedef struct
171{
172 kal_uint8 on;
173 kal_bool duplex_mode;
174 kal_uint8 band;
175 kal_uint8 ul_bandwidth;
176 kal_uint16 ul_freq;
177 kal_uint8 tdd_cfg;
178 kal_uint8 tdd_sp_sf_cfg;
179 kal_uint8 vrb_start;
180 kal_uint8 vrb_len;
181 kal_uint8 mcs;
182 kal_int16 tx_power;
183 kal_bool tas_en;
184 kal_uint8 tx_ant_state;
185 kal_uint8 rx_ant_state;
186} EL1_EM_TSTCmd_ForceTxPwr_T;
187
188typedef union
189{
190 EL1_EM_TSTCmd_ForceTxPwr_T forceTxPwr;
191} EL1_EM_TSTCmdParam;
192
193
194/* MSG_ID_L4C_EL1_EM_TST_CONTROL_REQ */
195typedef struct
196{
197 LOCAL_PARA_HDR
198
199 kal_uint8 src_id;
200 EL1_EM_TSTCmdType type;
201 EL1_EM_TSTCmdParam param;
202} l4c_el1_em_tst_control_req_struct;
203
204typedef enum
205{
206 //L4CEL1_ERR_START = IND_AT_CMD_CAUSE_START, // 0x1900
207 L4C_EL1_ERR_NOT_IN_FLIGHT = 0x1901,
208 L4C_EL1_ERR_SIM_IN_SLOT = 0x1902,
209 L4C_EL1_ERR_PARA_BAND = 0x1903,
210 L4C_EL1_ERR_PARA_UL_BW = 0x1904,
211 L4C_EL1_ERR_PARA_UL_FREQ = 0x1905,
212 L4C_EL1_ERR_PARA_DUPLEX_MODE= 0x1906,
213 L4C_EL1_ERR_PARA_TDD_CFG = 0x1907,
214 L4C_EL1_ERR_PARA_SP_SF_CFG = 0x1908,
215 L4C_EL1_ERR_PARA_VRB = 0x1909,
216 L4C_EL1_ERR_PARA_MCS = 0x190A,
217 L4C_EL1_ERR_ROUTE_VALID = 0x190B,
218 L4C_EL1_ERR_TEST_ONGOING = 0x190C,
219 L4C_EL1_ERR_ANT_STATE = 0x190D,
220 L4C_EL1_ERR_OTHERS = 0x194F,
221 L4CEL1_ERR_INVALID = 0x1950 //success=true, error_code is useless
222} l4cel1_error_enum ; //error_code should be larger than 256
223
224/* MSG_ID_L4C_EL1_EM_TST_CONTROL_CNF */
225typedef struct
226{
227 LOCAL_PARA_HDR
228
229 kal_uint8 src_id;
230 kal_bool success;
231 l4cel1_error_enum error_code;
232} l4c_el1_em_tst_control_cnf_struct;
233
234
235/* MSG_ID_L4C_EL1_EM_TX_REPORT_IND */
236typedef struct
237{
238 LOCAL_PARA_HDR
239
240 kal_int32 tx_power; // dBm*8
241} l4c_el1_em_tx_report_ind_struct;
242
243
244/* MSG_ID_L4CEL1_B3_INFO_REQ */
245typedef struct
246{
247 LOCAL_PARA_HDR
248
249 kal_uint8 type; // 0: Off, 1: TCH, 2: BCCH
250 kal_uint8 index; // frequency index
251 // 0:1850-1860
252 // 1:1860-1870
253 // 2:1870-1875
254 // 3:1875-1880
255 // 4:1845-1850
256 kal_uint16 arfcn; // GSM arfcn
257 kal_int16 rssi; // GSM rssi
258 kal_uint8 src; // Sourcd id
259} l4cel1_b3_info_req_struct;
260
261
262/* MSG_ID_L4CEL1_B3_INFO_CNF */
263typedef struct
264{
265 LOCAL_PARA_HDR
266
267 kal_uint8 result;// 1: success, 0: error
268 kal_uint8 src; // Sourcd id
269} l4cel1_b3_info_cnf_struct;
270
271typedef struct
272{
273 LOCAL_PARA_HDR
274 kal_uint8 srcid; // srcid is set by request
275 kal_uint32 lce_mode; // Stop:0, Push mode:1, Pull mode:2
276 kal_uint32 lce_rpt_interval_ms; // LCE report interval
277} l4c_el1_lce_report_start_req_struct;
278
279typedef struct
280{
281 LOCAL_PARA_HDR
282 kal_uint8 srcid;
283} l4c_el1_lce_report_pulldata_req_struct;
284
285typedef struct
286{
287 LOCAL_PARA_HDR
288 kal_uint8 srcid;
289 kal_uint8 lce_status; // stop:0, active:1
290 kal_uint32 lce_act_interval_ms; // actually reporting interval(ms)
291} l4c_el1_lce_report_cnf_struct;
292
293typedef struct
294{
295 LOCAL_PARA_HDR
296 kal_uint8 srcid;
297 kal_uint8 lce_suspend;
298 kal_uint32 tput_curr;
299 kal_uint32 conf_lv1;
300} l4c_el1_lce_report_ind_struct;
301
302typedef enum
303{
304 ANTENNA_CONFIG_NORMAL_DUAL = 0x1, // normal dual receiver operation (default UE behavior)
305 ANTENNA_CONFIG_SINGLE_PRIMARY = 0x2, // Single receiver operation ' enable primary receiver only (disable secondary/MIMO receiver)
306 ANTENNA_CONFIG_SINGLE_SECONDARY = 0x3 // Single receiver operation ' enable secondary/MIMO receiver only (disable primary receiver)
307} l4cel1_antenna_config_enum;
308
309typedef enum
310{
311 ANTENNA_STATUS_NORMAL_DUAL = 0x1, // normal dual receiver operation (default UE behavior)
312 ANTENNA_STATUS_SINGLE_PRIMARY = 0x2, // Single receiver operation ' enable primary receiver only (disable secondary/MIMO receiver)
313 ANTENNA_STATUS_SINGLE_SECONDARY = 0x3 // Single receiver operation ' enable secondary/MIMO receiver only (disable primary receiver)
314} l4cel1_antenna_status_enum;
315
316typedef struct
317{
318 LOCAL_PARA_HDR
319 kal_uint8 src_id;
320 kal_bool pri_receiver;
321 kal_bool sec_receiver;
322} l4cel1_antenna_information_req_struct;
323
324typedef struct
325{
326 LOCAL_PARA_HDR
327 kal_uint8 src_id;
328 kal_bool result; //KAL_TRUE if success; otherwise KAL_FALSE
329 kal_bool is_pri_receiver_valid;
330 kal_uint16 pri_rssi;
331 kal_bool is_sec_receiver_valid;
332 kal_uint16 sec_rssi;
333 kal_bool is_relative_phase_valid;
334 kal_uint16 relative_phase;
335} l4cel1_antenna_information_cnf_struct;
336
337typedef struct
338{
339 LOCAL_PARA_HDR
340 kal_uint8 src_id;
341 l4cel1_antenna_config_enum configuration;
342} l4cel1_antenna_config_req_struct;
343
344typedef struct
345{
346 LOCAL_PARA_HDR
347 kal_uint8 src_id;
348 kal_bool result; //KAL_TRUE if success; otherwise KAL_FALSE
349} l4cel1_antenna_config_cnf_struct;
350
351typedef struct
352{
353 LOCAL_PARA_HDR
354 kal_uint8 src_id;
355} l4cel1_antenna_config_status_req_struct;
356
357
358typedef struct
359{
360 LOCAL_PARA_HDR
361 kal_uint8 src_id;
362 kal_bool result; //antenna status result
363 l4cel1_antenna_status_enum ue_behavior;
364} l4cel1_antenna_config_status_cnf_struct;
365
366typedef struct
367{
368 LOCAL_PARA_HDR
369 kal_int32 rssi_edBm[LTE_UE_ANT_NUM];
370}l4cel1_ps_local_rx_rssi_verify_ind_struct;
371
372#if (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__)))
373typedef struct
374{
375 LOCAL_PARA_HDR
376 l4c_source_id_enum src_id; // piggyback value, indicate the source
377 omadm_cmd_type_enum cmd; // command mode
378 omadm_node_type_enum node_type; // OMADM node
379 kal_uint32 node_value; // the value for set mode
380} l4c_el1_omadm_update_req_struct;
381
382typedef struct
383{
384 LOCAL_PARA_HDR
385 l4c_source_id_enum src_id; // piggyback value, indicate the source
386 omadm_cmd_type_enum cmd; // command mode
387 kal_bool result; // TRUE=>pass, FALSE=>error
388 omadm_node_type_enum node_type; // OMADM node
389 kal_uint32 node_value; // the value for set mode
390} l4c_el1_omadm_update_cnf_struct;
391#endif /* (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__))) */
392
393#endif
394
395