view src/aci2/aci/psa_smsf.c @ 647:94cb5e76b3b5

FCHG: fixed corner case bug of missing discharge init on charger unplug also turn on LEDC during i2v calibration
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 16 Apr 2020 16:48:08 +0000
parents 93999a60b835
children
line wrap: on
line source

/* 
+----------------------------------------------------------------------------- 
|  Project :  GSM-PS (6147)
|  Modul   :  PSA_SMSF
+----------------------------------------------------------------------------- 
|  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 registration part of mobility
|             management. 
+----------------------------------------------------------------------------- 
*/ 

#ifndef PSA_SMSF_C
#define PSA_SMSF_C
#endif

#include "aci_all.h"

#undef TRACING

/*==== INCLUDES ===================================================*/
#include "aci_cmh.h"
#include "ati_cmd.h"
#include "aci_cmd.h"

#ifdef FAX_AND_DATA
#include "aci_fd.h"
#endif    /* of #ifdef FAX_AND_DATA */

#include "aci.h"
#include "aci_lst.h"
#include "aci_mem.h"
#include "psa.h"
#ifdef SIM_TOOLKIT
#include "psa_cc.h"
#include "psa_sat.h"
#endif
#include "psa_sms.h"
#include "psa_util.h"
#include "cmh.h"
#include "cmh_sms.h"
#include "psa_sim.h"

#if (defined (MFW) AND !defined (FF_MMI_RIV)) OR defined (_CONC_TESTING_)
#include "conc_sms.h"
#endif

/*==== CONSTANTS ==================================================*/
#define ITM_WDT         (14)    /* item width in chars */
#define HDR_WDT         (10)    /* header width in chars */

/*==== TYPES ======================================================*/

/*==== EXPORT =====================================================*/

/*==== VARIABLES ==================================================*/
GLOBAL T_ACI_LIST *set_prm_list = NULL;

/*==== FUNCTIONS ==================================================*/

#ifdef SIM_TOOLKIT
EXTERN BOOL cmhSMS_FileUpdate (int, T_SIM_FILE_UPDATE_IND *);
#endif

/*
+-------------------------------------------------------------------+
| PROJECT : GSM-PS (6147)         MODULE  : PSA_SMSF                |
|                                 ROUTINE : psaSMS_Init             |
+-------------------------------------------------------------------+

  PURPOSE : initialize the protocol stack adapter for SMS.

*/

/* MACRO: initializer for set parameter */
#define INIT_SET_PARM( dest, def )\
    {smsShrdPrm.pSetPrm[0]->dest = def;}





GLOBAL void psaSMS_InitParams ( void )
{
  INIT_SET_PARM( sca.ton,     SMS_TON_UNKNOWN                     );
  INIT_SET_PARM( sca.npi,     SMS_NPI_UNKNOWN                     );
  INIT_SET_PARM( sca.c_num,   0                                   );
  INIT_SET_PARM( vpRel,       TP_VP_RELATIVE_DEFAULT              );
  INIT_SET_PARM( pid,         SMS_PID_DEFAULT                     );
  INIT_SET_PARM( dcs,         SMS_DCS_GRP_DEF                     );
  INIT_SET_PARM( msgType,     (TP_MTI_SMS_SUBMIT + TP_VPF_RELATIVE));

  smsShrdPrm.cbmPrm.cbmFoundIds          = 0;
  memset(smsShrdPrm.cbmPrm.msgId, DEF_MID_RANGE, sizeof(smsShrdPrm.cbmPrm.msgId));
}
GLOBAL void psaSMS_Init ( void )
{
  int LpCnt;            /* holds loop counter for macro */
  T_SMS_SET_PRM * elem;

/*
 *-------------------------------------------------------------------
 * set default parms
 *-------------------------------------------------------------------
 */
  smsShrdPrm.smsStat      =  SMS_STATE_NOT_AVAILABLE;
  smsShrdPrm.accessEnabled = FALSE;
  smsShrdPrm.aci_sms_parameter.simTotal = 0;
  smsShrdPrm.aci_sms_parameter.simUsed  = 0;
  smsShrdPrm.aci_sms_parameter.meTotal  = 0;
  smsShrdPrm.aci_sms_parameter.meUsed   = 0;
  smsShrdPrm.owner        = OWN_NONE;
  smsShrdPrm.cbmPrm.cbchOwner    = OWN_NONE;
  smsShrdPrm.rslt         = 0x200/*CS_OK*/;

  smsShrdPrm.aci_sms_parameter.snd_msg_ref  = 0;

  smsShrdPrm.aci_sms_parameter.smsParamRecLen = 0;
  smsShrdPrm.aci_sms_parameter.smsParamMaxRec = 0;
  smsShrdPrm.mtHndl               = MT0;
  smsShrdPrm.srHndl               = DS0;
  smsShrdPrm.cbmPrm.cbmHndl              = BM0;
  smsShrdPrm.cbmPrm.cbmMode              = CBCH_ACCEPT;
  smsShrdPrm.cbmPrm.cbmFoundIds          = 0;
  smsShrdPrm.cbmPrm.cbmSIMmaxId          = 0;
  smsShrdPrm.cbmPrm.cbmSIMmaxIdRge       = 0;

  smsShrdPrm.tpdu.tp_submit              = NULL;
  smsShrdPrm.tpdu.tp_deliver             = NULL;
  smsShrdPrm.tpdu.tp_command             = NULL;

#ifdef FF_HOMEZONE
  smsShrdPrm.cbmPrm.hzMode    = CBHZ_MOD_NotActive;
  smsShrdPrm.cbmPrm.hzDcs     = CS_GsmDef;
  smsShrdPrm.cbmPrm.hzTimeout = CBHZ_DEF_TIMEOUT;
#endif /* FF_HOMEZONE */

  smsShrdPrm.mem1                        = MEM_SM;
  smsShrdPrm.mem2                        = MEM_SM;
  smsShrdPrm.mem3                        = MEM_SM;
  smsShrdPrm.status                      = CMGD_DEL_INDEX;
  smsShrdPrm.cnma_ack_expected           = FALSE;
  smsShrdPrm.uiInternalSmsStorage        = CMD_SRC_NONE;
  smsShrdPrm.smsSrcId                    = CMD_SRC_NONE;

  smsShrdPrm.CSMSservice                 = CSMS_SERV_GsmPh2;
  smsShrdPrm.CSMSmt                      = CSMS_SUPP_Enable;
  smsShrdPrm.CSMSmo                      = CSMS_SUPP_Enable;
  smsShrdPrm.CSMSbm                      = CSMS_SUPP_Enable;

  smsShrdPrm.CNMImt                      = CNMI_MT_NoSmsDeliverInd;
  smsShrdPrm.CNMIbm                      = CNMI_BM_NoCbmInd;
  smsShrdPrm.CNMIds                      = CNMI_DS_NoSmsStatRpt;


  smsShrdPrm.prmRdSeq                    = SMS_READ_SIM_CMPL;
  smsShrdPrm.pDecMsg                     = NULL;
  
  smsShrdPrm.rplyCB.cmss                 = NULL;
  smsShrdPrm.errorCB                     = NULL;

  smsShrdPrm.CMMSmode                    = CMMS_MODE_DEF;

#ifdef FF_MMI_RIV
  smsShrdPrm.perccmgf_smbs_mode = PERC_SMBS_MOD_DISABLE;
#endif /* #ifdef FF_MMI_RIV */

  if (set_prm_list EQ NULL)
  {
    set_prm_list = new_list();
    ACI_MALLOC(elem, sizeof(T_SMS_SET_PRM));
    memset(elem, 0, sizeof(T_SMS_SET_PRM));
    insert_list(set_prm_list, elem);
    
    /* all set prm pointer should point to this element */
    for( LpCnt = 0; LpCnt < OWN_MAX; LpCnt++ )
    {
      smsShrdPrm.pSetPrm[LpCnt] = elem;
    }
  }

#ifndef SMS_PDU_SUPPORT
  INIT_SET_PARM( CMGFmode,     CMGF_MOD_Txt                       );
#else
  INIT_SET_PARM( CMGFmode,     CMGF_MOD_Pdu                       );
#endif

  INIT_SET_PARM( prflId,      1                                   );
  INIT_SET_PARM( isCopy,      FALSE                               );
  INIT_SET_PARM( numOfRefs,   OWN_MAX                             );
  INIT_SET_PARM( sca.ton,     SMS_TON_UNKNOWN                     );
  INIT_SET_PARM( sca.npi,     SMS_NPI_UNKNOWN                     );
  INIT_SET_PARM( sca.c_num,   0                                   );
  INIT_SET_PARM( vpRel,       TP_VP_RELATIVE_DEFAULT              );
  INIT_SET_PARM( pid,         SMS_PID_DEFAULT                     );
  INIT_SET_PARM( dcs,         SMS_DCS_GRP_DEF                     );
  INIT_SET_PARM( msgType,     (TP_MTI_SMS_SUBMIT + TP_VPF_RELATIVE));

  memset(smsShrdPrm.cbmPrm.msgId, DEF_MID_RANGE, sizeof(smsShrdPrm.cbmPrm.msgId));
  memset(smsShrdPrm.cbmPrm.dcsId, DEF_DCS_RANGE, sizeof(smsShrdPrm.cbmPrm.dcsId));

  smsShrdPrm.pSetPrm[0]->vpAbs.year  [0] = 7;
  smsShrdPrm.pSetPrm[0]->vpAbs.year  [1] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.month [0] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.month [1] = 1;
  smsShrdPrm.pSetPrm[0]->vpAbs.day   [0] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.day   [1] = 1;
  smsShrdPrm.pSetPrm[0]->vpAbs.hour  [0] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.hour  [1] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.minute[0] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.minute[1] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.second[0] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.second[1] = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.tz_lsb    = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.tz_sign   = 0;
  smsShrdPrm.pSetPrm[0]->vpAbs.tz_msb    = 0;

  memset(&smsShrdPrm.pSetPrm[0]->vpEnh, 0, sizeof(smsShrdPrm.pSetPrm[0]->vpEnh));
  smsShrdPrm.pSetPrm[0]->vpEnh.tvpf        = SMS_TVPF_RELATIVE;
  smsShrdPrm.pSetPrm[0]->vpEnh.v_tp_vp_rel = 1;
  smsShrdPrm.pSetPrm[0]->vpEnh.tp_vp_rel   = TP_VP_RELATIVE_DEFAULT;

#ifdef SIM_TOOLKIT
  simShrdPrm.fuRef = -1;
  if (!psaSAT_FURegister (cmhSMS_FileUpdate))
  {
    TRACE_EVENT ("FAILED to register the handler cmhSMS_FileUpdate() for FU");
  }
#endif

#if (defined (MFW) AND !defined (FF_MMI_RIV)) OR defined (_CONC_TESTING_)
  concSMS_Init();
#endif
}

/*
+-------------------------------------------------------------------+
| PROJECT : GSM-PS (6147)         MODULE  : PSA_SMSF                |
|                                 ROUTINE : psaSMS_shrPrmDump       |
+-------------------------------------------------------------------+

  PURPOSE : this function dumps the shared parameter to the debug
            output.
*/

GLOBAL void psaSMS_shrPrmDump ( void )
{
#ifdef TRACING

  char  lnBuf [80];             /* holds buffer for output line */ 
  SHORT chrNr;                  /* holds number of processed chars */

  /* --- SIM total -----------------------------------------------*/
  chrNr  = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, " SIM total" );
  chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, 
                                         smsShrdPrm.aci_sms_parameter.simTotal );
  TRACE_EVENT( lnBuf );

  /* --- SIM used ------------------------------------------------*/
  chrNr  = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, "  SIM used" );
  chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, 
                                         smsShrdPrm.aci_sms_parameter.simUsed );
  TRACE_EVENT( lnBuf );

  /* --- ME total ------------------------------------------------*/
  chrNr  = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, "  ME total" );
  chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, 
                                         smsShrdPrm.aci_sms_parameter.meTotal );
  TRACE_EVENT( lnBuf );

  /* --- ME used -------------------------------------------------*/
  chrNr  = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, "   ME used" );
  chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, 
                                         smsShrdPrm.aci_sms_parameter.meUsed );
  TRACE_EVENT( lnBuf );

  /* --- SMS status ----------------------------------------------*/
  chrNr  = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, "SMS status" );
  chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, 
                                         smsShrdPrm.smsStat );
  TRACE_EVENT( lnBuf );

#endif  /* of #ifdef TRACING */
}


/*
+-------------------------------------------------------------------+
| PROJECT : GSM-PS (6147)         MODULE  : PSA_SMSF                |
|                                 ROUTINE : psaSMS_printSetPrm      |
+-------------------------------------------------------------------+

  PURPOSE : 
*/

GLOBAL void psaSMS_printSetPrm ( T_SMS_SET_PRM * pSMSSetPrm )
{
#ifdef TRACING

  UBYTE        prflId;
  UBYTE        isCopy;
  UBYTE        numOfRefs;

  SHORT        fo;
  SHORT        vprel;
  T_ACI_VP_ABS vpabs;
  T_ACI_VP_ENH vpenh;
  SHORT        pid;
  SHORT        dcs;
  char         vpenh_str[15];

  char          vpabs_str[25] = {'\0'};

  CHAR *buf;

  /*
   *-----------------------------------------------------------------
   * fill in parameters
   *-----------------------------------------------------------------
   */  

  isCopy = pSMSSetPrm -> isCopy; 
  prflId = pSMSSetPrm -> prflId;
  numOfRefs = pSMSSetPrm -> numOfRefs;

  fo    = pSMSSetPrm -> msgType;
  vprel = pSMSSetPrm -> vpRel;
  
  cmhSMS_setVpabsCmh ( &vpabs, &pSMSSetPrm -> vpAbs );
  cmhSMS_setVpenhCmh ( &vpenh, &pSMSSetPrm -> vpEnh );
  
  pid   = pSMSSetPrm -> pid;
  dcs   = pSMSSetPrm -> dcs;


  MALLOC(buf,MAX_CMD_LEN);
  if ((fo & TP_VPF_MASK) EQ TP_VPF_ABSOLUTE)   /*Bits 4,3 -> 11*/
  {
    sprintf(vpabs_str,"\"%d%d/%d%d/%d%d,%d%d:%d%d:%d%d%+03d\"",
            vpabs.year  [0], vpabs.year  [1],
            vpabs.month [0], vpabs.month [1],
            vpabs.day   [0], vpabs.day   [1],
            vpabs.hour  [0], vpabs.hour  [1],
            vpabs.minute[0], vpabs.minute[1],
            vpabs.second[0], vpabs.second[1],
            vpabs.timezone);
    sprintf(buf,"isCopy:%d,prflId:%d,numOfRefs:%d,fo:%d,vpabs:%s,pid:%d,dcs:%d",
            isCopy,prflId,numOfRefs,fo,vpabs_str,pid,dcs);
  }
  else if ((fo & TP_VPF_MASK) EQ TP_VPF_ENHANCED)
  {

    aci_encodeVpenh ( vpenh_str, &vpenh );

    sprintf(buf,"isCopy:%d,prflId:%d,numOfRefs:%d,fo:%d,vpenh:\"%s\",pid:%d,dcs:%d",
            isCopy,prflId,numOfRefs,fo,vpenh_str,pid,dcs);
  }
  else if ((fo & TP_VPF_MASK) EQ TP_VPF_RELATIVE) /*Bits 4,3 -> 10*/
  {
    sprintf(buf,"isCopy:%d,prflId:%d,numOfRefs:%d,fo:%d,vprel:%d,pid:%d,dcs:%d",
            isCopy,prflId,numOfRefs,fo,vprel,pid,dcs);
  }
  else
  {
    sprintf(buf,"isCopy:%d,prflId:%d,numOfRefs:%d,fo:%d,,pid:%d,dcs:%d",
            isCopy,prflId,numOfRefs,fo,pid,dcs);
  }
    
  TRACE_EVENT( buf );
  MFREE( buf );

#endif  /* of #ifdef TRACING */
}


/*
+-------------------------------------------------------------------+
| PROJECT : GSM-PS (6147)         MODULE  : PSA_SMSF                |
|                                 ROUTINE : psaSMS_printSetPrmList  |
+-------------------------------------------------------------------+

  PURPOSE : 
*/

GLOBAL void psaSMS_printSetPrmList ( T_ACI_CMD_SRC srcId )
{
#ifdef TRACING

  T_ACI_LIST    *current;
  UBYTE index=0;
  char tmp[25];

  current = set_prm_list;

  while (current)
  {
    sprintf(tmp, "SET PRM List Element %d:", index++);
    TRACE_EVENT(tmp);
    psaSMS_printSetPrm(current->msg);
    current = current->next;
  }

  TRACE_EVENT("CURRENT SET PRM:");
  psaSMS_printSetPrm(smsShrdPrm.pSetPrm[srcId]);

#endif  /* of #ifdef TRACING */
}

/*==== EOF ========================================================*/