FreeCalypso > hg > fc-magnetite
view src/aci2/aci/cmh_sm.h @ 516:1ed9de6c90bd
src/g23m-gsm/sms/sms_for.c: bogus malloc removed
The new error handling code that was not present in TCS211 blob version
contains a malloc call that is bogus for 3 reasons:
1) The memory allocation in question is not needed in the first place;
2) libc malloc is used instead of one of the firmware's proper ways;
3) The memory allocation is made inside a function and then never freed,
i.e., a memory leak.
This bug was caught in gcc-built FreeCalypso fw projects (Citrine
and Selenite) because our gcc environment does not allow any use of
libc malloc (any reference to malloc produces a link failure),
but this code from TCS3.2 is wrong even for Magnetite: if this code
path is executed repeatedly over a long time, the many small allocations
made by this malloc call without a subsequent free will eventually
exhaust the malloc heap provided by the TMS470 environment, malloc will
start returning NULL, and the bogus code will treat it as an error.
Because the memory allocation in question is not needed at all,
the fix entails simply removing it.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 22 Jul 2018 06:04:49 +0000 |
parents | 93999a60b835 |
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 : Definitions for the command handler of the | GPRS session management ( SM ). +----------------------------------------------------------------------------- */ #ifdef GPRS #ifndef CMH_SM_H #define CMH_SM_H /*==== CONSTANTS ==================================================*/ /* dynamic numbers of nsapis */ #define SMH_FIRST_FREE_NSAPIS SMREG_NSAPI_5 #define SMH_LAST_FREE_NSAPIS SMREG_NSAPI_15 #define SMH_NSAPI_MAX 16 /* invalid values */ #define INVALID_NSAPI (0xFF) /* marks an invalid nsapi */ /* not used nsapi */ #define UNUSED_NSAPI (0x00) /* nsapi currently not in use */ /* for network requested context activation */ #define MAX_GPRS_CALL_TABLE_ENTRIES 2 /* MAX_PDP_TYPE_LEN + MAX_PDP_ADDR_LEN + MAX_L2P_LENGTH = 7 + 21 + 6 = 34 */ #define MAX_CRING_INFORMATION_LENGTH 42 /* undefiend smreg_ti */ #define UNDEFINED_TI 0xFF typedef enum { PCO_USER, PCO_NETWORK } T_PCO_TYPE; typedef enum { SNDCP_PEER_NORMAL, SNDCP_PEER_SWITCHED } T_SNDCP_PEER; typedef enum { GCTT_NORMAL = 0, GCTT_REACTIVATION } T_GPRS_CALL_TABLE_TYPE; /*==== TYPES ======================================================*/ typedef struct { UBYTE len; UBYTE pco[251]; } T_GPRS_CONT_PCO; typedef struct { T_CONTEXT_STATE state; UBYTE nsapi; UBYTE smreg_ti; T_DTI_CONN_LINK_ID link_id_sn; T_DTI_CONN_LINK_ID link_id_uart; T_DTI_CONN_LINK_ID link_id_new; T_DTI_ENTITY_ID entity_id; T_GPRS_CONT_REC con; T_QOS qos; T_PDP_ADDRESS allocated_pdp_addr; T_ACI_CMD_SRC owner; T_GPRS_CONT_PCO user_pco; /* setup with %CGPCO=... */ T_GPRS_CONT_PCO network_pco; /* setup with SMREG_PDP_ACTIVATE_CNF */ } T_GPRS_CONT_CLASS; typedef struct { T_SMREG_PDP_ACTIVATE_IND sm_ind; char L2P[MAX_L2P_LENGTH]; SHORT cid; UBYTE reactivation; /* T_GPRS_CALL_TABLE_TYPE */ } T_GPRS_CALL_TABLE; typedef enum /* GPRS Packet Data Protocol type */ { PDP_T_NONE = 0, /* no valid PDP type */ PDP_T_X25, /* ITU-T/CCITT X.25 layer 3 */ PDP_T_IP, /* Internet Protocol (IETF STD 5) */ PDP_T_MAX /* maximum GPRS PDP types */ } T_GACI_PDP_TYPE; #ifdef CO_UDP_IP typedef void T_SM_IP_CB (T_ACI_RETURN result); #endif /* WAP || SAT E */ /*==== PROTOTYPES =================================================*/ EXTERN void cmhSM_NetDeactivate ( void ); EXTERN void cmhSM_Deactivated ( void ); EXTERN void cmhSM_NetActivate ( void ); EXTERN SHORT cmhSM_NoActivate ( void ); EXTERN SHORT cmhSM_Activated ( T_SMREG_PDP_ACTIVATE_CNF *pdp_cnf ); EXTERN void cmhSM_NetModify ( USHORT nsapi_set, T_smreg_qos *qos ); EXTERN void cmhSM_Init ( void ); EXTERN void cmhSM_Reset ( void ); EXTERN void cmhSM_ResetNonWorkingContexts( void ); EXTERN void cmhSM_empty_call_table ( void ); EXTERN void cmhSM_GiveNSapiFree ( USHORT cid ); EXTERN void cmhSM_contextDeactivated ( void ); EXTERN USHORT cmhSM_pdp_typ_to_string ( UBYTE pdp_typ_no, char* string ); EXTERN UBYTE cmhSM_Get_pdp_type ( void ); EXTERN void cmhSM_Get_pdp_address ( T_pdp_address *pdp_address ); EXTERN SHORT cmhSM_pdp_address_to_ip ( T_PDP_ADDRESS *pdp_address, UBYTE *ip ); EXTERN void cmhSM_ip_to_pdp_address ( UBYTE *ip, T_PDP_ADDRESS pdp_address ); EXTERN void cmhSM_Get_smreg_apn ( T_smreg_apn *smreg_apn ); EXTERN UBYTE cmhSM_Get_h_comp ( void ); EXTERN UBYTE cmhSM_Get_d_comp ( void ); EXTERN void cmhSM_change_def_QOS ( T_QOS *qos ); EXTERN void cmhSM_change_def_QOS_min ( T_QOS *qos ); EXTERN void cmhSM_Set_default_QOS ( SHORT cid ); EXTERN void cmhSM_Set_default_QOS_min ( SHORT cid ); EXTERN void cmhSM_Get_QOS ( T_smreg_qos *dest_qos ); EXTERN void cmhSM_Get_QOS_min ( T_smreg_min_qos *dest_qos_min ); EXTERN char* cmhSM_ring_gprs_par ( void ); EXTERN BOOL cmhSM_call_answer ( UBYTE ring_counter, T_ACI_CRING_MOD mode ); EXTERN BOOL cmhSM_call_reject ( UBYTE ring_counter, T_ACI_CRING_MOD mode ); EXTERN BOOL cmhSM_sAT_H ( T_ACI_CMD_SRC srcId, T_ACI_RETURN *aci_ret ); EXTERN BOOL cmhSM_sAT_A ( T_ACI_CMD_SRC srcId, T_ACI_RETURN *aci_ret ); EXTERN USHORT cmhSM_Give_nsapi_set ( SHORT cid ); EXTERN BOOL cmhSM_pdp_addr_well_formed( USHORT type, T_PDP_ADDRESS pdp_addr ); EXTERN BOOL cmhSM_apn_well_formed ( T_APN apn ); EXTERN USHORT cmhSM_transform_pdp_type ( char *pdp_type ); EXTERN void cmhSM_cgerep_buffer ( void ); EXTERN void cmhSM_save_event ( T_CGEREP_EVENT event, T_CGEREP_EVENT_REP_PARAM *param ); EXTERN void cmhSM_set_sms_service ( T_CGSMS_SERVICE service ); EXTERN void cmhSM_sms_service_changed ( UBYTE service ); EXTERN SHORT cmhSM_get_cid ( USHORT nsapi ); EXTERN BOOL cmhSM_next_work_cid ( T_ACI_AT_CMD curCmd ); EXTERN SHORT cmhSM_define_cid_list ( T_ACI_CMD_SRC srcId, SHORT *cids ); EXTERN SHORT cmhSM_get_pdp_addr_for_CGPADDR ( SHORT cid, T_PDP_ADDRESS pdp_adress ); EXTERN T_ACI_RETURN cmhSM_GprsAttached ( SHORT state ); EXTERN T_ACI_RETURN cmhSM_activate_context (void); EXTERN void cmhSM_data_link_context (void); #ifdef DTI EXTERN SHORT cmhSM_connect_context ( SHORT cid, T_DTI_ENTITY_ID peer, UBYTE ppp_hc, UBYTE msid ); #endif /* DTI */ EXTERN SHORT cmhSM_context_connected ( USHORT nsapi); EXTERN BOOL cmhSM_is_smreg_ti_used ( UBYTE smreg_ti, SHORT *cid ); EXTERN void cmhSM_context_reactivation ( void ); EXTERN void cmhSM_stop_context_reactivation ( void ); EXTERN void cmhSM_next_call_table_entry ( void ); EXTERN SHORT cmhSM_connect_working_cid ( void ); EXTERN void cmhSM_set_PCO( SHORT cid, T_PCO_TYPE pco_type, UBYTE* buf_addr, UBYTE length); #if defined (CO_UDP_IP) || defined (FF_GPF_TCPIP) EXTERN void cmhSM_IP_activate_cb (T_ACI_RETURN result); EXTERN void cmhSM_IP_Enable (T_DTI_CONN_LINK_ID link_id ); EXTERN void cmhSM_IP_Disable (void); #endif /* CO_UDP_IP || FF_GPF_TCPIP */ /* execution AT set command without parameter check */ EXTERN void sAT_PlusCGDCONT_exec ( T_ACI_CMD_SRC srcId, SHORT cid, T_GPRS_CONT_REC *inputCtxt); EXTERN ULONG cmhSM_get_link_id_SNDCP_peer ( SHORT cid, T_SNDCP_PEER which ); EXTERN void cmhSM_context_deactivated ( USHORT nsapi_set ); EXTERN void cmhSM_connection_down ( UBYTE dti_id ); EXTERN T_ACI_CMD_SRC cmhSM_getSrcIdOfRunningCGACTDeactivation(SHORT cid); EXTERN BOOL isContextDeactivationRequestedByCGACT(SHORT cid); EXTERN T_ACI_RETURN cmhSM_deactivateContexts ( T_ACI_CMD_SRC srcId, SHORT *cids); EXTERN T_ACI_RETURN cmhSM_deactivateAContext ( T_ACI_CMD_SRC srcId, SHORT cid ); #ifdef DTI EXTERN void cmhSNDCP_Disable ( T_DTI_CONN_LINK_ID link_id ); #endif /* DTI */ EXTERN void cmhSM_ip_to_pdp_address ( UBYTE *ip, T_PDP_ADDRESS pdp_address ); #ifdef FF_SAT_E EXTERN T_QOS* cmhSM_getCurQOS ( SHORT cid ); #endif /* FF_SAT_E */ EXTERN BOOL cmhSM_isContextActive ( void ); #ifdef DTI EXTERN void set_conn_param_on_working_cid ( UBYTE owner, T_DTI_ENTITY_ID entity_id ); EXTERN void set_conn_param_on_all_working_cids ( UBYTE owner, T_DTI_ENTITY_ID entity_id ); #endif /* DTI */ /*==== EXPORT =====================================================*/ #ifdef CMH_SMF_C GLOBAL T_ENT_STAT smEntStat; T_GPRS_CONT_CLASS pdp_context[MAX_CID]; SHORT work_cids[MAX_CID_PLUS_EINS]; SHORT cid_pointer; T_GPRS_CONT_REC defaultCtx; SHORT automatic_response_mode; /* network requested context activation */ T_GPRS_CALL_TABLE gprs_call_table[MAX_GPRS_CALL_TABLE_ENTRIES]; SHORT current_gprs_ct_index; SHORT gprs_ct_index; T_CGSMS_SERVICE sm_cgsms_service; #else EXTERN T_ENT_STAT smEntStat; EXTERN T_GPRS_CONT_CLASS pdp_context[MAX_CID]; EXTERN SHORT work_cids[MAX_CID_PLUS_EINS]; EXTERN SHORT cid_pointer; EXTERN T_GPRS_CONT_REC defaultCtx; EXTERN SHORT automatic_response_mode; /* network requested context activation */ EXTERN T_GPRS_CALL_TABLE gprs_call_table[MAX_GPRS_CALL_TABLE_ENTRIES]; EXTERN SHORT current_gprs_ct_index; EXTERN SHORT gprs_ct_index; EXTERN T_CGSMS_SERVICE sm_cgsms_service; #endif /* CMH_SMF_C */ #endif /* CMH_SM_H */ #endif /* GPRS */ /*==== EOF =======================================================*/