diff options
author | Michio Honda <micchie@sfc.wide.ad.jp> | 2011-04-26 20:19:36 +0900 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-06-02 02:04:53 -0700 |
commit | 8a07eb0a50aebc8c95478d49c28c7f8419a26cef (patch) | |
tree | a98ab91189d1dd0781d7768c0b0d395c1919d571 /net/sctp/outqueue.c | |
parent | 7dc04d712203eecdc1435a4cd135935c4a297be5 (diff) | |
download | linux-8a07eb0a50aebc8c95478d49c28c7f8419a26cef.tar.gz linux-8a07eb0a50aebc8c95478d49c28c7f8419a26cef.tar.bz2 linux-8a07eb0a50aebc8c95478d49c28c7f8419a26cef.zip |
sctp: Add ASCONF operation on the single-homed host
In this case, the SCTP association transmits an ASCONF packet
including addition of the new IP address and deletion of the old
address. This patch implements this functionality.
In this case, the ASCONF chunk is added to the beginning of the
queue, because the other chunks cannot be transmitted in this state.
Signed-off-by: Michio Honda <micchie@sfc.wide.ad.jp>
Signed-off-by: YOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>
Acked-by: Wei Yongjun <yjwei@cn.fujitsu.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sctp/outqueue.c')
-rw-r--r-- | net/sctp/outqueue.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/net/sctp/outqueue.c b/net/sctp/outqueue.c index 1c88c8911dc5..edc753297a49 100644 --- a/net/sctp/outqueue.c +++ b/net/sctp/outqueue.c @@ -754,6 +754,16 @@ static int sctp_outq_flush(struct sctp_outq *q, int rtx_timeout) */ list_for_each_entry_safe(chunk, tmp, &q->control_chunk_list, list) { + /* RFC 5061, 5.3 + * F1) This means that until such time as the ASCONF + * containing the add is acknowledged, the sender MUST + * NOT use the new IP address as a source for ANY SCTP + * packet except on carrying an ASCONF Chunk. + */ + if (asoc->src_out_of_asoc_ok && + chunk->chunk_hdr->type != SCTP_CID_ASCONF) + continue; + list_del_init(&chunk->list); /* Pick the right transport to use. */ @@ -881,6 +891,9 @@ static int sctp_outq_flush(struct sctp_outq *q, int rtx_timeout) } } + if (q->asoc->src_out_of_asoc_ok) + goto sctp_flush_out; + /* Is it OK to send data chunks? */ switch (asoc->state) { case SCTP_STATE_COOKIE_ECHOED: |