log_debug("Bind received port=%u (network order)\n", mptp_addr->dests[0].port);
port = ntohs(mptp_addr->dests[0].port);
+ if (port == 0)
+ port = get_next_free_port();
if (unlikely(port == 0 || port >= MAX_MPTP_PORT)) {
log_error("Invalid value for sockaddr port (%u)\n", port);
int err, copied;
int i;
struct sockaddr_mptp *ret_addr = (struct sockaddr_mptp *) msg->msg_name;
+ ret_addr->count = 0;
log_debug("Trying to receive sock=%p sk=%p flags=%d\n", sock, sk, flags);
log_error("skb_copy_datagram_iovec\n");
goto out_free;
}
+ log_debug("Received %d bytes\n", copied);
sock_recv_ts_and_drops(msg, sk, skb);
- if (ret_addr)
+ if (ret_addr) {
memcpy(&ret_addr->dests[i], &mptp_addr->dests[0], sizeof(ret_addr->dests[i]));
+ ret_addr->dests[i].bytes = copied;
+ }
err = copied;
out_free:
skb_free_datagram(sk, skb);
+ if (i == msg->msg_iovlen - 1)
+ break;
+
skb = skb_recv_datagram(sk, flags, 1, &err);
if (likely(err == -EAGAIN)) {
log_debug("No more skbs in the queue, returning...\n");