FreeCalypso > hg > fc-selenite
diff src/cs/layer1/tm_include/l1tm_defty.h @ 0:b6a5e36de839
src/cs: initial import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 15 Jul 2018 04:39:26 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/cs/layer1/tm_include/l1tm_defty.h Sun Jul 15 04:39:26 2018 +0000 @@ -0,0 +1,169 @@ +/************* Revision Controle System Header ************* + * GSM Layer 1 software + * L1TM_DEFTY.H + * + * Filename l1tm_defty.h + * Copyright 2003 (C) Texas Instruments + * + ************* Revision Controle System Header *************/ + + +// Max size of data portion of a testmode packet +#define TM_PAYLOAD_UPLINK_SIZE_MAX 128 + +// CID, STATUS and CHECKSUM +#define TM_UPLINK_PACKET_OVERHEAD 3 + +typedef struct +{ + UWORD32 toa_sum; + UWORD32 toa_sq_sum; + UWORD32 toa_recent; + UWORD32 pm_sum; + UWORD32 pm_sq_sum; + UWORD16 pm_recent; + WORD16 angle_sum; + UWORD32 angle_sq_sum; + WORD16 angle_min; + WORD16 angle_max; + WORD16 angle_recent; + UWORD32 snr_sum; + UWORD32 snr_sq_sum; + UWORD32 snr_recent; + UWORD8 rssi_fifo[4]; + UWORD8 rssi_recent; + WORD32 loop_count; //Must be signed for divide operation in statistics!!! + WORD32 flag_count; //Must be signed for divide operation in statistics!!! + UWORD32 flag_recent; + UWORD8 bsic; + UWORD32 fn; + UWORD32 qual_acc_full; // Fullset: accu. rxqual meas. + UWORD32 qual_nbr_meas_full; // Fullset: nbr meas. of rxqual. + #if L1_GPRS + UWORD8 nb_dl_pdtch_slots; + #endif +} +T_TM_STATS; + +typedef struct +{ + UWORD8 dedicated_active; + UWORD32 rx_counter; + UWORD16 num_bcchs; + #if L1_GPRS + BOOL packet_transfer_active; + #endif +} +T_TM_STATE; + +typedef struct +{ + UWORD16 prbs1_seed; + // UWORD16 prbs2_seed; //for future use +} +T_TM_PRBS; + +// Global TM variable +typedef struct +{ + BOOL tm_msg_received; + T_TM_STATS tmode_stats; + T_TM_STATE tmode_state; + T_TM_PRBS tmode_prbs; +} +T_L1TM_GLOBAL; + +typedef struct +{ + UWORD16 bcch_arfcn; + UWORD16 tch_arfcn; + UWORD16 mon_arfcn; + #if L1_GPRS + UWORD16 pdtch_arfcn; + UWORD8 multislot_class; + #endif + UWORD8 down_up; + UWORD8 channel_type; + UWORD8 subchannel; + UWORD8 tmode_continuous; + UWORD8 reload_ramps_flag; + BOOL mon_report; //Used to determine wether RX stats are done in Monitor channel or TCH channel + BOOL mon_tasks; //Used to enable tasks associated with Monitor Channel +} +T_TM_RF_PARAMS; + +typedef struct +{ + UWORD8 slot_num; + WORD8 agc; + WORD8 lna_off; + UWORD8 number_of_measurements; + UWORD8 place_of_measurement; + BOOL pm_enable; + UWORD8 rssi_band; + #if L1_GPRS + UWORD8 timeslot_alloc; + UWORD8 coding_scheme; + #endif +} +T_TM_RX_PARAMS; + +typedef struct +{ + UWORD8 tsc; + UWORD8 txpwr; + UWORD8 txpwr_skip; + UWORD8 timing_advance; + UWORD8 burst_type; + UWORD8 burst_data; + #if L1_GPRS + UWORD8 timeslot_alloc; + UWORD8 txpwr_gprs[8]; + UWORD8 coding_scheme; + UWORD8 rlc_buffer_size; + UWORD16 rlc_buffer[27]; + #endif +} +T_TM_TX_PARAMS; + +typedef struct +{ + UWORD32 num_loops; + UWORD32 auto_result_loops; + UWORD32 auto_reset_loops; + UWORD8 stat_type; + UWORD16 stat_bitmask; + #if L1_GPRS + UWORD8 stat_gprs_slots; + #endif +} +T_TM_STATS_CONFIG; + +typedef struct +{ + T_TM_RF_PARAMS rf_params; + T_TM_RX_PARAMS rx_params; + T_TM_TX_PARAMS tx_params; + T_TM_STATS_CONFIG stats_config; +} +T_TM_PARAMS; + +typedef struct +{ + UWORD8 cid; + UWORD8 index; + UWORD8 status; + UWORD16 size; // size of result[] array + UWORD8 result[TM_PAYLOAD_UPLINK_SIZE_MAX]; +} +T_TM_RETURN; + +typedef struct +{ + UWORD8 cid; + UWORD8 index; + UWORD8 status; + UWORD16 size; // size of result[] array + UWORD8 result[5]; +} +T_TM_RETURN_ABBREV;