rjw | 6c1fd8f | 2022-11-30 14:33:01 +0800 | [diff] [blame] | 1 | /***************************************************************************** |
| 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 */ |
| 146 | typedef 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 | |
| 163 | typedef 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 | |
| 170 | typedef 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 | |
| 188 | typedef union |
| 189 | { |
| 190 | EL1_EM_TSTCmd_ForceTxPwr_T forceTxPwr; |
| 191 | } EL1_EM_TSTCmdParam; |
| 192 | |
| 193 | |
| 194 | /* MSG_ID_L4C_EL1_EM_TST_CONTROL_REQ */ |
| 195 | typedef 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 | |
| 204 | typedef 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 */ |
| 225 | typedef 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 */ |
| 236 | typedef 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 */ |
| 245 | typedef 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 */ |
| 263 | typedef 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 | |
| 271 | typedef 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 | |
| 279 | typedef struct |
| 280 | { |
| 281 | LOCAL_PARA_HDR |
| 282 | kal_uint8 srcid; |
| 283 | } l4c_el1_lce_report_pulldata_req_struct; |
| 284 | |
| 285 | typedef 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 | |
| 293 | typedef 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 | |
| 302 | typedef 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 | |
| 309 | typedef 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 | |
| 316 | typedef 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 | |
| 324 | typedef 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 | |
| 337 | typedef struct |
| 338 | { |
| 339 | LOCAL_PARA_HDR |
| 340 | kal_uint8 src_id; |
| 341 | l4cel1_antenna_config_enum configuration; |
| 342 | } l4cel1_antenna_config_req_struct; |
| 343 | |
| 344 | typedef 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 | |
| 351 | typedef struct |
| 352 | { |
| 353 | LOCAL_PARA_HDR |
| 354 | kal_uint8 src_id; |
| 355 | } l4cel1_antenna_config_status_req_struct; |
| 356 | |
| 357 | |
| 358 | typedef 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 | |
| 366 | typedef 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__))) |
| 373 | typedef 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 | |
| 382 | typedef 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 | |