FreeCalypso > hg > fc-selenite
view src/g23m-gprs/gmm/gmm_em.h @ 192:4f40ae165be4
abb.c & init.c: sync with Magnetite for Luna additions
These Luna target-specific additions are conditionalized on CONFIG_TARGET_LUNA,
a C preprocessor symbol that will never be defined in Selenite, hence this
change has exactly zero impact on FC Selenite. However, they are being pulled
in as a sync in order to keep the diff between Magnetite and Selenite to a
minimum; keeping this diff to a minimum increases our opportunities for
possible evolution of future FC firmwares.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sat, 23 May 2020 07:03:46 +0000 |
parents | d393cd9bb723 |
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 : Engineering Mode (EM) Declarations + Macros | +----------------------------------------------------------------------------- */ #ifndef GMM_EM_H #define GMM_EM_H #ifdef FF_EM_MODE /*also defined in rr_em.h*/ /* * buffer size has been chosen to store ten state events for now. */ #define EM_GMM_BUFFER_SIZE 5 /* * EM_MAX_GMM_EVENTS defines maximum number of event traces for the engineering * mode. The number is increased by one to ensure that the event numbers * defined in the corresponding document are the same as in the sources. */ #define EM_MAX_GMM_EVENTS 2 /* * The offset is used to indicate the source entity the event trace is from. * L1/ALR = 0x00, DL = 0x2D, GRLC = 0x33, RR = 0x37, MM = 0x64, CC = 0x78, * GMM=0xAA, GRR=0xAC, SS = 0xAF, SMS = 0xBE, SIM = E1 */ #define GMM_OFFSET 0xAA #define TRACE_EVENT_EM_P8(s,a1,a2,a3,a4,a5,a6,a7,a8) TRACE_USER_CLASS_P8(TC_USER8,s,a1,a2,a3,a4,a5,a6,a7,a8) #define GMM_EM_NULL_STATE 0x0 #define GMM_EM_DEREG_STATE 0x1 #define GMM_EM_REG_INIT_STATE 0x2 #define GMM_EM_REG_STATE 0x3 #define GMM_EM_RAU_INIT_STATE 0x4 #define GMM_EM_DEREG_INIT_STATE 0x5 #define GMM_EM_NORMAL_SRVC_SUBSTATE 0x0 #define GMM_EM_NO_CELL_SUBSTATE 0x1 #define GMM_EM_SUSPENDED_SUBSTATE 0x2 #define GMM_EM_ATTEMPT_TO_ATT_SUBSTATE 0x3 #define GMM_EM_ATT_NEEDED_SUBSTATE 0x4 #define GMM_EM_STATUS_IND_SUBSTATE 0x5 #define GMM_EM_IMSI_DETACH_INIT_SUBSTATE 0x6 #define GMM_EM_ATTEMPT_TO_UPDATE_MM_SUBSTATE 0x7 #define GMM_EM_ATTEMPT_TO_UPDATE_SUBSTATE 0x8 #define GMM_EM_UPDATE_NEEDED_SUBSTATE 0x9 #define GMM_EM_POWER_OFF_SUBSTATE 0xA #define GMM_V_1 (1+GMM_OFFSET) #define TRACE_EVENT_EM_P2(s,a1,a2) TRACE_USER_CLASS_P2(TC_USER8,s,a1,a2) #define GMM_V_1 (1+GMM_OFFSET) EXTERN void em_gmm_pco_trace_req ( T_EM_PCO_TRACE_REQ *em_pco_trace_req); EXTERN BOOL gmm_v[EM_MAX_GMM_EVENTS]; EXTERN UBYTE em_gmm_event_buffer[EM_GMM_BUFFER_SIZE]; EXTERN UBYTE em_gmm_buffer_write; EXTERN void em_gmm_sc_gprs_info_req ( T_EM_SC_GPRS_INFO_REQ *em_sc_gprs_info_req); EXTERN void em_gmm_sc_gprs_info_cnf ( T_EM_SC_GPRS_INFO_CNF *em_sc_gprs_info_cnf); EXTERN void em_gmm_info_req ( T_EM_GMM_INFO_REQ *em_gmm_info_req); EXTERN void em_gmm_grlc_info_cnf ( T_EM_GRLC_INFO_CNF *em_grlc_info_cnf); EXTERN void em_gmm_grlc_info_req ( T_EM_GRLC_INFO_REQ *em_grlc_info_req); #define EM_GMM_SET_STATE(s) \ {\ UBYTE gmm_main_state, gmm_sub_state;\ em_gmm_map_state(s,&gmm_main_state,&gmm_sub_state);\ if (gmm_v[1])\ {\ gmm_v[1] = em_write_buffer_4 (GMM_V_1,gmm_main_state,gmm_sub_state);\ } \ } EXTERN void em_gmm_throughput_info_req ( T_EM_THROUGHPUT_INFO_REQ *em_throughput_info_req); EXTERN void em_gmm_throughput_info_cnf ( T_EM_THROUGHPUT_INFO_CNF *em_throughput_info_cnf); EXTERN void em_gmm_grr_event_req ( T_EM_GRR_EVENT_REQ *em_grr_event_req); EXTERN void em_gmm_grlc_event_req( T_EM_GRLC_EVENT_REQ *em_grlc_event_req); EXTERN void em_gmm_data_ind ( T_EM_DATA_IND *em_data_ind); EXTERN void em_init_gmm_event_trace (void); #ifdef OPTION_MULTITHREAD #define em_write_buffer_4 _ENTITY_PREFIXED(em_write_buffer_4) #define check_write_index _ENTITY_PREFIXED(check_write_index) #endif /*OPTION_MULTITHREAD*/ EXTERN UBYTE em_write_buffer_4 (UBYTE event_no, UBYTE value1, UBYTE value2); EXTERN void em_gmm_event_req (T_EM_GMM_EVENT_REQ *em_gmm_event_req); #else #define EM_GMM_SET_STATE /* Event 1*/ #endif /* FF_EM_MODE */ #endif /* GMM_EM_H */