mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 06:27:45 +00:00
IPv4: recvfrom() shouldn't care about what's in the outparam on entry.
This commit is contained in:
parent
ea6a537b70
commit
a9dc332a11
1 changed files with 3 additions and 7 deletions
|
@ -133,18 +133,12 @@ ssize_t IPv4Socket::sendto(const void* data, size_t data_length, int flags, cons
|
||||||
ssize_t IPv4Socket::recvfrom(void* buffer, size_t buffer_length, int flags, sockaddr* addr, socklen_t* addr_length)
|
ssize_t IPv4Socket::recvfrom(void* buffer, size_t buffer_length, int flags, sockaddr* addr, socklen_t* addr_length)
|
||||||
{
|
{
|
||||||
(void)flags;
|
(void)flags;
|
||||||
if (addr->sa_family != AF_INET) {
|
|
||||||
kprintf("recvfrom: Bad address family: %u is not AF_INET!\n", addr->sa_family);
|
|
||||||
return -EAFNOSUPPORT;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (*addr_length < sizeof(sockaddr_in))
|
if (*addr_length < sizeof(sockaddr_in))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
*addr_length = sizeof(sockaddr_in);
|
|
||||||
|
|
||||||
auto peer_address = IPv4Address((const byte*)&((const sockaddr_in*)addr)->sin_addr.s_addr);
|
auto peer_address = IPv4Address((const byte*)&((const sockaddr_in*)addr)->sin_addr.s_addr);
|
||||||
#ifdef IPV4_SOCKET_DEBUG
|
#ifdef IPV4_SOCKET_DEBUG
|
||||||
kprintf("recvfrom: peer_address=%s\n", peer_address.to_string().characters());
|
kprintf("recvfrom: type=%d, source_port=%u\n", type(), source_port());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ByteBuffer packet_buffer;
|
ByteBuffer packet_buffer;
|
||||||
|
@ -176,6 +170,8 @@ ssize_t IPv4Socket::recvfrom(void* buffer, size_t buffer_length, int flags, sock
|
||||||
|
|
||||||
auto& ia = *(sockaddr_in*)addr;
|
auto& ia = *(sockaddr_in*)addr;
|
||||||
memcpy(&ia.sin_addr, &m_destination_address, sizeof(IPv4Address));
|
memcpy(&ia.sin_addr, &m_destination_address, sizeof(IPv4Address));
|
||||||
|
ia.sin_family = AF_INET;
|
||||||
|
*addr_length = sizeof(sockaddr_in);
|
||||||
|
|
||||||
if (type() == SOCK_RAW) {
|
if (type() == SOCK_RAW) {
|
||||||
ASSERT(buffer_length >= ipv4_packet.payload_size());
|
ASSERT(buffer_length >= ipv4_packet.payload_size());
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue