mirror of
https://github.com/open-sdr/openwifi.git
synced 2024-12-25 00:11:16 +00:00
505 lines
12 KiB
C
505 lines
12 KiB
C
/*
|
|
* AD9361 - Private definitions to be used only in the ad9361.c fileer
|
|
* SPDX-FileCopyrightText: Copyright 2013-2018 Analog Devices Inc.
|
|
* Modified by Xianjun jiao
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
*/
|
|
|
|
#ifndef IIO_AD9361_PRIVATE_H_
|
|
#define IIO_AD9361_PRIVATE_H_
|
|
|
|
#ifndef IIO_AD9361_USE_PRIVATE_H_
|
|
#error "Please do not include ad9361_private.h; use ad9361.h instead"
|
|
#endif
|
|
|
|
#include "ad9361.h"
|
|
|
|
/*
|
|
* Driver
|
|
*/
|
|
|
|
enum rx_gain_table_type {
|
|
RXGAIN_FULL_TBL,
|
|
RXGAIN_SPLIT_TBL,
|
|
};
|
|
|
|
enum rx_gain_table_name {
|
|
TBL_200_1300_MHZ,
|
|
TBL_1300_4000_MHZ,
|
|
TBL_4000_6000_MHZ,
|
|
RXGAIN_TBLS_END,
|
|
};
|
|
|
|
enum fir_dest {
|
|
FIR_TX1 = 0x01,
|
|
FIR_TX2 = 0x02,
|
|
FIR_TX1_TX2 = 0x03,
|
|
FIR_RX1 = 0x81,
|
|
FIR_RX2 = 0x82,
|
|
FIR_RX1_RX2 = 0x83,
|
|
FIR_IS_RX = 0x80,
|
|
};
|
|
|
|
struct rf_gain_ctrl {
|
|
u32 ant;
|
|
u8 mode;
|
|
};
|
|
|
|
enum rf_gain_ctrl_mode {
|
|
RF_GAIN_MGC,
|
|
RF_GAIN_FASTATTACK_AGC,
|
|
RF_GAIN_SLOWATTACK_AGC,
|
|
RF_GAIN_HYBRID_AGC
|
|
};
|
|
|
|
enum f_agc_target_gain_index_type {
|
|
MAX_GAIN,
|
|
SET_GAIN,
|
|
OPTIMIZED_GAIN,
|
|
NO_GAIN_CHANGE,
|
|
};
|
|
|
|
struct gain_control {
|
|
enum rf_gain_ctrl_mode rx1_mode;
|
|
enum rf_gain_ctrl_mode rx2_mode;
|
|
|
|
/* Common */
|
|
u8 adc_ovr_sample_size; /* 1..8 Sum x samples, AGC_CONFIG_3 */
|
|
u8 adc_small_overload_thresh; /* 0..255, 0x105 */
|
|
u8 adc_large_overload_thresh; /* 0..255, 0x104 */
|
|
|
|
u16 lmt_overload_high_thresh; /* 16..800 mV, 0x107 */
|
|
u16 lmt_overload_low_thresh; /* 16..800 mV, 0x108 */
|
|
u16 dec_pow_measuremnt_duration; /* Samples, 0x15C */
|
|
u8 low_power_thresh; /* -64..0 dBFS, 0x114 */
|
|
bool use_rx_fir_out_for_dec_pwr_meas; /* clears 0x15C:6 USE_HB1_OUT_FOR_DEC_PWR_MEAS */
|
|
|
|
bool dig_gain_en; /* should be turned off, since ADI GT doesn't use dig gain */
|
|
u8 max_dig_gain; /* 0..31 */
|
|
|
|
/* MGC */
|
|
bool mgc_rx1_ctrl_inp_en; /* Enables Pin control on RX1 default SPI ctrl */
|
|
bool mgc_rx2_ctrl_inp_en; /* Enables Pin control on RX2 default SPI ctrl */
|
|
|
|
u8 mgc_inc_gain_step; /* 1..8 */
|
|
u8 mgc_dec_gain_step; /* 1..8 */
|
|
u8 mgc_split_table_ctrl_inp_gain_mode; /* 0=AGC determine this, 1=only in LPF, 2=only in LMT */
|
|
|
|
/* AGC */
|
|
u8 agc_attack_delay_extra_margin_us; /* 0..31 us */
|
|
|
|
u8 agc_outer_thresh_high;
|
|
u8 agc_outer_thresh_high_dec_steps;
|
|
u8 agc_inner_thresh_high;
|
|
u8 agc_inner_thresh_high_dec_steps;
|
|
u8 agc_inner_thresh_low;
|
|
u8 agc_inner_thresh_low_inc_steps;
|
|
u8 agc_outer_thresh_low;
|
|
u8 agc_outer_thresh_low_inc_steps;
|
|
|
|
u8 adc_small_overload_exceed_counter; /* 0..15, 0x122 */
|
|
u8 adc_large_overload_exceed_counter; /* 0..15, 0x122 */
|
|
u8 adc_large_overload_inc_steps; /* 0..15, 0x106 */
|
|
|
|
bool adc_lmt_small_overload_prevent_gain_inc; /* 0x120 */
|
|
|
|
u8 lmt_overload_large_exceed_counter; /* 0..15, 0x121 */
|
|
u8 lmt_overload_small_exceed_counter; /* 0..15, 0x121 */
|
|
u8 lmt_overload_large_inc_steps; /* 0..7, 0x121 */
|
|
|
|
u8 dig_saturation_exceed_counter; /* 0..15, 0x128 */
|
|
u8 dig_gain_step_size; /* 1..8, 0x100 */
|
|
bool sync_for_gain_counter_en; /* 0x128:4 !Hybrid */
|
|
|
|
u32 gain_update_interval_us; /* in us */
|
|
bool immed_gain_change_if_large_adc_overload; /* 0x123:3 */
|
|
bool immed_gain_change_if_large_lmt_overload; /* 0x123:7 */
|
|
|
|
/*
|
|
* Fast AGC
|
|
*/
|
|
u32 f_agc_dec_pow_measuremnt_duration; /* Samples, 0x15C */
|
|
u32 f_agc_state_wait_time_ns; /* 0x117 0..31 RX samples -> time_ns */
|
|
/* Fast AGC - Low Power */
|
|
bool f_agc_allow_agc_gain_increase; /* 0x110:1 */
|
|
u8 f_agc_lp_thresh_increment_time; /* 0x11B RX samples */
|
|
u8 f_agc_lp_thresh_increment_steps; /* 0x117 1..8 */
|
|
|
|
/* Fast AGC - Lock Level */
|
|
u8 f_agc_lock_level; /* NOT USED: 0x101 0..-127 dBFS same as agc_inner_thresh_high */
|
|
bool f_agc_lock_level_lmt_gain_increase_en; /* 0x111:6 */
|
|
u8 f_agc_lock_level_gain_increase_upper_limit; /* 0x118 0..63 */
|
|
/* Fast AGC - Peak Detectors and Final Settling */
|
|
u8 f_agc_lpf_final_settling_steps; /* 0x112:6 0..3 (Post Lock Level Step)*/
|
|
u8 f_agc_lmt_final_settling_steps; /* 0x113:6 0..3 (Post Lock Level Step)*/
|
|
u8 f_agc_final_overrange_count; /* 0x116:5 0..7 */
|
|
/* Fast AGC - Final Power Test */
|
|
bool f_agc_gain_increase_after_gain_lock_en; /* 0x110:7 */
|
|
/* Fast AGC - Unlocking the Gain */
|
|
/* 0 = MAX Gain, 1 = Set Gain, 2 = Optimized Gain */
|
|
enum f_agc_target_gain_index_type f_agc_gain_index_type_after_exit_rx_mode; /* 0x110:[4,2] */
|
|
bool f_agc_use_last_lock_level_for_set_gain_en; /* 0x111:7 */
|
|
u8 f_agc_optimized_gain_offset; /*0x116 0..15 steps */
|
|
bool f_agc_rst_gla_stronger_sig_thresh_exceeded_en; /* 0x110:~6 */
|
|
u8 f_agc_rst_gla_stronger_sig_thresh_above_ll; /*0x113 0..63 dbFS */
|
|
bool f_agc_rst_gla_engergy_lost_sig_thresh_exceeded_en; /* 0x110:6 */
|
|
bool f_agc_rst_gla_engergy_lost_goto_optim_gain_en; /* 0x110:6 */
|
|
u8 f_agc_rst_gla_engergy_lost_sig_thresh_below_ll; /* 0x112:6 */
|
|
u8 f_agc_energy_lost_stronger_sig_gain_lock_exit_cnt; /* 0x119 0..63 RX samples */
|
|
bool f_agc_rst_gla_large_adc_overload_en; /*0x110:~1 and 0x114:~7 */
|
|
bool f_agc_rst_gla_large_lmt_overload_en; /*0x110:~1 */
|
|
bool f_agc_rst_gla_en_agc_pulled_high_en;
|
|
/* 0 = Max Gain, 1 = Set Gain, 2 = Optimized Gain, 3 = No Gain Change */
|
|
|
|
enum f_agc_target_gain_index_type f_agc_rst_gla_if_en_agc_pulled_high_mode; /* 0x0FB, 0x111 */
|
|
u8 f_agc_power_measurement_duration_in_state5; /* 0x109, 0x10a RX samples 0..524288*/
|
|
u8 f_agc_large_overload_inc_steps; /* 0x106 [D6:D4] 0..7 */
|
|
|
|
};
|
|
|
|
struct auxdac_control {
|
|
u16 dac1_default_value;
|
|
u16 dac2_default_value;
|
|
|
|
bool auxdac_manual_mode_en;
|
|
|
|
bool dac1_in_rx_en;
|
|
bool dac1_in_tx_en;
|
|
bool dac1_in_alert_en;
|
|
|
|
bool dac2_in_rx_en;
|
|
bool dac2_in_tx_en;
|
|
bool dac2_in_alert_en;
|
|
|
|
u8 dac1_rx_delay_us;
|
|
u8 dac1_tx_delay_us;
|
|
u8 dac2_rx_delay_us;
|
|
u8 dac2_tx_delay_us;
|
|
};
|
|
|
|
#if 0
|
|
enum rssi_restart_mode {
|
|
AGC_IN_FAST_ATTACK_MODE_LOCKS_THE_GAIN,
|
|
EN_AGC_PIN_IS_PULLED_HIGH,
|
|
ENTERS_RX_MODE,
|
|
GAIN_CHANGE_OCCURS,
|
|
SPI_WRITE_TO_REGISTER,
|
|
GAIN_CHANGE_OCCURS_OR_EN_AGC_PIN_PULLED_HIGH,
|
|
};
|
|
|
|
struct rssi_control {
|
|
enum rssi_restart_mode restart_mode;
|
|
bool rssi_unit_is_rx_samples; /* default unit is time */
|
|
u32 rssi_delay;
|
|
u32 rssi_wait;
|
|
u32 rssi_duration;
|
|
};
|
|
#endif
|
|
|
|
struct rx_gain_info {
|
|
enum rx_gain_table_type tbl_type;
|
|
int starting_gain_db;
|
|
int max_gain_db;
|
|
int gain_step_db;
|
|
int max_idx;
|
|
int idx_step_offset;
|
|
};
|
|
|
|
struct port_control {
|
|
u8 pp_conf[3];
|
|
u8 rx_clk_data_delay;
|
|
u8 tx_clk_data_delay;
|
|
u8 digital_io_ctrl;
|
|
u8 lvds_bias_ctrl;
|
|
u8 lvds_invert[2];
|
|
};
|
|
|
|
#if 0
|
|
struct ctrl_outs_control {
|
|
u8 index;
|
|
u8 en_mask;
|
|
};
|
|
#endif
|
|
|
|
struct elna_control {
|
|
u16 gain_mdB;
|
|
u16 bypass_loss_mdB;
|
|
u32 settling_delay_ns;
|
|
bool elna_1_control_en; /* GPO0 */
|
|
bool elna_2_control_en; /* GPO1 */
|
|
bool elna_in_gaintable_all_index_en;
|
|
};
|
|
|
|
struct auxadc_control {
|
|
s8 offset;
|
|
u32 temp_time_inteval_ms;
|
|
u32 temp_sensor_decimation;
|
|
bool periodic_temp_measuremnt;
|
|
u32 auxadc_clock_rate;
|
|
u32 auxadc_decimation;
|
|
};
|
|
|
|
struct gpo_control {
|
|
u32 gpo_manual_mode_enable_mask;
|
|
bool gpo_manual_mode_en;
|
|
bool gpo0_inactive_state_high_en;
|
|
bool gpo1_inactive_state_high_en;
|
|
bool gpo2_inactive_state_high_en;
|
|
bool gpo3_inactive_state_high_en;
|
|
bool gpo0_slave_rx_en;
|
|
bool gpo0_slave_tx_en;
|
|
bool gpo1_slave_rx_en;
|
|
bool gpo1_slave_tx_en;
|
|
bool gpo2_slave_rx_en;
|
|
bool gpo2_slave_tx_en;
|
|
bool gpo3_slave_rx_en;
|
|
bool gpo3_slave_tx_en;
|
|
u8 gpo0_rx_delay_us;
|
|
u8 gpo0_tx_delay_us;
|
|
u8 gpo1_rx_delay_us;
|
|
u8 gpo1_tx_delay_us;
|
|
u8 gpo2_rx_delay_us;
|
|
u8 gpo2_tx_delay_us;
|
|
u8 gpo3_rx_delay_us;
|
|
u8 gpo3_tx_delay_us;
|
|
};
|
|
|
|
struct tx_monitor_control {
|
|
bool tx_mon_track_en;
|
|
bool one_shot_mode_en;
|
|
u32 low_high_gain_threshold_mdB;
|
|
u8 low_gain_dB;
|
|
u8 high_gain_dB;
|
|
u16 tx_mon_delay;
|
|
u16 tx_mon_duration;
|
|
u8 tx1_mon_front_end_gain;
|
|
u8 tx2_mon_front_end_gain;
|
|
u8 tx1_mon_lo_cm;
|
|
u8 tx2_mon_lo_cm;
|
|
};
|
|
|
|
enum ad9361_pdata_rx_freq {
|
|
BBPLL_FREQ,
|
|
ADC_FREQ,
|
|
R2_FREQ,
|
|
R1_FREQ,
|
|
CLKRF_FREQ,
|
|
RX_SAMPL_FREQ,
|
|
NUM_RX_CLOCKS,
|
|
};
|
|
|
|
enum ad9361_pdata_tx_freq {
|
|
IGNORE,
|
|
DAC_FREQ,
|
|
T2_FREQ,
|
|
T1_FREQ,
|
|
CLKTF_FREQ,
|
|
TX_SAMPL_FREQ,
|
|
NUM_TX_CLOCKS,
|
|
};
|
|
|
|
enum ad9361_clkout {
|
|
CLKOUT_DISABLE,
|
|
BUFFERED_XTALN_DCXO,
|
|
ADC_CLK_DIV_2,
|
|
ADC_CLK_DIV_3,
|
|
ADC_CLK_DIV_4,
|
|
ADC_CLK_DIV_8,
|
|
ADC_CLK_DIV_16,
|
|
};
|
|
|
|
enum synth_pd_ctrl {
|
|
LO_DONTCARE,
|
|
LO_OFF,
|
|
LO_ON,
|
|
};
|
|
|
|
struct ad9361_phy_platform_data {
|
|
bool rx2tx2;
|
|
bool fdd;
|
|
bool fdd_independent_mode;
|
|
bool split_gt;
|
|
bool use_extclk;
|
|
bool ensm_pin_pulse_mode;
|
|
bool ensm_pin_ctrl;
|
|
bool debug_mode;
|
|
bool tdd_use_dual_synth;
|
|
bool tdd_skip_vco_cal;
|
|
bool use_ext_rx_lo;
|
|
bool use_ext_tx_lo;
|
|
bool rx1rx2_phase_inversion_en;
|
|
bool qec_tracking_slow_mode_en;
|
|
bool dig_interface_tune_fir_disable;
|
|
bool lo_powerdown_managed_en;
|
|
u8 dc_offset_update_events;
|
|
u8 dc_offset_attenuation_high;
|
|
u8 dc_offset_attenuation_low;
|
|
u8 rf_dc_offset_count_high;
|
|
u8 rf_dc_offset_count_low;
|
|
u8 dig_interface_tune_skipmode;
|
|
u32 dcxo_coarse;
|
|
u32 dcxo_fine;
|
|
bool rf_rx_input_sel_lock;
|
|
bool rf_tx_output_sel_lock;
|
|
u32 rx1tx1_mode_use_rx_num;
|
|
u32 rx1tx1_mode_use_tx_num;
|
|
unsigned long rx_path_clks[NUM_RX_CLOCKS];
|
|
unsigned long tx_path_clks[NUM_TX_CLOCKS];
|
|
u32 trx_synth_max_fref;
|
|
u64 rx_synth_freq;
|
|
u64 tx_synth_freq;
|
|
u32 rf_rx_bandwidth_Hz;
|
|
u32 rf_tx_bandwidth_Hz;
|
|
int tx_atten;
|
|
bool update_tx_gain_via_alert;
|
|
u32 rx_fastlock_delay_ns;
|
|
u32 tx_fastlock_delay_ns;
|
|
bool trx_fastlock_pinctrl_en[2];
|
|
|
|
enum ad9361_clkout ad9361_clkout_mode;
|
|
|
|
struct gain_control gain_ctrl;
|
|
struct rssi_control rssi_ctrl;
|
|
u32 rssi_lna_err_tbl[4];
|
|
u32 rssi_mixer_err_tbl[16];
|
|
u32 rssi_gain_step_calib_reg_val[5];
|
|
bool rssi_skip_calib;
|
|
struct port_control port_ctrl;
|
|
struct ctrl_outs_control ctrl_outs_ctrl;
|
|
struct elna_control elna_ctrl;
|
|
struct auxadc_control auxadc_ctrl;
|
|
struct auxdac_control auxdac_ctrl;
|
|
struct gpo_control gpo_ctrl;
|
|
struct tx_monitor_control txmon_ctrl;
|
|
|
|
struct gpio_desc *reset_gpio;
|
|
/* MCS SYNC */
|
|
struct gpio_desc *sync_gpio;
|
|
struct gpio_desc *cal_sw1_gpio;
|
|
struct gpio_desc *cal_sw2_gpio;
|
|
|
|
};
|
|
|
|
struct rf_rx_gain {
|
|
u32 ant; /* Antenna number to read gain */
|
|
s32 gain_db; /* gain value in dB */
|
|
u32 fgt_lmt_index; /* Full Gain Table / LNA-MIXER-TIA gain index */
|
|
u32 lmt_gain; /* LNA-MIXER-TIA gain in dB (Split GT mode only)*/
|
|
u32 lpf_gain; /* Low pass filter gain in dB / index (Split GT mode only)*/
|
|
u32 digital_gain; /* Digital gain in dB / index */
|
|
/* Debug only */
|
|
u32 lna_index; /* LNA Index (Split GT mode only) */
|
|
u32 tia_index; /* TIA Index (Split GT mode only) */
|
|
u32 mixer_index; /* MIXER Index (Split GT mode only) */
|
|
|
|
};
|
|
#if 0
|
|
struct rf_rssi {
|
|
u32 ant; /* Antenna number for which RSSI is reported */
|
|
u32 symbol; /* Runtime RSSI */
|
|
u32 preamble; /* Initial RSSI */
|
|
s32 multiplier; /* Multiplier to convert reported RSSI */
|
|
u8 duration; /* Duration to be considered for measuring */
|
|
};
|
|
#endif
|
|
|
|
struct SynthLUT {
|
|
u16 VCO_MHz;
|
|
u8 VCO_Output_Level;
|
|
u8 VCO_Varactor;
|
|
u8 VCO_Bias_Ref;
|
|
u8 VCO_Bias_Tcf;
|
|
u8 VCO_Cal_Offset;
|
|
u8 VCO_Varactor_Reference;
|
|
u8 Charge_Pump_Current;
|
|
u8 LF_C2;
|
|
u8 LF_C1;
|
|
u8 LF_R1;
|
|
u8 LF_C3;
|
|
u8 LF_R3;
|
|
};
|
|
|
|
#define SYNTH_LUT_SIZE 53
|
|
|
|
enum {
|
|
LUT_FTDD_40,
|
|
LUT_FTDD_60,
|
|
LUT_FTDD_80,
|
|
LUT_FTDD_ENT,
|
|
};
|
|
|
|
struct ad9361_fastlock_entry {
|
|
#define FASTLOOK_INIT 1
|
|
u8 flags;
|
|
u8 alc_orig;
|
|
u8 alc_written;
|
|
};
|
|
|
|
struct ad9361_fastlock {
|
|
u8 save_profile;
|
|
u8 current_profile[2];
|
|
struct ad9361_fastlock_entry entry[2][8];
|
|
};
|
|
|
|
struct ad9361_rf_phy_state {
|
|
u8 prev_ensm_state;
|
|
u8 curr_ensm_state;
|
|
u8 cached_rx_rfpll_div;
|
|
u8 cached_tx_rfpll_div;
|
|
u8 cached_synth_pd[2];
|
|
int tx_quad_lpf_tia_match;
|
|
int current_table;
|
|
int rx_sampl_freq_avail[3];
|
|
int tx_sampl_freq_avail[3];
|
|
int rx_gain_avail[3];
|
|
|
|
bool ensm_pin_ctl_en;
|
|
|
|
bool auto_cal_en;
|
|
bool manual_tx_quad_cal_en;
|
|
u64 last_tx_quad_cal_freq;
|
|
u32 last_tx_quad_cal_phase;
|
|
u64 current_tx_lo_freq;
|
|
u64 current_rx_lo_freq;
|
|
bool current_tx_use_tdd_table;
|
|
bool current_rx_use_tdd_table;
|
|
unsigned long current_rx_path_clks[NUM_RX_CLOCKS];
|
|
unsigned long current_tx_path_clks[NUM_TX_CLOCKS];
|
|
unsigned long flags;
|
|
unsigned long cal_threshold_freq;
|
|
u32 current_rx_bw_Hz;
|
|
u32 current_tx_bw_Hz;
|
|
u32 rxbbf_div;
|
|
u32 rate_governor;
|
|
bool bypass_rx_fir;
|
|
bool bypass_tx_fir;
|
|
bool rx_eq_2tx;
|
|
bool filt_valid;
|
|
unsigned long filt_rx_path_clks[NUM_RX_CLOCKS];
|
|
unsigned long filt_tx_path_clks[NUM_TX_CLOCKS];
|
|
u32 filt_rx_bw_Hz;
|
|
u32 filt_tx_bw_Hz;
|
|
u8 tx_fir_int;
|
|
u8 tx_fir_ntaps;
|
|
u8 rx_fir_dec;
|
|
u8 rx_fir_ntaps;
|
|
u8 agc_mode[2];
|
|
bool rfdc_track_en;
|
|
bool bbdc_track_en;
|
|
bool quad_track_en;
|
|
bool txmon_tdd_en;
|
|
u16 auxdac1_value;
|
|
u16 auxdac2_value;
|
|
u32 tx1_atten_cached;
|
|
u32 tx2_atten_cached;
|
|
u8 bist_loopback_mode;
|
|
u8 bist_config;
|
|
u32 rf_rx_input_sel;
|
|
u32 rf_tx_output_sel;
|
|
|
|
struct ad9361_fastlock fastlock;
|
|
};
|
|
|
|
#endif
|
|
|