FreeCalypso > hg > freecalypso-citrine
view L1/cust1/l1_rf61.h @ 46:38cf7fa65976
sprintf/float.c: rounding corner case bug
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 29 Sep 2017 03:23:01 +0000 |
parents | 75a11d740a02 |
children |
line wrap: on
line source
/************* Revision Controle System Header ************* * GSM Layer 1 software * * Filename l1_rf61.h * Version 1.0 * Date June 16th, 2005 * ************* Revision Controle System Header *************/ #ifndef __L1_RF_H__ #define __L1_RF_H__ #if (ANLG_FAM == 11) #include "bspTwl3029_Madc.h" #endif #define RF_LOCOSTO 0x2050 // Check with TIDK //LNA Specific BAND Index Settings #define RF_QUADBAND 0 //Default Setting 850, EGSM,DCS,PCS #define RF_EU_TRIBAND 1 // EGSM,DCS,PCS #define RF_EU_DUALBAND 2 // EGSM,DCS #define RF_US_TRIBAND 3 // 850,DCS,PCS #define RF_US_DUALBAND 4 //850, PCS #define RF_PCS1900_900_DUALBAND 5 // EGSM, PCS #define RF_DCS1800_850_DUALBAND 6 //850, DCS #define RF_BAND_SYSTEM_INDEX RF_QUADBAND //for other PCB's Please redefine here. #define RF_LNA_MASK 0x0003 // Reuse last 2 bits from //End LNA Changes //#define RF_HW_BAND_EGSM //#define RF_HW_BAND_DCS #define RF_HW_BAND_PCS 0x4 #define RF_HW_BAND_DUAL_US 0x80 #define RF_HW_BAND_DUAL_EXT 0x20 #define RF_HW_BAND_SUPPORT (RF_HW_BAND_DUAL_EXT) /************************************/ /* SYNTHESIZER setup time... */ /************************************/ #define RX_SYNTH_SETUP_TIME (PROVISION_TIME - TRF_R1) //RX Synthesizer setup time in qbit. #define TX_SYNTH_SETUP_TIME (- TRF_T1) //TX Synthesizer setup time in qbit. /************************************/ /* Time for TPU scenario ending... */ /************************************/ // // The following values are used to take into account any TPU activity AFTER // BDLON (or BDLENA) down (for RX) and BULON down (for TX) // - If there are no TPU commands after BDLON (or BDLENA) down and BULON down, // these defines must be ZERO // - If there IS some TPU command after BDLON (or BDLENA) and BULON down, // these defines must be equal to the time difference (in qbits) between // the BDLON (or BDLENA) or BULON time and the last TPU command on // the TPU scenario #define RX_TPU_SCENARIO_ENDING 6 // execution time of AFTER BDLENA down last value : 0 #define TX_TPU_SCENARIO_ENDING 0 // execution time of AFTER BULON down last value : 14 /******************************************************/ /* TXPWR configuration... */ /* Fixed TXPWR value when GSM management is disabled. */ /******************************************************/ #if ( ANLG_FAM == 11) #define FIXED_TXPWR 0x5C // TXPWR=500 for the moment...change later TEMP_FIX #endif /************************************/ /* RF delay (in qbits) */ /************************************/ #define DL_DELAY_RF 0 // time spent in the Downlink global RF chain by the modulated signal #define UL_DELAY_1RF 0 // time spent in the first uplink RF block #define UL_DELAY_2RF 0 // time spent in the second uplink RF block #define UL_ABB_DELAY 12 // 12 for RF output DELAY #define GUARD_BITS 5 /************************************/ /* TX Propagation delay... */ /************************************/ #define PRG_TX (DL_DELAY_RF + UL_DELAY_2RF + (GUARD_BITS*4) + UL_DELAY_1RF + UL_ABB_DELAY) // = 50 /************************************/ /* Initial value for APC DELAY */ /************************************/ #define APCDEL_DOWN (0) // To add this value, the setup delay minimum value: 2 last value : 0 //SG #define APCDEL_UP (12) #define APCDEL_UP (0) //To add this value, the setup delay minimum value: 6 #define C_APCDEL1 (((APCDEL_DOWN & 0x1f)<<5) |(APCDEL_UP & 0x1f) ) #define C_APCDEL2 (((APCDEL_DOWN & 0x3e0)) |((APCDEL_UP>>5) & 0x1f) ) /************************************/ /* Initial value for AFC... */ /************************************/ #define EEPROM_AFC ((150)*8) // F14.2 required!!!!! (default : -952*8, initial deviation of -2400 forced) #if(CHIPSET == 15) #define SETUP_AFC_AND_RF 0 #else #define SETUP_AFC_AND_RF 6 // AFC converges in 2 frames and RF BAND GAP stable after 4 frames #endif #define C_DRP_DCXO_XTAL_DSP_ADDRESS 0x7F80 // DRP DCXO XTAL DSP address /************************************/ /* DCO Registers Initialization */ /************************************/ #define C_DCO_SAMPLES_PER_SYMBOL 1 /* The basic frequency table in DSP is approximately 2.115KHz (26MHZ/(512*24)) * The FCW value needs to intended IF Frequency / 2.115KHZ. * Hence since IF is 100KFZ, FCW = 100 / 2.115 ~= 47 */ #define C_DCO_FCW 47 /*************************************************************** * Threshold between LIF_100 KHZ (at high power levels) and * LIF_120KHz (at low power level) * the threshold defintion for GSM and GPRS is as given below * ************************************************************ */ #define C_IF_ZERO_LOW_THRESHOLD_GSM 180 // if IL < -90dbm use Zero IF else Low IF STd L1 format #define C_IF_ZERO_LOW_THRESHOLD_GPRS 180 // if IL < -90dbm use Zero IF else Low IF STd L1 format /* Since CSF filter coefficients are changed in accordance with GENIE * algorithm, below are values programmed in DRP to select HW/SW CSF filter */ #define CSF_CWL_HARDWARE_FILTER_64TAP 0x0100 #define CSF_CWL_PROGRAMMABLE_FILTER_64TAP 0x0000 /* Below are the attenuation losses to be compensated for LIF_100KHZ and LIF_120KHZ Path * !!!! Note: The below attenuations are applicable when ROC is enabled !!!! */ #define SCF_ATTENUATION_LIF_100KHZ (0) /* value of 0 represents 0dB attenuation as per L1 F7.1 format */ #define SCF_ATTENUATION_LIF_120KHZ (1) /* value of 1 represents 0.5dB attenuation */ #define SCF_ATTENUATION_ZIF (0) /* No attenuation when ZIF mode is used */ /************************************/ /* DRP Retiming Related */ /************************************/ #define C_RETIMING_DISABLED 0x0 #define C_RETIMING_ENABLED 0x1 #define C_RETIMING_CONFIG C_RETIMING_DISABLED /*************************************/ /* DRP WRAPPER Initialization */ /*************************************/ #define C_APCCTRL2 0x05C8 // BGEN=1, APCOFF=64, APC_LDO_EN=0, MODE=0 // SG #define C_APCCTRL2 0x01FC #define DRP_DBB_RX_IRQ_COUNT 16 #define TTY_L1_STANDALONE 0 /************************************/ /* Triton audio initialize */ /************************************/ #if (ANLG_FAM == 11) #if (TTY_L1_STANDALONE == 1) #define C_VULGAIN 0x10 // -12dB // #define C_VULGAIN 0x09 // voice uplink gain set to 7dB #define C_SIDETONE 0x0d // -23dB // #define C_SIDETONE 0x0f // side tone set to MUTE #define C_VDLGAIN 0x4c // // #define C_VDLGAIN 0x2c // set PGA gain to 2dB #define C_CTRL1 0x30 // MicBias = 1, DL Filter Bypass // #define C_CTRL1 0x00 // VSYNC = 1, reset Dig Modulator, VSP, Digital filter #define C_CTRL2 0x10 // // #define C_CTRL2 0x00 // reset value #define C_CTRL3 0x25 // MIC IN (diff), MICIP, MICIN. Amplifier: MIC AMP, Gain = 25.6 dB, SPKAMP = +2.5 dB #define C_CTRL4 0x00 // reset value #define C_CTRL5 0x28 // SAMP FREQ = 48Khz, EARAMP = 1 dB #define C_CTRL6 0x00 // reset value #define C_POPAUTO 0x01 // POPmode set to/Automatic mode #define C_OUTEN1 0x12 // Audio left/Audio Mono, Audio Right/ Audio mono #define C_OUTEN2 0x05 // EAR= voice speech, AUXO = voice speech #define C_OUTEN3 0x01 // SPK = voice speech #define C_AULGA 0x00 // reset value #define C_AURGA 0x00 // reset value #else #define C_VULGAIN 0x09 // voice uplink gain set to 7dB #define C_SIDETONE 0x06 // side tone set to MUTE #define C_VDLGAIN 0x2c // set PGA gain to 2dB #define C_CTRL1 0x00 // VSYNC = 1, reset Dig Modulator, VSP, Digital filter #define C_CTRL2 0x00 // reset value #define C_CTRL3 0x21 // MIC IN (diff), MICIP, MICIN. Amplifier: MIC AMP, Gain = 25.6 dB, SPKAMP = +2.5 dB #define C_CTRL4 0x00 // reset value #define C_CTRL5 0x28 // SAMP FREQ = 48Khz, EARAMP = 1 dB #define C_CTRL6 0x00 // reset value #define C_POPAUTO 0x01 // POPmode set to/Automatic mode #define C_OUTEN1 0x24 // Audio left/Audio Mono, Audio Right/ Audio mono #define C_OUTEN2 0x01 // EAR= voice speech, AUXO = voice speech #define C_OUTEN3 0x01 // SPK = voice speech #define C_AULGA 0x00 // reset value #define C_AURGA 0x00 // reset value #endif //(L1_GTT == 1) #endif //(ANLG_FAM == 11) /************************************/ /* Automatic frequency compensation */ /************************************/ /********************* C_Psi_sta definition *****************************/ /* C_Psi_sta = (2*pi*Fr) / (N * Fb) */ /* (1) = (2*pi*V*ppm*0.9) / (N*V*Fb) */ /* regarding Vega V/N = 2.4/4096 */ /* regarding VCO ppm/V = 16 / 1 (average slope of the VCO) */ /* (1) = (2*pi*2.4*16*0.9) / (4096*1*270.83) */ /* = 0.000195748 */ /* C_Psi_sta_inv = 1/C_Psi_sta = 5108 */ /************************************************************************/ #define C_Psi_sta_inv 6142L // 12902L // (1/C_Psi_sta) #define C_Psi_st 9L // 4L // C_Psi_sta * 0.8 F0.16 #define C_Psi_st_32 559386L // 266313L // F0.32 #define C_Psi_st_inv 7678L // 16128L // (1/C_Psi_st) #if (VCXO_ALGO == 1) // Linearity parameters #define C_AFC_DAC_CENTER ((4264)) //((-1242)*8) #define C_AFC_DAC_MIN ((-11128)) //((-2000)*8) #define C_AFC_DAC_MAX ((19656)) //((1419)*8) #define C_AFC_SNR_THR 2560 // 1/0.4 * 2**10 #endif typedef struct { WORD16 eeprom_afc; UWORD32 psi_sta_inv; UWORD32 psi_st; UWORD32 psi_st_32; UWORD32 psi_st_inv; #if (VCXO_ALGO) // VCXO adjustment parameters // Parameters used when assuming linearity WORD16 dac_center; WORD16 dac_min; WORD16 dac_max; WORD16 snr_thr; #endif } T_AFC_PARAMS; /************************************/ /* Swap IQ definitions... */ /************************************/ /* 0=No Swap, 1=Swap RX only, 2=Swap TX only, 3=Swap RX and TX */ #define SWAP_IQ_GSM 0 #define SWAP_IQ_DCS 0 #define SWAP_IQ_PCS 0 #define SWAP_IQ_GSM850 0 // Swap TX compared to GSM 900 #define LNA_OFF (1) #define LNA_ON (0) /************************************/ /************************************/ // typedef /************************************/ /************************************/ /*************************************************************/ /* Define structure for apc of TX Power ******/ /*************************************************************/ typedef struct { // pcm-file "rf/tx/level.gsm|dcs" UWORD16 apc; // 0..31 UWORD8 ramp_index; // 0..RF_TX_RAMP_SIZE UWORD8 chan_cal_index; // 0..RF_TX_CHAN_CAL_TABLE_SIZE } T_TX_LEVEL; /************************************/ /* Automatic Gain Control */ /************************************/ /* Define structure for sub-band definition of TX Power ******/ typedef struct { UWORD16 upper_bound; //highest physical arfcn of the sub-band WORD16 agc_calib; // AGC for each TXPWR } T_RF_AGC_BAND; /************************************/ /* Ramp definitions */ /************************************/ typedef struct { UWORD8 ramp_up [20]; // Ramp-up profile UWORD8 ramp_down [20]; // Ramp-down profile } T_TX_RAMP; // RF structure definition //======================== #if (L1_FF_MULTIBAND == 0) // Number of bands supported #define GSM_BANDS 2 #define MULTI_BAND1 0 #define MULTI_BAND2 1 #else #endif // RF table sizes #define RF_RX_CAL_CHAN_SIZE 10 // number of AGC sub-bands #define RF_RX_CAL_TEMP_SIZE 11 // number of temperature ranges #define RF_TX_CHAN_CAL_TABLE_SIZE 4 // channel calibration table size #define RF_TX_NUM_SUB_BANDS 8 // number of sub-bands in channel calibration table #define RF_TX_LEVELS_TABLE_SIZE 32 // level table size #define RF_TX_RAMP_SIZE 16 // number of ramp definitions #define RF_TX_CAL_TEMP_SIZE 5 // number of temperature ranges #define AGC_TABLE_SIZE 24 #define MIN_AGC_INDEX 0 // size step for AGC table #define TEMP_TABLE_SIZE 131 // number of elements in ADC->temp conversion table #if (REL99 && FF_PRF) #define MAX_UPLINK_TIME_SLOT 4 // max number of time slot in uplink #endif // RX parameters and tables //------------------------- // AGC parameters and tables typedef struct { UWORD16 low_agc_noise_thr; UWORD16 high_agc_sat_thr; UWORD16 low_agc; UWORD16 high_agc; UWORD8 il2agc_pwr[121]; UWORD8 il2agc_max[121]; UWORD8 il2agc_av[121]; } T_AGC; // Calibration parameters typedef struct { UWORD16 g_magic; UWORD16 lna_att; UWORD16 lna_switch_thr_low; UWORD16 lna_switch_thr_high; } T_RX_CAL_PARAMS; // RX temperature compensation typedef struct { WORD16 temperature; WORD16 agc_calib; } T_RX_TEMP_COMP; // RF RX structure typedef struct { T_AGC agc; } T_RF_RX; //common // RF RX structure typedef struct { T_RX_CAL_PARAMS rx_cal_params; T_RF_AGC_BAND agc_bands[RF_RX_CAL_CHAN_SIZE]; T_RX_TEMP_COMP temp[RF_RX_CAL_TEMP_SIZE]; } T_RF_RX_BAND; // TX parameters and tables //------------------------- // TX temperature compensation typedef struct { WORD16 temperature; #if (ORDER2_TX_TEMP_CAL==1) WORD16 a; WORD16 b; WORD16 c; #else WORD16 apc_calib; #endif } T_TX_TEMP_CAL; // Ramp up and ramp down delay typedef struct { UWORD16 up; UWORD16 down; } T_RAMP_DELAY; typedef struct { UWORD16 arfcn_limit; WORD16 chan_cal; } T_TX_CHAN_CAL; // RF TX structure typedef struct { T_RAMP_DELAY ramp_delay; UWORD8 guard_bits; // number of guard bits needed for ramp up UWORD8 prg_tx; } T_RF_TX; //common // RF TX structure typedef struct { T_TX_LEVEL levels[RF_TX_LEVELS_TABLE_SIZE]; #if (REL99 && FF_PRF) T_TX_LEVEL levels_power_reduction[MAX_UPLINK_TIME_SLOT]; #endif T_TX_CHAN_CAL chan_cal_table[RF_TX_CHAN_CAL_TABLE_SIZE][RF_TX_NUM_SUB_BANDS]; T_TX_RAMP ramp_tables[RF_TX_RAMP_SIZE]; T_TX_TEMP_CAL temp[RF_TX_CAL_TEMP_SIZE]; } T_RF_TX_BAND; // band structure typedef struct { T_RF_RX_BAND rx; T_RF_TX_BAND tx; UWORD8 swap_iq; } T_RF_BAND; // RF structure typedef struct { // common for all bands UWORD16 rf_revision; UWORD16 radio_band_support; T_RF_RX rx; T_RF_TX tx; T_AFC_PARAMS afc; } T_RF; /************************************/ /* MADC definitions */ /************************************/ // TRITON: 5 external channels enum ADC_INDEX { ADC_ADIN1, ADC_ADIN2, ADC_ADIN3, ADC_BATT_TYPE, ADC_BTEMP, ADC_USBVBUS , ADC_VBKP, ADC_ICHG, ADC_VCHG, ADC_VBAT, ADC_HOTDIE , ADC_RFTEMP, ADC_INDEX_END // ADC_INDEX_END must be the end of the enums }; typedef struct { WORD16 converted[ADC_INDEX_END]; // converted UWORD16 raw[ADC_INDEX_END]; // raw from ADC } T_ADC; /************************************/ /* MADC calibration */ /************************************/ typedef struct { UWORD16 a[ADC_INDEX_END]; WORD16 b[ADC_INDEX_END]; } T_ADCCAL; // Conversion table: ADC value -> temperature typedef struct { UWORD16 adc; // ADC reading is 10 bits WORD16 temp; // temp is in approx. range -30..+80 } T_TEMP; typedef struct { char *name; void *addr; int size; } T_CONFIG_FILE; #if (L1_FF_MULTIBAND == 0) typedef struct { char *name; // name of ffs file suffix T_RF_BAND *addr; // address to default flash structure UWORD16 max_carrier; // max carrier UWORD16 max_txpwr; // max tx power } T_BAND_CONFIG; typedef struct { UWORD8 band[GSM_BANDS]; // index to band address UWORD8 txpwr_tp; // tx power turning point UWORD16 first_arfcn; // first index } T_STD_CONFIG; enum GSMBAND_DEF { BAND_NONE, BAND_EGSM900, BAND_DCS1800, BAND_PCS1900, BAND_GSM850, // put new bands here BAND_GSM900 //last entry }; #endif // L1_FF_MULTIBAND == 0 /************************************/ /* ABB (TRITON) Initialization */ /************************************/ /* ABB_TABLE_SIZE definitions for Triton */ #if (ANLG_FAM == 11) #define ABB_TABLE_SIZE 15 #endif /* ABB enum definitions for TRITON */ #if (ANLG_FAM == 11) enum ABB_REGISTERS { ABB_VULGAIN = 0, ABB_VDLGAIN, ABB_SIDETONE, ABB_CTRL1, ABB_CTRL2, ABB_CTRL3, ABB_CTRL4, ABB_CTRL5, ABB_CTRL6, ABB_POPAUTO, ABB_OUTEN1, ABB_OUTEN2, ABB_OUTEN3, ABB_AULGA, ABB_AURGA }; #endif /*************************************/ /* DRP WRAPPER Table */ /*************************************/ #define DRP_WRAPPER_TABLE_SIZE 3 enum DRP_WRAPPER_REGISTERS { DRP_WRAPPER_APCCTRL2 = 0, DRP_WRAPPER_APCDEL1, DRP_WRAPPER_APCDEL2 }; extern T_RF_BAND rf_band[]; #endif //__L1_RF_H