diff options
author | Martin Braun <martin.braun@ettus.com> | 2017-07-13 15:57:32 -0700 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2017-10-04 14:58:41 -0700 |
commit | ad1e0bc855cfa418f1a297c64e44a8352e80c4ee (patch) | |
tree | 94872818648329f110d604caf48f216eafd7987a | |
parent | ac6d27348d4e01035183423a031445808c0f6b90 (diff) | |
download | uhd-ad1e0bc855cfa418f1a297c64e44a8352e80c4ee.tar.gz uhd-ad1e0bc855cfa418f1a297c64e44a8352e80c4ee.tar.bz2 uhd-ad1e0bc855cfa418f1a297c64e44a8352e80c4ee.zip |
udp: Added option to query local address of socket
-rw-r--r-- | host/include/uhd/transport/udp_zero_copy.hpp | 13 | ||||
-rw-r--r-- | host/lib/transport/udp_wsa_zero_copy.cpp | 15 | ||||
-rw-r--r-- | host/lib/transport/udp_zero_copy.cpp | 11 |
3 files changed, 38 insertions, 1 deletions
diff --git a/host/include/uhd/transport/udp_zero_copy.hpp b/host/include/uhd/transport/udp_zero_copy.hpp index 851e004d7..5acd8dc56 100644 --- a/host/include/uhd/transport/udp_zero_copy.hpp +++ b/host/include/uhd/transport/udp_zero_copy.hpp @@ -68,7 +68,20 @@ public: const device_addr_t &hints = device_addr_t() ); + /*! Return the local port of the UDP connection + * + * Port is in host byte order. No funny business here. + * + * \returns Port number or 0 if port number couldn't be identified. + */ virtual uint16_t get_local_port(void) const = 0; + + /*! Return the local IP address of the UDP connection as a dotted string. + * + * \returns IP address as a string or empty string if the IP address could + * not be identified. + */ + virtual std::string get_local_addr(void) const = 0; }; }} //namespace diff --git a/host/lib/transport/udp_wsa_zero_copy.cpp b/host/lib/transport/udp_wsa_zero_copy.cpp index 66af394a9..68e94d319 100644 --- a/host/lib/transport/udp_wsa_zero_copy.cpp +++ b/host/lib/transport/udp_wsa_zero_copy.cpp @@ -286,6 +286,21 @@ public: return local_port; } + std::string get_local_addr(void) const { + // Behold the beauty of winsock + struct sockaddr_in addr_info; + int addr_len = sizeof(addr_info); + std::string local_addr; + if (getsockname(_sock_fd, (SOCKADDR*) &addr_info, &addr_len) == 0) { + // inet_ntoa() guarantees either NULL or null-terminated array + char *local_ip = inet_ntoa(addr_info.sin_addr); + if (local_ip) { + local_addr = std::string(local_ip); + } + } + return local_addr; + } + //! Read back the socket's buffer space reserved for receives size_t get_recv_buff_size(void) { int recv_buff_size = 0; diff --git a/host/lib/transport/udp_zero_copy.cpp b/host/lib/transport/udp_zero_copy.cpp index 814f41500..cd271eccf 100644 --- a/host/lib/transport/udp_zero_copy.cpp +++ b/host/lib/transport/udp_zero_copy.cpp @@ -244,7 +244,16 @@ public: size_t get_num_send_frames(void) const {return _num_send_frames;} size_t get_send_frame_size(void) const {return _send_frame_size;} - uint16_t get_local_port(void) const {return _socket->local_endpoint().port();} + + uint16_t get_local_port(void) const + { + return _socket->local_endpoint().port(); + } + + std::string get_local_addr(void) const + { + return _socket->local_endpoint().address().to_string(); + } private: //memory management -> buffers and fifos |