Commit e78d20ff authored by Simon Giesecke's avatar Simon Giesecke

Problem: test_radio_dish_udp_ipv6 triggers assertion under Windows

Solution: fix handling of sockaddr in recvfrom
parent dd1c87f9
...@@ -425,8 +425,8 @@ void zmq::udp_engine_t::restart_output () ...@@ -425,8 +425,8 @@ void zmq::udp_engine_t::restart_output ()
void zmq::udp_engine_t::in_event () void zmq::udp_engine_t::in_event ()
{ {
struct sockaddr_in in_address; sockaddr_storage in_address;
socklen_t in_addrlen = sizeof (sockaddr_in); socklen_t in_addrlen = sizeof (sockaddr_storage);
#ifdef ZMQ_HAVE_WINDOWS #ifdef ZMQ_HAVE_WINDOWS
int nbytes = recvfrom (fd, (char *) in_buffer, MAX_UDP_MSG, 0, int nbytes = recvfrom (fd, (char *) in_buffer, MAX_UDP_MSG, 0,
(sockaddr *) &in_address, &in_addrlen); (sockaddr *) &in_address, &in_addrlen);
...@@ -459,7 +459,8 @@ void zmq::udp_engine_t::in_event () ...@@ -459,7 +459,8 @@ void zmq::udp_engine_t::in_event ()
msg_t msg; msg_t msg;
if (options.raw_socket) { if (options.raw_socket) {
sockaddr_to_msg (&msg, &in_address); zmq_assert (in_address.ss_family == AF_INET);
sockaddr_to_msg (&msg, reinterpret_cast<sockaddr_in *> (&in_address));
body_size = nbytes; body_size = nbytes;
body_offset = 0; body_offset = 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment