FreeCalypso > hg > freecalypso-sw
view gsm-fw/g23m-aci/aci/psa_smp.c @ 976:ca65f5adf1af
rvinterf: print old ASCII GPF traces emitted by 20020917 firmware on D-Sample
author | Mychaela Falconia <falcon@ivan.Harhan.ORG> |
---|---|
date | Sun, 29 Nov 2015 05:22:41 +0000 |
parents | eedbf248bac0 |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : | Modul : +----------------------------------------------------------------------------- | 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 processing functions for the | primitives send to the protocol stack adapter by the | session management of GPRS ( SM ). +----------------------------------------------------------------------------- */ #ifdef GPRS #ifndef PSA_SMP_C #define PSA_SMP_C #endif #include "aci_all.h" /*==== INCLUDES ===================================================*/ #include "dti.h" /* functionality of the dti library */ #include "aci_cmh.h" #include "ati_cmd.h" #include "aci_cmd.h" #include "aci.h" #include "dti_conn_mng.h" #include "dti_cntrl_mng.h" #include "gaci.h" #include "gaci_cmh.h" #include "psa.h" #include "psa_sm.h" #include "cmh.h" #include "cmh_sm.h" #if defined (FF_WAP) || defined (FF_GPF_TCPIP) || defined (FF_SAT_E) #include "psa_tcpip.h" #include "wap_aci.h" #endif /* defined (FF_WAP) || defined (FF_GPF_TCPIP) */ #ifdef FF_GPF_TCPIP #include "dcm_utils.h" #include "dcm_state.h" #include "dcm_env.h" #endif #include "dcm_f.h" /*==== CONSTANTS ==================================================*/ /*==== TYPES ======================================================*/ /*==== EXPORT =====================================================*/ /*==== VARIABLES ==================================================*/ /*==== FUNCTIONS ==================================================*/ /* +----------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_activate_cnf | +----------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_ACTIVATE_CNF primitive send by SM. this confirms a successful context activation. */ GLOBAL void psa_smreg_pdp_activate_cnf ( T_SMREG_PDP_ACTIVATE_CNF *smreg_pdp_activate_cnf ) { T_PDP_CONTEXT_INTERNAL *p_pdp_context_node = NULL; TRACE_FUNCTION ("psa_smreg_pdp_activate_cnf()"); p_pdp_context_node = pdp_context_find_node_from_cid( work_cids[cid_pointer] ); if( ! p_pdp_context_node ) { TRACE_ERROR( "ERROR: PDP context not found, in function psa_smreg_pdp_activate_cnf" ); return; } /* *------------------------------------------------------------------- * notify ACI *------------------------------------------------------------------- */ smShrdPrm.pdp_cnf = smreg_pdp_activate_cnf; /* * Store negotiated QOS parameters, only used for read out */ p_pdp_context_node->ctrl_neg_qos = smreg_pdp_activate_cnf->ctrl_qos; memcpy( &p_pdp_context_node->neg_qos, &smreg_pdp_activate_cnf->qos, sizeof(T_PS_qos) ); if ( cmhSM_Activated(smreg_pdp_activate_cnf) < 0) { TRACE_EVENT("cmhSM_Activated( ) returned error."); } /* free the primitive buffer */ PFREE (smreg_pdp_activate_cnf); } /* +----------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_activate_rej | +----------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_ACTIVATE_REJ primitive send by SM. this indicates a context activation failed. */ GLOBAL void psa_smreg_pdp_activate_rej ( T_SMREG_PDP_ACTIVATE_REJ *smreg_pdp_activate_rej ) { TRACE_FUNCTION ("psa_smreg_pdp_activate_rej()"); /* update shared parameter and notify ACI */ smShrdPrm.pdp_rej = smreg_pdp_activate_rej; if ( cmhSM_NoActivate( ) < 0) { TRACE_EVENT("cmhSM_NoActivate( ) returned error."); } #ifdef FF_GPF_TCPIP if(is_gpf_tcpip_call()) { T_DCM_STATUS_IND_MSG msg; msg.hdr.msg_id = DCM_NEXT_CMD_STOP_MSG; dcm_send_message(msg, DCM_SUB_WAIT_CGACT_CNF); } #endif /* FF_GPF_TCPIP */ /* free the primitive buffer */ PFREE (smreg_pdp_activate_rej); } /* +----------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : developing ROUTINE : convert_apn_to_netaddr | +----------------------------------------------------------------------+ PURPOSE : converts an APN to a dotted network address */ LOCAL SHORT convert_apn_to_netaddr ( T_SMREG_apn *apn_src, T_SMREG_apn *apn_dest) { T_SMREG_apn dummy_apn = {0,0,0}; U8 counter1 = 0; U8 counter2 = 0; U8 dest_pos = 0; U8 bytecount = 0; TRACE_FUNCTION ("convert_apn_to_netaddr()"); if(apn_src EQ apn_dest) { apn_dest=&dummy_apn; } while(counter1<apn_src->c_apn_buf-1) { bytecount=apn_src->apn_buf[counter1]; for(counter2=0;counter2<bytecount;counter2++) { counter1++; if (counter1>=apn_src->c_apn_buf) { return -1; } else { apn_dest->apn_buf[dest_pos]=apn_src->apn_buf[counter1]; dest_pos++; } } if (counter1<apn_src->c_apn_buf-1) { apn_dest->apn_buf[dest_pos]='.'; dest_pos++; counter1++; } else { apn_dest->apn_buf[dest_pos]=0; } } if (apn_dest EQ &dummy_apn) { apn_dest=apn_src; memcpy(apn_dest->apn_buf,&dummy_apn.apn_buf,dest_pos+1); apn_dest->c_apn_buf=dest_pos; } return 0; } /* +----------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_activate_ind | +----------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_ACTIVATE_IND primitive send by SM. this indicates a network asked for a PDP context activation. */ GLOBAL void psa_smreg_pdp_activate_ind ( T_SMREG_PDP_ACTIVATE_IND *smreg_pdp_activate_ind ) { TRACE_FUNCTION ("psa_smreg_pdp_activate_ind()"); /* update shared parameter and notify ACI */ memcpy(&smShrdPrm.act_ind, smreg_pdp_activate_ind, sizeof(T_SMREG_PDP_ACTIVATE_IND)); convert_apn_to_netaddr(&smShrdPrm.act_ind.apn,&smShrdPrm.act_ind.apn); cmhSM_NetActivate( ); /* free the primitive buffer */ PFREE (smreg_pdp_activate_ind); } /* +------------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_deactivate_cnf | +------------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_DEACTIVATE_CNF primitive send by SM. this confirms a successful PDP context deactivation. */ GLOBAL void psa_smreg_pdp_deactivate_cnf ( T_SMREG_PDP_DEACTIVATE_CNF *smreg_pdp_deactivate_cnf ) { TRACE_FUNCTION ("psa_smreg_pdp_deactivate_cnf()"); /* update shared parameter and notify ACI */ smShrdPrm.nsapi_set = smreg_pdp_deactivate_cnf->nsapi_set; cmhSM_Deactivated(); /* free the primitive buffer */ PFREE (smreg_pdp_deactivate_cnf); } /* +------------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_deactivate_ind | +------------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_DEACTIVATE_IND primitive send by SM. this indicates a network initiated PDP context deactivation. */ GLOBAL void psa_smreg_pdp_deactivate_ind ( T_SMREG_PDP_DEACTIVATE_IND *smreg_pdp_deactivate_ind ) { TRACE_FUNCTION ("psa_smreg_pdp_deactivate_ind()"); /* update shared parameter and notify ACI */ smShrdPrm.nsapi_set = smreg_pdp_deactivate_ind->nsapi_set; cmhSM_NetDeactivate( ); /* free the primitive buffer */ PFREE (smreg_pdp_deactivate_ind); } /* +--------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_modify_ind | +--------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_MODIFY_IND primitive send by SM. this indicates a network initiated PDP context modification. */ GLOBAL void psa_smreg_pdp_modify_ind ( T_SMREG_PDP_MODIFY_IND *smreg_pdp_modify_ind ) { TRACE_FUNCTION ("psa_smreg_pdp_modify_ind()"); /* *------------------------------------------------------------------- * informs context manager *------------------------------------------------------------------- */ cmhSM_NetModify(smreg_pdp_modify_ind); /* *------------------------------------------------------------------- * free the primitive buffer *------------------------------------------------------------------- */ PFREE (smreg_pdp_modify_ind); } /* +----------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_modify_cnf | +----------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_MODIFY_CNF primitive send by SM. this confirms a successful context modification. */ #ifdef REL99 GLOBAL void psa_smreg_pdp_modify_cnf ( T_SMREG_PDP_MODIFY_CNF *smreg_pdp_modify_cnf ) { T_PDP_CONTEXT_INTERNAL *p_pdp_context_node = NULL; TRACE_FUNCTION ("psa_smreg_pdp_modify_cnf()"); p_pdp_context_node = pdp_context_find_node_from_cid( work_cids[cid_pointer] ); if( !p_pdp_context_node ) { TRACE_ERROR( "ERROR: PDP context not found, in function psa_smreg_pdp_modify_cnf" ); return; } /* *------------------------------------------------------------------- * update shared parameter with new QoS and notify ACI *------------------------------------------------------------------- */ if( smreg_pdp_modify_cnf->ctrl_qos NEQ PS_is_qos_not_present ) { p_pdp_context_node->ctrl_neg_qos = smreg_pdp_modify_cnf->ctrl_qos; memcpy( &p_pdp_context_node->neg_qos, &smreg_pdp_modify_cnf->qos, sizeof(T_PS_qos) ); } if( cmhSM_Modified( smreg_pdp_modify_cnf) > 0 ) { TRACE_EVENT("cmhSM( SM_NTF_MOD_CNF ): not supported return value."); } /* *------------------------------------------------------------------- * free the primitive buffer *------------------------------------------------------------------- */ PFREE (smreg_pdp_modify_cnf); } /* +----------------------------------------------------------------------+ | PROJECT : GPRS (8441) MODULE : PSA_SM | | STATE : finished ROUTINE : psa_smreg_pdp_modify_rej | +----------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_MODIFY_REJ primitive send by SM. this indicates a context modification failed. */ GLOBAL void psa_smreg_pdp_modify_rej ( T_SMREG_PDP_MODIFY_REJ *smreg_pdp_modify_rej ) { TRACE_FUNCTION ("psa_smreg_pdp_modify_rej()"); /* *------------------------------------------------------------------- * notify ACI *------------------------------------------------------------------- */ if( cmhSM_NoModify( smreg_pdp_modify_rej ) < 0 ) { TRACE_EVENT("cmhSM( SM_NTF_MOD_REJ ) give not supported return value."); } /* *------------------------------------------------------------------- * free the primitive buffer *------------------------------------------------------------------- */ PFREE (smreg_pdp_modify_rej); } /* +----------------------------------------------------------------------------+ | PROJECT : UMTS MODULE : PSA_SM | | STATE : ROUTINE : psa_smreg_pdp_activate_sec_cnf | +----------------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_ACTIVATE_SEC_CNF primitive send by SM. */ GLOBAL void psa_smreg_pdp_activate_sec_cnf( T_SMREG_PDP_ACTIVATE_SEC_CNF *smreg_pdp_activate_sec_cnf ) { T_PDP_CONTEXT_INTERNAL *p_pdp_context_node = NULL; TRACE_FUNCTION ("psa_smreg_pdp_activate_sec_cnf()"); p_pdp_context_node = pdp_context_find_node_from_cid( work_cids[cid_pointer] ); if( !p_pdp_context_node ) { TRACE_ERROR( "ERROR: PDP context not found, in function psa_smreg_pdp_activate_sec_cnf" ); return; } /* *------------------------------------------------------------------- * update shared parameter with new QoS and notify ACI *------------------------------------------------------------------- */ p_pdp_context_node->ctrl_neg_qos = smreg_pdp_activate_sec_cnf->ctrl_qos; memcpy( &p_pdp_context_node->neg_qos, &smreg_pdp_activate_sec_cnf->qos, sizeof(T_PS_qos) ); /* *------------------------------------------------------------------- * notify ACI *------------------------------------------------------------------- */ if( cmhSM_ActivatedSecondary( smreg_pdp_activate_sec_cnf ) < 0 ) { TRACE_EVENT("cmhSM( SM_NTF_ACT_SEC_CNF ) un-supported return value."); } /* *------------------------------------------------------------------- * free the primitive buffer *------------------------------------------------------------------- */ PFREE( smreg_pdp_activate_sec_cnf ); } /* +----------------------------------------------------------------------------+ | PROJECT : UMTS MODULE : PSA_SM | | STATE : ROUTINE : psa_smreg_pdp_activate_sec_rej | +----------------------------------------------------------------------------+ PURPOSE : processes the SMREG_PDP_ACTIVATE_SEC_REJ primitive send by SM. */ GLOBAL void psa_smreg_pdp_activate_sec_rej( T_SMREG_PDP_ACTIVATE_SEC_REJ *smreg_pdp_activate_sec_rej ) { TRACE_FUNCTION ("psa_smreg_pdp_activate_sec_rej()"); /* *------------------------------------------------------------------- * notify ACI *------------------------------------------------------------------- */ if( cmhSM_NoActivateSecondary( smreg_pdp_activate_sec_rej ) < 0 ) { TRACE_EVENT("cmhSM( SM_NTF_ACT_SEC_REJ ) un-supported return value."); } /* *------------------------------------------------------------------- * free the primitive buffer *------------------------------------------------------------------- */ PFREE( smreg_pdp_activate_sec_rej ); } #endif /* REL99 */ #endif /* GPRS */ /*==== EOF =========================================================*/