From f700f5a43afa8840262fadf15c4d6fd2648b298b Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Fri, 3 Nov 2017 16:29:22 -0700 Subject: mg: Add defer_commit argument to CPLD controls This will set you call setters on the CPLD control object without immediately triggering a SPI transaction. --- .../usrp/dboard/magnesium/magnesium_cpld_ctrl.cpp | 33 ++++++++++++++-------- .../usrp/dboard/magnesium/magnesium_cpld_ctrl.hpp | 14 ++++++--- 2 files changed, 32 insertions(+), 15 deletions(-) (limited to 'host/lib/usrp') diff --git a/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.cpp b/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.cpp index 18402e764..66fa02360 100644 --- a/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.cpp +++ b/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.cpp @@ -22,7 +22,7 @@ magnesium_cpld_ctrl::magnesium_cpld_ctrl( { _write_fn = [write_fn](const uint8_t addr, const uint32_t data){ UHD_LOG_TRACE("MG_CPLD", - str(boost::format("Writing to CPLD: 0x%X -> 0x%4X") + str(boost::format("Writing to CPLD: 0x%02X -> 0x%04X") % uint32_t(addr) % data)); const uint32_t spi_transaction = 0 | ((addr & 0x7F) << 16) @@ -31,9 +31,8 @@ magnesium_cpld_ctrl::magnesium_cpld_ctrl( write_fn(spi_transaction); }; _read_fn = [read_fn](const uint8_t addr){ - UHD_LOG_TRACE("MG_CPLD", "Reading from addr " << addr); UHD_LOG_TRACE("MG_CPLD", - str(boost::format("Reading from CPLD address 0x%X") + str(boost::format("Reading from CPLD address 0x%02X") % uint32_t(addr))); const uint32_t spi_transaction = (1<<23) | ((addr & 0x7F) << 16) @@ -88,7 +87,8 @@ void magnesium_cpld_ctrl::set_tx_switches( const tx_sw3_t tx_sw3, const lowband_mixer_path_sel_t select_lowband_mixer_path, const bool enb_lowband_mixer, - const atr_state_t atr_state + const atr_state_t atr_state, + const bool defer_commit ) { std::lock_guard l(_set_mutex); if (chan == CHAN1 or chan == BOTH) { @@ -128,7 +128,9 @@ void magnesium_cpld_ctrl::set_tx_switches( } } - commit(); + if (not defer_commit) { + commit(); + } } void magnesium_cpld_ctrl::set_rx_switches( @@ -140,7 +142,8 @@ void magnesium_cpld_ctrl::set_rx_switches( const rx_sw6_t rx_sw6, const lowband_mixer_path_sel_t select_lowband_mixer_path, const bool enb_lowband_mixer, - const atr_state_t atr_state + const atr_state_t atr_state, + const bool defer_commit ) { std::lock_guard l(_set_mutex); if (chan == CHAN1 or chan == BOTH) { @@ -184,7 +187,9 @@ void magnesium_cpld_ctrl::set_rx_switches( _regs.ch2_on_rx_mixer_en = enb_lowband_mixer; } } - commit(); + if (not defer_commit) { + commit(); + } } void magnesium_cpld_ctrl::set_tx_atr_bits( @@ -194,7 +199,8 @@ void magnesium_cpld_ctrl::set_tx_atr_bits( const sw_trx_t trx_sw, const bool tx_pa_enb, const bool tx_amp_enb, - const bool tx_myk_en + const bool tx_myk_en, + const bool defer_commit ) { std::lock_guard l(_set_mutex); if (chan == CHAN1 or chan == BOTH) { @@ -229,7 +235,9 @@ void magnesium_cpld_ctrl::set_tx_atr_bits( _regs.ch2_on_tx_myk_en = tx_myk_en; } } - commit(); + if (not defer_commit) { + commit(); + } } void magnesium_cpld_ctrl::set_rx_atr_bits( @@ -241,7 +249,8 @@ void magnesium_cpld_ctrl::set_rx_atr_bits( const bool rx_lna1_enb, const bool rx_lna2_enb, const bool rx_amp_enb, - const bool rx_myk_en + const bool rx_myk_en, + const bool defer_commit ) { std::lock_guard l(_set_mutex); if (chan == CHAN1 or chan == BOTH) { @@ -285,7 +294,9 @@ void magnesium_cpld_ctrl::set_rx_atr_bits( } } - commit(); + if (not defer_commit) { + commit(); + } } diff --git a/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.hpp b/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.hpp index d9000401e..ad369df99 100644 --- a/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.hpp +++ b/host/lib/usrp/dboard/magnesium/magnesium_cpld_ctrl.hpp @@ -179,7 +179,8 @@ public: const tx_sw3_t tx_sw3, const lowband_mixer_path_sel_t select_lowband_mixer_path, const bool enb_lowband_mixer, - const atr_state_t atr_state = ANY + const atr_state_t atr_state = ANY, + const bool defer_commit = false ); /*! Frequency-related settings, receive side @@ -207,7 +208,8 @@ public: const rx_sw6_t rx_sw6, const lowband_mixer_path_sel_t select_lowband_mixer_path, const bool enb_lowband_mixer, - const atr_state_t atr_state = ANY + const atr_state_t atr_state = ANY, + const bool defer_commit = false ); /*! ATR settings: LEDs, PAs, LNAs, ... for TX side @@ -232,7 +234,8 @@ public: const sw_trx_t trx_sw, const bool tx_pa_enb, const bool tx_amp_enb, - const bool tx_myk_enb + const bool tx_myk_enb, + const bool defer_commit = false ); /*! ATR settings: LEDs, PAs, LNAs, ... for RX side @@ -250,7 +253,9 @@ public: * \param rx2_led State of the RX LED for this ATR state (on or off). This * is the LED on the RX2 port. * \param rx_lna1_enb State of RX LNA 1 for this ATR state (on or off). + * This is the high-band LNA. * \param rx_lna2_enb State of RX LNA 2 for this ATR state (on or off). + * This is the low-band LNA. * \param rx_amp_enb State of RX amp for this ATR state (on or off). * \param rx_myk_enb State of the AD9371 RX enable pin for this ATR state */ @@ -263,7 +268,8 @@ public: const bool rx_lna1_enb, const bool rx_lna2_enb, const bool rx_amp_enb, - const bool rx_myk_en + const bool rx_myk_en, + const bool defer_commit = false ); private: -- cgit v1.2.3