from trex_stl_lib.api import * class STLS1: def create_stream(self, port_id): # base_pkt = Ether()/IP(dst="2.2.0.1")/UDP(dport=12) # pad = Padding() # if len(base_pkt) < 64: # pad_len = 64 - len(base_pkt) # pad.load = '\x00' * pad_len # vm = STLVM() # vm.tuple_var(name="tuple", ip_min="10.0.0.3", ip_max="10.0.0.202", port_min=1025, port_max=61124, limit_flows = 100000) # vm.write(fv_name="tuple.ip", pkt_offset="IP.src") # vm.fix_chksum() # vm.write(fv_name="tuple.port", pkt_offset="UDP.sport") # pkt = STLPktBuilder(pkt=base_pkt/pad, vm=vm) # return STLStream(packet=pkt, mode=STLTXCont()) vm = STLScVmRaw([STLVmTupleGen(ip_min="10.0.0.1", ip_max="10.255.255.254", port_min=1025, port_max=65535, name="stuple", limit_flows=10000), STLVmTupleGen(ip_min="2.0.0.1", ip_max="2.255.255.254", port_min=1025, port_max=65535, name="dtuple", limit_flows=100000000), # write ip to packet IP.src STLVmWrFlowVar(fv_name="stuple.ip", pkt_offset="IP.src"), STLVmWrFlowVar(fv_name="dtuple.ip", pkt_offset="IP.dst"), # fix checksum STLVmFixIpv4(offset="IP"), # write udp.port STLVmWrFlowVar(fv_name="stuple.port", pkt_offset="UDP.sport"), STLVmWrFlowVar(fv_name="dtuple.port", pkt_offset="UDP.dport"), ] ) base_pkt = Ether()/IP(src="16.0.0.1", dst="2.0.0.1")/UDP(dport=12, sport=1025) pad = Padding() if len(base_pkt) < 64: pad_len = 64 - len(base_pkt) pad.load = '\x00' * pad_len pad = max(0, 64 - len(base_pkt)) * 'x' pad_latency = max(0, (64-4) - len(base_pkt)) * 'x' pkt = STLPktBuilder(pkt=base_pkt/pad, vm=vm) return [STLStream(packet=pkt, mode=STLTXCont()), # latency stream STLStream(packet = STLPktBuilder(pkt = base_pkt/pad_latency), mode = STLTXCont(pps=1000), flow_stats = STLFlowLatencyStats(pg_id = 12+port_id)) ] def get_streams(self, direction=0, **kwargs): # return [self.create_stream()] return self.create_stream(kwargs['port_id']) # dynamic load - used for trex console or simulator def register(): return STLS1()