• Xin Long's avatar
    sctp: fix the transports round robin issue when init is retransmitted · c56f6820
    Xin Long authored
    commit 39d2adeb upstream.
    
    prior to this patch, at the beginning if we have two paths in one assoc,
    they may have the same params other than the last_time_heard, it will try
    the paths like this:
    
    1st cycle
      try trans1 fail.
      then trans2 is selected.(cause it's last_time_heard is after trans1).
    
    2nd cycle:
      try  trans2 fail
      then trans2 is selected.(cause it's last_time_heard is after trans1).
    
    3rd cycle:
      try  trans2 fail
      then trans2 is selected.(cause it's last_time_heard is after trans1).
    
    ....
    
    trans1 will never have change to be selected, which is not what we expect.
    we should keeping round robin all the paths if they are just added at the
    beginning.
    
    So at first every tranport's last_time_heard should be initialized 0, so
    that we ensure they have the same value at the beginning, only by this,
    all the transports could get equal chance to be selected.
    
    Then for sctp_trans_elect_best, it should return the trans_next one when
    *trans == *trans_next, so that we can try next if it fails,  but now it
    always return trans. so we can fix it by exchanging these two params when
    we calls sctp_trans_elect_tie().
    
    Fixes: 4c47af4d ('net: sctp: rework multihoming retransmission path selection to rfc4960')
    Signed-off-by: default avatarXin Long <lucien.xin@gmail.com>
    Acked-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
    Acked-by: default avatarMarcelo Ricardo Leitner <marcelo.leitner@gmail.com>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    Signed-off-by: default avatarKamal Mostafa <kamal@canonical.com>
    c56f6820
transport.c 19.7 KB