aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
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
5103 __u16 sport; 5103 __u16 sport;
5104 __u16 dport; 5104 __u16 dport;
5105 __u32 vtag; 5105 __u32 vtag;
5106 union sctp_addr tmp;
5106 5107
5107 /* Get the source and destination port from the inbound packet. */ 5108 /* Get the source and destination port from the inbound packet. */
5108 sport = ntohs(chunk->sctp_hdr->dest); 5109 sport = ntohs(chunk->sctp_hdr->dest);
@@ -5140,7 +5141,8 @@ static struct sctp_packet *sctp_ootb_pkt_new(const struct sctp_association *asoc
5140 /* Cache a route for the transport with the chunk's destination as 5141 /* Cache a route for the transport with the chunk's destination as
5141 * the source address. 5142 * the source address.
5142 */ 5143 */
5143 sctp_transport_route(transport, (union sctp_addr *)&chunk->dest, 5144 flip_to_n(&tmp, &chunk->dest);
5145 sctp_transport_route(transport, &tmp,
5144 sctp_sk(sctp_get_ctl_sock())); 5146 sctp_sk(sctp_get_ctl_sock()));
5145 5147
5146 packet = sctp_packet_init(&transport->packet, transport, sport, dport); 5148 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,
253 struct sctp_af *af = transport->af_specific; 253 struct sctp_af *af = transport->af_specific;
254 union sctp_addr *daddr = &transport->ipaddr; 254 union sctp_addr *daddr = &transport->ipaddr;
255 struct dst_entry *dst; 255 struct dst_entry *dst;
256 union sctp_addr tmp;
257 flip_to_n(&tmp, saddr);
258 256
259 dst = af->get_dst(asoc, daddr, &tmp); 257 dst = af->get_dst(asoc, daddr, saddr);
260 258
261 if (saddr) { 259 if (saddr)
262 memcpy(&transport->saddr_h, saddr, sizeof(union sctp_addr)); 260 memcpy(&transport->saddr, saddr, sizeof(union sctp_addr));
263 flip_to_n(&transport->saddr, &transport->saddr_h); 261 else
264 } else {
265 af->get_saddr(asoc, dst, daddr, &transport->saddr); 262 af->get_saddr(asoc, dst, daddr, &transport->saddr);
266 flip_to_h(&transport->saddr_h, &transport->saddr);
267 }
268 263
264 flip_to_h(&transport->saddr_h, &transport->saddr);
269 transport->dst = dst; 265 transport->dst = dst;
270 if ((transport->param_flags & SPP_PMTUD_DISABLE) && transport->pathmtu) { 266 if ((transport->param_flags & SPP_PMTUD_DISABLE) && transport->pathmtu) {
271 return; 267 return;