[SCTP] bug: endianness problem in sctp_getsockopt_sctp_status()
authorAl Viro <viro@zeniv.linux.org.uk>
Tue, 21 Nov 2006 01:03:18 +0000 (17:03 -0800)
committerDavid S. Miller <davem@sunset.davemloft.net>
Sun, 3 Dec 2006 05:26:28 +0000 (21:26 -0800)
Again, invalid sockaddr passed to userland - host-endiand sin_port.
Potential leak, again, but less dramatic than in previous case.

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sctp/socket.c

index f4d13ab79f49c1469a98e9ba71f17da2127ee3eb..b6e038a387c201054678adfe92c2169638af44f7 100644 (file)
@@ -3217,8 +3217,8 @@ static int sctp_getsockopt_sctp_status(struct sock *sk, int len,
        status.sstat_outstrms = asoc->c.sinit_num_ostreams;
        status.sstat_fragmentation_point = asoc->frag_point;
        status.sstat_primary.spinfo_assoc_id = sctp_assoc2id(transport->asoc);
-       memcpy(&status.sstat_primary.spinfo_address,
-              &(transport->ipaddr), sizeof(union sctp_addr));
+       flip_to_n((union sctp_addr *)&status.sstat_primary.spinfo_address,
+              &transport->ipaddr);
        /* Map ipv4 address into v4-mapped-on-v6 address.  */
        sctp_get_pf_specific(sk->sk_family)->addr_v4map(sctp_sk(sk),
                (union sctp_addr *)&status.sstat_primary.spinfo_address);