diff options
Diffstat (limited to 'net/sctp/sm_sideeffect.c')
-rw-r--r-- | net/sctp/sm_sideeffect.c | 32 |
1 files changed, 13 insertions, 19 deletions
diff --git a/net/sctp/sm_sideeffect.c b/net/sctp/sm_sideeffect.c index 0146cfb1f182..5385150df296 100644 --- a/net/sctp/sm_sideeffect.c +++ b/net/sctp/sm_sideeffect.c | |||
@@ -434,7 +434,8 @@ sctp_timer_event_t *sctp_timer_events[SCTP_NUM_TIMEOUT_TYPES] = { | |||
434 | * | 434 | * |
435 | */ | 435 | */ |
436 | static void sctp_do_8_2_transport_strike(struct sctp_association *asoc, | 436 | static void sctp_do_8_2_transport_strike(struct sctp_association *asoc, |
437 | struct sctp_transport *transport) | 437 | struct sctp_transport *transport, |
438 | int is_hb) | ||
438 | { | 439 | { |
439 | /* The check for association's overall error counter exceeding the | 440 | /* The check for association's overall error counter exceeding the |
440 | * threshold is done in the state function. | 441 | * threshold is done in the state function. |
@@ -466,7 +467,7 @@ static void sctp_do_8_2_transport_strike(struct sctp_association *asoc, | |||
466 | * The first unacknowleged HB triggers it. We do this with a flag | 467 | * The first unacknowleged HB triggers it. We do this with a flag |
467 | * that indicates that we have an outstanding HB. | 468 | * that indicates that we have an outstanding HB. |
468 | */ | 469 | */ |
469 | if (transport->hb_sent) { | 470 | if (!is_hb || transport->hb_sent) { |
470 | transport->last_rto = transport->rto; | 471 | transport->last_rto = transport->rto; |
471 | transport->rto = min((transport->rto * 2), transport->asoc->rto_max); | 472 | transport->rto = min((transport->rto * 2), transport->asoc->rto_max); |
472 | } | 473 | } |
@@ -657,20 +658,6 @@ static void sctp_cmd_transport_on(sctp_cmd_seq_t *cmds, | |||
657 | sctp_transport_hold(t); | 658 | sctp_transport_hold(t); |
658 | } | 659 | } |
659 | 660 | ||
660 | /* Helper function to do a transport reset at the expiry of the hearbeat | ||
661 | * timer. | ||
662 | */ | ||
663 | static void sctp_cmd_transport_reset(sctp_cmd_seq_t *cmds, | ||
664 | struct sctp_association *asoc, | ||
665 | struct sctp_transport *t) | ||
666 | { | ||
667 | sctp_transport_lower_cwnd(t, SCTP_LOWER_CWND_INACTIVE); | ||
668 | |||
669 | /* Mark one strike against a transport. */ | ||
670 | sctp_do_8_2_transport_strike(asoc, t); | ||
671 | |||
672 | t->hb_sent = 1; | ||
673 | } | ||
674 | 661 | ||
675 | /* Helper function to process the process SACK command. */ | 662 | /* Helper function to process the process SACK command. */ |
676 | static int sctp_cmd_process_sack(sctp_cmd_seq_t *cmds, | 663 | static int sctp_cmd_process_sack(sctp_cmd_seq_t *cmds, |
@@ -1459,12 +1446,19 @@ static int sctp_cmd_interpreter(sctp_event_t event_type, | |||
1459 | 1446 | ||
1460 | case SCTP_CMD_STRIKE: | 1447 | case SCTP_CMD_STRIKE: |
1461 | /* Mark one strike against a transport. */ | 1448 | /* Mark one strike against a transport. */ |
1462 | sctp_do_8_2_transport_strike(asoc, cmd->obj.transport); | 1449 | sctp_do_8_2_transport_strike(asoc, cmd->obj.transport, |
1450 | 0); | ||
1451 | break; | ||
1452 | |||
1453 | case SCTP_CMD_TRANSPORT_IDLE: | ||
1454 | t = cmd->obj.transport; | ||
1455 | sctp_transport_lower_cwnd(t, SCTP_LOWER_CWND_INACTIVE); | ||
1463 | break; | 1456 | break; |
1464 | 1457 | ||
1465 | case SCTP_CMD_TRANSPORT_RESET: | 1458 | case SCTP_CMD_TRANSPORT_HB_SENT: |
1466 | t = cmd->obj.transport; | 1459 | t = cmd->obj.transport; |
1467 | sctp_cmd_transport_reset(commands, asoc, t); | 1460 | sctp_do_8_2_transport_strike(asoc, t, 1); |
1461 | t->hb_sent = 1; | ||
1468 | break; | 1462 | break; |
1469 | 1463 | ||
1470 | case SCTP_CMD_TRANSPORT_ON: | 1464 | case SCTP_CMD_TRANSPORT_ON: |