FreeCalypso > hg > fc-tourmaline
view src/g23m-aci/aci/psa_satf.c @ 301:4bb5772a05a3
AT%SPVER: new command for setting custom speech version lists
The speech version list in the Bearer Capability IE tells the network
which speech codecs are supported by the MS, and in which order of
preference. The standard behaviour is to list all codecs that are
supported by the hw+fw platform, and the standard preference order
is newer over older, FR over HR. But sometimes it is desirable
(for network testing) to artificially restrict which codecs the test MS
will declare as supported, and/or to list them in some peculiar
non-standard order of preference. Add a new private AT command,
AT%SPVER, allowing the user to set and clear custom speech version
lists for the Bearer Capability IE composer in CC.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 21 May 2023 21:43:10 +0000 |
parents | fa8dc04885d8 |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : GSM-PS (6147) | Modul : PSA_SATF +----------------------------------------------------------------------------- | Copyright 2002 Texas Instruments Berlin, AG | All rights reserved. | | This file is confidential and a trade secret of Texas | Instruments Berlin, AG | The receipt of or possession of this file does not convey | any rights to reproduce or disclose its contents or to | manufacture, use, or sell anything it may describe, in | whole, or in part, without the specific written consent of | Texas Instruments Berlin, AG. +----------------------------------------------------------------------------- | Purpose : This module defines the functions for the protocol | stack adapter for the SIM application toolkit. +----------------------------------------------------------------------------- */ #ifdef SIM_TOOLKIT #ifndef PSA_SATF_C #define PSA_SATF_C #endif #include "aci_all.h" /*==== INCLUDES ===================================================*/ #include "aci_cmh.h" #include "aci_mem.h" #ifdef GPRS #include "gaci_cmh.h" #endif #ifdef FAX_AND_DATA #include "aci_fd.h" #endif /* of #ifdef FAX_AND_DATA */ #include "aci.h" #include "psa.h" #include "psa_cc.h" #include "psa_sat.h" #include "psa_util.h" #include "cmh.h" #include "cmh_sat.h" #include "psa_mm.h" #include "psa_ss.h" #include "psa_sim.h" #include "cmh_cc.h" #include "ksd.h" /*==== CONSTANTS ==================================================*/ #define ITM_WDT (14) /* item width in chars */ #define HDR_WDT (10) /* header width in chars */ /*==== TYPES ======================================================*/ /*==== EXPORT =====================================================*/ /*==== VARIABLES ==================================================*/ LOCAL UBYTE ssResPrms[MAXIMUM( sizeof(BUF_res_params_sat), MAXIMUM(sizeof(BUF_rej_params_sat), sizeof(BUF_err_params_sat)))]; /*==== FUNCTIONS ==================================================*/ LOCAL void psaSAT_getTonNpi(CHAR *inSeq, BOOL call_active, UBYTE *ton, UBYTE *npi); /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_BuildEnvCC | +-------------------------------------------------------------------+ PURPOSE : Build envelope call control command. */ GLOBAL void psaSAT_BuildEnvCC ( SHORT cId, T_CLPTY_PRM *ss_cldPty, T_sat_ussd *ussd, T_MNCC_bcconf *ccp1, T_MNCC_bcconf *ccp2) { T_CC_CALL_TBL *pCtbNtry = ccShrdPrm.ctb[cId]; UBYTE ton; UBYTE npi; /* *------------------------------------------------------------------- * build envelope call control command *------------------------------------------------------------------- */ { MCAST( env, ENV_CMD ); memset( env, 0, sizeof( T_ENV_CMD )); env->v_cc_cmd = TRUE; /* device identities */ env->cc_cmd.v_dev_ids = TRUE; env->cc_cmd.dev_ids.src_dev = DEV_SRC_ME; env->cc_cmd.dev_ids.dest_dev = DEV_DST_SIM; if( cId NEQ NO_ENTRY ) { /* address */ env->cc_cmd.v_addr = TRUE; if( (pCtbNtry->SATinv & SAT_REDIAL_ECCBE) AND (rdlPrm.rdlState) ) { memcpy(&env->cc_cmd.addr, &satRdlCCEnv.addr, sizeof(T_addr)); } else { /* address */ env->cc_cmd.addr.v_noa = TRUE; env->cc_cmd.addr.noa = pCtbNtry->cldPty.ton; env->cc_cmd.addr.v_npi = TRUE; env->cc_cmd.addr.npi = pCtbNtry->cldPty.npi; env->cc_cmd.addr.c_bcdDigit = pCtbNtry->cldPty.c_called_num; memcpy( env->cc_cmd.addr.bcdDigit, pCtbNtry->cldPty.called_num, pCtbNtry->cldPty.c_called_num ); } #ifdef SIM_TOOLKIT if ( !rdlPrm.rdlState ) { memcpy(&satRdlCCEnv.addr, &env->cc_cmd.addr, sizeof(T_addr)); } #endif /* capability configuration parameters 1*/ if( ccp1 ) { env->cc_cmd.v_cap_cnf_parms = TRUE; env->cc_cmd.cap_cnf_parms.l_cap_cnf_parms = ccp1->bc_len<<3; memcpy( env->cc_cmd.cap_cnf_parms.b_cap_cnf_parms, ccp1->bc, ccp1->bc_len ); } /* capability configuration parameters 2*/ if( ccp2 ) { env->cc_cmd.v_cap_cnf_parms_2 = TRUE; env->cc_cmd.cap_cnf_parms_2.l_cap_cnf_parms_2 = ccp2->bc_len<<3; memcpy( env->cc_cmd.cap_cnf_parms_2.b_cap_cnf_parms_2, ccp2->bc, ccp2->bc_len ); } /* If ccp is present in the setUpCall */ if ((satShrdPrm.capParm.cntxt EQ CTX_SAT_SETUP) AND satShrdPrm.stk_ccp.l_cap_cnf_parms ) { env->cc_cmd.v_cap_cnf_parms = TRUE; /* Storing the ccp if ECCBE is enabled */ if( (ccShrdPrm.ctb[cId]->SATinv & SAT_REDIAL_ECCBE) AND (rdlPrm.rdlState) ) { memcpy(&env->cc_cmd.cap_cnf_parms, &satRdlCCEnv.ccp, sizeof(BUF_cap_cnf_parms)); } else { env->cc_cmd.cap_cnf_parms.l_cap_cnf_parms = satShrdPrm.stk_ccp.l_cap_cnf_parms; memcpy( env->cc_cmd.cap_cnf_parms.b_cap_cnf_parms, &satShrdPrm.stk_ccp.b_cap_cnf_parms, satShrdPrm.stk_ccp.l_cap_cnf_parms ); } #ifdef SIM_TOOLKIT if ( !rdlPrm.rdlState ) { memcpy( &satRdlCCEnv.ccp, &env->cc_cmd.cap_cnf_parms, sizeof(BUF_cap_cnf_parms)); } #endif } /* subaddress */ if( pCtbNtry->cldPtySub.c_subaddr ) { env->cc_cmd.v_subaddr = TRUE; if( (pCtbNtry->SATinv & SAT_REDIAL_ECCBE) AND (rdlPrm.rdlState) ) { memcpy( &env->cc_cmd.subaddr, &satRdlCCEnv.sub_addr, sizeof(T_subaddr) ); } else { env->cc_cmd.subaddr.v_tos = TRUE; env->cc_cmd.subaddr.tos = pCtbNtry->cldPtySub.tos; env->cc_cmd.subaddr.v_oei = TRUE; env->cc_cmd.subaddr.oei = pCtbNtry->cldPtySub.odd_even; env->cc_cmd.subaddr.c_subadr_str = pCtbNtry->cldPtySub.c_subaddr; memcpy( env->cc_cmd.subaddr.subadr_str, pCtbNtry->cldPtySub.subaddr, pCtbNtry->cldPtySub.c_subaddr ); } #ifdef SIM_TOOLKIT if ( !rdlPrm.rdlState ) { memcpy( &satRdlCCEnv.sub_addr, &env->cc_cmd.subaddr, sizeof(T_subaddr)); } #endif } } else if( ss_cldPty NEQ NULL ) { /* SS string */ env->cc_cmd.v_ss_string = TRUE; psaSAT_getTonNpi(ss_cldPty->num, FALSE, &ton, &npi); env->cc_cmd.ss_string.v_noa = TRUE; env->cc_cmd.ss_string.noa = ton; env->cc_cmd.ss_string.v_npi = TRUE; env->cc_cmd.ss_string.npi = npi; env->cc_cmd.ss_string.c_ss_ctrl_string = (UBYTE)utl_dialStr2BCD (ss_cldPty->num, /*ssStr,*/ env->cc_cmd.ss_string.ss_ctrl_string, MAX_SS_STRING_LEN); } else if( ussd NEQ NULL ) { /* USSD string */ env->cc_cmd.v_ussd_string = TRUE; env->cc_cmd.ussd_string.dcs = ussd->dcs; env->cc_cmd.ussd_string.c_ussd_str = MINIMUM (ussd->c_ussd_str, MAX_SAT_USSD_LEN); memcpy( env->cc_cmd.ussd_string.ussd_str, ussd->ussd_str, env->cc_cmd.ussd_string.c_ussd_str); } /* location information */ /* code MCC */ env->cc_cmd.cc_smc_loc_info.mnc_mcc |= ((mmShrdPrm.usedPLMN.mcc[1]<<4) + mmShrdPrm.usedPLMN.mcc[0]) <<16; env->cc_cmd.cc_smc_loc_info.mnc_mcc |= ((mmShrdPrm.usedPLMN.mnc[2]<<4) + mmShrdPrm.usedPLMN.mcc[2]) << 8; /* code MNC */ env->cc_cmd.cc_smc_loc_info.mnc_mcc |= (mmShrdPrm.usedPLMN.mnc[1]<<4)+mmShrdPrm.usedPLMN.mnc[0]; /* code LAC */ env->cc_cmd.cc_smc_loc_info.lac = mmShrdPrm.lac; /* code CID */ env->cc_cmd.cc_smc_loc_info.cid = mmShrdPrm.cid; env->cc_cmd.v_cc_smc_loc_info = TRUE; } } /* +--------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : psa_sat | | STATE : code ROUTINE : psaSAT_getTonNpi | +--------------------------------------------------------------------+ PURPOSE : Get TON and NPI. The SS string in inSeq will be decoded to check if it contains a phone number. If SS String contains a number, its TON and NPI will be returned. Otherwise TON and NPI will be set to FF as required in GSM 11.14/GSM 11.11. */ LOCAL void psaSAT_getTonNpi(CHAR *inSeq, BOOL call_active, UBYTE *ton, UBYTE *npi) { T_KSD_SEQGRP grp; CHAR *rest; T_KSD_SEQPARAM para; CHAR seq[MAX_DIAL_LEN]; *ton = MNCC_TON_NOT_PRES; *npi = MNCC_NPI_NOT_PRES; strcpy(seq, inSeq); /* decode sequence */ ksd_decode(seq, call_active, &grp, &rest, ¶); /* analyse TON and NPI */ switch( grp ) { case SEQGRP_CF: if ( (para.cf.num NEQ NULL) AND (para.cf.num[0] NEQ 0) ) { *ton = para.cf.ton; *npi = para.cf.npi; } break; case SEQGRP_DIAL: if ( ( para.dial.number NEQ NULL ) AND ( para.dial.number[0] EQ 0 ) ) { if ( para.dial.number[0] EQ '+' ) { *ton = TON_International; } else { *ton = TON_Unknown; } *npi = NPI_IsdnTelephony; } break; #ifdef SMI case SEQGRP_SET_ABBR_DIAL: if ( (para.abbrDial.number NEQ NULL) AND ( para.abbrDial.number[0] EQ 0 ) ) { if ( para.abbrDial.number[0] EQ '+' ) { *ton = TON_International; } else { *ton = TON_Unknown; } *npi = NPI_IsdnTelephony; } break; #endif /* SMI */ default: /* Sequence group does not contain number. TON and NPI still set to FF */ break; } } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_BuildEnvCB | +-------------------------------------------------------------------+ PURPOSE : Build envelope cell broadcast data download command. */ GLOBAL void psaSAT_BuildEnvCB ( UBYTE *cbMsg, SHORT cbLen ) { /* *------------------------------------------------------------------- * build envelope cell broadcast data download command *------------------------------------------------------------------- */ { MCAST( env, ENV_CMD ); memset( env, 0, sizeof( T_ENV_CMD )); env->v_cbd_cmd = TRUE; /* device identities */ env->cbd_cmd.v_dev_ids = TRUE; env->cbd_cmd.dev_ids.src_dev = DEV_SRC_NTW; env->cbd_cmd.dev_ids.dest_dev = DEV_DST_SIM; /* CB message */ env->cbd_cmd.v_cb_page = TRUE; env->cbd_cmd.cb_page.l_cb_page = cbLen<<3; env->cbd_cmd.cb_page.o_cb_page = 0; memcpy( env->cbd_cmd.cb_page.b_cb_page, cbMsg, cbLen ); } } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_BuildEnvMoSmCntr | +-------------------------------------------------------------------+ PURPOSE : Build envelope cell broadcast data download command. */ GLOBAL void psaSAT_BuildEnvMoSmCntr ( T_rp_addr sc_addr, T_tp_da dest_addr ) { /* *------------------------------------------------------------------- * build envelope *------------------------------------------------------------------- */ { MCAST( env, ENV_CMD ); memset( env, 0, sizeof( T_ENV_CMD )); env->v_smc_cmd = TRUE; /* device identities */ env->smc_cmd.v_dev_ids = TRUE; env->smc_cmd.dev_ids.src_dev = DEV_DST_ME; env->smc_cmd.dev_ids.dest_dev = DEV_DST_SIM; /* short message address */ env->smc_cmd.v_sm_addr = TRUE; env->smc_cmd.sm_addr.v_noa = TRUE; env->smc_cmd.sm_addr.noa = sc_addr.ton; env->smc_cmd.sm_addr.v_npi = TRUE; env->smc_cmd.sm_addr.npi = sc_addr.npi; env->smc_cmd.sm_addr.c_bcdDigit = sc_addr.c_num; memcpy(&(env->smc_cmd.sm_addr.bcdDigit[0]), &(sc_addr.num[0]), sc_addr.c_num /*MAX_SMS_DIGIT_LEN*/); /* address 2 */ env->smc_cmd.v_sm_addr_2 = TRUE; env->smc_cmd.sm_addr_2.v_noa = TRUE; env->smc_cmd.sm_addr_2.noa = dest_addr.ton; env->smc_cmd.sm_addr_2.v_npi = TRUE; env->smc_cmd.sm_addr_2.npi = dest_addr.npi; env->smc_cmd.sm_addr_2.c_bcdDigit = dest_addr.c_num; memcpy(&(env->smc_cmd.sm_addr_2.bcdDigit[0]), &(dest_addr.num[0]), dest_addr.c_num /*MAX_SMS_DIGIT_LEN*/); /* location information */ /* code MCC */ env->smc_cmd.cc_smc_loc_info.mnc_mcc |= ((mmShrdPrm.usedPLMN.mcc[1]<<4) + mmShrdPrm.usedPLMN.mcc[0]) <<16; env->smc_cmd.cc_smc_loc_info.mnc_mcc |= ((mmShrdPrm.usedPLMN.mnc[2]<<4) + mmShrdPrm.usedPLMN.mcc[2]) << 8; /* code MNC */ env->smc_cmd.cc_smc_loc_info.mnc_mcc |= (mmShrdPrm.usedPLMN.mnc[1]<<4)+mmShrdPrm.usedPLMN.mnc[0]; /* code LAC */ env->smc_cmd.cc_smc_loc_info.lac = mmShrdPrm.lac; /* code CID */ env->smc_cmd.cc_smc_loc_info.cid = mmShrdPrm.cid; env->smc_cmd.v_cc_smc_loc_info = TRUE; } } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_BuildEnvEventDwn | +-------------------------------------------------------------------+ PURPOSE : Build envelope event download command. */ GLOBAL BOOL psaSAT_BuildEnvEventDwn ( UBYTE event, SHORT callId, T_CC_INITIATER actionSrc ) { T_CC_CALL_TBL * pCtbNtry; /* holds pointer to call table entry */ BOOL MT_flag; UBYTE trans_id = 0xFF; UBYTE ti_flag = 0xFF; /* lint: initialization warning */ TRACE_FUNCTION("psaSAT_BuildEnvEventDwn()"); pCtbNtry = ccShrdPrm.ctb[callId]; /* *------------------------------------------------------------------- * build envelope *------------------------------------------------------------------- */ { MCAST( env, ENV_CMD ); memset( env, 0, sizeof( T_ENV_CMD )); env->v_evd_cmd = TRUE; /* event */ env->evd_cmd.v_ev_list = TRUE; env->evd_cmd.ev_list.c_event = 1; env->evd_cmd.ev_list.event[0] = event; /* device identities */ env->evd_cmd.v_dev_ids = TRUE; env->evd_cmd.dev_ids.dest_dev = DEV_DST_SIM; switch( actionSrc ) { case( NEAR_END ): env->evd_cmd.dev_ids.src_dev = DEV_SRC_ME; break; case( FAR_END ): env->evd_cmd.dev_ids.src_dev = DEV_SRC_NTW; break; default: env->evd_cmd.v_dev_ids = FALSE; } if ( event EQ EVENT_MT_CALL OR event EQ EVENT_CALL_CONN OR event EQ EVENT_CALL_DISC ) { /* process ti identifier */ env->evd_cmd.v_ti_list = TRUE; env->evd_cmd.ti_list.c_ti_oct = 1; MT_flag = pCtbNtry -> ti & 0x08; /* TRUE if MS terminated transaction */ trans_id = ( pCtbNtry -> ti) & 0x07; /* see GSM 04.07 ?1.2.3.1.3 */ } switch( event ) { case( EVENT_MT_CALL ): /* ti identifier */ /* MNCC_SETUP_IND means message sent from the side that originated the TI */ env->evd_cmd.ti_list.ti_oct[0].ti = /*lint -e(644) */ trans_id; /* address */ if (pCtbNtry->clgPty.c_num NEQ 0) { env->evd_cmd.v_addr = TRUE; env->evd_cmd.addr.v_noa = TRUE; env->evd_cmd.addr.noa = pCtbNtry->clgPty.ton; env->evd_cmd.addr.v_npi = TRUE; env->evd_cmd.addr.npi = pCtbNtry->clgPty.npi; env->evd_cmd.addr.c_bcdDigit = pCtbNtry->clgPty.c_num; memcpy(&(env->evd_cmd.addr.bcdDigit[0]), &(pCtbNtry->clgPty.num[0]), pCtbNtry->clgPty.c_num); } /* called party subaddress */ if (pCtbNtry->clgPtySub.c_subaddr NEQ 0) { env->evd_cmd.v_subaddr = TRUE; env->evd_cmd.subaddr.v_tos = TRUE; env->evd_cmd.subaddr.tos = pCtbNtry -> clgPtySub.tos; env->evd_cmd.subaddr.v_oei = TRUE; env->evd_cmd.subaddr.oei = pCtbNtry -> clgPtySub.odd_even; env->evd_cmd.subaddr.c_subadr_str = pCtbNtry->clgPtySub.c_subaddr; memcpy(&(env->evd_cmd.subaddr.subadr_str[0]), &(pCtbNtry->clgPtySub.subaddr[0]), pCtbNtry->clgPtySub.c_subaddr); } break; case( EVENT_CALL_CONN ): /* ti identifier */ /* MNCC_SETUP_CNF context with MO Call or: MNCC_SETUP_RES context with MT Call means: message sent to the side that originates the TI */ ti_flag = 0x08; env->evd_cmd.ti_list.ti_oct[0].ti = trans_id | ti_flag; break; case( EVENT_CALL_DISC ): /* ti identifier */ /* means: message sent to the side that originates the TI */ switch (actionSrc) { case( NEAR_END ): /* MNCC_REJ_IND / MNCC_DISC_REQ / MNCC_REL_REQ */ if ( /*lint -e(644) */ MT_flag ) ti_flag = 0x08; else ti_flag = 0x00; break; case( FAR_END ): /* MNCC_DISC_IND / MNCC_REL_IND / MNCC_REL_REQ */ if ( MT_flag ) ti_flag = 0x00; else ti_flag = 0x08; break; } env->evd_cmd.ti_list.ti_oct[0].ti = trans_id | ti_flag; /* Cause */ env->evd_cmd.v_cause = TRUE; if (pCtbNtry -> numRawCauseBytes EQ 0) { if (GET_CAUSE_VALUE(pCtbNtry -> rejCs) NEQ NOT_PRESENT_8BIT) /* radio-link failure */ { env->evd_cmd.cause.c_cs = 0; } else { if (GET_CAUSE_VALUE(pCtbNtry -> nrmCs) NEQ NOT_PRESENT_8BIT) { env->evd_cmd.cause.c_cs = 2; /*Location is user : 0 and coding standard defined for the GSM PLMNS : 3 */ env->evd_cmd.cause.cs[0] =0xE0; env->evd_cmd.cause.cs[1] = GET_CAUSE_VALUE(pCtbNtry -> nrmCs) |0x80 ; } else { env->evd_cmd.v_cause = FALSE; } } } else { env->evd_cmd.cause.c_cs = pCtbNtry -> numRawCauseBytes; memcpy( env->evd_cmd.cause.cs, pCtbNtry -> rawCauseBytes, pCtbNtry -> numRawCauseBytes ); } break; case( EVENT_LOC_STATUS ): env->evd_cmd.v_loc_state = TRUE; switch( satShrdPrm.locInfo.regStatus ) { case( NO_VLD_RS ): env->evd_cmd.v_loc_state = FALSE; break; case( RS_NO_SRV ): env->evd_cmd.loc_state = 0x02; break; case( RS_LMTD_SRV ): env->evd_cmd.loc_state = 0x01; break; case( RS_FULL_SRV ): env->evd_cmd.loc_state = 0x00; /*--------------------------------------------------- only in this case would location info be included ----------------------------------------------------*/ /* location information */ /* code MCC */ env->evd_cmd.cc_smc_loc_info.mnc_mcc |= ((satShrdPrm.locInfo.currPLMN.mcc[1]<<4) + satShrdPrm.locInfo.currPLMN.mcc[0]) <<16; env->evd_cmd.cc_smc_loc_info.mnc_mcc |= ((satShrdPrm.locInfo.currPLMN.mnc[2]<<4) + satShrdPrm.locInfo.currPLMN.mcc[2]) << 8; /* code MNC */ env->evd_cmd.cc_smc_loc_info.mnc_mcc |= (satShrdPrm.locInfo.currPLMN.mnc[1]<<4)+satShrdPrm.locInfo.currPLMN.mnc[0]; /* code LAC */ env->evd_cmd.cc_smc_loc_info.lac = satShrdPrm.locInfo.lac; /* code CID */ env->evd_cmd.cc_smc_loc_info.cid = satShrdPrm.locInfo.cid; env->evd_cmd.v_cc_smc_loc_info = TRUE; break; } break; #ifdef FF_SAT_E case( EVENT_CHAN_STAT ): env->evd_cmd.v_chan_stat = TRUE; env->evd_cmd.chan_stat.chan_id = CHANNEL_ID_1; env->evd_cmd.chan_stat.chan_stat_link = LINK_NO_ESTABL; env->evd_cmd.chan_stat.chan_stat_inf2 = LINK_DROPPED; break; #endif /* FF_SAT_E */ default: env->v_evd_cmd = FALSE; TRACE_EVENT("wrong event id for SAT event download"); break; } /* *------------------------------------------------------------------- * check if a call control request is already in progress *------------------------------------------------------------------- */ if( satShrdPrm.SIMCCParm.busy EQ TRUE ) { /* event has to be queued */ T_SAT_QUEUE *p_queue; if (satShrdPrm.event.c_queued >= MAX_EVENT_QUEUED - 1 ) { TRACE_EVENT("Too many events have been queued: failed to queue this new event"); return FALSE; } p_queue = &satShrdPrm.event.queued[satShrdPrm.event.c_queued - 1]; p_queue->owner = (T_OWN)satShrdPrm.owner; if (p_queue->stk_cmd NEQ NULL) { MFREE (p_queue->stk_cmd); /* Should not happen */ } ACI_MALLOC (p_queue->stk_cmd, sizeof (T_stk_cmd)); if (psaSAT_STKBuildCmd (p_queue->stk_cmd) < 0) { ACI_MFREE (p_queue->stk_cmd); p_queue->stk_cmd = NULL; TRACE_ERROR ("problem encoding SAT cmd"); return FALSE; } satShrdPrm.event.c_queued++; } return TRUE; } } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_SendTrmResp | +-------------------------------------------------------------------+ PURPOSE : Send a terminal response for a previous SAT command. */ GLOBAL void psaSAT_InitTrmResp ( T_ACI_SAT_TERM_RESP *init_resp ) { init_resp->addLen = 0; init_resp->add = NULL; init_resp->add_content = 0; init_resp->resCC = NULL; init_resp->text = NULL; init_resp->at_resp = NULL; init_resp->at_resp_count = 0; #ifdef FF_SAT_E init_resp->chnStat = FALSE; init_resp->bearDesc = FALSE; init_resp->bufSize = FALSE; #endif /* FF_SAT_E */ memset (init_resp->dtt_buf, 0xFF, TIME_STAMP_LENGTH); memset (init_resp->lang, 0xFF, CLAN_CODE_LEN); } LOCAL void sat_build_cc_action_resp(UBYTE rspId, UBYTE addLen, UBYTE *add, UBYTE *resCC, T_TERM_RESP *res) { UBYTE byteLen; /* holds byte length */ UBYTE *p; /* byte pointer */ if( satShrdPrm.stkCnfPrim OR resCC ) { p = (resCC)? resCC : satShrdPrm.stkCnfPrim->stk_cmd.cmd; if( p[1] EQ 0x81 ) { byteLen = p[2]; p = &p[3]; } else { byteLen = p[1]; p = &p[2]; } res->v_cc_req_act = TRUE; res->cc_req_act.l_cc_req_act = byteLen<<3; memcpy( res->cc_req_act.b_cc_req_act, p, byteLen ); /* result 2 */ res->v_res_2 = TRUE; res->res_2.gen = res->res.gen; /* adjust first result according to second result (GSM 11.14 / 9.1) */ if( rspId <= 0x1F ) res->res.gen = RSLT_PERF_MDFY_SIM; else if( rspId >= 0x20 AND rspId <= 0x2F ) res->res.gen = RSLT_CC_SIM_TMP; else if( rspId >= 0x30 AND rspId <= 0x3F ) { res->res.gen = RSLT_CC_SIM_PRM; res->res.v_add = TRUE; res->res.add.l_add = 8; res->res.add.b_add[0] = ADD_CC_REQ_CHNG; } if( addLen ) { if( res->res.gen NEQ RSLT_CC_SIM_PRM ) res->res.v_add = FALSE; res->res_2.v_add = TRUE; res->res_2.add.l_add = addLen<<3; memcpy( res->res_2.add.b_add, add, addLen ); } /* free the primitive */ if( satShrdPrm.stkCnfPrim ) { PFREE( satShrdPrm.stkCnfPrim ); satShrdPrm.stkCnfPrim = NULL; } } } GLOBAL BOOL psaSAT_SendTrmResp ( UBYTE rspId, T_ACI_SAT_TERM_RESP *data_for_term_resp) { TRACE_FUNCTION("psaSAT_SendTrmResp()"); /* *------------------------------------------------------------------- * build terminal response *------------------------------------------------------------------- */ CCD_START; { MCAST( res, TERM_RESP ); memset( res, 0, sizeof( T_TERM_RESP )); /* init of data_for_term_resp */ /* return network error cause GSM 11.14 / 12.12.3 (it's mandatory) */ if( ( data_for_term_resp->add_content NEQ 0 ) OR ( rspId EQ RSLT_NTW_UNAB_PROC ) ) { data_for_term_resp->add = &(data_for_term_resp->add_content); data_for_term_resp->addLen = 1; } /* device identities */ res->v_cmd_details = TRUE; res->cmd_details.cmd_nr = satShrdPrm.cmdDet.cmdNr; res->cmd_details.cmd_typ = satShrdPrm.cmdDet.cmdType; res->cmd_details.cmd_qlf = satShrdPrm.cmdDet.cmdQlf; /* device identities */ res->v_dev_ids = TRUE; res->dev_ids.src_dev = DEV_SRC_ME; res->dev_ids.dest_dev = DEV_DST_SIM; /* result */ res->v_res = TRUE; res->res.gen = (rspId EQ RSLT_PERF_SUCCESS AND cmpFlg)? RSLT_PERF_PART_CMPR:rspId; if( data_for_term_resp->addLen ) { res->res.v_add = TRUE; res->res.add.l_add = data_for_term_resp->addLen<<3; memcpy( res->res.add.b_add, data_for_term_resp->add, data_for_term_resp->addLen ); } /* call control requested action */ sat_build_cc_action_resp( rspId, data_for_term_resp->addLen, data_for_term_resp->add, data_for_term_resp->resCC, res ); /* USSD related terminal response */ if( data_for_term_resp->text NEQ NULL ) { res->v_text = TRUE; res->text.dcs = data_for_term_resp->text->dcs; res->text.c_text_str = data_for_term_resp->text->c_text_str; memcpy( &(res->text.text_str), data_for_term_resp->text->text_str, data_for_term_resp->text->c_text_str); } /* Run AT related terminal response */ if( data_for_term_resp->at_resp NEQ NULL ) { res->v_at_resp = TRUE; memcpy( res->at_resp.text_str, data_for_term_resp->at_resp, data_for_term_resp->at_resp_count ); res->at_resp.c_text_str = (UBYTE)data_for_term_resp->at_resp_count; } /* Provide Local Information (date, time and time zone) related terminal response */ if( data_for_term_resp->dtt_buf[0] NEQ 0xFF) { res->v_dtt = TRUE; memcpy( res->dtt.text_str, data_for_term_resp->dtt_buf, TIME_STAMP_LENGTH ); res->dtt.c_text_str = (UBYTE)TIME_STAMP_LENGTH; } /* Provide Local Information (Language Setting) */ if( data_for_term_resp->lang[0] NEQ 0xFF) { res->v_lang = TRUE; memcpy( res->lang.lang_buf, data_for_term_resp->lang, CLAN_CODE_LEN ); res->lang.c_lang_buf = (UBYTE)CLAN_CODE_LEN; } #ifdef FF_SAT_E /* add channel status to terminal response */ if( data_for_term_resp->chnStat NEQ FALSE ) { /* restricted to only one channel for class e */ res->v_chan_stat = TRUE; res->c_chan_stat = 1; res->chan_stat[0].chan_id = CHANNEL_ID_1; res->chan_stat[0].chan_stat_inf2 = NO_FURTH_INFO; res->chan_stat[0].chan_stat_link = LINK_NO_ESTABL; if( satShrdPrm.chnTb.chnUsdFlg ) { switch( satShrdPrm.chnTb.lnkStat ) { case( SIM_LINK_CNCT ): res->chan_stat[0].chan_stat_link = LINK_ESTABL; break; case( SIM_LINK_DROP ): res->chan_stat[0].chan_stat_inf2 = LINK_DROPPED; break; default: /* already handled by pre-setting */ break; } } } /* add bearer description to terminal response */ if( data_for_term_resp->bearDesc NEQ FALSE AND satShrdPrm.opchPrm ) { if( satShrdPrm.opchType EQ B_CSD ) { res->v_bear_desc = TRUE; res->bear_desc.bear_type = BT_CSD; res->bear_desc.v_csd_bear_prm = TRUE; res->bear_desc.csd_bear_prm = ((T_SAT_CSD_PRM*)satShrdPrm.opchPrm)->csd_bear_prm; } if( satShrdPrm.opchType EQ B_GPRS ) { res->v_bear_desc = TRUE; res->bear_desc.bear_type = BT_GPRS; res->bear_desc.v_gprs_bear_prm = TRUE; res->bear_desc.gprs_bear_prm = ((T_SAT_GPRS_PRM*)satShrdPrm.opchPrm)->gprs_bear_prm; } } /* add buffer size to terminal response */ if( data_for_term_resp->bufSize NEQ FALSE ) { res->v_buffer_size = TRUE; res->buffer_size = satShrdPrm.buffer_size; } #endif /* FF_SAT_E */ cmpFlg = FALSE; } /* *------------------------------------------------------------------- * send terminal response *------------------------------------------------------------------- */ satShrdPrm.owner = OWN_SRC_INV; satShrdPrm.ownSAT = FALSE; memset( &satShrdPrm.stk_ccp, 0, sizeof(BUF_cap_cnf_parms)); #ifdef TI_PS_FF_AT_P_CMD_CUST if (satShrdPrm.cust1StkCmd != (void *)0) { ACI_MFREE(satShrdPrm.cust1StkCmd); /* Free the dynamically allocated Cust1 Stk Cmd memory */ satShrdPrm.cust1StkCmd = (void *)0; satShrdPrm.cust1StkCmdLen = 0; } #endif /* TI_PS_FF_AT_P_CMD_CUST */ if( psaSAT_STKResponse() < 0 ) /* STK command response */ { TRACE_EVENT( "FATAL RETURN SAT in send term resp" ); CCD_END; return( FALSE ); } CCD_END; return (TRUE); } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SATF | | ROUTINE : psaSAT_dasmMECmd | +-------------------------------------------------------------------+ PURPOSE : disassemble ME proactive SIM command. */ GLOBAL BOOL psaSAT_dasmMECmd ( BUF_cmd_prms *cmdPrm ) { UBYTE ccdRet, err; T_ACI_SAT_TERM_RESP resp_data; BOOL aciOnlyEvents; /* holds information whether only ACI events are in SET UP EVENT LIST */ BOOL sendRes; /* holds temporaly return result whether to send response or not */ /* response message in the case of SET UP EVENT LIST, only ACI events */ static UBYTE TRSetEventOk [12] = { 0x81, /* command details tag */ 0x03, /* command details length */ 0x00, /* will be updated to current cmd num */ 0x05, /* command SETUP EVENT LIST */ 0x00, /* not used */ 0x82, /* device details tag */ 0x02, /* device details length */ 0x82, /* source ME */ 0x81, /* destination SIM */ 0x83, /* result tag */ 0x01, /* result length */ 0x00 /* result OK */ }; TRACE_FUNCTION("psaSAT_dasmMECmd"); psaSAT_InitTrmResp( &resp_data ); #ifdef TI_PS_FF_AT_P_CMD_CUST if ((satShrdPrm.cmdDet.cmdType NEQ SAT_CMD_EVENT_LIST) AND /* ACI has to process the event before */ (simShrdPrm.overall_cust_mode EQ (UBYTE)CUST_NORMAL_BEHAVIOUR)) /* and NOT Cust1 behaviour */ #else if (satShrdPrm.cmdDet.cmdType NEQ SAT_CMD_EVENT_LIST) #endif /* TI_PS_FF_AT_P_CMD_CUST */ cmhSAT_STKUsrNtfy(); if( cmdPrm EQ NULL ) /* no parameter */ { memset(&satShrdPrm.stkCmdPrm, 0, sizeof(satShrdPrm.stkCmdPrm)); } else { memcpy( &satShrdPrm.stkCmdPrm, cmdPrm, sizeof(satShrdPrm.stkCmdPrm)); ccdRet = ccd_decodeMsg (CCDENT_SAT, DOWNLINK, (T_MSGBUF *) &satShrdPrm.stkCmdPrm, (UBYTE *) _decodedMsg, satShrdPrm.cmdDet.cmdType ); /* check for CCD error */ if( ccdRet NEQ ccdOK ) { TRACE_EVENT_P1( "CCD Decoding Error: %d", ccdRet ); err = psaSAT_ccdErrChk(); if( err NEQ 0 ) { psaSAT_SendTrmResp( err, &resp_data ); return( FALSE ); } } } /* continue processing */ switch( satShrdPrm.cmdDet.cmdType ) { case( SAT_CMD_SETUP_CALL ): { MCAST( calCmd, SETUP_CALL ); return( cmhSAT_setupCall( calCmd )); } case( SAT_CMD_SEND_SS ): { MCAST( ssCmd, SEND_SS ); return( cmhSAT_sendSS( ssCmd )); } case( SAT_CMD_SEND_USSD ): { MCAST( ussdCmd, SEND_USSD ); return( cmhSAT_sendUSSD( ussdCmd )); } case( SAT_CMD_SEND_SMS ): { MCAST( smCmd, SEND_SM ); return( cmhSAT_sendSM( smCmd )); } case( SAT_CMD_SEND_DTMF ): { MCAST( dtmfCmd, SEND_DTMF ); return( cmhSAT_sendDTMF( dtmfCmd )); } case( SAT_CMD_EVENT_LIST ): { MCAST( setEvent, SETUP_EVENT ); if (cmhSAT_setupEvent_Test( setEvent, &aciOnlyEvents )) { /* ACI-SPR-18200: If there are no Events to be processed by MMI ACI bypasses the MMI functionality and returns TR by itself */ /* something went wrong, temp event list is empty --> TR(30) */ if ( satShrdPrm.event.temp_list EQ 0L ) { psaSAT_SendTrmResp( RSLT_PERF_SUCCESS, &resp_data ); return FALSE; } if ( aciOnlyEvents ) { /* prepare response to signal OK to SATK */ TRSetEventOk[2] = satShrdPrm.cmdDet.cmdNr; satShrdPrm.setPrm[satShrdPrm.owner].stkCmd = TRSetEventOk; satShrdPrm.setPrm[satShrdPrm.owner].stkCmdLen = 12; /* inform SIM about acknowledged event list */ sendRes = cmhSAT_CheckSetEventResp( ); if (sendRes) { if( psaSAT_STKResponse() < 0 ) /* respond to STK command */ { TRACE_EVENT( "FATAL RETURN - TR could not be send" ); } } } else /* signal MMI to process further events */ { cmhSAT_STKCmdInd(); } return TRUE; } else { if ( satShrdPrm.event.temp_list NEQ 0L ) { satShrdPrm.event.temp_list = 0L; /* reinitialize temp_event_list */ psaSAT_SendTrmResp( RSLT_ME_CAP, &resp_data ); } } } break; case( SAT_CMD_RUN_AT ): { MCAST( calCmd, RUN_AT ); return( cmhSAT_runAt( calCmd )); } case( SAT_CMD_LAUNCH_BROWSER ): { MCAST( launchBrowserCmd, LAUNCH_BROWSER ); return( cmhSAT_launchBrowser( launchBrowserCmd )); } case( SAT_CMD_PROV_LOC_INFO): { return( cmhSAT_provLocalInfo()); } #ifdef FF_SAT_E case( SAT_CMD_OPEN_CHANNEL ): { MCAST( opchCmd, OPEN_CHANNEL ); return( cmhSAT_OpenChannelReq( opchCmd )); } #endif /* FF_SAT_E */ } return( FALSE ); } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SATF | | ROUTINE : psaSAT_SSResComp | +-------------------------------------------------------------------+ PURPOSE : SS result component handling. */ GLOBAL void psaSAT_SSResComp ( T_res_comp* resCmp ) { UBYTE addLen = 0; T_ACI_SAT_TERM_RESP resp_data; psaSAT_InitTrmResp( &resp_data ); /* Add the operation code and parameters to terminal response (reference: section 12.12.1 "Additional information for SEND SS" of 11.14) */ if( resCmp -> v_sequence AND resCmp -> sequence.v_op_code ) { ssResPrms[0] = resCmp -> sequence.op_code; if( resCmp -> sequence.params.l_params ) { addLen = resCmp -> sequence.params.l_params >> 3; memcpy( &ssResPrms[1], resCmp -> sequence.params.b_params, addLen); } ++addLen; } resp_data.add = ssResPrms; resp_data.addLen = addLen; psaSAT_SendTrmResp( RSLT_PERF_SUCCESS, &resp_data ); } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SATF | | ROUTINE : psaSAT_SSErrComp | +-------------------------------------------------------------------+ PURPOSE : SS error result component handling. */ GLOBAL void psaSAT_SSErrComp ( T_fac_inf* errCmp, BOOL is_fac_ussd ) { UBYTE ccdRet; UBYTE addLen = 1; T_ACI_SAT_TERM_RESP resp_data; MCAST( com, COMP_SAT ); TRACE_FUNCTION("psaSAT_SSErrComp()"); psaSAT_InitTrmResp( &resp_data ); *ssResPrms = ADD_NO_CAUSE; memset( com, 0, sizeof( T_COMP_SAT )); ccdRet = ccd_decodeMsg (CCDENT_FAC, DOWNLINK, (T_MSGBUF *) errCmp, (UBYTE *) _decodedMsg, COMP_SAT); if( ccdRet NEQ ccdOK ) { TRACE_EVENT_P1("CCD Decoding Error: %d",ccdRet ); } else { if( com->err_comp_sat.err_desc_sat.err_params_sat. l_err_params_sat ) { addLen = com->err_comp_sat.err_desc_sat.err_params_sat. l_err_params_sat >> 3; memcpy( ssResPrms,com->err_comp_sat.err_desc_sat.err_params_sat. b_err_params_sat, addLen ); } } resp_data.add = ssResPrms; resp_data.addLen = addLen; if( is_fac_ussd ) { psaSAT_SendTrmResp( RSLT_USSD_ERR, &resp_data ); } else { psaSAT_SendTrmResp( RSLT_SS_ERR, &resp_data ); } } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SATF | | ROUTINE : psaSAT_SSRejComp | +-------------------------------------------------------------------+ PURPOSE : SS reject component handling. */ GLOBAL void psaSAT_SSRejComp ( UBYTE cRejectInfo ) { UBYTE addLen = 1; T_ACI_SAT_TERM_RESP resp_data; TRACE_FUNCTION("psaSAT_SSRejComp()"); psaSAT_InitTrmResp( &resp_data ); *ssResPrms = ADD_NO_CAUSE; resp_data.add = ssResPrms; resp_data.addLen = addLen; psaSAT_SendTrmResp( cRejectInfo, &resp_data ); } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SATF | | ROUTINE : psaSAT_ss_end_ind | +-------------------------------------------------------------------+ PURPOSE : handles SAT responses to SAT after a SAT originated SS. */ GLOBAL T_ACI_RETURN psaSAT_ss_end_ind ( SHORT sId, T_COMPONENT *com, T_MNSS_END_IND *mnss_end_ind, BOOL is_fac_ussd ) { TRACE_FUNCTION("psaSAT_ss_end_ind()"); if( com->v_res_comp ) { if( is_fac_ussd EQ FALSE ) /* not for USSD !! */ { //TISH, patch for ASTec20762 //start psaSS_dasmResultCmp( sId, &com->res_comp ); //end psaSAT_SSResComp( &com->res_comp ); } else { psaSS_dasmResultCmp( sId, &com->res_comp ); } return( AT_EXCT ); } if( com->v_err_comp ) { ssShrdPrm.stb[sId].failType = SSF_SS_ERR; psaSAT_SSErrComp( &mnss_end_ind -> fac_inf, is_fac_ussd ); return( AT_FAIL ); } if( com->v_rej_comp ) { UBYTE cRejectInfo = RSLT_NTW_UNAB_PROC; /* check for protocol incompatibility for USSD */ if ( (is_fac_ussd) AND (com->rej_comp.v_inv_problem) ) { switch( com->rej_comp.inv_problem ) { case 0x01 : /* invoke problem code #1 */ { if (psaSS_asmUSSDProt1(sId)) { /* facility with Protocole 1 format has been sent: wait for answer */ return( AT_CMPL ); } cRejectInfo = RSLT_NTW_UNAB_PROC; break; } case 0x02 : /* invoke problem code #2 */ { cRejectInfo = RSLT_USSD_ERR; break; } default : { TRACE_EVENT_P1("psaSAT_ss_end_ind(): unknown invoke problem: %x", com->rej_comp.inv_problem ); break; } } ssShrdPrm.stb[sId].failType = SSF_INV_PRB; } /* check for protocol incompatibility for USSD */ if ((is_fac_ussd EQ FALSE) AND (com->rej_comp.v_gen_problem)) { ssShrdPrm.stb[sId].failType = SSF_GEN_PRB; /* for 27.22.4.11.1 Seq. 1.3 SEND SS */ if (com->rej_comp.gen_problem EQ GEN_PROB_UNRECOG_CMP) { cRejectInfo = RSLT_SS_ERR; } } psaSAT_SSRejComp( cRejectInfo ); return( AT_FAIL ); } return(AT_FAIL); } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SATF | | ROUTINE : psaSAT_ccdErrChk | +-------------------------------------------------------------------+ PURPOSE : CCD error checking. The function returns a SAT result value unequal to 0 if the operation is must be terminated. Otherwise the condition is only a warning and the operation should be proceeded. */ GLOBAL UBYTE psaSAT_ccdErrChk ( void ) { USHORT parLst[MAX_ERR_PAR]; UBYTE ccdErr; UBYTE fstFlg = TRUE; TRACE_FUNCTION("psaSAT_ccdErrChk()"); /* *------------------------------------------------------------------- * handling of first error *------------------------------------------------------------------- */ do { memset (parLst,0, sizeof (parLst)); if( fstFlg ) { ccdErr = ccd_getFirstError (CCDENT_SAT, parLst); fstFlg = FALSE; } else ccdErr = ccd_getNextError (CCDENT_SAT, parLst); switch (ccdErr) { case( ERR_IE_NOT_EXPECTED ): /* unexpected element */ if( !((UBYTE)parLst[0] & 0x80) ) { cmpFlg = TRUE; break; } /* otherwise continue, no break */ /*lint -fallthrough*/ case( ERR_COMPREH_REQUIRED ): /* comprehension required */ return( RSLT_UNKN_DATA ); case( ERR_MAND_ELEM_MISS ): /* mandatory elements missing */ return( RSLT_ERR_REQ_VAL ); } } while( ccdErr NEQ ERR_NO_MORE_ERROR ); return( 0 ); } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SAT | | ROUTINE : psaSAT_DumpCmd | +-------------------------------------------------------------------+ PURPOSE : Dump SAT command to debug output. */ GLOBAL void psaSAT_DumpCmd ( T_stk_cmd * cmd ) { #define SAT_TRC_LEN 32 CHAR strBuf[2*SAT_TRC_LEN+1]; /* holds string buffer */ ULONG idx, cnt, mcnt; /* buffer index */ CHAR *pDest; /* points to destination */ TRACE_FUNCTION("psaSAT_DumpCmd()"); /* *------------------------------------------------------------------- * format command *------------------------------------------------------------------- */ TRACE_EVENT( "SAT CMD SENT/RECEIVED:" ); mcnt = (ULONG)cmd->l_cmd >> 3; if( !mcnt ) { TRACE_EVENT_P1("an empty envelope. (%d)", (ULONG)cmd->l_cmd); return; } for( cnt = 0; cnt < mcnt; cnt += SAT_TRC_LEN ) { pDest = strBuf; for( idx = 0; idx < SAT_TRC_LEN AND (idx + cnt) < mcnt; idx++ ) { /* Implements Measure#32: Row 1277 */ pDest += sprintf( pDest, format_2X_str, (UBYTE)cmd->cmd[idx + cnt] ); } *pDest = 0x0; TRACE_EVENT_P1("%s", strBuf ); } } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SAT | | ROUTINE : psaSAT_FURegister | +-------------------------------------------------------------------+ PURPOSE : Register a handler for FILE UPDATE. */ GLOBAL BOOL psaSAT_FURegister ( T_SAT_FU_FUNC fu_func ) { int i; TRACE_FUNCTION("psaSAT_FURegister()"); for (i = 0; i < MAX_FU_OPS; i++) { if (satShrdPrm.fu_func[i] EQ fu_func) { TRACE_EVENT ("FU func already registered"); return TRUE; } if (satShrdPrm.fu_func[i] EQ NULL) { satShrdPrm.fu_func[i] = fu_func; return TRUE; } } return FALSE; } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SAT | | ROUTINE : psaSAT_FUConfirm | +-------------------------------------------------------------------+ PURPOSE : Confirm a handled FILE UPDATE. The parameter is the same with which the handler was called and refers to the entry of the callback table. */ GLOBAL void psaSAT_FUConfirm (int currFU, USHORT resFU) { BOOL fu_active; BOOL aci_sent_no_primitive; TRACE_EVENT_P2("psaSAT_FUConfirm(): currFU: %d, resFU: %d", currFU, resFU); if (resFU EQ SIM_FU_ERROR) /*If there is one error, the rest of the procedure is to be cancelled */ { PALLOC (fu_res, SIM_FILE_UPDATE_RES); fu_res->source = SRC_MMI; fu_res->fu_rsc = SIM_FU_ERROR; if (satShrdPrm.fu_func_notif) (void)satShrdPrm.fu_func_notif((int)fu_res->fu_rsc,satShrdPrm.fu_ind); /*Sends the final result to MMI */ PSENDX (SIM, fu_res); return; } TRACE_EVENT_P1("satShrdPrm.fu_ind: %d", satShrdPrm.fu_ind); if (satShrdPrm.fu_ind NEQ NULL AND currFU < MAX_FU_OPS) { if (currFU < 0) { if (satShrdPrm.fu_func_notif) { /*Sends the file update request notification to MMI */ if (!satShrdPrm.fu_func_notif(-1,satShrdPrm.fu_ind)) { PALLOC (fu_res, SIM_FILE_UPDATE_RES); /* If rejected, send negative response to SIM */ fu_res->source = SRC_MMI; fu_res->fu_rsc = SIM_FU_ERROR; PSENDX (SIM, fu_res); } } currFU = 0; /*satShrdPrm.fu_rsc = SIM_FU_ERROR;*/ /* default*/ fu_active = FALSE; } else { ++currFU; if ( (resFU EQ SIM_FU_SUCC_ADD) AND (satShrdPrm.fu_rsc NEQ SIM_FU_ERROR) ) { satShrdPrm.fu_rsc = resFU; } /* switch (resFU) { case SIM_FU_SUCCESS: if (satShrdPrm.fu_rsc EQ SIM_FU_SUCC_ADD) break; case SIM_FU_SUCC_ADD: satShrdPrm.fu_rsc = resFU; } */ fu_active = TRUE; } for ( ; currFU < MAX_FU_OPS; currFU++) { if (satShrdPrm.fu_func[currFU] EQ NULL) continue; /* else fu_active = TRUE;*/ aci_sent_no_primitive = satShrdPrm.fu_func[currFU](currFU, satShrdPrm.fu_ind); if (!aci_sent_no_primitive) { return; /* otherwise, result would be sent directly, and not at the end */ } } { PALLOC (fu_res, SIM_FILE_UPDATE_RES); fu_res->source = SRC_MMI; fu_res->fu_rsc = (fu_active)? satShrdPrm.fu_rsc: SIM_FU_SUCCESS; if (satShrdPrm.fu_func_notif) (void)satShrdPrm.fu_func_notif((int)fu_res->fu_rsc,satShrdPrm.fu_ind); /*Sends the final result to MMI */ TRACE_EVENT("FREE satShrdPrm.fu_ind"); PFREE (satShrdPrm.fu_ind); satShrdPrm.fu_ind = NULL; PSENDX (SIM, fu_res); simShrdPrm.fuRef = -1; } } } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SAT | | ROUTINE : psaSAT_FUNotifyRegister | +-------------------------------------------------------------------+ PURPOSE : Register a handler for FILE UPDATE. */ GLOBAL BOOL psaSAT_FUNotifyRegister ( T_SAT_FU_FUNC fu_func ) { TRACE_FUNCTION("psaSAT_FUNotifyRegister()"); if (fu_func) { satShrdPrm.fu_func_notif = fu_func; return TRUE; } else return FALSE; } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : PSA_SAT | | ROUTINE : psaSAT_Init | +-------------------------------------------------------------------+ PURPOSE : initialize the protocol stack adapter for SAT. */ /* MACRO: initializer for set parameter */ #define INIT_SAT_SET_PARM( dest, def )\ for( LpCnt = 0; LpCnt < OWN_SRC_MAX; LpCnt++ )\ satShrdPrm.setPrm[LpCnt].dest = def GLOBAL void psaSAT_Init ( void ) { TRACE_FUNCTION("psaSAT_Init()"); /* *------------------------------------------------------------------- * set default parms *------------------------------------------------------------------- */ memset( &satShrdPrm, 0, sizeof(T_SAT_SHRD_PRM)); satShrdPrm.dur = -1; satShrdPrm.SentUSSDid = NO_ENTRY; satShrdPrm.fu_rsc = SIM_FU_SUCCESS; satShrdPrm.fu_ind = NULL; satShrdPrm.sId_pwd_requested = NO_ENTRY; #ifdef TI_PS_FF_AT_P_CMD_CUST satShrdPrm.cust1SimRefreshRespRqd = FALSE; #endif /* TI_PS_FF_AT_P_CMD_CUST */ satShrdPrm.locInfo.currPLMN.v_plmn = INVLD_PLMN; satShrdPrm.Cbch_EvtDnl = FALSE; satShrdPrm.ownSAT = FALSE; } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_ChkEventList | +-------------------------------------------------------------------+ PURPOSE : Check if the event is monitored and shall alert SAT. */ GLOBAL BOOL psaSAT_ChkEventList( UBYTE eventNr ) { BOOL event_listed = FALSE; TRACE_FUNCTION("psaSAT_ChkEventList()"); event_listed = (satShrdPrm.event.list >> eventNr ) & 0x01; if( event_listed ) return( TRUE ); return( FALSE ); } #ifdef FF_SAT_E /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_ctbFindActCall | +-------------------------------------------------------------------+ PURPOSE : Return the call id of a call which is in an active state. If no call could be found the function returns NO_ENTRY. */ GLOBAL SHORT psaSAT_ctbFindActCall( void ) { UBYTE ctbIdx; SHORT actId = NO_ENTRY; TRACE_FUNCTION("psaSAT_ctbFindActCall()"); for( ctbIdx = 0; ctbIdx < MAX_CALL_NR; ctbIdx++ ) { if (ccShrdPrm.ctb[ctbIdx] NEQ NULL) { switch( psaCC_ctb(ctbIdx)->calStat ) { case( CS_ACT ): case( CS_ACT_REQ ): case( CS_MDF_REQ ): actId = ctbIdx; break; } } } return( actId ); } /* +-------------------------------------------------------------------+ | PROJECT : GSM-PS (6147) MODULE : SAT | | ROUTINE : psaSAT_gprsFindFreeCntxt| +-------------------------------------------------------------------+ PURPOSE : Return a free context id, if busy return NO_ENTRY. */ #ifdef GPRS GLOBAL SHORT psaSAT_gprsFindFreeCntxt( void ) { BOOL cntxtStat[MAX_CID+1]; SHORT cntxtId[MAX_CID+1]; SHORT cid = NO_ENTRY; UBYTE idx; TRACE_FUNCTION("psaSAT_gprsFindFreeCntxt()"); if( qAT_PlusCGACT( CMD_SRC_LCL, cntxtStat, cntxtId ) NEQ AT_CMPL ) return( NO_ENTRY ); for( idx = 0; idx < MAX_CID; idx++ ) { if( cntxtId[idx] NEQ INVALID_CID AND cntxtStat[idx] EQ TRUE ) continue; cid = (cntxtId[idx] EQ INVALID_CID)? idx+1:cntxtId[idx]; break; } return( cid ); } #endif /* GPRS */ #endif /* FF_SAT_E */ #endif /* #ifdef SIM_TOOLKIT */ /*==== EOF ========================================================*/