summaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2006-11-21 02:13:21 +0100
committerDavid S. Miller <davem@sunset.davemloft.net>2006-12-03 06:26:54 +0100
commitd448388bdaca946aa2b07973cb72a9b834e530bf (patch)
tree9189eec85228062327745cee6f121af9f98a9364 /net
parent[SCTP]: Pass net-endian to ->get_dst(). (diff)
downloadlinux-d448388bdaca946aa2b07973cb72a9b834e530bf.tar.xz
linux-d448388bdaca946aa2b07973cb72a9b834e530bf.zip
[SCTP]: sctp_transport_route() switched to net-endian.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r--net/sctp/sm_statefuns.c4
-rw-r--r--net/sctp/transport.c14
2 files changed, 8 insertions, 10 deletions
diff --git a/net/sctp/sm_statefuns.c b/net/sctp/sm_statefuns.c
index 0848309773a5..42377f75ee1c 100644
--- a/net/sctp/sm_statefuns.c
+++ b/net/sctp/sm_statefuns.c
@@ -5103,6 +5103,7 @@ static struct sctp_packet *sctp_ootb_pkt_new(const struct sctp_association *asoc
__u16 sport;
__u16 dport;
__u32 vtag;
+ union sctp_addr tmp;
/* Get the source and destination port from the inbound packet. */
sport = ntohs(chunk->sctp_hdr->dest);
@@ -5140,7 +5141,8 @@ static struct sctp_packet *sctp_ootb_pkt_new(const struct sctp_association *asoc
/* Cache a route for the transport with the chunk's destination as
* the source address.
*/
- sctp_transport_route(transport, (union sctp_addr *)&chunk->dest,
+ flip_to_n(&tmp, &chunk->dest);
+ sctp_transport_route(transport, &tmp,
sctp_sk(sctp_get_ctl_sock()));
packet = sctp_packet_init(&transport->packet, transport, sport, dport);
diff --git a/net/sctp/transport.c b/net/sctp/transport.c
index 33e7d85f1119..d1b6834a3a47 100644
--- a/net/sctp/transport.c
+++ b/net/sctp/transport.c
@@ -253,19 +253,15 @@ void sctp_transport_route(struct sctp_transport *transport,
struct sctp_af *af = transport->af_specific;
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, &tmp);
+ dst = af->get_dst(asoc, daddr, saddr);
- if (saddr) {
- memcpy(&transport->saddr_h, saddr, sizeof(union sctp_addr));
- flip_to_n(&transport->saddr, &transport->saddr_h);
- } else {
+ if (saddr)
+ memcpy(&transport->saddr, saddr, sizeof(union sctp_addr));
+ else
af->get_saddr(asoc, dst, daddr, &transport->saddr);
- flip_to_h(&transport->saddr_h, &transport->saddr);
- }
+ flip_to_h(&transport->saddr_h, &transport->saddr);
transport->dst = dst;
if ((transport->param_flags & SPP_PMTUD_DISABLE) && transport->pathmtu) {
return;