diff --git a/Socket/ReadWritePolicy.cc b/Socket/ReadWritePolicy.cc index c8426044fca075c8edc8ea94f3fe942a05e746b1..9ca08ad84c27a9a7f3dc075288465959cc8492c0 100644 --- a/Socket/ReadWritePolicy.cc +++ b/Socket/ReadWritePolicy.cc @@ -61,11 +61,11 @@ prefix_ unsigned senf::ReadablePolicy::read(FileHandle handle, char * buffer, prefix_ unsigned senf::ReadablePolicy::do_readfrom(FileHandle handle, char * buffer, unsigned size, - struct ::sockaddr * addr, socklen_t len) + struct ::sockaddr * addr, socklen_t * len) { int rv = -1; do { - rv = ::recvfrom(handle.fd(),buffer, size, 0, addr, &len); + rv = ::recvfrom(handle.fd(),buffer, size, 0, addr, len); if (rv < 0) switch (errno) { case EINTR: diff --git a/Socket/ReadWritePolicy.cti b/Socket/ReadWritePolicy.cti index 618c2d3ffcb1dde0fb97bc1982e464ea679d9a0c..edb7915c94deafbdfe5b7a5e21cf565b481681ca 100644 --- a/Socket/ReadWritePolicy.cti +++ b/Socket/ReadWritePolicy.cti @@ -38,7 +38,7 @@ readfrom(ClientSocketHandle<SPolicy> handle, char * buffer, unsigned size, typename SPolicy::AddressingPolicy::Address & address, typename IfCommunicationPolicyIs<SPolicy,UnconnectedCommunicationPolicy>::type *) { - return do_readfrom(handle, buffer, size, address.sockaddr_p(), address.socklen()); + return do_readfrom(handle, buffer, size, address.sockaddr_p(), address.socklen_p()); } #else template <class SPolicy> diff --git a/Socket/ReadWritePolicy.hh b/Socket/ReadWritePolicy.hh index 023b3f66476b80ed156da6190c8bcff0421d91ca..24d5cea6bf246a5e8c1bf9bd37d13ee35c8e9902 100644 --- a/Socket/ReadWritePolicy.hh +++ b/Socket/ReadWritePolicy.hh @@ -78,7 +78,7 @@ namespace senf { private: static unsigned do_readfrom(FileHandle handle, char * buffer, unsigned size, - struct ::sockaddr * addr, socklen_t len); + struct ::sockaddr * addr, socklen_t * len); }; /** \brief ReadPolicy for unreadable sockets