aboutsummaryrefslogtreecommitdiffstats
path: root/GPL/traffic_profiles/trex/trex-stl-2n-ethip4udp-1000u15p.py
blob: 64fe1a705f7431a55336b816e66761eeed26e0b0 (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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
# Copyright (c) 2020 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.

"""Stream profile for T-rex traffic generator.

Stream profile:
 - Two streams sent in directions 0 --> 1 and 1 --> 0 at the same time.
 - Packet: ETH / IP / UDP
 - Direction 0 --> 1:
   - Source IP address range:      20.0.0.0 - 20.0.3.231
   - Destination IP address range: 12.0.0.2
   - Source UDP port range:        1024 - 1038
   - Destination UDP port range:   1024
 - Direction 1 --> 0:
   - Source IP address range:      12.0.0.2
   - Destination IP address range: 200.0.0.0
   - Source UDP port range:        1024
   - Destination UDP port range:   1024 - 16023
"""

from trex.stl.api import *
from profile_trex_stateless_base_class import TrafficStreamsBaseClass


class TrafficStreams(TrafficStreamsBaseClass):
    """Stream profile."""

    def __init__(self):
        """Initialization and setting of streams' parameters."""

        super(TrafficStreamsBaseClass, self).__init__()

        # IPs used in packet headers.
        self.p1_src_start_ip = u"20.0.0.0"
        self.p1_src_end_ip = u"20.0.3.231"
        self.p1_dst_start_ip = u"12.0.0.2"

        self.p2_src_start_ip = u"12.0.0.2"
        self.p2_src_end_ip = u"12.0.0.2"
        self.p2_dst_start_ip = u"200.0.0.0"

        # UDP ports used in packet headers.
        self.p1_src_start_udp_port = 1024
        self.p1_src_end_udp_port = 1038
        self.p1_dst_start_udp_port = 1024

        self.p2_src_start_udp_port = 1024
        self.p2_dst_start_udp_port = 1024
        self.p2_dst_end_udp_port = 16023

    def define_packets(self):
        """Defines the packets to be sent from the traffic generator.

        Packet definition: | ETH | IP | UDP |

        :returns: Packets to be sent from the traffic generator.
        :rtype: tuple
        """

        # Direction 0 --> 1
        base_pkt_a = (
            Ether() /
            IP(
                src=self.p1_src_start_ip,
                dst=self.p1_dst_start_ip,
                proto=17
            ) /
            UDP(
                sport=self.p1_src_start_udp_port,
                dport=self.p1_dst_start_udp_port
            )
        )
        # Direction 1 --> 0
        base_pkt_b = (
            Ether() /
            IP(
                src=self.p2_src_start_ip,
                dst=self.p2_dst_start_ip,
                proto=17
            ) /
            UDP(
                sport=self.p2_src_start_udp_port,
                dport=self.p2_dst_start_udp_port
            )
        )

        # Direction 0 --> 1
        vm1 = STLScVmRaw(
            [
                STLVmTupleGen(
                    ip_min=self.p1_src_start_ip,
                    ip_max=self.p1_src_end_ip,
                    port_min=self.p1_src_start_udp_port,
                    port_max=self.p1_src_end_udp_port,
                    name=u"tuple"
                ),
                STLVmWrFlowVar(
                    fv_name=u"tuple.ip",
                    pkt_offset=u"IP.src"
                ),
                STLVmFixIpv4(offset=u"IP"),
                STLVmWrFlowVar(
                    fv_name=u"tuple.port",
                    pkt_offset=u"UDP.sport"
                )
            ]
        )
        # Direction 0 --> 1
        vm2 = STLScVmRaw(
            [
                STLVmFlowVar(
                    name=u"dport",
                    min_value=self.p2_dst_start_udp_port,
                    max_value=self.p2_dst_end_udp_port,
                    size=2,
                    op=u"inc"
                ),
                STLVmWrFlowVar(
                    fv_name=u"dport",
                    pkt_offset=u"UDP.dport"
                )
            ]
        )

        return base_pkt_a, base_pkt_b, vm1, vm2


def register():
    """Register this traffic profile to T-rex.

    Do not change this function.

    :return: Traffic streams.
    :rtype: Object
    """
    return TrafficStreams()
, &write_shared_counter, rtm))) clib_unix_warning ("pthread_create failed with %d", error); if ((error = pthread_setaffinity_np (pthread[t_index], sizeof (cpu_set_t), &cpuset))) clib_unix_warning ("pthread_set_affinity_np failed with %d", error); } cores_set++; cpu_id++; } /* Launch all threads */ clib_atomic_store_rel_n (&all_threads_online, 1); for (uword thread_num = 0; thread_num < total_threads; thread_num++) { f64 *time; if ((error = pthread_join (pthread[thread_num], (void *) &time))) clib_unix_warning ("pthread_join failed with %d", error); *elapse_time += *time; vec_free (time); } fformat (stdout, "Time elapsed: %.4e\n", *elapse_time); return rtm->shared_count; } uword num_cores_in_cpu_mask (uword mask) { uword num_cores = 0; for (uword cpu_mask = mask; cpu_mask; cpu_mask >>= 1) num_cores += (cpu_mask & 1); return num_cores; } int test_rwlock_main (unformat_input_t * i) { rwlock_test_main_t _rtm, *rtm = &_rtm; clib_memset (rtm, 0, sizeof (rwlock_test_main_t)); while (unformat_check_input (i) != UNFORMAT_END_OF_INPUT) { if (0 == unformat (i, "threads/core %d", &rtm->threads_per_core) && 0 == unformat (i, "cpu_mask_read %x", &rtm->cpu_mask_read) && 0 == unformat (i, "cpu_mask_write %x", &rtm->cpu_mask_write) && 0 == unformat (i, "increment %d", &rtm->increment_per_thread) && 0 == unformat (i, "iterations %d", &rtm->iterations)) { clib_unix_warning ("unknown input '%U'", format_unformat_error, i); return 1; } } rtm->read_cores = num_cores_in_cpu_mask (rtm->cpu_mask_read); rtm->write_cores = num_cores_in_cpu_mask (rtm->cpu_mask_write); uword total_increment = rtm->threads_per_core * rtm->write_cores * rtm->increment_per_thread; clib_rwlock_init (&rtm->rwlock); f64 average_time = 0; for (uword trial = 0; trial < rtm->iterations; trial++) { rtm->shared_count = 0; f64 elapse_time = 0; if (test_rwlock (rtm, &elapse_time) != total_increment) { clib_rwlock_free (&rtm->rwlock); fformat (stdout, "FAILED: expected count: %d, actual count: %d\n", total_increment, rtm->shared_count); return 1; } fformat (stdout, "Trial %d SUCCESS: %d = %d\n", trial, rtm->shared_count, total_increment); average_time = (average_time * trial + elapse_time) / (trial + 1); fformat (stdout, "Average lock/unlock cycles: %.4e\n", average_time); } clib_rwlock_free (&rtm->rwlock); return 0; } #ifdef CLIB_UNIX /** Launches a number of writer threads to simultaneously increment a global counter and a number of reader threads to continuously poll the counter, and records timestamps for rwlock performance benchmarking @param "threads/core [# threads/core]" - number of threads per core @param "cpu_mask_read [cpu_mask]" - reader thread cpu string e.g. input ff sets cpus 0 - 7 @param "cpu_mask_write [cpu_mask]" - writer thread cpu string @param "increment [# increments]" - number of increments per writer thread @param "iterations [# iterations]" - number of iterations @returns exit code */ int main (int argc, char *argv[]) { unformat_input_t i; i32 ret; clib_time_t time; clib_mem_init (0, 3ULL << 30); clib_time_init (&time); unformat_init_command_line (&i, argv); ret = test_rwlock_main (&i); unformat_free (&i); return ret; } #endif /* CLIB_UNIX */ /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "gnu") * End: */