From b920557788fc5435915584bec6ab16a97d7c6090 Mon Sep 17 00:00:00 2001 From: Josh Blum Date: Tue, 27 Apr 2010 09:42:36 -0700 Subject: work on controlling the socket buffer sizes from the front end api --- host/lib/usrp/usrp2/usrp2_impl.cpp | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'host/lib/usrp') diff --git a/host/lib/usrp/usrp2/usrp2_impl.cpp b/host/lib/usrp/usrp2/usrp2_impl.cpp index 4079357f9..ffcdbb43d 100644 --- a/host/lib/usrp/usrp2/usrp2_impl.cpp +++ b/host/lib/usrp/usrp2/usrp2_impl.cpp @@ -24,6 +24,7 @@ #include #include #include +#include #include #include //htonl and ntohl #include @@ -117,6 +118,26 @@ device::sptr usrp2::make(const device_addr_t &device_addr){ device_addr["addr"], num2str(USRP2_UDP_DATA_PORT) ); + //resize the recv data transport buffers + if (device_addr.has_key("recv_buff_size")){ + size_t num_byes = size_t(boost::lexical_cast(device_addr["recv_buff_size"])); + size_t actual_bytes = data_transport->set_recv_buff_size(num_byes); + std::cout << boost::format( + "Target recv buffer size: %d" + "Actual recv byffer size: %d" + ) % num_byes % actual_bytes << std::endl; + } + + //resize the send data transport buffers + if (device_addr.has_key("send_buff_size")){ + size_t num_byes = size_t(boost::lexical_cast(device_addr["send_buff_size"])); + size_t actual_bytes = data_transport->set_send_buff_size(num_byes); + std::cout << boost::format( + "Target send buffer size: %d" + "Actual send byffer size: %d" + ) % num_byes % actual_bytes << std::endl; + } + //create the usrp2 implementation guts return device::sptr( new usrp2_impl(ctrl_transport, data_transport) -- cgit v1.2.3