blob: baa942ccf776a925be8a982fd642e277b93c80ce [file] [log] [blame]
/*****************************************************************************
* 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) 2013
*
* 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:
* ------------
* vdm_atp_struct.h
*
* Project:
* ------------
* MOLY
*
* Description:
* ------------
* This file defines the interface messages between VDM and IMS Proxy.
*
* Author:
* -----------
* -------
*
*===========================================================
* $Log$
*
* 06 21 2022 vijay.goyal
* [MOLY00765081] [FeatureDevelopment][ALPSAR06336232] TMOUS 22Q1 Requirement Gap Development - UE MO Timer F1
* .
*
* 01 27 2022 taffy.cheng
* [MOLY00803278] [Gen97][MD700] CR patch-back from R3.MP
*
* [MOLY00678551][MOLY00679592][MOLY00686355][MOLY00683334][MOLY00701221][MOLY00721364][MOLY00773738] Patch Back
*
* 01 10 2022 ot_hitesh.c
* [MOLY00774161] [mt2735][CS eCall][NG eCall][patch back] ecall patch back from NR15.R3.MD700.MP.ECAll.DEV
* .
*
* 12 16 2021 ot_hitesh.c
* [MOLY00774161] [mt2735][CS eCall][NG eCall][patch back] ecall patch back from NR15.R3.MD700.MP.ECAll.DEV
* .
*
* 12 01 2020 yulong.chang
* [MOLY00598875] Request a SRVCC CS Call Resource control by VDM
*
* ALPS05460502
*
* 10 14 2020 chen-wei.lan
* [MOLY00580995] [Titan97]IPC c2k call flow change for VDM enabled
* titan c2k
*
* 08 28 2020 chen-wei.lan
* [MOLY00562709] [5GHP][feature][Data&Call]game space mode
* .
*
* 08 14 2020 yulong.chang
* [MOLY00543239] [MT6883][VoNR] request to support API for call preference change
*
* Add At command ECNWS
*
* 07 27 2020 yulong.chang
* [MOLY00549478] [Gen97][HE3.0]N3GPP offload over data feature
* VoData VDM part
*
* 03 16 2020 chen-wei.lan
* [MOLY00504146] [5G-A][5G Modem·sfeature]ɬ¤Æ5G±µ¤J±±¨î
* ssac opt
*
* 03 10 2020 chen-wei.lan
* [MOLY00504146] [5G-A][5G Modem·sfeature]ɬ¤Æ5G±µ¤J±±¨î
* ssac opt
*
* 12 08 2019 chen-wei.lan
* [MOLY00346647] [MT6297][VDM/L4] changes for 97
* [patch back]6996240,7189967,7222841,7241346,7367549,8756435
*
* 12 02 2019 chen-wei.lan
* [MOLY00346647] [MT6297][VDM/L4] changes for 97
* [patch back]8519908,8519818,8915296,9086988,9086148,9085815,9318206,9357101
*
* 11 20 2019 chen-wei.lan
* [MOLY00460626] [Petrus]BSP+][Q0][Operator IOT] ECC cannot be established by RJIL after flight mode
* fix eXreg
*
* 11 13 2019 chen-wei.lan
* [MOLY00458901] [Rose][Petrus]BSP+][Q0]The CMCC volte card will register E network all the time.(Once)
* AT+EMCI=0
*
* 10 31 2019 chen-wei.lan
* [MOLY00455800] [Rose][Petrus]BSP+][Q0]The DUT will popup ECBM.(Once)
* add +VMCCMNC urc handling for VDM
*
* 10 25 2019 chen-wei.lan
* [MOLY00454520] ¡idump¡j??Éó?¥d??¤U?¥´120¡Amodem ­«? 1/5
* fix emcs
*
* 10 17 2019 chen-wei.lan
* [MOLY00449571] [MT6885][Petrus][Q0][MP1][SI2][SQC][China][SH][4GMM][FT][hVoLTE][hVoLTE_FT_2.1]sim1 C2K call failure after 4G3
* fix AT+EIMSCFG.
*
* 09 24 2019 danny.kuo
* [MOLY00440886] [Gen97] DSDA-like feature check in
* .
*
* 01 30 2019 kuan-wei.chen
* [MOLY00346647] [MT6297][VDM/L4] changes for 97
* [VMOLY.EVB.SEPT.DEV][MPD] sync VDM CL: 6995175~7345261
*
* 11 01 2018 kuan-wei.chen
* [MOLY00346647] [MT6297][VDM/L4] changes for 97
* [VMOLY][VDM][MPD]
*
* 08 17 2018 chen-wei.lan
* [MOLY00346647] [MT6297][VDM/L4] changes for 97
* l4c cc
*
* 05 24 2018 szu-chieh.chiu
* [MOLY00328315] [IMS][Gen95] Emergency PDN handover
* Emergency PDN handover.
*
* 05 23 2018 yulong.chang
* [MOLY00327672] [UMOLYE][Rose][MERLOT][O1][BSP+][Initial Tool]The device was not regist network after some operate.(once)
* VDM relay +CIEV:102,X to AP
*
* 05 03 2018 jerry.cheng
* [MOLY00322938] ?�H�ƥd����`?VOLTE - notify C2K call end to L4 (VDM part)
* .[UMOLYE] Send AT+EHVOLTE=0,2 to notify L4 C2K call end in order not to block switching to SRLTE mode
*
* 03 29 2018 yulong.chang
* [MOLY00313953] [UMOLYE][VDM][Vzw][CDMA-less][PCO] Trigger NWSEL search for Vzw CDMA less if UE has received PCO_FF00H=5 and AP radio control off and timer expired and UE is roaming
* PCO FF00H 5 - VDM main part
*
* 03 13 2018 yulong.chang
* [MOLY00312598] [DSBP] patch back "D-SBP enhancment for all modem" to UMOLYE and TC01.R3.DEV
* EFUN/CFUN controlled by L4BPWR (VDM part)
*
* 02 23 2018 yulong.chang
* [MOLY00309362] [Rose][Sylvia][O1][BSP+][Telephony switch]The ECC call will dialing all the time.(Once)
*
* improve +EMCSS (VDM part)
*
* 12 18 2017 yulong.chang
* [MOLY00296177] [MT6293][GMSS] prefer RAT handling enhancement
* Add one parameter in AT+EMCSS.
*
* AT+EMCSS=1,[<available_rat>,<prefer_rat>,<is_new_call>]
*
* 12 01 2017 yulong.chang
* [MOLY00293536] [VDM][TMO-US][RTT] Redial voice only VoLTE EMCl when RTT VoLTE EMC fail (VDM part)
* TMO RTT redial
*
* 12 01 2017 yulong.chang
* Roll back MOLY00291130
*
*
* 11 23 2017 jerry.cheng
* [MOLY00291130] [R3][VZW feature] VZ_REQ_e911_30203 (EMC call type)
* .rollback to resolve autosync conflict
*
* 11 21 2017 jerry.cheng
* [MOLY00287748] [93][TMO][VDM] Digits implementation
* .[TMO][Digits] modify query TRN AT cmd/URC format
*
* 11 21 2017 yulong.chang
* [MOLY00288769] [Zion][N1][Free Test][MCD][TEFT]make a vilte call,the picture is unclear(5/5) (vdm part)
* notify ERRC IMS call RAT (VDM part)
*
* 11 06 2017 jerry.cheng
* [MOLY00287748] [93][TMO][VDM] Digits implementation
* .Digits implementation - VDM part
*
* 09 01 2017 yulong.chang
* [MOLY00274843] [CDMA-less][LR12] main CR (VDM part)
* [LR11.MP5->UMOLYA sync] MOLY00262171 [CDMA-less][LR12] main CR (VDM part)
*
* 08 31 2017 yulong.chang
* [MOLY00274168] [MT6293][NWSIM][Regression][TC_9_3_1_3] UE return CME error for ATD01234567890;
* ALPS03464343 Bug fix (also reference At+CFUN)
*
* 08 30 2017 yulong.chang
* [MOLY00274412] [6755][E66_DUGL][ITS#1174]Without SIM and make Emergency call:911, DUT will met call drop
* [LR11.MP5->UMOLYA sync] MOLY00255649 [6755][E66_DUGL][ITS#1174]Without SIM and make Emergency call:911, DUT will met call drop
*
* 08 28 2017 yulong.chang
* [MOLY00274096] [VzW] addl call_domain_cause - IMSP/VDM/IMC part
* [LR11.MP5->UMOLYA sync] MOLY00254610 [VzW] addl call_domain_cause - IMSP/VDM/IMC part
*
* 08 24 2017 yulong.chang
* [MOLY00272923] [Bianco][N1][MTK FT][SRLTE][CT 6M C][LZ][Random] call can't hang up (ATP part)
* .
*
* 08 17 2017 jerry.cheng
* [MOLY00271227] [UMOLYA] [Rose][Vinson][N1]The ECC call will can't be dial out success.(5/5)
* [LR12->UMOLYA sync] [MOLY00259723] send call_status_req to NAS/AS : VDM/ATP - add call_type in AT+EVVS
*
* 08 17 2017 yulong.chang
* [MOLY00271652] [TCL][MICKEY6T TMO] [IMS/VoLTE] - L_IMS_VoLTE_50944_1 - for VDM/IMSP check-in
* [LR11.MP5->UMOLYA sync] MOLY00250915 [TCL][MICKEY6T TMO] [IMS/VoLTE] - L_IMS_VoLTE_50944_1 - for VDM/IMSP check-in
*
* 08 15 2017 jerry.cheng
* [MOLY00210061] [93][VDM] UMOLY sync to UMOLYA
* .[LR12->UMOLYA sync] MOLY00264006[LR12] patch back Skip ACB feature/VDM part to LR12
*
* 07 25 2017 jerry.cheng
* [MOLY00262992] [93][VDM] IMS parameter OTA update
* .OPPO IMS parameter OTA update
*
* 07 19 2017 jerry.cheng
* [MOLY00210061] [93][VDM] UMOLY sync to UMOLYA
* .[LR11.MP5 to UMOLYA].
* porting [MOLY00215268] [VDM][ATT] ACB enable, select CS domain to dial up call. VDM part.
* porting [MOLY00215276] [VDM][ATT] ACB enable, select CS domain to dial up call. NVRAM part
*
* 07 19 2017 jerry.cheng
* [MOLY00210061] [93][VDM] UMOLY sync to UMOLYA
* .[LR11.MP5 to UMOLYA] porting [MOLY00206357] [VzW] Call Pull & VICE Feature
*
* 06 26 2017 jerry.cheng
* [MOLY00259370] .EVADSMOD rearch
* .EVADSMOD rearch
*
* 04 25 2017 jerry.cheng
* [MOLY00242146] [93][VDM] bug fix
* .rename EVADSMOD parameter
*
* 04 19 2017 jerry.cheng
* [MOLY00242146] [93][VDM] bug fix
* .fix C2K ECPI
*
* 04 07 2017 jerry.cheng
* [MOLY00240312] [93] CT VoLTE modem re-architecture
* .[CT VoLTE] +CIEV: 102,2 for ECBM mode no need
*
* 04 07 2017 jerry.cheng
* [MOLY00240312] [93] CT VoLTE modem re-architecture
* .[CT VoLTE] hVoLTE / E911 configuration, VDM re-arch, extend AT+EVADMOD, AT+EMVSS
*
* 04 05 2017 jerry.cheng
* [MOLY00221572] [Gen93][L4 integration][VDM]
*
* .AT+EVIVS support for indicating ERRC to occupy CS semaphore in VoLTE/ViTLE/VoWifFI/ViWiFI period
*
* 04 05 2017 jerry.cheng
* [MOLY00221572] [Gen93][L4 integration][VDM]
* .[M3] relay conference call number from UA to CSCC
*
* 04 05 2017 jerry.cheng
* [MOLY00221572] [Gen93][L4 integration][VDM]
* .[M3] CLCCS .remove CLCC cnf check for unsync call(C2K) in order to fulfill C2K call waiting
*
* 04 05 2017 jerry.cheng
* [MOLY00221572] [Gen93][L4 integration][VDM]
* .[M3] STK/UTK
*
* 04 05 2017 jerry.cheng
* [MOLY00221572] [Gen93][L4 integration][VDM]
* .[M3] EIMSCFG - VDM part
*
* 04 05 2017 jerry.cheng
* [MOLY00221572] [Gen93][L4 integration][VDM]
* .[M3] 380 redial as ECC by VDM
*
* 02 20 2017 jerry.cheng
* [MOLY00221572] [Gen93][L4 integration][VDM]
* .+EVPC2K.
*
* 01 06 2017 jerry.cheng
* [MOLY00220510] [93 PREIT_DEV][UMOLYA] Rename IMSP interface/context/API to ATP and reorg folder layout
* rename IMSP to ATP, ATP related files.
*
* 01 05 2017 jerry.cheng
* [MOLY00220510] [93 PREIT_DEV][UMOLYA] Rename IMSP interface/context/API to ATP and reorg folder layout
* rename IMSP to ATP.
*
* 01 05 2017 chinte.chen
* [MOLY00220510] [93 PREIT_DEV][UMOLYA] Rename IMSP interface/context/API to ATP and reorg folder layout
* fixed VDM codegen failure
*
* 11 02 2016 jerry.cheng
* [MOLY00211075] [93][VDM][L4 Integration] CC AT cmd merge
* sync [MOLY00204150] TK vzw hVoLTE/E911 implementation
*
* . ATP part.
*
* 11 02 2016 jerry.cheng
* [MOLY00211075] [93][VDM][L4 Integration] CC AT cmd merge
* sync [MOLY00204150] TK vzw hVoLTE/E911 implementation
*
* TK hVoLTE: L4/ATP/VDM.
*
* 10 13 2016 timo.korpela
* [MOLY00206906] [FT][NL][VoLTE]he hidden caller ID does not work when make call to alphanumeric SIP-URI.
* Implemented handling for CLIR parameter received in AT+CDU command.
*
* 08 11 2016 kuan-wei.chen
* [MOLY00196499] [Jade N0][TK]Waiting call screen show "Unknown" when receive a waiting call from hiden number - vdm/atp source file
* .
*
* 06 27 2016 lexel.yu
* [MOLY00183611] [VZW_LC_IOT][PH1_VZW][Radio_Protocol][NDET_Lab] hVoLTE 2.2.40_Option-A fail
* Add AT+EICE=3 workaround for silent redial
*
* 06 06 2016 yingfui.hung
* [MOLY00171513] [PH1_VZW][joint-camp][GPS][Privacy Test] When Device's Location Setting is 'Location OFF', GPS work.
*
* .
*
* 06 01 2016 kuan-wei.chen
* [MOLY00146327] [VzW] hVoLTE implementation
* vzw patchback - L4, VDM
*
* 03 23 2016 yingfui.hung
* [MOLY00168587] [MT6755][Jade M6][MP3][L+W][In-house FTA][Case Fail][VoLTE] TC_11.2.2 FAIL
*
* .
*
* 03 08 2016 yingfui.hung
* [MOLY00167924] [L4][R12] Handling of SCM at VDM/SDM/L4 part
*
* .
*
* 12 16 2015 xinwei.cui
* [MOLY00153299] [VILTE][Anite][v37][E40][12.21]FAIL
* .
*
* 12 15 2015 kuan-wei.chen
* [MOLY00153140] [D1][WFC][M0] WFC preference if wifi only, disable WFC, prompt "server unreachable" when make a call. - VDM part
* wifi only mode is active only when AT+EIMSWFC=1
*
* 12 14 2015 kuan-wei.chen
* [MOLY00150109] [IMS Feature] Non-UE detectable emergency call R12 feature
* .
*
* 12 01 2015 kuan-wei.chen
* [MOLY00133272] [NTT DOCOMO][VoLTE][IO030143] UE sends SM__ACTIVATE_PDP_CONTEXT_REQUEST unexpectedly
* DCM, 1504929
*
* 11 26 2015 yingfui.hung
* [MOLY00116938] [VOLTE][NTT DOCOMO] requirement 5A.7.1.1 Service category
*
* .
*
* 11 13 2015 lexel.yu
* [MOLY00149112] [VDM] NAS should keep search network when IMS call over WiFi ongoing
*
* .
*
* 09 14 2015 lexel.yu
* [MOLY00141573] [UMOLY][LR11][TMO][IMS] bCSFB
* .
*
* 08 26 2015 ben.chiu
* [MOLY00138217] [ViLTE] M0 migration ViLTE feature Interface
* ViLTE interface patch back
*
* 07 09 2015 nick.wang
* [MOLY00127009] WFC Patch back to UMOLY- interface part
* .moly wfc interface patch
*
* 07 09 2015 nick.wang
* [MOLY00127009] WFC Patch back to UMOLY- interface part
* .jade interface sync
*
* 06 11 2015 lexel.yu
* [MOLY00085703] [VDM][MT6291] Sync MOLY to UMOLY
* [MOLY00114718] [VDM][Volunteer Patch] Patch back for MOLY trunk
* ATDC for conference call
*
* 06 10 2015 edwin.liu
* [MOLY00120219] Merge MOLY ATP changes to UMOLY
* .
*
* 06 05 2015 edwin.liu
* ATP to UMOLY.
*
* 04 09 2015 lexel.yu
* [MOLY00106459] [MT6291][IMS] VoLTE call event download
* IMS Call Event Download
*
* 03 16 2015 lexel.yu
* [MOLY00085703] [VDM][MT6291] Sync MOLY to UMOLY
* [MOLY00080860] fix typo: replace vdm_atp_snd_ads_staus_req_struct by vdm_atp_snd_ads_status_req_struct
* [MOLY00093643] [K2][CMCC][VoLTE][NS-IOT][R&S][TC 5.2.9.2][B3-E38]UE GSM??????^LTE?????????`? fail
*
* 02 24 2015 lexel.yu
* [MOLY00085703] [VDM][MT6291] Sync MOLY to UMOLY
* [MOLY00095972] [CMCC VoLTE][VDM] Add "4 to 23G" and "23G to 4" for IRAT event.
*
* 12 05 2014 lexel.yu
* [MOLY00085703] [VDM][MT6291] Sync MOLY to UMOLY
* [MOLY00085717] [VoLTE] Android L release VoLTE refactory for VDM and ATP
*
* 11 26 2014 lexel.yu
* [MOLY00085703] [VDM][MT6291] Sync MOLY to UMOLY
* [MOLY00083542] [L4]add a new internal URC to notify VDM STK call number (+ESTKCNUM)
* VDM part
*
* 11 05 2014 lexel.yu
* [MOLY00083035] [VDM] IMS call information
* .
*
* 09 02 2014 allan.ke
* [MOLY00075245] Change the algorithm of ADS SSAC timer control and include IMSVoPS as the conditions for domain selection when dialing emergency call
*
* 04 25 2014 tehuang.liu
* [MOLY00063538] [6290E2][VoLTE][VDM] Support VoLTE Gemini architecture
* not use compile options for VoLTE Gemini interface structures definition
*
* 04 23 2014 tehuang.liu
* [MOLY00063538] [6290E2][VoLTE][VDM] Support VoLTE Gemini architecture
* Check in VoLTE+Gemini related interfaces for VDM, ATP, L4C, EVAL, and ERRC
*
* 04 11 2014 tehuang.liu
* [MOLY00062327] [6290E2][VoLTE][VDM] Support STKCALL in CS domain
* .
*
* 04 09 2014 jinghan.wang
* [MOLY00062091] [IMS][VoLTE] Check in STKCALL part for VDM TRK
* .
*
* 02 20 2014 benjamin.kuo
* [MOLY00056441] Use string instead enum for call type in CRING
* .
*
* 02 17 2014 benjamin.kuo
* [MOLY00056253] Merge SRVCC implementation from personal CBr to MOLY trunk
* SRVCC
*
* 02 14 2014 benjamin.kuo
* [MOLY00055885] [6290E2][VoLTE][MWC] incorrect URC oder of VDM and ATP
* +CRING
*
* 12 10 2013 vend_edwin.liu
* ATP.
*****************************************************************************/
#ifndef _VDM_ATP_STRUCT_H_
#define _VDM_ATP_STRUCT_H_
#include "kal_general_types.h"
#include "kal_public_defs.h"
#include "ims_common_def.h"
#include "vdm_imc_struct.h"
#include "vdm_atp_enums.h"
#include "ps_public_enum.h"
#include "l3_inc_enums.h"
#include "sim_public_enum.h"
#include "mcd_l3_inc_struct.h"
#include "c2k_irat_msg_struct.h"
#include "l4b_vdm_struct.h"
#include "l4_vdm_enum.h"
#define VDM_AT_CMD_TO_MD_NAME_LEN 32
#define VDM_AT_CMD_TO_MD_VALUE_LEN 512
typedef enum
{
VDM_IRAT_STATUS_IDLE = 0,
VDM_IRAT_STATUS_ONGOING
} vdm_irat_status_enum;
typedef enum
{
ADS_PROGRESS_ATTEMPT = 0,
ADS_PROGRESS_SUCCESS
} ads_indication_progress_enum;
typedef enum
{
ADS_DOMAIN_CS = 0,
ADS_DOMAIN_IMS
} ads_indication_domain_enum;
typedef enum
{
VDM_ADS_CALL_TYPE_INVALID = 0,
VDM_ADS_VOICE_OVER_CS,
VDM_ADS_VOICE_OVER_LTE,
VDM_ADS_VIDEO_OVER_LTE
}vdm_ads_call_type_enum;
typedef enum
{
AP_CALL_STATE_IDLE = 0,
AP_CALL_STATE_RINGRING_FOR_MT_ONLY,
AP_CALL_STATE_OFFHOOK,
} ap_call_state_enum;
typedef enum
{
AP_CALL_REASON_NORMAL = 0,
AP_CALL_REASON_SILENT_REDIAL,
} ap_call_reason_enum;
typedef enum
{
AP_CALL_TYPE_VOICE = 0,
AP_CALL_TYPE_VIDEO,
} ap_call_type_enum;
/******************************************************************************
* Common AT command structure
*****************************************************************************/
/*
* temp. for UT by MSC
*/
typedef struct
{
kal_uint8 at_cmd_string[128];
} at_cmd_buf_struct;
typedef struct
{
LOCAL_PARA_HDR
ims_result_code_enum result;
ims_err_id_enum err_id;
} vdm_atp_common_at_rsp_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_common_at_cnf_struct;
typedef struct {
LOCAL_PARA_HDR
kal_uint8 call_id;
kal_uint8 ecpi_type;
ims_ecpi_info_struct ecpi_info;
} vdm_atp_common_cs_cc_epci_ind_struct;
/******************************************************************************
* ATD<num> or ATD<num>;
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 dial_num[MAX_CC_ATD_NUM_LEN];
kal_bool is_video_call;
} vdm_atp_cmd_dial_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_dial_rsp_struct;
/******************************************************************************
* AT+CDV=<dial_num>,,,,,,so
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 dial_num[MAX_CC_ATD_NUM_LEN];
kal_uint8 so;
} vdm_atp_cmd_cdv_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_cdv_rsp_struct;
/******************************************************************************
* AT+CDU=1,<uri>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 dial_uri[MAX_CC_CDU_URI_LEN];
kal_bool video_call;
kal_uint8 clir;
} vdm_atp_cmd_dial_uri_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
ims_result_code_enum result;
ims_err_id_enum err_id;
kal_uint8 call_id;
} vdm_atp_cmd_dial_uri_rsp_struct;
/******************************************************************************
* AT+STKCALL=0
* NOTE: This AT command is forwarded from ATP to VDM.
* NOTE: For AT_STKCALL=x where x!=0, this AT command is not forwarded to VDM.
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
sat_terminal_res_enum tr; // o or 4
kal_uint8 additional_info;
} vdm_atp_cmd_stk_call_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
proxy_cmd_result_enum result;
atp_err_id_enum err_id;
} vdm_atp_cmd_stk_call_rsp_struct;
/******************************************************************************
* AT+EVADSMOD=<mode>,<ecc_preferred_domain>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
vdm_ads_mode_enum ads_mode;
vdm_ads_ecc_preferred_domain_enum ads_ecc_preferred_domain;
} vdm_atp_cmd_ads_mode_ind_struct;
/******************************************************************************
* AT+EVADSREP=<mode>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
vdm_ads_result_report_mode_enum ads_result_report_mode;
} vdm_atp_cmd_ads_result_report_ind_struct;
/******************************************************************************
* ATDE<num>;
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 dial_num[MAX_CC_ATD_NUM_LEN];
} vdm_atp_cmd_dial_emerg_ind_struct;
/******************************************************************************
* ATDER=<num>,<call_id>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 dial_num[MAX_CC_ATD_NUM_LEN];
kal_uint8 call_id;
} vdm_atp_cmd_dial_emerg_retry_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_dial_emerg_rsp_struct;
typedef vdm_atp_common_at_cnf_struct vdm_atp_cs_cc_emerg_call_cnf_struct;
/******************************************************************************
* ATDF<dial_string>,<from_line>[;]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 dial_num[MAX_CC_ATD_NUM_LEN];
kal_uint8 from_line[IMC_MAX_URI_LENGTH];
kal_bool is_video_call;
} vdm_atp_cmd_dial_from_line_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_dial_from_line_rsp_struct;
/******************************************************************************
* AT+ECALLPULL
* This command is used to dial with call pull
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 dial_uri[MAX_CC_CDU_URI_LEN];
kal_bool video_call;
} vdm_atp_cmd_dial_call_pull_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
ims_result_code_enum result;
ims_err_id_enum err_id;
kal_uint8 call_id;
} vdm_atp_cmd_dial_call_pull_rsp_struct;
/******************************************************************************
* AT+EWFCP=<profile>;
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
wfc_profile_enum wfc_profile;
} vdm_atp_cmd_wfc_profile_ind_struct;
/******************************************************************************
* AT+EVPC2K=<is_voice_prefer_c2k>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_bool is_voice_prefer_c2k;
} vdm_atp_cmd_voice_call_prefer_c2k_ind_struct;
/******************************************************************************
* +ECPI:<call_id>,<msg_type=130>,<is_ibt>,<is_tch>,<dir>,
* <call_mode>,[<number>,<type>],"<pau">,[<disc_cause>]
*****************************************************************************/
typedef struct {
LOCAL_PARA_HDR
kal_uint8 call_id;
ims_ecpi_info_struct ecpi_info;
} vdm_atp_snd_ecpi_mo_call_id_alloc_req_struct;
/******************************************************************************
* +ECPI:<call_id>,<msg_type=0>,<is_ibt>,<is_tch>,<dir>,
* <call_mode>,[<number>,<type>],"<pau>",[<disc_cause>]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
ims_ecpi_info_struct ecpi_info;
} vdm_atp_snd_ecpi_mt_call_setup_req_struct;
/******************************************************************************
* +ECPI:<call_id>,<msg_type=133>,<is_ibt>,<is_tch>,<dir>,
* <call_mode>,[<number>,<type>],"<pau>",[<disc_cause>]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
ims_ecpi_info_struct ecpi_info;
kal_bool is_far_end;
} vdm_atp_snd_ecpi_call_release_req_struct;
/******************************************************************************
* +ECPI:<call_id>,<msg_type=137>,<is_ibt>,<is_tch>,<dir>,
* <call_mode>,[<number>,<type>],"<pau>",[<disc_cause>]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
ims_ecpi_info_struct ecpi_info;
} vdm_atp_snd_ecpi_rtt_redial_req_struct;
/******************************************************************************
* +ECPI:<call_id>,<msg_type!=0,130,133>,<is_ibt>,<is_tch>,<dir>,
* <call_mode>,[<number>,<type>],"<pau>",[<disc_cause>]
*****************************************************************************/
typedef vdm_atp_common_cs_cc_epci_ind_struct vdm_atp_cs_cc_ecpi_translate_ind_struct;
typedef vdm_atp_cs_cc_ecpi_translate_ind_struct vdm_atp_cs_cc_ecpi_translate_rsp_struct;
typedef vdm_atp_cs_cc_ecpi_translate_ind_struct vdm_atp_c2k_cc_ecpi_translate_rsp_struct;
/******************************************************************************
* AT+CHLD=[<n>]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
ims_call_related_ss_type_enum opcode;
ims_cc_mo_disconnect_cause_enum cause;
} vdm_atp_cmd_call_related_ss_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_call_related_ss_rsp_struct;
typedef vdm_atp_cmd_call_related_ss_ind_struct vdm_atp_cs_cc_call_related_ss_req_struct;
/******************************************************************************
* ATH
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_cmd_hangup_all_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_hangup_all_rsp_struct;
/******************************************************************************
* AT+ECHUP=<call_id>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
} vdm_atp_cmd_force_hangup_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_force_hangup_rsp_struct;
/******************************************************************************
* Combine ims_cc_eaic_info_struct with l4b_cc_eaic_info_struct
*****************************************************************************/
typedef struct
{
kal_uint8 number[MAX_CC_ECPI_NUM_LEN];
ims_call_type_enum call_type;
ims_call_mode_enum call_mode;
kal_uint8 redirect_num[MAX_CC_ECPI_NUM_LEN]; // CS CC
kal_uint8 digit_to_line_number[IMC_MAX_URI_LENGTH]; // IMS CC
} vdm_atp_cc_eaic_info_struct;
/******************************************************************************
* +EAIC: <call_id>,<number>,<type>,<call_mode>,<seq_no>[,<redirect_num>[,<digit_to_line_num>]]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
vdm_atp_cc_eaic_info_struct eaic_info;
kal_uint8 seq_no;
vdm_enh_volte_si_flow_enum evoltesi_flow;
} vdm_atp_snd_mt_call_approve_req_struct;
/******************************************************************************
* AT+EAIC=<mode>,<call_id>,<seq_no>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
kal_uint8 seq_no;
vdm_atp_mt_call_approval_mode_enum eaic_mode;
ims_cc_eaic_result_enum eaic_result;
atp_cmd_mode_enum cmd_mode;
kal_uint16 reject_cause;
} vdm_atp_cmd_mt_call_approve_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
atp_cmd_mode_enum cmd_mode;
ims_result_code_enum result;
ims_err_id_enum err_id;
vdm_atp_mt_call_approval_mode_enum eaic_mode;
} vdm_atp_cmd_mt_call_approve_rsp_struct;
/******************************************************************************
* ATA
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_cmd_mt_call_accept_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_mt_call_accept_rsp_struct;
/******************************************************************************
* VTS=<dtmf>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 digit;
} vdm_atp_cmd_dtmf_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_dtmf_rsp_struct;
/******************************************************************************
* AT+EVTS=<action>,<digit>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
ims_dtmf_action_enum action;
kal_uint8 digit;
} vdm_atp_cmd_ext_dtmf_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_ext_dtmf_rsp_struct;
/******************************************************************************
* AT+CEER
* +CEER:<cause>,<report>
* NOTE: ATP maps <ceer_cause> (int) to <report> (char string)
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_cmd_ext_error_report_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
ims_ext_error_report_enum ceer_cause;
ims_result_code_enum result;
ims_err_id_enum err_id;
kal_uint16 ecc_category;
} vdm_atp_cmd_ext_error_report_rsp_struct;
/******************************************************************************
* AT+CSTA:<type>
* NOTE: ATP multicasts this command to VDM (without rsp) and ATCI
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 type;
} vdm_atp_cmd_select_type_of_addr_ind_struct;
/******************************************************************************
* AT+CLCC
* +CLCC:<idx>,<dir>,<stat>,<mode>,<mpty>,[<number>,<type>[,<alpha>[,<priority>[,<CLI_validity>]]]]...
*****************************************************************************/
typedef vdm_imc_ims_cc_list_current_calls_req_struct
vdm_atp_cmd_list_current_calls_ind_struct;
//avoid modifying ims_interface_md.h, declare new structure for CS CLCC
typedef struct {
kal_uint8 call_id;
ims_call_dir_enum dir;
ims_call_state_enum call_state;
ims_call_mode_enum call_mode;
kal_bool mpty; // FALSE: is NOT conference call, TRUE: is conference call
ims_call_type_enum call_type;
kal_uint8 number[MAX_CC_ATD_NUM_LEN];
kal_uint8 cli_validity;
} vdm_atp_call_list_struct;
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 total_call;
vdm_atp_call_list_struct call_list[IMS_MAX_CALL_NUM];
} vdm_atp_cmd_list_current_calls_rsp_struct;
/******************************************************************************
* AT+CLCCS
* +CLCCS: <ccid1>,<dir>,<neg_status_present>,<neg_status>,<SDP_md>,<cs_mode>,<ccstatus>,<mpty>,[,<numbertype>,<ton>,<number>[,<priority_present>,<priority>[,<CLI_validity_present>,<CLI_validity>]]]
*****************************************************************************/
typedef vdm_atp_cmd_list_current_calls_ind_struct
vdm_atp_cmd_list_current_calls_ext_ind_struct;
typedef struct {
kal_uint8 call_id;
l4_call_dir_enum dir;
l4_clccs_call_mode_enum clccs_cs_mode;
l4_call_ccstatus_enum ccstatus;
kal_bool mpty; // FALSE: is NOT conference call, TRUE: is conference call
l4_call_number_type_enum number_type;
l4_call_type_enum call_type;
kal_uint8 number[MAX_SIP_URI_LEN];
kal_bool cli_present;
kal_uint8 cli_validity;
} vdm_atp_call_list_ext_struct;
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 total_call;
vdm_atp_call_list_ext_struct call_list[IMS_MAX_CALL_NUM];
} vdm_atp_cmd_list_current_calls_ext_rsp_struct;
/******************************************************************************
* +EADS: <progress>,<domain>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
ads_indication_progress_enum progress;
ads_indication_domain_enum domain;
} vdm_atp_snd_ads_status_req_struct;
/******************************************************************************
* +EIMSINFO: <rat>,<cell_id>,<cell_service>, <plmn_id>,<plmn_type>,
* <lac>,<tac>,<support_emc>,<lte_underly_cs_plmn_id>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
rat_enum rat;
cell_service_enum cell_service;
kal_bool is_limited_service_emc_support;
kal_uint32 cell_id;
plmn_id_struct plmn_id;
domain_id_enum domain_id;
plmn_id_struct lte_cs_plmn_id;//LTE underlying CS PLMN ID, only available for LTE combined attach UE
#if defined(__NG_ECALL_SUPPORT__)
kal_bool is_ecall_support;
#endif
} vdm_atp_cell_info_update_ind_struct;
/******************************************************************************
* +VMCCMNC: <mcc>,<mnc> (source PSW)
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
plmn_id_struct plmn_id;
} vdm_atp_c2k_mccmnc_ind_struct;
/******************************************************************************
* IMS Registration relayed by ATP (source: IMC)
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
ims_reg_state_enum reg_state;
ims_reg_type_enum reg_type;
ims_access_rat_enum rat;
ims_reg_service_enum reg_service;
ims_reg_event_enum reg_event;
imcb_imc_sip_cause_enum sip_cause;
ims_reg_sub_state_enum reg_sub_state;
kal_bool has_sent_register;
} vdm_atp_ims_reg_status_ind_struct;
/******************************************************************************
* AT+EVVS=<voice_status>,<is_emergency>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 voice_status;
kal_bool is_emergency;
} vdm_atp_cmd_call_status_ind_struct;
/******************************************************************************
* TODO
*****************************************************************************/
typedef vdm_imc_ims_cc_list_current_calls_req_struct
vdm_atp_cs_cc_list_current_calls_req_struct;
typedef struct
{
LOCAL_PARA_HDR
// TODO
} vdm_atp_snd_ads_attempt_notification_req_struct;
typedef struct
{
LOCAL_PARA_HDR
// TODO
} vdm_atp_snd_ads_end_notification_req_struct;
/******************************************************************************
* +CRING: <type>
* NOTE: <type> is string type but without ""
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_snd_mt_call_ring_req_struct;
#if 0
/* under construction !*/
/* under construction !*/
/* under construction !*/
/* under construction !*/
#endif
/******************************************************************************
* AT+EGMC: <OP>,<Configure_Name>,<Set_Value>
* NOTE:in game mode to release ERRC
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_cmd_general_modem_configure_set_struct;
/******************************************************************************
* AT+EVOLTESI: <mode>
* NOTE:Enhanced VOLTE Short Interruption is ON/OFF
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
vdm_trk_enh_volte_si_enum is_enh_volte_si;
} vdm_atp_cmd_enh_volte_si_ind_struct;
/******************************************************************************
* +ECRFCPY: <call_id>,<call_status>
* NOTE:Enhance VOLTE call status update to normal
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint32 call_id;
ims_enh_volte_si_call_status_enum call_status;
} vdm_atp_snd_enh_volte_si_call_status_ind_struct;
/******************************************************************************
* +ECONFSRVCC: <call_no>,<call1_id>[,<call2_id>[,<call3_id>[,...]]]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint32 num_of_conf_parts;
kal_uint32 call_id_table[IMS_MAX_CALL_NUM];
} vdm_atp_snd_srvcc_conf_call_id_req_struct;
/******************************************************************************
* +EVADSREP: <domain>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
vdm_ads_result_enum ads_result;
} vdm_atp_snd_ads_result_report_req_struct;
/******************************************************************************
* +ERDECCIND: <call_id>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
} vdm_atp_snd_ads_switch_to_emergency_req_struct;
/******************************************************************************
* IMS Handover (WIFI/LTE) status relayed by ATP (source: IMC)
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
ims_access_rat_enum source_rat;
ims_access_rat_enum target_rat;
ims_reg_type_enum reg_type;
} vdm_atp_ims_handover_start_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
ims_access_rat_enum source_rat;
ims_access_rat_enum target_rat;
kal_bool result;
ims_reg_type_enum reg_type;
} vdm_atp_ims_handover_end_ind_struct;
/******************************************************************************
* +EICE: <ims_call_exist>,<is_emergency>,<ims_access_rat>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint32 is_ims_call_exist;
kal_bool is_emergency;
ims_access_rat_enum ims_access_rat;
#ifdef __TC01_IMS_SUPPORT__
kal_uint32 call_id;
ap_call_state_enum call_state;
ap_call_reason_enum call_reason;
ap_call_type_enum call_type;
#endif
} vdm_atp_cmd_ims_call_exist_ind_struct;
/******************************************************************************
* AT+ECNWS=<available_rat>,<prefer_rat>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
rat_enum available_rat;
rat_enum prefer_rat;
} vdm_atp_cmd_call_nw_scan_ind_struct;
/******************************************************************************
* AT+EDCONF
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 conf_call_participants;
kal_uint8 conf_call_number_list[IMS_MAX_CALL_NUM_IN_CONF][MAX_CC_ATD_NUM_LEN];
kal_bool is_video_call;
} vdm_atp_cmd_dial_conf_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_dial_conf_rsp_struct;
/******************************************************************************
* +ECONFCHECK:<num_of_conf_call_members>,<is_allowed>[,<is_allowed>...
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 conf_call_participants;
kal_bool is_allowed[IMS_MAX_CALL_NUM_IN_CONF];
} vdm_atp_snd_conf_check_result_req_struct;
/******************************************************************************
* +QUERYTRN: <call_id>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
kal_uint8 dial_string[MAX_CC_ECPI_NUM_LEN];
kal_uint8 from_line[IMC_MAX_URI_LENGTH];
} vdm_atp_snd_digits_trn_query_req_struct;
/******************************************************************************
* AT+DIGITSTRN=<call_id>,<TRN>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
kal_uint8 trn[MAX_CC_ATD_NUM_LEN];
} vdm_atp_cmd_ads_digits_trn_ind_struct;
/******************************************************************************
* EVTA
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 call_id;
ims_cc_evta_mode_enum mode;
} vdm_atp_cmd_mt_vt_special_accept_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_mt_vt_special_accept_rsp_struct;
/******************************************************************************
* AT+EIMSCCP=<op> / AT+ECCP=<op>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
vdm_video_capability_enum video_capability;
kal_bool on_off;
} vdm_atp_cmd_video_capability_ind_struct;
/******************************************************************************
* AT+EIMSCFG = <volte_cfg>, <vilte_cfg>, <vowifi_cfg>, <viwifi_cfg>, <ims_sms_cfg>, <eims_cfg>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
ims_cap_rat_enum vo3gpp_enable; // currently not used by VDM
ims_cap_rat_enum vi3gpp_enable; // previous AT+EIMSCCP
kal_bool is_vowifi_enable; // previous AT+EIMSWFC
kal_bool is_viwifi_enable; // previous AT+EIMSCCP, AP did not have this configuration
} vdm_atp_cmd_ims_config_ind_struct;
/******************************************************************************
* +EC2KREG: <domain>,<state>,<service>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
domain_id_enum domain;
kal_bool state;
irat_ps_type_enum service;
} vdm_atp_c2k_service_state_ind_struct;
/******************************************************************************
* +EC2KCI: <is_cs_conn_ongoing>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_bool is_cs_conn_ongoing;
} vdm_atp_c2k_1x_conn_status_ind_struct;
/******************************************************************************
* +EXXX: <reported_rat>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 reported_rat;
} vdm_atp_reported_rat_ind_struct;
/******************************************************************************
* AT+EHVOLTE=<mode>,<submode>
* This command is used to set hvolte mode
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
hvolte_mode_enum mode;
kal_uint8 submode;
} vdm_atp_gmss_set_hvolte_mode_req_struct;
typedef vdm_atp_common_at_cnf_struct vdm_atp_gmss_set_hvolte_mode_cnf_struct;
/******************************************************************************
* AT+EMCS=<mode>
* This command is used to set emergency call session start and end
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_emc_session_start_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_emc_session_stop_ind_struct;
/******************************************************************************
* AT+EMCB=<mode>
* This command is used to set emergency callback mode
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_emcb_mode_start_req_struct;
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_emcb_mode_stop_req_struct;
/******************************************************************************
* AT+VMEMEXIT
* This command is used to exit emergency callback mode
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_cmd_exit_emcb_ind_struct;
/******************************************************************************
* +ESVC:<emergency_service_category>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint16 emergency_service_category;
atp_cmd_mode_enum cmd_mode;
kal_uint16 sub_service_field_length;
kal_uint8 sub_service_field[IMC_SUB_SERVICE_LENGTH];
} vdm_atp_cmd_emerg_serv_cat_ind_struct;
typedef struct
{
LOCAL_PARA_HDR
kal_uint16 emergency_service_category;
ims_result_code_enum result;
ims_err_id_enum err_id;
atp_cmd_mode_enum cmd_mode;
} vdm_atp_cmd_emerg_serv_cat_rsp_struct;
/******************************************************************************
* AT+EHVOLTE=0,1
* indication for silent redial event from AP to MD
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
} vdm_atp_hvolte_silent_redial_ind_struct;
/******************************************************************************
* AT+ECBM
* This command is used to enter/exit emergency callback mode
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
rat_enum ecbm_rat_mode;
} vdm_atp_ecbm_mode_start_req_struct;
typedef struct
{
LOCAL_PARA_HDR
rat_enum ecbm_rat_mode;
} vdm_atp_ecbm_mode_stop_req_struct;
/******************************************************************************
* AT+ECFGSET=<cfg_name>,<cfg_value>
* Set VDM setting through this AT command
*****************************************************************************/
typedef struct {
LOCAL_PARA_HDR
kal_uint8 name[64];
kal_uint8 value[128];
} vdm_atp_ecfg_set_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_ecfg_set_rsp_struct;
/******************************************************************************
* AT+EIMSRTT=<op>
* Set rtt_capability through this AT command
*****************************************************************************/
typedef struct {
LOCAL_PARA_HDR
kal_uint8 operation;
} vdm_atp_cmd_rtt_capability_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_rtt_capability_rsp_struct;
/******************************************************************************
* AT+ESELFACT="<key>","<value>"
* Set Vzw self-activation feature related value through this AT command
*****************************************************************************/
typedef struct {
LOCAL_PARA_HDR
kal_uint8 key[16];
kal_uint8 value[16];
} vdm_atp_cmd_self_activation_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_self_activation_rsp_struct;
/******************************************************************************
* AT+VMEMEXIT result
*****************************************************************************/
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_vmemexit_rsp_struct;
/******************************************************************************
* AT+EMCS=<mode>[,<airplane_mode>,<ims_reg_state>]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 mode;
kal_uint8 airplane_mode;
kal_uint8 ims_reg_state;
atp_channel_enum ch_id;
kal_bool is_stop_from_ap;
} atp_vdm_cmd_emcs_req_struct;
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 mode;
kal_uint8 airplane_mode;
kal_uint8 ims_reg_state;
atp_channel_enum ch_id;
kal_bool response_at_ok;
} atp_vdm_cmd_emcs_cnf_struct;
/******************************************************************************
* AT+EMCSS=<mode>,<available_rat>,<prefer_rat>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 mode;
rat_enum available_rat;
rat_enum prefer_rat;
}atp_vdm_cmd_emcss_ind_struct;
/******************************************************************************
* AT+ECBM=<mode>,<rat_mode>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 mode;
rat_enum rat_mode;
} atp_vdm_cmd_ecbm_req_struct;
/******************************************************************************
* +EMCSS: <available_rat>,<cause>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
rat_enum available_rat;
vdm_emcss_cause_enum cause;
} atp_vdm_snd_emcss_urc_req_struct;
/******************************************************************************
* +ECNWS: <proc_status>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
proc_status_enum status;
} atp_vdm_snd_ecnws_urc_req_struct;
/******************************************************************************
* +CIEV: 102,<ecbm_status>
* ecbm_status:
* 0 - ECBM end
* 1 - ECBM start
* 2 - disable ECBM (notify AP need not to enter ECBM, leave emc mode directly)
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint8 ecbm_status;
} atp_vdm_snd_ecbm_urc_req_struct;
/******************************************************************************
* AT+ERDECCAPV=<is_approve>,<call_id>
* Set leaving flight mode result through this AT command
*****************************************************************************/
typedef struct {
LOCAL_PARA_HDR
kal_uint8 is_approve;
kal_uint8 call_id;
} vdm_atp_cmd_switch_to_emergency_ind_struct;
/******************************************************************************
* AT+ESRVCCTFR: <call_num>, <call1_id>,<call1_mode>,<call1_direction>,<call1_state>,<call1_ecc_category>,<call1_number type>,<call1_number>,<call1_alpha>,<call1_CLI validity>
*****************************************************************************/
typedef struct
{
kal_uint8 call_id; /* call_id_ims = call_id_ap */
ims_srvcc_call_mode_enum call_mode;
ims_srvcc_call_direction_enum call_direction;
ims_srvcc_call_state_enum call_state;
ims_srvcc_call_ecc_category_enum call_ecc_category;
ims_srvcc_call_number_format_enum call_number_format;
kal_uint8 call_number[IMC_MAX_URI_LENGTH];
//these two parameter is defined by L4 but seems not used by IMS CC
kal_uint8 call_alpha[MAX_PS_NAME_SIZE + 1]; // MAX_PS_NAME_SIZE: 42
kal_uint8 cli;
//just for TK compatible, not sure how to use this in TC01 project
kal_uint8 num_of_conf_parts;
} ims_srvcc_call_ctxt_to_cs_struct;
typedef struct
{
LOCAL_PARA_HDR
kal_uint32 num_call;
ims_srvcc_call_ctxt_to_cs_struct srvcc_call_ctxt_to_cs_domain[IMS_MAX_CALL_NUM];
} vdm_atp_cmd_srvcc_context_transfer_ind_struct; //MSG_ID_VDM_ATP_CMD_SRVCC_CONTEXT_TRANSFER_IND
/******************************************************************************
* +ESRVCCTFR: <call_no>[,<call1_id>[,<call2_id>[,...]]]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_uint32 num_of_call_instances;
kal_uint32 call_id_table[IMS_MAX_CALL_NUM];
} vdm_atp_cmd_srvcc_context_transfer_rsp_struct; // MSG_ID_VDM_ATP_CMD_SRVCC_CONTEXT_TRANSFER_RSP
/******************************************************************************
* +ERESELR:<result>
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_bool result; //0, fail; 1, success
} vdm_atp_ssac_resel_result_ind_struct;
/******************************************************************************
* AT+EMGC
*****************************************************************************/
typedef enum {
VDM_EMGC_OP_QUERY = 0,
VDM_EMGC_OP_SET
} vdm_atp_emgc_op_enum;
typedef struct {
LOCAL_PARA_HDR
vdm_atp_emgc_op_enum op;
kal_uint8 name[VDM_AT_CMD_TO_MD_NAME_LEN];
kal_uint8 value[VDM_AT_CMD_TO_MD_VALUE_LEN];
} vdm_atp_at_cmd_to_md_ind_struct;
/******************************************************************************
* AT+EVODATA = <en>[,<data_mode>[,<allow_rat>]]
*****************************************************************************/
typedef struct
{
LOCAL_PARA_HDR
kal_bool is_vodata_enable;
} vdm_atp_cmd_evodata_config_ind_struct;
#if defined(__ECALL_SUPPORT__) || defined(__NG_ECALL_SUPPORT__)
/******************************************************************************
* AT+CECALL=<type_of_eCall>[,<format>,<msd_data_length>,<msd_data>]
* Dial eCall through this AT command
*****************************************************************************/
typedef struct {
LOCAL_PARA_HDR
ecall_type_enum ecall_type;
ecall_format_enum ecall_format;
kal_uint8 msd_data_len;
kal_uint8 msd_data[MAX_MSD_LENGTH];
} vdm_atp_cmd_dial_ecall_ind_struct;
typedef vdm_atp_common_at_rsp_struct vdm_atp_cmd_dial_ecall_rsp_struct;
#endif
#endif // _VDM_ATP_STRUCT_H_