| /***************************************************************************** |
| * Copyright Statement: |
| * -------------------- |
| * This software is protected by Copyright and the information contained |
| * herein is confidential. The software may not be copied and the information |
| * contained herein may not be used or disclosed except with the written |
| * permission of MediaTek Inc. (C) 2012 |
| * |
| * BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES |
| * THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE") |
| * RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON |
| * AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES, |
| * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF |
| * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT. |
| * NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE |
| * SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR |
| * SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH |
| * THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO |
| * NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S |
| * SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM. |
| * |
| * BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE |
| * LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE, |
| * AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE, |
| * OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO |
| * MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE. |
| * |
| * THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE |
| * WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF |
| * LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND |
| * RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER |
| * THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC). |
| * |
| *****************************************************************************/ |
| |
| /******************************************************************************* |
| * Filename: |
| * --------- |
| * l4c_el1_struct.h |
| * |
| * Project: |
| * -------- |
| * MOLY |
| * |
| * Description: |
| * ------------ |
| * message and common structure definition between L4C and EL1 modules. |
| * |
| * Author: |
| * ------- |
| * ------- |
| * |
| * ========================================================================== |
| * $Log$ |
| * |
| * 06 02 2021 titi.wu |
| * [MOLY00609450] [FM350][HP][Kaixuan.Zhang]LTE«D«H¥OTx©MRxªºAT©R¥O»Ý¨D |
| * |
| * . |
| * |
| * 04 09 2021 titi.wu |
| * [MOLY00609450] [FM350][HP][Kaixuan.Zhang]LTE«D«H¥OTx©MRxªºAT©R¥O»Ý¨D |
| * . |
| * |
| * 07 03 2020 wade.chen |
| * [MOLY00534567] LTE B38 ©M B41ªº «ü¥OAT+ERFTX=6,0,1,41,2,26825,1,1,4,0,25,0,23,1,1 ?¤£¥X?¥\²v |
| * |
| * [EWSP0000125300][R3]add rx ant state for ERFTX test |
| * |
| * 05 26 2020 chun-yu.chien |
| * [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: |
| * |
| * AT+EGDM extension : GET/SET omadm 4x4 MIMO interface |
| * R3.MP |
| * |
| * 09 25 2019 wade.chen |
| * [MOLY00347940] [Gen97][MT6297] tstm_meta development |
| * |
| * [VMOLY]ERFTX error handle enhancement (code sync) |
| * |
| * 01 29 2019 wade.chen |
| * [MOLY00347940] [Gen97][MT6297] tstm_meta development |
| * |
| * [ERS00028822][EVB.SEPT.DEV][code sync] RF De-sense modification |
| * |
| * 06 06 2018 vend_mtb_mobiveil012 |
| * [MOLY00331680] [CODE SYNC] Looking for TAS AT comamnd while target execte RF test by AT+ERFTX |
| * Added two antenna parameters to AT+ERFTX=6. |
| * |
| * 05 22 2018 aki.hietala |
| * [MOLY00260136] [MT6295] EL1C TX development |
| * -SAR update for Gen95, EL1C part |
| * |
| * 12 04 2017 bart.liang |
| * [MOLY00293238] [GEN93] EM Power Detector - error handling |
| * |
| * 12 01 2017 bart.liang |
| * [MOLY00293238] [GEN93] EM Power Detector - error handling |
| * |
| * 12 01 2017 bart.liang |
| * [MOLY00293238] [GEN93] EM Power Detector - error handling |
| * Rollback for V-list sync fail |
| * |
| * 07 10 2017 jung-ching.hsieh |
| * [MOLY00262750] [PH1 VZW] Regarding Antenna Testing interface modify |
| * |
| * 12 19 2016 gary.liu |
| * [MOLY00207413] EL1C 6293 development |
| * [EL1 CH] change lte band from uint8 to uint16 |
| * |
| * 11 16 2016 popcafa.shih |
| * [MOLY00196065] [MT6293][folder structure] Move EL1/EL2 files from LTE domain to SWRD domain |
| * modify MOLY00173949 & MOLY00172964 for IS_EL1_ANDROID_M_LCE_REPORT_SUPPORT 0. |
| * |
| * 01 15 2016 ty.shen |
| * [MOLY00159734] TX power detector support on Jade |
| * L4C/EL1 Interface. |
| * |
| * 07 09 2014 yr.chiang |
| * [MOLY00071851] [MT6290E2][EL1TX] ROME DSDA support for AT+EB3INFO |
| * . |
| * |
| * 05 20 2014 yr.chiang |
| * [MOLY00066106] [MT6290E2][EL1] EL1 support for EM forceTx function |
| * . |
| * |
| ****************************************************************************/ |
| |
| |
| #ifndef _L4C_EL1_STRUCT_H_ |
| #define _L4C_EL1_STRUCT_H_ |
| |
| #include "kal_general_types.h" |
| #include "kal_public_defs.h" |
| #include "el1_comm_inter_category_public.h" |
| |
| #if (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__))) |
| #include "l3_inc_enums.h" |
| #include "l4c_common_enum.h" |
| #endif |
| |
| //#include "ps_public_enum.h" |
| |
| #define LTE_MAX_TX_PWR_REQ_ANT_NUM 16 // LTE_MAX_TX_PWR_REQ_ANT_NUM >= LTE_SAR_ENABLE_MAX_ANT_TABLE_NUM |
| /* MSG_ID_EL1_LTE_MAX_TX_PWR_RED_REQ */ |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| // op 1: for all band, op 3,5: only for band, op 4: reset, n = 1 |
| // op 9: for all band (2 antennas), op 10: one band (2 antennas), n = 2 |
| // op 11: for all band (n antennas), op 12: one band (n antennas), 1 < n <= LTE_MAX_TX_PWR_REQ_ANT_NUM |
| kal_uint8 op; |
| kal_uint16 band; // Band in integer format (1 - 255) |
| // note: para1, para2 and para3 to be removed |
| kal_uint8 para1; // 0~255, unit: 1/8 dB, (0~32 dB) |
| kal_uint8 para2; // reserved |
| kal_uint8 para3; // reserved |
| kal_uint8 n; // 1~LTE_MAX_TX_PWR_REQ_ANT_NUM, number of valid parameters in param[] |
| kal_uint8 param[LTE_MAX_TX_PWR_REQ_ANT_NUM]; // 0~255, unit: 1/8 dB, (0~32 dB) |
| } el1_lte_max_tx_pwr_red_req_struct; |
| |
| |
| typedef enum |
| { |
| EL1_EM_TST_CMD_FORCE_TX_PWR, |
| EL1_EM_TST_CMD_END, |
| EL1_EM_TST_CMD_TX_REPORT, |
| } EL1_EM_TSTCmdType; |
| |
| typedef struct |
| { |
| kal_uint8 on; |
| kal_bool duplex_mode; |
| kal_uint8 band; |
| kal_uint8 ul_bandwidth; |
| kal_uint16 ul_freq; |
| kal_uint8 tdd_cfg; |
| kal_uint8 tdd_sp_sf_cfg; |
| kal_uint8 vrb_start; |
| kal_uint8 vrb_len; |
| kal_uint8 mcs; |
| kal_int16 tx_power; |
| kal_bool tas_en; |
| kal_uint8 tx_ant_state; |
| kal_uint8 rx_ant_state; |
| } EL1_EM_TSTCmd_ForceTxPwr_T; |
| |
| typedef union |
| { |
| EL1_EM_TSTCmd_ForceTxPwr_T forceTxPwr; |
| } EL1_EM_TSTCmdParam; |
| |
| |
| /* MSG_ID_L4C_EL1_EM_TST_CONTROL_REQ */ |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| |
| kal_uint8 src_id; |
| EL1_EM_TSTCmdType type; |
| EL1_EM_TSTCmdParam param; |
| } l4c_el1_em_tst_control_req_struct; |
| |
| typedef enum |
| { |
| //L4CEL1_ERR_START = IND_AT_CMD_CAUSE_START, // 0x1900 |
| L4C_EL1_ERR_NOT_IN_FLIGHT = 0x1901, |
| L4C_EL1_ERR_SIM_IN_SLOT = 0x1902, |
| L4C_EL1_ERR_PARA_BAND = 0x1903, |
| L4C_EL1_ERR_PARA_UL_BW = 0x1904, |
| L4C_EL1_ERR_PARA_UL_FREQ = 0x1905, |
| L4C_EL1_ERR_PARA_DUPLEX_MODE= 0x1906, |
| L4C_EL1_ERR_PARA_TDD_CFG = 0x1907, |
| L4C_EL1_ERR_PARA_SP_SF_CFG = 0x1908, |
| L4C_EL1_ERR_PARA_VRB = 0x1909, |
| L4C_EL1_ERR_PARA_MCS = 0x190A, |
| L4C_EL1_ERR_ROUTE_VALID = 0x190B, |
| L4C_EL1_ERR_TEST_ONGOING = 0x190C, |
| L4C_EL1_ERR_ANT_STATE = 0x190D, |
| L4C_EL1_ERR_OTHERS = 0x194F, |
| L4CEL1_ERR_INVALID = 0x1950 //success=true, error_code is useless |
| } l4cel1_error_enum ; //error_code should be larger than 256 |
| |
| /* MSG_ID_L4C_EL1_EM_TST_CONTROL_CNF */ |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| |
| kal_uint8 src_id; |
| kal_bool success; |
| l4cel1_error_enum error_code; |
| } l4c_el1_em_tst_control_cnf_struct; |
| |
| |
| /* MSG_ID_L4C_EL1_EM_TX_REPORT_IND */ |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| |
| kal_int32 tx_power; // dBm*8 |
| } l4c_el1_em_tx_report_ind_struct; |
| |
| |
| /* MSG_ID_L4CEL1_B3_INFO_REQ */ |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| |
| kal_uint8 type; // 0: Off, 1: TCH, 2: BCCH |
| kal_uint8 index; // frequency index |
| // 0:1850-1860 |
| // 1:1860-1870 |
| // 2:1870-1875 |
| // 3:1875-1880 |
| // 4:1845-1850 |
| kal_uint16 arfcn; // GSM arfcn |
| kal_int16 rssi; // GSM rssi |
| kal_uint8 src; // Sourcd id |
| } l4cel1_b3_info_req_struct; |
| |
| |
| /* MSG_ID_L4CEL1_B3_INFO_CNF */ |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| |
| kal_uint8 result;// 1: success, 0: error |
| kal_uint8 src; // Sourcd id |
| } l4cel1_b3_info_cnf_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 srcid; // srcid is set by request |
| kal_uint32 lce_mode; // Stop:0, Push mode:1, Pull mode:2 |
| kal_uint32 lce_rpt_interval_ms; // LCE report interval |
| } l4c_el1_lce_report_start_req_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 srcid; |
| } l4c_el1_lce_report_pulldata_req_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 srcid; |
| kal_uint8 lce_status; // stop:0, active:1 |
| kal_uint32 lce_act_interval_ms; // actually reporting interval(ms) |
| } l4c_el1_lce_report_cnf_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 srcid; |
| kal_uint8 lce_suspend; |
| kal_uint32 tput_curr; |
| kal_uint32 conf_lv1; |
| } l4c_el1_lce_report_ind_struct; |
| |
| typedef enum |
| { |
| ANTENNA_CONFIG_NORMAL_DUAL = 0x1, // normal dual receiver operation (default UE behavior) |
| ANTENNA_CONFIG_SINGLE_PRIMARY = 0x2, // Single receiver operation ' enable primary receiver only (disable secondary/MIMO receiver) |
| ANTENNA_CONFIG_SINGLE_SECONDARY = 0x3 // Single receiver operation ' enable secondary/MIMO receiver only (disable primary receiver) |
| } l4cel1_antenna_config_enum; |
| |
| typedef enum |
| { |
| ANTENNA_STATUS_NORMAL_DUAL = 0x1, // normal dual receiver operation (default UE behavior) |
| ANTENNA_STATUS_SINGLE_PRIMARY = 0x2, // Single receiver operation ' enable primary receiver only (disable secondary/MIMO receiver) |
| ANTENNA_STATUS_SINGLE_SECONDARY = 0x3 // Single receiver operation ' enable secondary/MIMO receiver only (disable primary receiver) |
| } l4cel1_antenna_status_enum; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 src_id; |
| kal_bool pri_receiver; |
| kal_bool sec_receiver; |
| } l4cel1_antenna_information_req_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 src_id; |
| kal_bool result; //KAL_TRUE if success; otherwise KAL_FALSE |
| kal_bool is_pri_receiver_valid; |
| kal_uint16 pri_rssi; |
| kal_bool is_sec_receiver_valid; |
| kal_uint16 sec_rssi; |
| kal_bool is_relative_phase_valid; |
| kal_uint16 relative_phase; |
| } l4cel1_antenna_information_cnf_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 src_id; |
| l4cel1_antenna_config_enum configuration; |
| } l4cel1_antenna_config_req_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 src_id; |
| kal_bool result; //KAL_TRUE if success; otherwise KAL_FALSE |
| } l4cel1_antenna_config_cnf_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 src_id; |
| } l4cel1_antenna_config_status_req_struct; |
| |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_uint8 src_id; |
| kal_bool result; //antenna status result |
| l4cel1_antenna_status_enum ue_behavior; |
| } l4cel1_antenna_config_status_cnf_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| kal_int32 rssi_edBm[LTE_UE_ANT_NUM]; |
| }l4cel1_ps_local_rx_rssi_verify_ind_struct; |
| |
| #if (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__))) |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| l4c_source_id_enum src_id; // piggyback value, indicate the source |
| omadm_cmd_type_enum cmd; // command mode |
| omadm_node_type_enum node_type; // OMADM node |
| kal_uint32 node_value; // the value for set mode |
| } l4c_el1_omadm_update_req_struct; |
| |
| typedef struct |
| { |
| LOCAL_PARA_HDR |
| l4c_source_id_enum src_id; // piggyback value, indicate the source |
| omadm_cmd_type_enum cmd; // command mode |
| kal_bool result; // TRUE=>pass, FALSE=>error |
| omadm_node_type_enum node_type; // OMADM node |
| kal_uint32 node_value; // the value for set mode |
| } l4c_el1_omadm_update_cnf_struct; |
| #endif /* (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__))) */ |
| |
| #endif |
| |
| |