diff options
Diffstat (limited to 'host')
-rw-r--r-- | host/lib/usrp/common/ad9361_driver/ad9361_device.cpp | 91 |
1 files changed, 46 insertions, 45 deletions
diff --git a/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp b/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp index 95df62e9a..952ed983d 100644 --- a/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp +++ b/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp @@ -9,6 +9,7 @@ #include "ad9361_device.h" #include <cstring> #include <cmath> +#include <uhd/exception.hpp> #include <boost/date_time/posix_time/posix_time.hpp> #include <boost/thread/thread.hpp> #include <boost/scoped_array.hpp> @@ -16,8 +17,8 @@ #define AD9361_MIN(a, b) (((a) < (b)) ? (a) : (b)) #define AD9361_MAX(a, b) (((a) > (b)) ? (a) : (b)) -#define msg -#define post_err_msg(x) +//TODO: Convert these debug messages into UHD_LOG statements +#define debug_msg(s, ...) inline int floor_to_int(double val) { return static_cast<int>(std::floor(val)); @@ -71,7 +72,7 @@ void ad9361_device_t::output_test_tone() void ad9361_device_t::data_port_loopback(const bool loopback_enabled) { - msg("[data_port_loopback] Enabled: %d", loopback_enabled); + debug_msg("[data_port_loopback] Enabled: %d", loopback_enabled); _io_iface->poke8(0x3F5, (loopback_enabled ? 0x01 : 0x00)); } @@ -187,7 +188,7 @@ void ad9361_device_t::_setup_rx_fir(size_t num_taps) coeffs[i] = boost::uint16_t(hb47_coeffs[i]); break; default: - post_err_msg("Unsupported number of Rx FIR taps."); + throw uhd::runtime_error("[ad9361_device_t] Unsupported number of Rx FIR taps."); } } @@ -213,7 +214,7 @@ void ad9361_device_t::_setup_tx_fir(size_t num_taps) coeffs[i] = boost::uint16_t(hb47_coeffs[i]); break; default: - post_err_msg("Unsupported number of Tx FIR taps."); + throw uhd::runtime_error("[ad9361_device_t] Unsupported number of Tx FIR taps."); } } @@ -241,7 +242,7 @@ void ad9361_device_t::_calibrate_lock_bbpll() size_t count = 0; while (!(_io_iface->peek8(0x05e) & 0x80)) { if (count > 1000) { - post_err_msg("BBPLL not locked"); + throw uhd::runtime_error("[ad9361_device_t] BBPLL not locked"); break; } count++; @@ -258,7 +259,7 @@ void ad9361_device_t::_calibrate_synth_charge_pumps() /* If this function ever gets called, and the ENSM isn't already in the * ALERT state, then something has gone horribly wrong. */ if ((_io_iface->peek8(0x017) & 0x0F) != 5) { - post_err_msg("AD9361 not in ALERT during cal"); + throw uhd::runtime_error("[ad9361_device_t] AD9361 not in ALERT during cal"); } /* Calibrate the RX synthesizer charge pump. */ @@ -266,7 +267,7 @@ void ad9361_device_t::_calibrate_synth_charge_pumps() _io_iface->poke8(0x23d, 0x04); while (!(_io_iface->peek8(0x244) & 0x80)) { if (count > 5) { - post_err_msg("RX charge pump cal failure"); + throw uhd::runtime_error("[ad9361_device_t] RX charge pump cal failure"); break; } count++; @@ -279,7 +280,7 @@ void ad9361_device_t::_calibrate_synth_charge_pumps() _io_iface->poke8(0x27d, 0x04); while (!(_io_iface->peek8(0x284) & 0x80)) { if (count > 5) { - post_err_msg("TX charge pump cal failure"); + throw uhd::runtime_error("[ad9361_device_t] TX charge pump cal failure"); break; } count++; @@ -332,7 +333,7 @@ double ad9361_device_t::_calibrate_baseband_rx_analog_filter() _io_iface->poke8(0x016, 0x80); while (_io_iface->peek8(0x016) & 0x80) { if (count > 100) { - post_err_msg("RX baseband filter cal FAILURE"); + throw uhd::runtime_error("[ad9361_device_t] RX baseband filter cal FAILURE"); break; } count++; @@ -379,7 +380,7 @@ double ad9361_device_t::_calibrate_baseband_tx_analog_filter() _io_iface->poke8(0x016, 0x40); while (_io_iface->peek8(0x016) & 0x40) { if (count > 100) { - post_err_msg("TX baseband filter cal FAILURE"); + throw uhd::runtime_error("[ad9361_device_t] TX baseband filter cal FAILURE"); break; } @@ -443,7 +444,7 @@ void ad9361_device_t::_calibrate_secondary_tx_filter() } else if ((bbbw_mhz * 2) > 24) { reg0d0 = 0x57; } else { - post_err_msg("Cal2ndTxFil: INVALID_CODE_PATH bad bbbw_mhz"); + throw uhd::runtime_error("[ad9361_device_t] Cal2ndTxFil: INVALID_CODE_PATH bad bbbw_mhz"); reg0d0 = 0x00; } @@ -506,7 +507,7 @@ void ad9361_device_t::_calibrate_rx_TIAs() } else if (ceil_bbbw_mhz > 10) { reg1db = 0x20; } else { - post_err_msg("CalRxTias: INVALID_CODE_PATH bad bbbw_mhz"); + throw uhd::runtime_error("[ad9361_device_t] CalRxTias: INVALID_CODE_PATH bad bbbw_mhz"); } if (CTIA_fF > 2920) { @@ -677,7 +678,7 @@ void ad9361_device_t::_calibrate_baseband_dc_offset() _io_iface->poke8(0x016, 0x01); while (_io_iface->peek8(0x016) & 0x01) { if (count > 100) { - post_err_msg("Baseband DC Offset Calibration Failure"); + throw uhd::runtime_error("[ad9361_device_t] Baseband DC Offset Calibration Failure"); break; } count++; @@ -711,7 +712,7 @@ void ad9361_device_t::_calibrate_rf_dc_offset() _io_iface->poke8(0x016, 0x02); while (_io_iface->peek8(0x016) & 0x02) { if (count > 100) { - post_err_msg("RF DC Offset Calibration Failure"); + throw uhd::runtime_error("[ad9361_device_t] RF DC Offset Calibration Failure"); break; } count++; @@ -766,7 +767,7 @@ void ad9361_device_t::_tx_quadrature_cal_routine() { bbbw = 0.20e6; } if (max_cal_freq > bbbw) - post_err_msg("max_cal_freq > bbbw"); + throw uhd::runtime_error("[ad9361_device_t] max_cal_freq > bbbw"); _io_iface->poke8(0x0a1, 0x7B); // Set tracking coefficient _io_iface->poke8(0x0a9, 0xff); // Cal count @@ -796,7 +797,7 @@ void ad9361_device_t::_tx_quadrature_cal_routine() { _io_iface->poke8(0x016, 0x10); while (_io_iface->peek8(0x016) & 0x10) { if (count > 100) { - post_err_msg("TX Quadrature Calibration Failure"); + throw uhd::runtime_error("[ad9361_device_t] TX Quadrature Calibration Failure"); break; } count++; @@ -813,7 +814,7 @@ void ad9361_device_t::_calibrate_tx_quadrature() /* Make sure we are, in fact, in the ALERT state. If not, something is * terribly wrong in the driver execution flow. */ if ((_io_iface->peek8(0x017) & 0x0F) != 5) { - post_err_msg("TX Quad Cal started, but not in ALERT"); + throw uhd::runtime_error("[ad9361_device_t] TX Quad Cal started, but not in ALERT"); } /* Turn off free-running and continuous calibrations. Note that this @@ -903,7 +904,7 @@ void ad9361_device_t::_program_gain_table() { gain_table = gain_table_4000mhz_to_6000mhz; new_gain_table = 3; } else { - post_err_msg("Wrong _rx_freq value"); + throw uhd::runtime_error("[ad9361_device_t] Wrong _rx_freq value"); new_gain_table = 1; } @@ -992,7 +993,7 @@ void ad9361_device_t::_setup_synth(direction_t direction, double vcorate) } } if (vcoindex > 53) - post_err_msg("vcoindex > 53"); + throw uhd::runtime_error("[ad9361_device_t] vcoindex > 53"); /* Parse the values out of the LUT based on our calculated index... */ boost::uint8_t vco_output_level = synth_cal_lut[vcoindex][0]; @@ -1034,7 +1035,7 @@ void ad9361_device_t::_setup_synth(direction_t direction, double vcorate) _io_iface->poke8(0x27f, loop_filter_c3 | (loop_filter_r1 << 4)); _io_iface->poke8(0x280, loop_filter_r3); } else { - post_err_msg("[_setup_synth] INVALID_CODE_PATH"); + throw uhd::runtime_error("[ad9361_device_t] [_setup_synth] INVALID_CODE_PATH"); } } @@ -1046,7 +1047,7 @@ void ad9361_device_t::_setup_synth(direction_t direction, double vcorate) * fed to the public set_clock_rate function. */ double ad9361_device_t::_tune_bbvco(const double rate) { - msg("[_tune_bbvco] rate=%.10f", rate); + debug_msg("[_tune_bbvco] rate=%.10f", rate); /* Let's not re-tune to the same frequency over and over... */ if (freq_is_nearly_equal(rate, _req_coreclk)) { @@ -1072,17 +1073,17 @@ double ad9361_device_t::_tune_bbvco(const double rate) break; } if (i == 7) - post_err_msg("_tune_bbvco: wrong vcorate"); + throw uhd::runtime_error("[ad9361_device_t] _tune_bbvco: wrong vcorate"); - msg("[_tune_bbvco] vcodiv=%d vcorate=%.10f", vcodiv, vcorate); + debug_msg("[_tune_bbvco] vcodiv=%d vcorate=%.10f", vcodiv, vcorate); /* Fo = Fref * (Nint + Nfrac / mod) */ int nint = vcorate / fref; - msg("[_tune_bbvco] (nint)=%.10f", (vcorate / fref)); + debug_msg("[_tune_bbvco] (nint)=%.10f", (vcorate / fref)); int nfrac = lround(((vcorate / fref) - (double) nint) * (double) modulus); - msg("[_tune_bbvco] (nfrac)=%.10f", + debug_msg("[_tune_bbvco] (nfrac)=%.10f", (((vcorate / fref) - (double) nint) * (double) modulus)); - msg("[_tune_bbvco] nint=%d nfrac=%d", nint, nfrac); + debug_msg("[_tune_bbvco] nint=%d nfrac=%d", nint, nfrac); double actual_vcorate = fref * ((double) nint + ((double) nfrac / (double) modulus)); @@ -1152,7 +1153,7 @@ double ad9361_device_t::_tune_helper(direction_t direction, const double value) break; } if (i == 7) - post_err_msg("RFVCO can't find valid VCO rate!"); + throw uhd::runtime_error("[ad9361_device_t] RFVCO can't find valid VCO rate!"); int nint = vcorate / fref; int nfrac = ((vcorate / fref) - nint) * modulus; @@ -1177,7 +1178,7 @@ double ad9361_device_t::_tune_helper(direction_t direction, const double value) && (value <= 6e9)) { _regs.inputsel = (_regs.inputsel & 0xC0) | 0x03; } else { - post_err_msg("[_tune_helper] INVALID_CODE_PATH"); + throw uhd::runtime_error("[ad9361_device_t] [_tune_helper] INVALID_CODE_PATH"); } _io_iface->poke8(0x004, _regs.inputsel); @@ -1199,7 +1200,7 @@ double ad9361_device_t::_tune_helper(direction_t direction, const double value) /* Lock the PLL! */ boost::this_thread::sleep(boost::posix_time::milliseconds(2)); if ((_io_iface->peek8(0x247) & 0x02) == 0) { - post_err_msg("RX PLL NOT LOCKED"); + throw uhd::runtime_error("[ad9361_device_t] RX PLL NOT LOCKED"); } _rx_freq = actual_lo; @@ -1218,7 +1219,7 @@ double ad9361_device_t::_tune_helper(direction_t direction, const double value) && (value <= 6e9)) { _regs.inputsel = _regs.inputsel & 0xBF; } else { - post_err_msg("[_tune_helper] INVALID_CODE_PATH"); + throw uhd::runtime_error("[ad9361_device_t] [_tune_helper] INVALID_CODE_PATH"); } _io_iface->poke8(0x004, _regs.inputsel); @@ -1240,7 +1241,7 @@ double ad9361_device_t::_tune_helper(direction_t direction, const double value) /* Lock the PLL! */ boost::this_thread::sleep(boost::posix_time::milliseconds(2)); if ((_io_iface->peek8(0x287) & 0x02) == 0) { - post_err_msg("TX PLL NOT LOCKED"); + throw uhd::runtime_error("[ad9361_device_t] TX PLL NOT LOCKED"); } _tx_freq = actual_lo; @@ -1333,10 +1334,10 @@ double ad9361_device_t::_setup_rates(const double rate) _tfir_factor = 1; } else { // should never get in here - post_err_msg("[_setup_rates] INVALID_CODE_PATH"); + throw uhd::runtime_error("[ad9361_device_t] [_setup_rates] INVALID_CODE_PATH"); } - msg("[_setup_rates] divfactor=%d", divfactor); + debug_msg("[_setup_rates] divfactor=%d", divfactor); /* Tune the BBPLL to get the ADC and DAC clocks. */ const double adcclk = _tune_bbvco(rate * divfactor); @@ -1358,7 +1359,7 @@ double ad9361_device_t::_setup_rates(const double rate) _io_iface->poke8(0x004, _regs.inputsel); _io_iface->poke8(0x00A, _regs.bbpll); - msg("[_setup_rates] adcclk=%f", adcclk); + debug_msg("[_setup_rates] adcclk=%f", adcclk); _baseband_bw = (adcclk / divfactor); /* @@ -1445,7 +1446,7 @@ void ad9361_device_t::initialize() } break; default: - post_err_msg("NOT IMPLEMENTED"); + throw uhd::runtime_error("[ad9361_device_t] NOT IMPLEMENTED"); } boost::this_thread::sleep(boost::posix_time::milliseconds(20)); @@ -1474,7 +1475,7 @@ void ad9361_device_t::initialize() } break; default: - post_err_msg("NOT IMPLEMENTED"); + throw uhd::runtime_error("[ad9361_device_t] NOT IMPLEMENTED"); } /* Data delay for TX and RX data clocks */ @@ -1580,7 +1581,7 @@ void ad9361_device_t::initialize() } break; default: - post_err_msg("NOT IMPLEMENTED"); + throw uhd::runtime_error("[ad9361_device_t] NOT IMPLEMENTED"); } _io_iface->poke8(0x013, 0x01); // Set ENSM FDD bit @@ -1620,10 +1621,10 @@ void ad9361_device_t::initialize() double ad9361_device_t::set_clock_rate(const double req_rate) { if (req_rate > 61.44e6) { - post_err_msg("Requested master clock rate outside range"); + throw uhd::runtime_error("[ad9361_device_t] Requested master clock rate outside range"); } - msg("[set_clock_rate] req_rate=%.10f", req_rate); + debug_msg("[set_clock_rate] req_rate=%.10f", req_rate); /* UHD has a habit of requesting the same rate like four times when it * starts up. This prevents that, and any bugs in user code that request @@ -1649,7 +1650,7 @@ double ad9361_device_t::set_clock_rate(const double req_rate) break; default: - post_err_msg("[set_clock_rate:1] AD9361 in unknown state"); + throw uhd::runtime_error("[ad9361_device_t] [set_clock_rate:1] AD9361 in unknown state"); break; }; @@ -1663,7 +1664,7 @@ double ad9361_device_t::set_clock_rate(const double req_rate) * all the hard work gets done. */ double rate = _setup_rates(req_rate); - msg("[set_clock_rate] rate=%.10f", rate); + debug_msg("[set_clock_rate] rate=%.10f", rate); /* Transition to the ALERT state and calibrate everything. */ _io_iface->poke8(0x015, 0x04); //dual synth mode, synth en ctrl en @@ -1702,7 +1703,7 @@ double ad9361_device_t::set_clock_rate(const double req_rate) }break; default: - post_err_msg("NOT IMPLEMENTED"); + throw uhd::runtime_error("[ad9361_device_t] NOT IMPLEMENTED"); } _io_iface->poke8(0x013, 0x01); // Set ENSM FDD bit _io_iface->poke8(0x015, 0x04); // dual synth mode, synth en ctrl en @@ -1725,7 +1726,7 @@ double ad9361_device_t::set_clock_rate(const double req_rate) break; default: - post_err_msg("[set_clock_rate:2] AD9361 in unknown state"); + throw uhd::runtime_error("[ad9361_device_t] [set_clock_rate:2] AD9361 in unknown state"); break; }; @@ -1814,7 +1815,7 @@ double ad9361_device_t::tune(direction_t direction, const double value) } } else { - post_err_msg("[tune] INVALID_CODE_PATH"); + throw uhd::runtime_error("[ad9361_device_t] [tune] INVALID_CODE_PATH"); } /* If we aren't already in the ALERT state, we will need to return to |