diff options
-rw-r--r-- | host/include/uhd/transport/nirio/niusrprio_session.h | 75 | ||||
-rw-r--r-- | host/lib/transport/nirio/niusrprio_session.cpp | 128 |
2 files changed, 104 insertions, 99 deletions
diff --git a/host/include/uhd/transport/nirio/niusrprio_session.h b/host/include/uhd/transport/nirio/niusrprio_session.h index f6f0d78a1..41f05aec0 100644 --- a/host/include/uhd/transport/nirio/niusrprio_session.h +++ b/host/include/uhd/transport/nirio/niusrprio_session.h @@ -9,12 +9,12 @@ #ifndef INCLUDED_UHD_TRANSPORT_NIRIO_NIUSRPRIO_SESSION_H #define INCLUDED_UHD_TRANSPORT_NIRIO_NIUSRPRIO_SESSION_H -#include <stdint.h> -#include <uhd/transport/nirio/rpc/usrprio_rpc_client.hpp> -#include <uhd/transport/nirio/niriok_proxy.h> -#include <uhd/transport/nirio/nirio_resource_manager.h> #include <uhd/transport/nirio/nifpga_lvbitx.h> +#include <uhd/transport/nirio/nirio_resource_manager.h> +#include <uhd/transport/nirio/niriok_proxy.h> +#include <uhd/transport/nirio/rpc/usrprio_rpc_client.hpp> #include <uhd/utils/noncopyable.hpp> +#include <stdint.h> #include <boost/smart_ptr.hpp> #include <boost/thread/recursive_mutex.hpp> #include <string> @@ -29,68 +29,63 @@ public: typedef uhd::usrprio_rpc::usrprio_device_info_vtr device_info_vtr; static nirio_status enumerate( - const std::string& rpc_port_name, - device_info_vtr& device_info_vtr); + const std::string& rpc_port_name, device_info_vtr& device_info_vtr); - niusrprio_session( - const std::string& resource_name, - const std::string& port_name); + niusrprio_session(const std::string& resource_name, const std::string& port_name); virtual ~niusrprio_session(); - nirio_status open( - nifpga_lvbitx::sptr lvbitx, - bool force_download = false); + nirio_status open(nifpga_lvbitx::sptr lvbitx, bool force_download = false); void close(bool skip_reset = false); nirio_status reset(); - template<typename data_t> + template <typename data_t> nirio_status create_tx_fifo( - const char* fifo_name, - boost::shared_ptr< nirio_fifo<data_t> >& fifo) + const char* fifo_name, boost::shared_ptr<nirio_fifo<data_t>>& fifo) { - if (!_session_open) return NiRio_Status_ResourceNotInitialized; + if (!_session_open) + return NiRio_Status_ResourceNotInitialized; return _resource_manager.create_tx_fifo(fifo_name, fifo); } - template<typename data_t> + template <typename data_t> nirio_status create_tx_fifo( - uint32_t fifo_instance, - boost::shared_ptr< nirio_fifo<data_t> >& fifo) + uint32_t fifo_instance, boost::shared_ptr<nirio_fifo<data_t>>& fifo) { - if ((size_t)fifo_instance >= _lvbitx->get_output_fifo_count()) return NiRio_Status_InvalidParameter; + if ((size_t)fifo_instance >= _lvbitx->get_output_fifo_count()) + return NiRio_Status_InvalidParameter; return create_tx_fifo(_lvbitx->get_output_fifo_names()[fifo_instance], fifo); } - template<typename data_t> + template <typename data_t> nirio_status create_rx_fifo( - const char* fifo_name, - boost::shared_ptr< nirio_fifo<data_t> >& fifo) + const char* fifo_name, boost::shared_ptr<nirio_fifo<data_t>>& fifo) { - if (!_session_open) return NiRio_Status_ResourceNotInitialized; + if (!_session_open) + return NiRio_Status_ResourceNotInitialized; return _resource_manager.create_rx_fifo(fifo_name, fifo); } - template<typename data_t> + template <typename data_t> nirio_status create_rx_fifo( - uint32_t fifo_instance, - boost::shared_ptr< nirio_fifo<data_t> >& fifo) + uint32_t fifo_instance, boost::shared_ptr<nirio_fifo<data_t>>& fifo) { - if ((size_t)fifo_instance >= _lvbitx->get_input_fifo_count()) return NiRio_Status_InvalidParameter; + if ((size_t)fifo_instance >= _lvbitx->get_input_fifo_count()) + return NiRio_Status_InvalidParameter; return create_rx_fifo(_lvbitx->get_input_fifo_names()[fifo_instance], fifo); } - UHD_INLINE niriok_proxy::sptr get_kernel_proxy() { + UHD_INLINE niriok_proxy::sptr get_kernel_proxy() + { return _riok_proxy; } nirio_status download_bitstream_to_flash(const std::string& bitstream_path); - //Static + // Static static niriok_proxy::sptr create_kernel_proxy( - const std::string& resource_name, - const std::string& rpc_port_name); + const std::string& resource_name, const std::string& rpc_port_name); private: nirio_status _verify_signature(); @@ -98,16 +93,16 @@ private: nirio_status _write_bitstream_checksum(const std::string& checksum); nirio_status _ensure_fpga_ready(); - std::string _resource_name; - nifpga_lvbitx::sptr _lvbitx; - std::string _interface_path; - bool _session_open; - niriok_proxy::sptr _riok_proxy; - nirio_resource_manager _resource_manager; + std::string _resource_name; + nifpga_lvbitx::sptr _lvbitx; + std::string _interface_path; + bool _session_open; + niriok_proxy::sptr _riok_proxy; + nirio_resource_manager _resource_manager; usrprio_rpc::usrprio_rpc_client _rpc_client; - boost::recursive_mutex _session_mutex; + boost::recursive_mutex _session_mutex; }; -}} +}} // namespace uhd::niusrprio #endif /* INCLUDED_UHD_TRANSPORT_NIRIO_NIUSRPRIO_SESSION_H */ diff --git a/host/lib/transport/nirio/niusrprio_session.cpp b/host/lib/transport/nirio/niusrprio_session.cpp index bda0ec1c1..b2ea659df 100644 --- a/host/lib/transport/nirio/niusrprio_session.cpp +++ b/host/lib/transport/nirio/niusrprio_session.cpp @@ -8,30 +8,31 @@ //@TODO: Move the register defs required by the class to a common location #include "../../usrp/x300/x300_regs.hpp" -#include <uhd/transport/nirio/niusrprio_session.h> #include <uhd/transport/nirio/nirio_fifo.h> +#include <uhd/transport/nirio/niusrprio_session.h> #include <uhd/transport/nirio/status.h> -#include <boost/format.hpp> +#include <stdio.h> #include <boost/algorithm/string.hpp> -#include <fstream> +#include <boost/format.hpp> #include <chrono> +#include <fstream> #include <thread> -#include <stdio.h> namespace { - constexpr uint32_t FPGA_READY_TIMEOUT_IN_MS = 1000; +constexpr uint32_t FPGA_READY_TIMEOUT_IN_MS = 1000; } namespace uhd { namespace niusrprio { -niusrprio_session::niusrprio_session(const std::string& resource_name, const std::string& rpc_port_name) : - _resource_name(resource_name), - _session_open(false), - _resource_manager(), - _rpc_client("localhost", rpc_port_name) +niusrprio_session::niusrprio_session( + const std::string& resource_name, const std::string& rpc_port_name) + : _resource_name(resource_name) + , _session_open(false) + , _resource_manager() + , _rpc_client("localhost", rpc_port_name) { - _riok_proxy = create_kernel_proxy(resource_name,rpc_port_name); - _resource_manager.set_proxy(_riok_proxy); + _riok_proxy = create_kernel_proxy(resource_name, rpc_port_name); + _resource_manager.set_proxy(_riok_proxy); } niusrprio_session::~niusrprio_session() @@ -39,7 +40,8 @@ niusrprio_session::~niusrprio_session() close(); } -nirio_status niusrprio_session::enumerate(const std::string& rpc_port_name, device_info_vtr& device_info_vtr) +nirio_status niusrprio_session::enumerate( + const std::string& rpc_port_name, device_info_vtr& device_info_vtr) { usrprio_rpc::usrprio_rpc_client temp_rpc_client("localhost", rpc_port_name); nirio_status status = temp_rpc_client.get_ctor_status(); @@ -47,9 +49,7 @@ nirio_status niusrprio_session::enumerate(const std::string& rpc_port_name, devi return status; } -nirio_status niusrprio_session::open( - nifpga_lvbitx::sptr lvbitx, - bool force_download) +nirio_status niusrprio_session::open(nifpga_lvbitx::sptr lvbitx, bool force_download) { boost::unique_lock<boost::recursive_mutex> lock(_session_mutex); @@ -59,25 +59,29 @@ nirio_status niusrprio_session::open( std::string bitfile_path(_lvbitx->get_bitfile_path()); std::string signature(_lvbitx->get_signature()); - //Make sure that the RPC client connected to the server properly + // Make sure that the RPC client connected to the server properly nirio_status_chain(_rpc_client.get_ctor_status(), status); - //Get a handle to the kernel driver - nirio_status_chain(_rpc_client.niusrprio_get_interface_path(_resource_name, _interface_path), status); + // Get a handle to the kernel driver + nirio_status_chain( + _rpc_client.niusrprio_get_interface_path(_resource_name, _interface_path), + status); nirio_status_chain(_riok_proxy->open(_interface_path), status); if (nirio_status_not_fatal(status)) { - //Bitfile build for a particular LVFPGA interface will have the same signature - //because the API of the bitfile does not change. Two files with the same signature - //can however have different bitstreams because of non-LVFPGA code differences. - //That is why we need another identifier to qualify the signature. The BIN - //checksum is a good candidate. + // Bitfile build for a particular LVFPGA interface will have the same signature + // because the API of the bitfile does not change. Two files with the same + // signature can however have different bitstreams because of non-LVFPGA code + // differences. That is why we need another identifier to qualify the signature. + // The BIN checksum is a good candidate. std::string lvbitx_checksum(_lvbitx->get_bitstream_checksum()); - uint16_t download_fpga = (force_download || (_read_bitstream_checksum() != lvbitx_checksum)) ? 1 : 0; + uint16_t download_fpga = + (force_download || (_read_bitstream_checksum() != lvbitx_checksum)) ? 1 : 0; nirio_status_chain(_ensure_fpga_ready(), status); nirio_status_chain(_rpc_client.niusrprio_open_session( - _resource_name, bitfile_path, signature, download_fpga), status); + _resource_name, bitfile_path, signature, download_fpga), + status); _session_open = nirio_status_not_fatal(status); if (nirio_status_not_fatal(status)) { @@ -101,7 +105,8 @@ void niusrprio_session::close(bool skip_reset) if (_session_open) { nirio_status status = NiRio_Status_Success; - if (!skip_reset) reset(); + if (!skip_reset) + reset(); nirio_status_chain(_rpc_client.niusrprio_close_session(_resource_name), status); _session_open = false; } @@ -113,33 +118,37 @@ nirio_status niusrprio_session::reset() return _rpc_client.niusrprio_reset_device(_resource_name); } -nirio_status niusrprio_session::download_bitstream_to_flash(const std::string& bitstream_path) +nirio_status niusrprio_session::download_bitstream_to_flash( + const std::string& bitstream_path) { boost::unique_lock<boost::recursive_mutex> lock(_session_mutex); return _rpc_client.niusrprio_download_fpga_to_flash(_resource_name, bitstream_path); } niriok_proxy::sptr niusrprio_session::create_kernel_proxy( - const std::string& resource_name, - const std::string& rpc_port_name) + const std::string& resource_name, const std::string& rpc_port_name) { usrprio_rpc::usrprio_rpc_client temp_rpc_client("localhost", rpc_port_name); nirio_status status = temp_rpc_client.get_ctor_status(); std::string interface_path; - nirio_status_chain(temp_rpc_client.niusrprio_get_interface_path(resource_name, interface_path), status); + nirio_status_chain( + temp_rpc_client.niusrprio_get_interface_path(resource_name, interface_path), + status); niriok_proxy::sptr proxy = niriok_proxy::make_and_open(interface_path); - + return proxy; } nirio_status niusrprio_session::_verify_signature() { - //Validate the signature using the kernel proxy + // Validate the signature using the kernel proxy nirio_status status = NiRio_Status_Success; uint32_t sig_offset = 0; - nirio_status_chain(_riok_proxy->get_attribute(RIO_FPGA_DEFAULT_SIGNATURE_OFFSET, sig_offset), status); + nirio_status_chain( + _riok_proxy->get_attribute(RIO_FPGA_DEFAULT_SIGNATURE_OFFSET, sig_offset), + status); niriok_scoped_addr_space(_riok_proxy, FPGA, status); std::string signature; for (uint32_t i = 0; i < 8; i++) { @@ -163,9 +172,10 @@ std::string niusrprio_session::_read_bitstream_checksum() nirio_status status = NiRio_Status_Success; niriok_scoped_addr_space(_riok_proxy, BUS_INTERFACE, status); std::string usr_signature; - for (uint32_t i = 0; i < FPGA_USR_SIG_REG_SIZE; i+=4) { + for (uint32_t i = 0; i < FPGA_USR_SIG_REG_SIZE; i += 4) { uint32_t quarter_sig; - nirio_status_chain(_riok_proxy->peek(FPGA_USR_SIG_REG_BASE + i, quarter_sig), status); + nirio_status_chain( + _riok_proxy->peek(FPGA_USR_SIG_REG_BASE + i, quarter_sig), status); usr_signature += boost::str(boost::format("%08x") % quarter_sig); } boost::to_upper(usr_signature); @@ -177,16 +187,17 @@ nirio_status niusrprio_session::_write_bitstream_checksum(const std::string& che { nirio_status status = NiRio_Status_Success; niriok_scoped_addr_space(_riok_proxy, BUS_INTERFACE, status); - for (uint32_t i = 0; i < FPGA_USR_SIG_REG_SIZE; i+=4) { + for (uint32_t i = 0; i < FPGA_USR_SIG_REG_SIZE; i += 4) { uint32_t quarter_sig; try { std::stringstream ss; - ss << std::hex << checksum.substr(i*2,8); + ss << std::hex << checksum.substr(i * 2, 8); ss >> quarter_sig; } catch (std::exception&) { quarter_sig = 0; } - nirio_status_chain(_riok_proxy->poke(FPGA_USR_SIG_REG_BASE + i, quarter_sig), status); + nirio_status_chain( + _riok_proxy->poke(FPGA_USR_SIG_REG_BASE + i, quarter_sig), status); } return status; } @@ -196,8 +207,8 @@ nirio_status niusrprio_session::_ensure_fpga_ready() nirio_status status = NiRio_Status_Success; niriok_scoped_addr_space(_riok_proxy, BUS_INTERFACE, status); - //Verify that the Ettus FPGA loaded in the device. This may not be true if the - //user is switching to UHD after using LabVIEW FPGA. In that case skip this check. + // Verify that the Ettus FPGA loaded in the device. This may not be true if the + // user is switching to UHD after using LabVIEW FPGA. In that case skip this check. uint32_t pcie_fpga_signature = 0; nirio_status_chain(_riok_proxy->peek(FPGA_PCIE_SIG_REG, pcie_fpga_signature), status); //@TODO: Remove X300 specific constants for future products @@ -207,16 +218,14 @@ nirio_status niusrprio_session::_ensure_fpga_ready() uint32_t reg_data = 0xffffffff; nirio_status_chain(_riok_proxy->peek(FPGA_STATUS_REG, reg_data), status); - if (nirio_status_not_fatal(status) && (reg_data & FPGA_STATUS_DMA_ACTIVE_MASK)) - { - //In case this session was re-initialized *immediately* after the previous - //there is a small chance that the server is still finishing up cleaning up - //the DMA FIFOs. We currently don't have any feedback from the driver regarding - //this state so just wait. - std::this_thread::sleep_for( - std::chrono::milliseconds(FPGA_READY_TIMEOUT_IN_MS)); - - //Disable all FIFOs in the FPGA + if (nirio_status_not_fatal(status) && (reg_data & FPGA_STATUS_DMA_ACTIVE_MASK)) { + // In case this session was re-initialized *immediately* after the previous + // there is a small chance that the server is still finishing up cleaning up + // the DMA FIFOs. We currently don't have any feedback from the driver regarding + // this state so just wait. + std::this_thread::sleep_for(std::chrono::milliseconds(FPGA_READY_TIMEOUT_IN_MS)); + + // Disable all FIFOs in the FPGA for (size_t i = 0; i < _lvbitx->get_input_fifo_count(); i++) { _riok_proxy->poke(PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, i), DMA_CTRL_DISABLED); } @@ -224,19 +233,20 @@ nirio_status niusrprio_session::_ensure_fpga_ready() _riok_proxy->poke(PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, i), DMA_CTRL_DISABLED); } - //Disable all FIFOs in the kernel driver + // Disable all FIFOs in the kernel driver _riok_proxy->stop_all_fifos(); - boost::posix_time::ptime start_time = boost::posix_time::microsec_clock::local_time(); + boost::posix_time::ptime start_time = + boost::posix_time::microsec_clock::local_time(); boost::posix_time::time_duration elapsed; do { - std::this_thread::sleep_for(std::chrono::milliseconds(10)); //Avoid flooding the bus + std::this_thread::sleep_for( + std::chrono::milliseconds(10)); // Avoid flooding the bus elapsed = boost::posix_time::microsec_clock::local_time() - start_time; nirio_status_chain(_riok_proxy->peek(FPGA_STATUS_REG, reg_data), status); - } while ( - nirio_status_not_fatal(status) && - (reg_data & FPGA_STATUS_DMA_ACTIVE_MASK) && - elapsed.total_milliseconds() < FPGA_READY_TIMEOUT_IN_MS); + } while (nirio_status_not_fatal(status) + && (reg_data & FPGA_STATUS_DMA_ACTIVE_MASK) + && elapsed.total_milliseconds() < FPGA_READY_TIMEOUT_IN_MS); nirio_status_chain(_riok_proxy->peek(FPGA_STATUS_REG, reg_data), status); if (nirio_status_not_fatal(status) && (reg_data & FPGA_STATUS_DMA_ACTIVE_MASK)) { @@ -247,4 +257,4 @@ nirio_status niusrprio_session::_ensure_fpga_ready() return status; } -}} +}} // namespace uhd::niusrprio |