📄 l1_rf10.h
字号:
#define AGC_TABLE_SIZE 27
#define TEMP_TABLE_SIZE 131 // number of elements in ADC->temp conversion table
// 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; //WORD16 c
#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];
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 */
/************************************/
// Omega: 5 external channels if touch screen not used, 3 otherwise
enum ADC_INDEX {
ADC_VBAT,
ADC_VCHARG,
ADC_ICHARG,
ADC_VBACKUP,
ADC_BATTYP,
ADC_BATTEMP,
ADC_ADC3, // name of this ??
ADC_RFTEMP,
ADC_ADC4,
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;
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,
BAND_PCS1900_US,
// put new bands here
BAND_GSM900 //last entry
};
/************************************/
/* ABB (Omega) Initialization */
/************************************/
#if ((ANALOG == 1) || (ANALOG == 2))
#define ABB_TABLE_SIZE 16
#elif (ANALOG == 3)
#define ABB_TABLE_SIZE 22
#endif
// Note that this translation is probably not needed at all. But until L1 is
// (maybe) changed to simply initialize the ABB from a table of words, we
// use this to make things more easy-readable.
#if (ANALOG == 1)
enum ABB_REGISTERS {
ABB_AFCCTLADD = 0,
ABB_VBUR,
ABB_VBDR,
ABB_BBCTL,
ABB_APCOFF,
ABB_BULIOFF,
ABB_BULQOFF,
ABB_DAI_ON_OFF,
ABB_AUXDAC,
ABB_VBCR,
ABB_APCDEL
};
#elif (ANALOG == 2)
enum ABB_REGISTERS {
ABB_AFCCTLADD = 0,
ABB_VBUR,
ABB_VBDR,
ABB_BBCTL,
ABB_BULGCAL,
ABB_APCOFF,
ABB_BULIOFF,
ABB_BULQOFF,
ABB_DAI_ON_OFF,
ABB_AUXDAC,
ABB_VBCR,
ABB_VBCR2,
ABB_APCDEL,
ABB_APCDEL2
};
#elif (ANALOG == 3)
enum ABB_REGISTERS {
ABB_AFCCTLADD = 0,
ABB_VBUR,
ABB_VBDR,
ABB_BBCTL,
ABB_BULGCAL,
ABB_APCOFF,
ABB_BULIOFF,
ABB_BULQOFF,
ABB_DAI_ON_OFF,
ABB_AUXDAC,
ABB_VBCR,
ABB_VBCR2,
ABB_APCDEL,
ABB_APCDEL2,
ABB_VBPOP,
ABB_VAUDINITD,
ABB_VAUDCR,
ABB_VAUOCR,
ABB_VAUSCR,
ABB_VAUDPLL
};
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -