[SCTP]: Pass net-endian to ->get_dst().

all instances are actually endian-agnostic...

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Al Viro 2006-11-20 17:13:01 -08:00 committed by David S. Miller
parent d3f7a54a29
commit cb7b4a0dcf

View File

@ -234,7 +234,7 @@ void sctp_transport_pmtu(struct sctp_transport *transport)
{
struct dst_entry *dst;
dst = transport->af_specific->get_dst(NULL, &transport->ipaddr_h, NULL);
dst = transport->af_specific->get_dst(NULL, &transport->ipaddr, NULL);
if (dst) {
transport->pathmtu = dst_mtu(dst);
@ -251,16 +251,18 @@ void sctp_transport_route(struct sctp_transport *transport,
{
struct sctp_association *asoc = transport->asoc;
struct sctp_af *af = transport->af_specific;
union sctp_addr *daddr = &transport->ipaddr_h;
union sctp_addr *daddr = &transport->ipaddr;
struct dst_entry *dst;
union sctp_addr tmp;
flip_to_n(&tmp, saddr);
dst = af->get_dst(asoc, daddr, saddr);
dst = af->get_dst(asoc, daddr, &tmp);
if (saddr) {
memcpy(&transport->saddr_h, saddr, sizeof(union sctp_addr));
flip_to_n(&transport->saddr, &transport->saddr_h);
} else {
af->get_saddr(asoc, dst, &transport->ipaddr, &transport->saddr);
af->get_saddr(asoc, dst, daddr, &transport->saddr);
flip_to_h(&transport->saddr_h, &transport->saddr);
}