aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp/mpmd/mpmd_impl.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/usrp/mpmd/mpmd_impl.hpp')
-rw-r--r--host/lib/usrp/mpmd/mpmd_impl.hpp130
1 files changed, 58 insertions, 72 deletions
diff --git a/host/lib/usrp/mpmd/mpmd_impl.hpp b/host/lib/usrp/mpmd/mpmd_impl.hpp
index 3143378dd..7b81be0f6 100644
--- a/host/lib/usrp/mpmd/mpmd_impl.hpp
+++ b/host/lib/usrp/mpmd/mpmd_impl.hpp
@@ -1,22 +1,13 @@
//
-// Copyright 2017 Ettus Research (National Instruments)
+// Copyright 2017 Ettus Research, a National Instruments Company
//
-// This program is free software: you can redistribute it and/or modify
-// it under the terms of the GNU General Public License as published by
-// the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see <http://www.gnu.org/licenses/>.
+// SPDX-License-Identifier: GPL-3.0
//
#ifndef INCLUDED_MPMD_IMPL_HPP
#define INCLUDED_MPMD_IMPL_HPP
+
+#include "mpmd_xport_mgr.hpp"
#include "../../utils/rpc.hpp"
#include "../device3/device3_impl.hpp"
#include <uhd/stream.hpp>
@@ -25,17 +16,9 @@
#include <uhd/utils/tasks.hpp>
#include <uhd/transport/muxed_zero_copy_if.hpp>
#include <map>
+#include <memory>
-static const size_t MPMD_RX_SW_BUFF_SIZE_ETH = 0x2000000;//32MiB For an ~8k frame size any size >32MiB is just wasted buffer space
-static const size_t MPMD_RX_SW_BUFF_SIZE_ETH_MACOS = 0x100000; //1Mib
-
-static const size_t MPM_DISCOVERY_PORT = 49600;
-static const size_t MPM_RPC_PORT = 49601;
-static const char MPM_RPC_GET_LAST_ERROR_CMD[] = "get_last_error";
-static const char MPM_DISCOVERY_CMD[] = "MPM-DISC";
-static const char MPM_ECHO_CMD[] = "MPM-ECHO";
-static const size_t MPMD_10GE_DATA_FRAME_MAX_SIZE = 8000; // CHDR packet size in bytes
-
+namespace uhd { namespace mpmd {
/*! Stores all attributes specific to a single MPM device
*/
@@ -93,28 +76,42 @@ class mpmd_mboard_impl
/*************************************************************************
* API
************************************************************************/
- uhd::sid_t allocate_sid(const uint16_t port,
- const uhd::sid_t address,
- const uint32_t xbar_src_addr,
- const uint32_t xbar_src_dst,
- const uint32_t dst_addr
- );
-
//! Configure a crossbar to have a certain local address
void set_xbar_local_addr(const size_t xbar_index, const size_t local_addr);
//! Return the local address of a given crossbar
- size_t get_xbar_local_addr(const size_t xbar_index) {
+ size_t get_xbar_local_addr(const size_t xbar_index) const {
return xbar_local_addrs.at(xbar_index);
}
+ //! Device-specific make_transport implementation
+ //
+ // A major difference to the mpmd_impl::make_transport() is the meaning of
+ // the first argument (\p sid). mpmd_impl::make_transport() will add a
+ // source part to the SID which needs to be taken into account in this
+ // function.
+ //
+ // \param sid The full SID of this transport (UHD to device)
+ // \param xport_type Transport type (CTRL, RX_DATA, ...)
+ // \param args Any kind of args passed in via get_?x_stream()
+ uhd::both_xports_t make_transport(
+ const sid_t& sid,
+ usrp::device3_impl::xport_type_t xport_type,
+ const uhd::device_addr_t& args
+ );
+
+
+ uhd::device_addr_t get_rx_hints() const;
+ uhd::device_addr_t get_tx_hints() const;
+
private:
/*************************************************************************
* Private methods
************************************************************************/
/*! Renew the claim onto the device.
*
- * This is meant to be called repeatedly, e.g., using a UHD task.
+ * This is meant to be called repeatedly, e.g., using a UHD task. See also
+ * _claimer_task.
*/
bool claim();
@@ -130,10 +127,11 @@ class mpmd_mboard_impl
// what we use when addressing a crossbar in a CHDR header.
std::vector<size_t> xbar_local_addrs;
-
/*! Continuously reclaims the device.
*/
uhd::task::sptr _claimer_task;
+
+ uhd::mpmd::xport::mpmd_xport_mgr::uptr _xport_mgr;
};
@@ -145,16 +143,36 @@ class mpmd_mboard_impl
*/
class mpmd_impl : public uhd::usrp::device3_impl
{
- public:
+public:
+ //! Port on which the discovery process is listening
+ static const size_t MPM_DISCOVERY_PORT = 49600;
+ //! Port on which the RPC process is listening
+ static const size_t MPM_RPC_PORT = 49601;
+ //! This is the command that needs to be sent to the discovery port to
+ // trigger a response.
+ static const std::string MPM_DISCOVERY_CMD;
+ //! This is the command that will let you measure ping responses from the
+ // device via the discovery process. Useful for MTU discovery.
+ static const std::string MPM_ECHO_CMD;
+ //! This is the RPC command that will return the last known error from MPM.
+ static const std::string MPM_RPC_GET_LAST_ERROR_CMD;
+
+ /**************************************************************************
+ * Structors
+ ************************************************************************/
mpmd_impl(const uhd::device_addr_t& device_addr);
~mpmd_impl();
+ /**************************************************************************
+ * API
+ ************************************************************************/
uhd::both_xports_t make_transport(const uhd::sid_t&,
uhd::usrp::device3_impl::xport_type_t,
const uhd::device_addr_t&);
private:
uhd::device_addr_t get_rx_hints(size_t mb_index);
+ uhd::device_addr_t get_tx_hints(size_t mb_index);
/*************************************************************************
* Private methods/helpers
@@ -185,49 +203,14 @@ class mpmd_impl : public uhd::usrp::device3_impl
*/
size_t allocate_xbar_local_addr();
- /*! Return the index of the motherboard carrying the crossbar at \p remote_addr
+ /*! Return the index of the motherboard given the local address of a
+ * crossbar
*/
- size_t identify_mboard_by_sid(const size_t remote_addr);
-
- using xport_info_t = std::map<std::string, std::string>;
- using xport_info_list_t = std::vector<std::map<std::string, std::string>>;
-
- uhd::both_xports_t make_transport_udp(
- const size_t mb_index,
- xport_info_t &xport_info,
- const xport_type_t xport_type,
- const uhd::device_addr_t& xport_args
- );
-
-#ifdef HAVE_LIBERIO
- /*! Create a muxed liberio transport for control packets */
- uhd::transport::muxed_zero_copy_if::sptr make_muxed_liberio_xport(
- const std::string &tx_dev,
- const std::string &rx_dev,
- const uhd::transport::zero_copy_xport_params &buff_args,
- const size_t max_muxed_ports
- );
-
- uhd::both_xports_t make_transport_liberio(
- const size_t mb_index,
- xport_info_t &xport_info,
- const xport_type_t xport_type,
- const uhd::device_addr_t& xport_args
- );
-#endif
+ size_t identify_mboard_by_xbar_addr(const size_t xbar_addr) const;
/*************************************************************************
* Private attributes
************************************************************************/
- // FIXME move the next two into their own transport manager class
- //! Control transport for one liberio connection
- uhd::transport::muxed_zero_copy_if::sptr _ctrl_dma_xport;
- //! Control transport for one liberio connection
- uhd::transport::muxed_zero_copy_if::sptr _async_msg_dma_xport;
-
- uhd::dict<std::string, std::string> recv_args;
- uhd::dict<std::string, std::string> send_args;
-
//! Stores the args with which the device was originally initialized
uhd::device_addr_t _device_args;
//! Stores a list of mboard references
@@ -237,9 +220,12 @@ class mpmd_impl : public uhd::usrp::device3_impl
// No-one touches this except allocate_xbar_local_addr(), gotcha?
size_t _xbar_local_addr_ctr = 2;
+ // TODO make sure this can't wrap
size_t _sid_framer;
};
+}} /* namespace uhd::mpmd */
+
uhd::device_addrs_t mpmd_find(const uhd::device_addr_t& hint_);
#endif /* INCLUDED_MPMD_IMPL_HPP */