|
@@ -256,11 +256,13 @@ void sctp_transport_route(struct sctp_transport *transport,
|
|
|
|
|
|
dst = af->get_dst(asoc, daddr, saddr);
|
|
dst = af->get_dst(asoc, daddr, saddr);
|
|
|
|
|
|
- if (saddr)
|
|
|
|
|
|
+ if (saddr) {
|
|
memcpy(&transport->saddr_h, saddr, sizeof(union sctp_addr));
|
|
memcpy(&transport->saddr_h, saddr, sizeof(union sctp_addr));
|
|
- else
|
|
|
|
- af->get_saddr(asoc, dst, daddr, &transport->saddr_h);
|
|
|
|
- flip_to_n(&transport->saddr, &transport->saddr_h);
|
|
|
|
|
|
+ flip_to_n(&transport->saddr, &transport->saddr_h);
|
|
|
|
+ } else {
|
|
|
|
+ af->get_saddr(asoc, dst, &transport->ipaddr, &transport->saddr);
|
|
|
|
+ flip_to_h(&transport->saddr_h, &transport->saddr);
|
|
|
|
+ }
|
|
|
|
|
|
transport->dst = dst;
|
|
transport->dst = dst;
|
|
if ((transport->param_flags & SPP_PMTUD_DISABLE) && transport->pathmtu) {
|
|
if ((transport->param_flags & SPP_PMTUD_DISABLE) && transport->pathmtu) {
|