// // Copyright 2019 Ettus Research, a National Instruments Brand // // SPDX-License-Identifier: GPL-3.0-or-later // #ifndef INCLUDED_LIBUHD_RFNOC_DEVICE_HPP #define INCLUDED_LIBUHD_RFNOC_DEVICE_HPP #include #include #include #include #include #include namespace uhd { namespace rfnoc { namespace detail { /*! Extends uhd::device with features required to operate in an rfnoc_graph */ class rfnoc_device : public uhd::device { public: using sptr = boost::shared_ptr; // FIXME make std::shared_ptr when // uhd::device is ready rfnoc_device() { _type = uhd::device::USRP; _tree = uhd::property_tree::make(); } /*! Return a reference to the mb_iface for a given motherboard */ uhd::rfnoc::mb_iface& get_mb_iface(const size_t mb_idx) { if (mb_idx >= _iface_registry.size()) { throw uhd::index_error( std::string("Cannot get mb_iface, invalid motherboard index: ") + std::to_string(mb_idx)); } return *_iface_registry.at(mb_idx); } //! Return a reference to an MB controller mb_controller::sptr get_mb_controller(const size_t mb_idx) const { return _mbc_registry.at(mb_idx); } /*! Return the number of motherboards in this device */ size_t get_num_mbs() { return _iface_registry.size(); } //! Directly getting a streamer no longer supported uhd::rx_streamer::sptr get_rx_stream(const stream_args_t&) { UHD_THROW_INVALID_CODE_PATH(); } //! Directly getting a streamer no longer supported uhd::tx_streamer::sptr get_tx_stream(const stream_args_t&) { UHD_THROW_INVALID_CODE_PATH(); } //! Directly getting async messages no longer supported bool recv_async_msg(uhd::async_metadata_t&, double) { UHD_THROW_INVALID_CODE_PATH(); } protected: void register_mb_iface(const size_t mb_idx, mb_iface* mb_if) { _iface_registry.emplace(mb_idx, std::move(mb_if)); } void register_mb_controller(const size_t mb_idx, mb_controller::sptr mbc) { _mbc_registry.emplace(mb_idx, mbc); } private: std::unordered_map _iface_registry; std::unordered_map _mbc_registry; }; // class rfnoc_device }}} // namespace uhd::rfnoc::detail #endif /* INCLUDED_LIBUHD_RFNOC_DEVICE_HPP */