summaryrefslogtreecommitdiffstats
path: root/src/vnet/tcp/tcp_newreno.c
blob: e36416cdfe1dc3a775450372ef635e693e4d5663 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/*
 * Copyright (c) 2017 Cisco and/or its affiliates.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include <vnet/tcp/tcp.h>

void
newreno_congestion (tcp_connection_t * tc)
{
  tc->ssthresh = clib_max (tcp_flight_size (tc) / 2, 2 * tc->snd_mss);
}

void
newreno_recovered (tcp_connection_t * tc)
{
  tc->cwnd = tc->ssthresh;
}

void
newreno_rcv_ack (tcp_connection_t * tc)
{
  if (tcp_in_slowstart (tc))
    {
      tc->cwnd += clib_min (tc->snd_mss, tc->bytes_acked);
    }
  else
    {
      /* tc->cwnd += clib_max ((tc->snd_mss * tc->snd_mss) / tc->cwnd, 1); */
      tcp_cwnd_accumulate (tc, tc->cwnd, tc->bytes_acked);
    }
}

void
newreno_rcv_cong_ack (tcp_connection_t * tc, tcp_cc_ack_t ack_type)
{
  if (ack_type == TCP_CC_DUPACK)
    {
      if (!tcp_opts_sack_permitted (tc))
	tc->cwnd += tc->snd_mss;
    }
  else if (ack_type == TCP_CC_PARTIALACK)
    {
      /* RFC 6582 Sec. 3.2 */
      if (!tcp_opts_sack_permitted (&tc->rcv_opts))
	{
	  /* Deflate the congestion window by the amount of new data
	   * acknowledged by the Cumulative Acknowledgment field.
	   * If the partial ACK acknowledges at least one SMSS of new data,
	   * then add back SMSS bytes to the congestion window. This
	   * artificially inflates the congestion window in order to reflect
	   * the additional segment that has left the network. This "partial
	   * window deflation" attempts to ensure that, when fast recovery
	   * eventually ends, approximately ssthresh amount of data will be
	   * outstanding in the network.*/
	  tc->cwnd = (tc->cwnd > tc->bytes_acked + tc->snd_mss) ?
	    tc->cwnd - tc->bytes_acked : tc->snd_mss;
	  if (tc->bytes_acked > tc->snd_mss)
	    tc->cwnd += tc->snd_mss;
	}
    }
}

void
newreno_conn_init (tcp_connection_t * tc)
{
  tc->ssthresh = tc->snd_wnd;
  tc->cwnd = tcp_initial_cwnd (tc);
}

const static tcp_cc_algorithm_t tcp_newreno = {
  .name = "newreno",
  .congestion = newreno_congestion,
  .recovered = newreno_recovered,
  .rcv_ack = newreno_rcv_ack,
  .rcv_cong_ack = newreno_rcv_cong_ack,
  .init = newreno_conn_init
};

clib_error_t *
newreno_init (vlib_main_t * vm)
{
  clib_error_t *error = 0;

  tcp_cc_algo_register (TCP_CC_NEWRENO, &tcp_newreno);

  return error;
}

VLIB_INIT_FUNCTION (newreno_init);

/*
 * fd.io coding-style-patch-verification: ON
 *
 * Local Variables:
 * eval: (c-set-style "gnu")
 * End:
 */
btain a copy of the License at: # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. *** Settings *** | Resource | resources/libraries/robot/performance/performance_setup.robot | ... | Force Tags | 3_NODE_SINGLE_LINK_TOPO | PERFTEST | HW_ENV | MRR | ... | NIC_Intel-X520-DA2 | ETH | IP6FWD | SCALE | FIB_200K | ... | Suite Setup | Set up 3-node performance topology with DUT's NIC model | ... | L3 | Intel-X520-DA2 | Suite Teardown | Tear down 3-node performance topology | ... | Test Setup | Set up performance test | ... | Test Teardown | Tear down performance mrr test | ... | Documentation | *Raw results IPv6 routing test cases* | ... | ... | *[Top] Network Topologies:* TG-DUT1-DUT2-TG 3-node circular topology | ... | with single links between nodes. | ... | *[Enc] Packet Encapsulations:* Eth-IPv6 for IPv6 routing. | ... | *[Cfg] DUT configuration:* DUT1 and DUT2 are configured with IPv6 | ... | routing and 2x100k static IPv6 /64 route entries. DUT1 and DUT2 tested | ... | with 2p10GE NIC X520 Niantic by Intel. | ... | *[Ver] TG verification:* In MaxReceivedRate tests TG sends traffic\ | ... | at line rate and reports total received/sent packets over trial period.\ | ... | Test packets are generated by TG on | ... | links to DUTs. TG traffic profile contains two L3 flow-groups | ... | (flow-group per direction, 100k flows per flow-group) with all packets | ... | containing Ethernet header, IPv6 header withq IP and static payload. | ... | MAC addresses are matching MAC addresses of the TG node interfaces. | ... | Incrementing of IP.dst (IPv6 destination address) field is applied to | ... | both streams. | ... | *[Ref] Applicable standard specifications:* RFC2544. *** Variables *** # X520-DA2 bandwidth limit | ${s_limit} | ${10000000000} | ${rts_per_flow}= | ${100000} # Traffic profile: | ${traffic_profile} | trex-sl-3n-ethip6-ip6dst${rts_per_flow} *** Keywords *** | Check RR for ip6base-ip6scale | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with ${wt} \ | | ... | thread(s), ${wt} phy core(s), ${rxq} receive queue(s) per NIC port. | | ... | [Ver] Measure MaxReceivedRate for ${framesize} frames using single\ | | ... | trial throughput test. | | ... | | [Arguments] | ${framesize} | ${wt} | ${rxq} | | ... | | # Test Variables required for test teardown | | Set Test Variable | ${framesize} | | ${get_framesize}= | Get Frame Size | ${framesize} | | ${max_rate}= | Calculate pps | ${s_limit} | ${get_framesize} | | ... | | Given Add '${wt}' worker threads and '${rxq}' rxqueues in 3-node single-link circular topology | | And Add PCI devices to all DUTs | | And Run Keyword If | ${get_framesize} < ${1522} | | ... | Add no multi seg to all DUTs | | And Apply startup configuration on all VPP DUTs | | When Initialize IPv6 forwarding with scaling in 3-node circular topology | | ... | ${rts_per_flow} | | Then Traffic should pass with maximum rate | | ... | ${max_rate}pps | ${framesize} | ${traffic_profile} *** Test Cases *** | tc01-78B-1t1c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 1 phy core, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 78B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 78B | 1C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=1 | rxq=1 | framesize=${78} | tc02-1518B-1t1c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 1 phy core, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 1518B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 1518B | 1C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=1 | rxq=1 | framesize=${1518} | tc03-9000B-1t1c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 1 phy core, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 9000B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 9000B | 1C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=1 | rxq=1 | framesize=${9000} | tc04-IMIX-1t1c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 1 phy core, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for IMIX_v4_1 frames using single trial\ | | ... | throughput test. | | ... | IMIX_v4_1 = (28x64B; 16x570B; 4x1518B) | | ... | | [Tags] | IMIX | 1C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=1 | rxq=1 | framesize=IMIX_v4_1 | tc05-78B-2t2c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 2 phy cores, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 78B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 78B | 2C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=2 | rxq=1 | framesize=${78} | tc06-1518B-2t2c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 2 phy cores, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 1518B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 1518B | 2C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=2 | rxq=1 | framesize=${1518} | tc07-9000B-2t2c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 2 phy cores, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 9000B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 9000B | 2C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=2 | rxq=1 | framesize=${9000} | tc08-IMIX-2t2c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 2 phy cores, 1 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for IMIX_v4_1 frames using single trial\ | | ... | throughput test. | | ... | IMIX_v4_1 = (28x64B; 16x570B; 4x1518B) | | ... | | [Tags] | IMIX | 2C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=2 | rxq=1 | framesize=IMIX_v4_1 | tc09-78B-4t4c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 4 phy cores, 2 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 78B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 78B | 4C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=4 | rxq=2 | framesize=${78} | tc10-1518B-4t4c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 4 phy cores, 2 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 1518B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 1518B | 4C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=4 | rxq=2 | framesize=${1518} | tc11-9000B-4t4c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 4 phy cores, 2 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for 9000B frames using single trial\ | | ... | throughput test. | | ... | | [Tags] | 9000B | 4C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=4 | rxq=2 | framesize=${9000} | tc12-IMIX-4t4c-ethip6-ip6base-ip6scale200k-mrr | | [Documentation] | | ... | [Cfg] DUT runs IPv6 routing config with \ | | ... | 4 phy cores, 2 receive queue per NIC port. | | ... | [Ver] Measure MaxReceivedRate for IMIX_v4_1 frames using single trial\ | | ... | throughput test. | | ... | IMIX_v4_1 = (28x64B; 16x570B; 4x1518B) | | ... | | [Tags] | IMIX | 4C | | ... | | [Template] | Check RR for ip6base-ip6scale | | wt=4 | rxq=2 | framesize=IMIX_v4_1