mirror of
				https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
				synced 2025-10-30 02:12:38 +00:00 
			
		
		
		
	 72712ff548
			
		
	
	72712ff548
	
	
	
		
			
			These scripts will now be publicly available in a git repo for easier shared development and change tracking.
		
			
				
	
	
		
			1122 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			1122 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/perl
 | |
| 
 | |
| # This program is used to stress test the LANforge system, and may be used as
 | |
| # an example for others who wish to automate LANforge tests.
 | |
| 
 | |
| # This script sets up VoIP connections.
 | |
| # It then continously starts and stops the connections.
 | |
| 
 | |
| # Un-buffer output
 | |
| $| = 1;
 | |
| 
 | |
| use strict;
 | |
| use Switch;
 | |
| 
 | |
| use Net::Telnet ();
 | |
| use LANforge::Port;
 | |
| use LANforge::Utils;
 | |
| 
 | |
| my $script_speed = 25; # Increase to issue commands faster
 | |
| 
 | |
| my $lfmgr_host = undef;
 | |
| my $lfmgr_port = 4001;
 | |
| 
 | |
| my $shelf = 1;
 | |
| 
 | |
| my $INIT = 1;           # If true, removes all previous tests!!!
 | |
| 
 | |
| # This sets up connections between 2 LANforge machines with minor EIDs of 4 and 15
 | |
| #my $lf1 = 4; my $lf2 = 15; my @lf1_ports = (0); my @lf2_ports = (0);
 | |
| 
 | |
| # This sets up connections between 2 ports of a single machine;
 | |
| # $lf1 and $lf2 are the minor number of the EIDs of the resource/card.
 | |
| #my $lf1 = 4; my $lf2 = 4; my @lf1_ports = ("eth1"); my @lf2_ports = ("eth2");
 | |
| #my $lf1 = 1; my $lf2 = 2; my @lf1_ports = ("ad0"); my @lf2_ports = ("ad0");
 | |
| my $lf1 = 1; my $lf2 = 1; my @lf1_ports = ("eth1"); my @lf2_ports = ("eth2");
 | |
| 
 | |
| my $ignore_phys_ports = 0;  # If 1, just muck with mac-vlans instead.
 | |
| my $mac1 = 0x00;         # Starting MAC address 00:m5:m4:m3:m2:m1 where:
 | |
| my $mac2 = 0x00;         # m5 is shelf EID, m4 is card EID, m3 is $mac3, 
 | |
| my $mac3 = 0x00;         # m2 is $mac2 and m1 is $mac1.
 | |
| my $ip_base = "10.0";
 | |
| my $ip_c = 1;
 | |
| my $ip_lsb = 10;
 | |
| my $msk = "255.0.0.0";
 | |
| my $default_gw = "0.0.0.0";
 | |
| 
 | |
| my $start_mvlan = 0; # Starting MACVLAN index for VoIP endpoints.
 | |
| my $num_cxs = 70;     # Overrides $num_mvlans.
 | |
| my $num_mvlans = 0;  # Only used if $num_cxs is zero:  The number of MACVLANs per interface.
 | |
|                      # Representing the total number of VoIP CXs. VoIP CXs are created
 | |
|                      # across the two physical interfaces + the MACVLANs per interface.
 | |
| 
 | |
| 
 | |
| my $codec = "G711U"; # Other options:  G711U, g729a, SPEEX, g726-16, g726-24, g726-32, g726-40
 | |
| my $jB_size = 1;     # Set jitter buffer size in 20ms packets.  Default value is 8 packets, 160ms.
 | |
| my $tos = 0xBE;      # Set ToS/QoS for VoIP can be decimal or 0xNN for hexadecimal but values will display in decimal in the GUI.
 | |
| 
 | |
| 
 | |
| my $mn_icg = 3;            # minimum intercall gap
 | |
| my $mx_icg = 3;            # maximum intercall gap
 | |
| my $min_call_duration = 0; # set to zero for 'file'
 | |
| my $max_call_duration = 0; # Set to zero for 'file'
 | |
| 
 | |
| my $start_dly = 3;         # seconds to delay call start
 | |
| my $start_dly_inc = 0;     # seconds to increase delay by for each test
 | |
| 
 | |
| my $no_send_rtp = 0;      # Set to zero to send RTP traffic, 1 to suppress RTP
 | |
| my $use_VAD = 0;          # Set to zero to not use VAD, 1 to use VAD
 | |
| my $vad_timer = 500;      # how much silence (ms) before we start VAD (Silence Suppression)
 | |
| my $vad_fs = 3000;        # how often (ms) to force an rtp pkt send even if we are in VAD
 | |
| my $use_PESQ = 0;         # Set to 1 for PESQ, zero for not PESQ
 | |
| my $pesq_server = "127.0.0.1";
 | |
| my $pesq_server_port = 3998;
 | |
| my $vproto = "SIP";       # set $vproto = "H323"; for H.323
 | |
| my $bsip_port_a = "5066"; # Base SIP port for endpoint-A
 | |
| my $bsip_port_b = "5067"; # Base SIP port for endpoint-B
 | |
| my $i_sip_port_a = 0;     # If zero, do not increment, otherwise increment by assigned value.
 | |
| my $i_sip_port_b = 0;     # If zero, do not increment, otherwise increment by assigned value.
 | |
| my $brtp_port = "AUTO";   # Base RTP port
 | |
| my $i_rtp_port = 0;       # If zero, do not increment, otherwise increment by assgined value
 | |
| 
 | |
| 
 | |
| # If zero, will have one of EACH of the cx types on each port.
 | |
| #my $one_cx_per_port = 1;
 | |
| #my $one_cx_per_port = 0;
 | |
| 
 | |
| #my @cx_types =     ("", "lf_udp", "lf_tcp", "custom_udp", "custom_tcp", "l4");
 | |
| #my @min_pkt_szs =  (64,   1,        1,         1,            1,            0);
 | |
| #my @max_pkt_szs =  (1514, 12000,    13000,     2048,         2048,         0);
 | |
| 
 | |
| # Layer-4 only
 | |
| #my @cx_types =     ("l4", "l4");
 | |
| #my @min_pkt_szs =  (0, 0);
 | |
| #my @max_pkt_szs =  (0, 0);
 | |
| 
 | |
| # VOIP only
 | |
| #my @cx_types =     ("voip", "voip", "voip", "voip");
 | |
| #my @min_pkt_szs =  (0, 0, 0, 0);
 | |
| #my @max_pkt_szs =  (0, 0, 0, 0);
 | |
| #my @cx_types =     ("voip");
 | |
| #my @min_pkt_szs =  (0);
 | |
| #my @max_pkt_szs =  (0);
 | |
| 
 | |
| my $peer_to_peer_voip = 1; # Don't register with SIP proxy, but just call peer to peer.
 | |
| 
 | |
| my @src_sound_files = ("media/female_voice_8khz.wav");
 | |
| 
 | |
| # URL will be acted on from machine $lf1
 | |
| #my $l4_url = "http://172.1.5.75";
 | |
| #my $l4_url = "http://172.1.2.3"; # not used in lf_voip.pl script but makes it work
 | |
| 
 | |
| #my $min_rate = 64000; # not used in lf_voip.pl script but makes it work
 | |
| #my $max_rate = 512000; # not used in lf_voip.pl script but makes it work
 | |
| 
 | |
| my $test_mgr = "voip_tm";
 | |
| 
 | |
| my $STARTSTOP_LOOP = 0; # set $STARTSTOP_LOOP = 1; to start and stop ALL endpoints 
 | |
|                         # after script finishes populating the database.
 | |
| my $loop_max = 100;
 | |
| my $start_stop_iterations = 100;
 | |
| my $run_for_time = 1200; # Run for XX seconds..then will be stopped again
 | |
| my $stop_for_time = 5;   # Run for XX seconds..then will be stopped again
 | |
| my $report_timer = 5000; # 8 seconds
 | |
| 
 | |
| 
 | |
| ########################################################################
 | |
| # Nothing to configure below here, most likely.
 | |
| ########################################################################
 | |
| my $script_name = $0;
 | |
| 
 | |
| # Parse cmd-line args
 | |
| my $i;
 | |
| for ($i = 0; $i<@ARGV; $i++) {
 | |
|   my $var = $ARGV[$i];
 | |
|   if ($var =~ m/(\S+)=(.*)/) {
 | |
|     my $arg = $1;
 | |
|     my $val = $2;
 | |
|     handleCmdLineArg($arg, $val);
 | |
|   }
 | |
|   else {
 | |
|     handleCmdLineArg($var);
 | |
|   }
 | |
| }
 | |
| 
 | |
| if ($lfmgr_host == undef) {
 | |
|   print "\nYou must define a LANforge Manager!!!\n\n"
 | |
|       . "For example:\n"
 | |
|       . "./$script_name mgr=locahost\n"
 | |
|       . "OR\n"
 | |
|       . "./$script_name mgr=192.168.1.101\n\n";
 | |
|   printHelp();
 | |
|   exit (1);
 | |
| }
 | |
| 
 | |
| my @num = (); #make sorting by name easier :P
 | |
| my $num_len = 0;
 | |
| my $total = 0;
 | |
| 
 | |
| if ($num_mvlans == 0 && $num_cxs == 0) {
 | |
|   printHelp();
 | |
|   print "\nYou must specify a non-zero value for:  num_cxs: $num_cxs  OR  num_mvl: $num_mvlans\n\n";
 | |
|   exit (1);
 | |
| }
 | |
| 
 | |
| if ($num_cxs != 0) {
 | |
|   $total = $num_cxs*2;
 | |
|   $num_len = length ($total);
 | |
|   $num_mvlans = $num_cxs-1;
 | |
| }
 | |
| else {
 | |
|   $total = (($num_mvlans+1)*2);
 | |
|   $num_len = length ($total);
 | |
| }
 | |
| 
 | |
| my $i = 0;
 | |
| switch ($num_len) {
 | |
|   case 1 {
 | |
|     for ($i=0;$i<$total;$i++) {
 | |
|       $num[$i] = sprintf("%01d", $i);
 | |
|     }
 | |
|   }
 | |
|   case 2 {
 | |
|     for ($i=0;$i<$total;$i++) {
 | |
|       $num[$i] = sprintf("%02d", $i);
 | |
|     }
 | |
|   }
 | |
|   case 3 {
 | |
|     for ($i=0;$i<$total;$i++) {
 | |
|       $num[$i] = sprintf("%03d", $i);
 | |
|     }
 | |
|   }
 | |
|   case 4 {
 | |
|     for ($i=0;$i<$total;$i++) {
 | |
|       $num[$i] = sprintf("%04d", $i);
 | |
|     }
 | |
|   }
 | |
|   else { print '***** Error Invalid Number of MAC VLANS i.e. >10,000 !!!!'; }
 | |
| }
 | |
| 
 | |
| 
 | |
| print
 | |
|   . "init: $INIT\n"
 | |
|   . "\nmanager: $lfmgr_host\n"
 | |
|   . "\nlf1: $lf1\nlf2: $lf2\n"
 | |
|   . "\nlf1_ports: " . join(" ", @lf1_ports)
 | |
|   . "\nlf2_ports: " . join(" ", @lf2_ports) . "\n"
 | |
|   . "\nstart_macvlans: $start_mvlan"
 | |
|   . "\nnum_mvlans: $num_mvlans\n\n";
 | |
| 
 | |
| 
 | |
| #my $junk=0;
 | |
| #for ($junk=0;$junk<$total;$junk++) {
 | |
| #  printf "$num[$junk],";
 | |
| #}
 | |
| #printf "\n";
 | |
| #exit(0);
 | |
| 
 | |
| my @endpoint_names = (); #will be added to as they are created
 | |
| my @cx_names = ();
 | |
| 
 | |
| # Open connection to the LANforge server.
 | |
| 
 | |
| my $t = new Net::Telnet(Timeout => 45,
 | |
|                         Prompt  => '/default\@btbits\>\>/');
 | |
| 
 | |
| 
 | |
| $t->open(Host    => $lfmgr_host,
 | |
|          Port    => $lfmgr_port,
 | |
|          Timeout => 45);
 | |
| 
 | |
| $t->waitfor("/btbits\>\>/");
 | |
| 
 | |
| # Configure our utils.
 | |
| my $utils = new LANforge::Utils();
 | |
| $utils->telnet($t);         # Set our telnet object.
 | |
| $utils->cli_send_silent(0); # Do show input to CLI
 | |
| $utils->cli_rcv_silent(0);  # Repress output from CLI ??
 | |
| 
 | |
| 
 | |
| my $dt = "";
 | |
| 
 | |
| my $loop = 0;
 | |
| for ($loop = 0; $loop<$loop_max; $loop++) {
 | |
|   $dt = `date`;
 | |
|   chomp($dt);
 | |
|   print "\n\n*****  Starting loop: $loop at: $dt  *****\n\n";
 | |
| 
 | |
|   if ($INIT) {
 | |
|     initToDefaults();
 | |
|   }
 | |
|   #exit(0);
 | |
| 
 | |
|   # Now, add back the test manager we will be using
 | |
|   doCmd("add_tm $test_mgr");
 | |
|   doCmd("tm_register $test_mgr default");  #Add default user
 | |
|   doCmd("tm_register $test_mgr default_gui");  #Add default GUI user
 | |
| 
 | |
|   if ($num_mvlans != 0) {
 | |
|     addMacVlans();
 | |
|     # Add some IP addresses to the ports
 | |
|     initIpAddresses();
 | |
|   }
 | |
| 
 | |
|   # Add our endpoints
 | |
|   addCrossConnects();
 | |
| 
 | |
|   if ($STARTSTOP_LOOP) {
 | |
|     my $rl = 0;
 | |
|     for ($rl = 0; $rl<$start_stop_iterations; $rl++) {
 | |
|       if (($rl % 2) == 0) {
 | |
|         doCmd("set_cx_state $test_mgr all RUNNING");
 | |
|       }
 | |
|       else {
 | |
|         # Do one at a time
 | |
|         my $q = 0;
 | |
|         for ($q = 0; $q<@cx_names; $q++) {
 | |
|       my $cmd = "set_cx_state $test_mgr " . $cx_names[$q] . " RUNNING";
 | |
|       doCmd($cmd);
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       print "Done starting endpoints...sleeping $run_for_time seconds.\n";
 | |
|       sleep($run_for_time);
 | |
| 
 | |
|       # Now, stop them...
 | |
| 
 | |
|       if (($rl % 2) == 0) {
 | |
|         doCmd("set_cx_state $test_mgr all STOPPED");
 | |
|       }
 | |
|       else {
 | |
|         # Do one at a time
 | |
|         my $q = 0;
 | |
|         for ($q = 0; $q<@cx_names; $q++) {
 | |
|       my $cmd = "set_cx_state $test_mgr " . $cx_names[$q] . " STOPPED";
 | |
|       doCmd($cmd);
 | |
|         }
 | |
|       }
 | |
|       sleep($stop_for_time);
 | |
|     }# For some amount of start_stop iterations...
 | |
|   }# STARTSTOP_LOOP
 | |
|   else {
 | |
|     $dt = `date`;
 | |
|     chomp($dt);
 | |
|     print "Done at: $dt\n\n";
 | |
|     exit(0);
 | |
|   }# STARTSTOP_LOOP
 | |
| }# for some amount of loop iterations
 | |
| 
 | |
| $dt = `date`;
 | |
| chomp($dt);
 | |
| print "Done at: $dt\n\n";
 | |
| exit(0);
 | |
| 
 | |
| 
 | |
| sub initToDefaults {
 | |
|   # Clean up database if stuff exists
 | |
| 
 | |
|   doCmd("rm_cx $test_mgr all");
 | |
|   doCmd("rm_endp YES_ALL");
 | |
|   doCmd("rm_test_mgr $test_mgr");
 | |
| 
 | |
|   initPortsToDefault();
 | |
| }#initToDefaults
 | |
| 
 | |
| my $lsb1 = sprintf("%d", $mac1);
 | |
| my $lsb2 = sprintf("%d", $mac2);
 | |
| my $lsb3 = sprintf("%d", $mac3);
 | |
| 
 | |
| # Return a unique MAC address using last 3 octets
 | |
| sub getNextMac {
 | |
|   $lsb1++;
 | |
|   if ($lsb1 > 255) {
 | |
|     $lsb2++;
 | |
|     $lsb1 = 0;
 | |
|     if ($lsb2 > 255) {
 | |
|       $lsb3++;
 | |
|       $lsb2 = 0;
 | |
|       if ($lsb3 > 255) {
 | |
|         print "*** WARNING, MAC address rolling over XX:YY:ZZ:ff:ff:ff ***\n";
 | |
|         $lsb3 = 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
|   $mac1 = sprintf("%02x", $lsb1);
 | |
|   $mac2 = sprintf("%02x", $lsb2);
 | |
|   $mac3 = sprintf("%02x", $lsb3);
 | |
|   return "$mac3:$mac2:$mac1";
 | |
| } # getNextMac
 | |
| 
 | |
| sub addMacVlans {
 | |
|   my $i;
 | |
|   my $q;
 | |
|   my $v;
 | |
|   my $throttle = $script_speed;
 | |
|   my $since_throttle = 0;
 | |
|   for ($q = 0; $q<@lf1_ports; $q++) {
 | |
|     my $pnum1 = $lf1_ports[$q];
 | |
|     my $pnum2 = $lf2_ports[$q];
 | |
|     for ($i = $start_mvlan; $i<($num_mvlans + $start_mvlan); $i++) {
 | |
|       
 | |
|       my $shlf = sprintf("%02x", $shelf);
 | |
|       my $card = sprintf("%02x", $lf1);
 | |
|       my $mac_index = getNextMac();
 | |
|       my $mac_addr = "00:$shlf:$card:$mac_index";
 | |
|       doCmd("add_mvlan $shelf $lf1 $pnum1 $mac_addr $i");
 | |
| 
 | |
|       if ($lf2 ne "") {
 | |
|         $card = sprintf("%02x", $lf2);
 | |
|         $mac_index = getNextMac();
 | |
|         $mac_addr = "00:$shlf:$card:$mac_index";
 | |
|         doCmd("add_mvlan $shelf $lf2 $pnum2 $mac_addr $i");
 | |
|       }
 | |
| 
 | |
|       # Throttle ourself so we don't over-run the poor LANforge system.
 | |
|       if ($since_throttle++ > $throttle) {
 | |
|         my $p1 = new LANforge::Port();
 | |
|         $utils->updatePort($p1, $shelf, $lf1, $pnum1);
 | |
|         if ($lf2 ne "") {
 | |
|           my $p1 = new LANforge::Port();
 | |
|           $utils->updatePort($p1, $shelf, $lf2, $pnum2);
 | |
|         }
 | |
|         $since_throttle = 0;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   doCmd("probe_ports");
 | |
| 
 | |
|   # Wait until we discover all the ports...
 | |
| 
 | |
|   for ($q = 0; $q<@lf1_ports; $q++) {
 | |
|     my $p1 = new LANforge::Port();
 | |
|     $utils->updatePort($p1, $shelf, $lf1, $lf1_ports[$q]);
 | |
|     my $pname = $p1->{dev};
 | |
| 
 | |
|     my $p2 = new LANforge::Port();
 | |
|     my $pname2;
 | |
|     if ($lf2 ne "") {
 | |
|       $utils->updatePort($p2, $shelf, $lf2, $lf2_ports[$q]);
 | |
|       $pname2 = $p2->{dev};
 | |
|     }
 | |
| 
 | |
|     for ($i = 0; $i<$num_mvlans; $i++) {
 | |
|       while (1) {
 | |
|         $utils->updatePort($p1, $shelf, $lf1, "$pname\#$i");
 | |
|         if ($lf2 ne "") {
 | |
|           $utils->updatePort($p2, $shelf, $lf2, "$pname2\#$i");
 | |
|         }
 | |
|         if ($p1->isPhantom() || (($lf2 ne "") && $p2->isPhantom())) {
 | |
|           sleep(1);
 | |
|         }
 | |
|         else {
 | |
|           last;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }#addMacVlans
 | |
| 
 | |
| # Wait untill the system can update a port..
 | |
| sub throttleCard {
 | |
|   my $s = shift;
 | |
|   my $c = shift;
 | |
|   my $p1 = new LANforge::Port();
 | |
|   $utils->updatePort($p1, $s, $c, 0);
 | |
| }#throttle
 | |
| 
 | |
| sub initPortsToDefault {
 | |
|   clearMacVlanPorts($shelf, $lf1);
 | |
|   if ($lf2 ne "") {
 | |
|     clearMacVlanPorts($shelf, $lf2);
 | |
|   }
 | |
| 
 | |
|   throttleCard($shelf, $lf1);
 | |
| 
 | |
|   if ($lf2 ne "") {
 | |
|     throttleCard($shelf, $lf2);
 | |
|   }
 | |
| 
 | |
|   # Set all ports we are messing with to known state.
 | |
|   if (!$ignore_phys_ports) {
 | |
|     my $i = 0;
 | |
|     for ($i = 0; $i<@lf1_ports; $i++) {
 | |
|       my $tmp = $lf1_ports[$i];
 | |
|       my $tmp2 = $lf2_ports[$i];
 | |
|       doCmd("set_port $shelf $lf1 $tmp 0.0.0.0 0.0.0.0 0.0.0.0 NA NA NA");
 | |
|       if ($lf2 ne "") {
 | |
|         doCmd("set_port $shelf $lf2 $tmp2 0.0.0.0 0.0.0.0 0.0.0.0 NA NA NA");
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| sub clearMacVlanPorts {
 | |
|   my $s = shift;
 | |
|   my $c = shift;
 | |
| 
 | |
|   my $i;
 | |
|   my $found_one = 1;
 | |
|   my @ports = ();
 | |
|   while ($found_one) {
 | |
|     $found_one = 0;
 | |
|     doCmd("probe_ports");
 | |
|     # Clear out any existing MAC-VLAN ports.
 | |
|     $utils->error("");
 | |
|     @ports = $utils->getPortListing($s, $c);
 | |
|     my $mx = @ports;
 | |
|     print "Found $mx ports for card: $shelf.$lf1\n";
 | |
| 
 | |
|     if (($mx == 0) || ($utils->error() =~ /Timed out/g)) {
 | |
|       # System is too backlogged to answer, wait a bit
 | |
|       print " Will try listing ports again in a few seconds...system is backlogged now!\n";
 | |
|       sleep(5);
 | |
|       $found_one = 1;
 | |
|       next;
 | |
|     }
 | |
| 
 | |
|     my $throttle = 0;
 | |
|     for ($i = 0; $i<$mx; $i++) {
 | |
|       if ($ports[$i]->isMacVlan()) {
 | |
|         doCmd($ports[$i]->getDeleteCmd());
 | |
|       } #fi isMacVlan
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| 
 | |
| sub initIpAddresses {
 | |
|   # Set all ports we are messing with to known state.
 | |
|   my $i = 0;
 | |
|   for ($i = 0; $i<@lf1_ports; $i++) {
 | |
|     if ($ip_lsb > 250) {
 | |
|       $ip_c++;
 | |
|       $ip_lsb = 2;
 | |
|     }
 | |
| 
 | |
|     my $tmp = $lf1_ports[$i];
 | |
|     my $tmp2 = $lf2_ports[$i];
 | |
|     my $cmd = "";
 | |
|     if (!$ignore_phys_ports) {
 | |
|       $cmd = "set_port $shelf $lf1 $tmp $ip_base.$ip_c.$ip_lsb $msk " .
 | |
|              "$default_gw NA NA NA";
 | |
|       doCmd($cmd);
 | |
|       $ip_lsb++;
 | |
| 
 | |
|       if ($lf2 ne "") {
 | |
|       $cmd = "set_port $shelf $lf2 $tmp2 $ip_base.$ip_c.$ip_lsb $msk " .
 | |
|              "$default_gw NA NA NA";
 | |
|       doCmd($cmd);
 | |
|       $ip_lsb++;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     my $p1 = new LANforge::Port();
 | |
|     $utils->updatePort($p1, $shelf, $lf1, $tmp);
 | |
|     my $pname = $p1->{dev};
 | |
| 
 | |
|     my $q;
 | |
|     my $throttle = $script_speed;
 | |
|     my $since_throttle = 0;
 | |
|     for ($q = 0; $q<$num_mvlans; $q++) {
 | |
|       $cmd = "set_port $shelf $lf1 $pname\#$q $ip_base.$ip_c.$ip_lsb $msk "
 | |
|            . "$default_gw NA NA NA NA 400";
 | |
|       doCmd($cmd);
 | |
|       $ip_lsb++;
 | |
| 
 | |
|       if ($ip_lsb > 250) {
 | |
|         $ip_c++;
 | |
|         $ip_lsb = 2;
 | |
|       }
 | |
| 
 | |
|       if ($since_throttle++ > $throttle) {
 | |
|         my $p1 = new LANforge::Port();
 | |
|         $utils->updatePort($p1, $shelf, $lf1, "$pname\#$q");
 | |
|         $since_throttle = 0;
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     $ip_lsb++;
 | |
| 
 | |
|     if ($lf2 ne "") {
 | |
|       $p1 = new LANforge::Port();
 | |
|       $utils->updatePort($p1, $shelf, $lf2, $tmp2);
 | |
|       $pname = $p1->{dev};
 | |
| 
 | |
|       for ($q = 0; $q<$num_mvlans; $q++) {
 | |
|         $cmd = "set_port $shelf $lf2 $pname\#$q $ip_base.$ip_c.$ip_lsb $msk "
 | |
|              . "$default_gw NA NA NA NA 400";
 | |
|         doCmd($cmd);
 | |
|         $ip_lsb++;
 | |
| 
 | |
|         if ($ip_lsb > 250) {
 | |
|           $ip_c++;
 | |
|           $ip_lsb = 2;
 | |
|         }
 | |
| 
 | |
|         if ($since_throttle++ > $throttle) {
 | |
|           my $p1 = new LANforge::Port();
 | |
|           $utils->updatePort($p1, $shelf, $lf2, "$pname\#$q");
 | |
|           $since_throttle = 0;
 | |
|         }
 | |
|       }
 | |
|     }# If we have an LF-2 defined.
 | |
|   }
 | |
| }
 | |
| 
 | |
| sub addCrossConnects {
 | |
|   my $ep = 0;
 | |
|   my $cx = 0;
 | |
|   my $i = 0;
 | |
| 
 | |
|   my $voip_phone = 3000; # Start here and count on up as needed.
 | |
|   my $rtp_port = 10000;  # Starting RTP port.
 | |
|   my $sound_file_idx = 0;
 | |
|   my $sip_port_a = $bsip_port_a;
 | |
|   my $sip_port_b = $bsip_port_b;
 | |
| 
 | |
| 
 | |
|   my @all_ports1 = @lf1_ports;
 | |
|   my $j;
 | |
|   my $pname;
 | |
|   for ($j = 0; $j<@lf1_ports; $j++) {
 | |
|     my $p1 = new LANforge::Port();
 | |
|     $utils->updatePort($p1, $shelf, $lf1, $lf1_ports[$j]);
 | |
|     $pname = $p1->{dev};
 | |
| 
 | |
|     my $q;
 | |
|     my $q_end = 0;
 | |
| 
 | |
|     if ($num_mvlans == 0) {
 | |
|       $q_end = $num_cxs;
 | |
|     }
 | |
|     else {
 | |
|       $q_end = $num_mvlans;
 | |
|     }
 | |
| 
 | |
|     for ($q = 0; $q<$q_end; $q++) {
 | |
|       @all_ports1 = (@all_ports1, "$pname\#$q");
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   my @all_ports2 = @lf2_ports;
 | |
|   if ($lf2 ne "") {
 | |
|     for ($j = 0; $j<@lf2_ports; $j++) {
 | |
|       my $p1 = new LANforge::Port();
 | |
|       $utils->updatePort($p1, $shelf, $lf2, $lf2_ports[$j]);
 | |
|       $pname = $p1->{dev};
 | |
| 
 | |
|       my $q;
 | |
|       my $q_end = 0;
 | |
| 
 | |
|       if ($num_mvlans == 0) {
 | |
|         $q_end = $num_cxs;
 | |
|       }
 | |
|       else {
 | |
|         $q_end = $num_mvlans;
 | |
|       }
 | |
| 
 | |
|       for ($q = 0; $q<$q_end; $q++) {
 | |
|         @all_ports2 = (@all_ports2, "$pname\#$q");
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   print "About to start endpoints, all_ports1:\n" . join(" ", @all_ports1) .
 | |
|         "\nall_ports2: " . join(" ", @all_ports2) . "\n\n";
 | |
| 
 | |
| # if ($one_cx_per_port) {
 | |
| #   my $j = 0;
 | |
| #   my $cxcnt = 0;
 | |
| #   for ($j ; $j<@all_ports1; $j++) {
 | |
| #     my $i = $cxcnt % @cx_types;
 | |
| #     $cxcnt++;
 | |
| #
 | |
| #     my $cxt = $cx_types[$i];
 | |
| #     if ($cxt eq "l4") {
 | |
| #       # Create layer-4 endpoint
 | |
| #
 | |
| #       my $ep1 = "l4e-${ep}-TX";
 | |
| #       $ep++;
 | |
| #       my $ep2 = "D_l4e-${ep}-TX";
 | |
| #       $ep++;
 | |
| #       
 | |
| #       @endpoint_names = (@endpoint_names, $ep1, $ep2);
 | |
| #       
 | |
| #       # Add the dummy endpoint
 | |
| #       my $cmd = "add_l4_endp $ep2 $shelf $lf1 " . $all_ports1[$j] . " l4_generic  0 0 0 ' ' ' '";
 | |
| #       doCmd($cmd);
 | |
| #       $cmd = "set_endp_flag $ep2 unmanaged 1";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       $cmd = "add_l4_endp $ep1 $shelf $lf1 " . $all_ports1[$j] . " l4_generic 0 10000 100 '" .
 | |
| #         "dl $l4_url /tmp/$ep1' ' '";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       # Now, add the cross-connects
 | |
| #       my $cx_name = "l4-cx-${cx}";
 | |
| #       $cmd = "add_cx $cx_name $test_mgr $ep1 $ep2";
 | |
| #       doCmd($cmd);
 | |
| #       doCmd("set_cx_report_timer $test_mgr $cx_name $report_timer");
 | |
| #       
 | |
| #       $cx++;
 | |
| #       
 | |
| #       @cx_names = (@cx_names, $cx_name);
 | |
| #     }
 | |
| #     elsif ($cxt eq "voip") {
 | |
| #       # Create VOIP endpoint
 | |
| #       
 | |
| #       my $ep1 = "rtpe-${num[$ep]}-TX";
 | |
| #       $ep++;
 | |
| #       my $ep2 = "rtpe-${num[$ep]}-RX";
 | |
| #       $ep++;
 | |
| #       
 | |
| #       @endpoint_names = (@endpoint_names, $ep1, $ep2);
 | |
| #       
 | |
| #       my $cmd = "add_voip_endp $ep2 $shelf $lf2 " . $all_ports2[$j] .
 | |
| #                 " $voip_phone $rtp_port AUTO " .
 | |
| #             $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
| #                         " " . $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
| #             ".$ep2 $vad_timer $vad_fs";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       $cmd = "set_voip_info $ep2 NA $mn_icg $mx_icg NA $codec $vproto NA NA $min_call_duration $max_call_duration /dev/null 20000 $sip_port_b $pesq_server $pesq_server_port NA $jB_size";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       if ($i_sip_port_b != 0) {
 | |
| #         $sip_port_b = $sip_port_b + $i_sip_port_b;
 | |
| #       }
 | |
| #       
 | |
| #       $cmd = "set_endp_flag $ep2 SavePCM 0";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       $cmd = "set_endp_tos $ep2 ${tos} 0";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       if ($peer_to_peer_voip) {
 | |
| #         $cmd = "set_endp_flag $ep2 DoNotRegister 1";
 | |
| #         doCmd($cmd);
 | |
| #         $cmd = "set_endp_flag $ep2 BindSIP 1";
 | |
| #         doCmd($cmd);
 | |
| #       }
 | |
| #       if ($no_send_rtp) {
 | |
| #         $cmd = "set_endp_flag $ep2 nosendrtp 1";
 | |
| #                 doCmd($cmd);
 | |
| #               }
 | |
| #       
 | |
| #       if ($use_VAD) {
 | |
| #         $cmd = "set_endp_flag $ep2 VAD 1";
 | |
| #                 doCmd($cmd);
 | |
| #               }
 | |
| #       
 | |
| #       if ($use_PESQ) {
 | |
| #         $cmd = "set_endp_flag $ep2 pesq 1";
 | |
| #                 doCmd($cmd);
 | |
| #       }
 | |
| #       
 | |
| #       $voip_phone++;
 | |
| #       $rtp_port += 2;
 | |
| #       $sound_file_idx++;
 | |
| #       
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       $cmd = "add_voip_endp $ep1 $shelf $lf1 " . $all_ports1[$j] .
 | |
| #              " $voip_phone $rtp_port AUTO " .
 | |
| #              $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
| #              " " . $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
| #              ".$ep1 $vad_timer $vad_fs";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       $cmd = "set_voip_info $ep1 NA $mn_icg $mx_icg NA $codec $vproto NA NA $min_call_duration $max_call_duration /dev/null 20000 $sip_port_a $pesq_server $pesq_server_port NA $jB_size";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       if ($i_sip_port_a != 0) {
 | |
| #         $sip_port_a = $sip_port_a + $i_sip_port_a;
 | |
| #       }
 | |
| #       
 | |
| #       $cmd = "set_endp_flag $ep1 SavePCM 0";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       $cmd = "set_endp_tos $ep1 ${tos} 0";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       if ($peer_to_peer_voip) {
 | |
| #         $cmd = "set_endp_flag $ep1 DoNotRegister 1";
 | |
| #         doCmd($cmd);
 | |
| #         $cmd = "set_endp_flag $ep1 BindSIP 1";
 | |
| #         doCmd($cmd);
 | |
| #       }
 | |
| #       if ($no_send_rtp) {
 | |
| #         $cmd = "set_endp_flag $ep1 nosendrtp 1";
 | |
| #         doCmd($cmd);
 | |
| #       }
 | |
| #       if ($use_VAD) {
 | |
| #         $cmd = "set_endp_flag $ep1 VAD 1";
 | |
| #                 doCmd($cmd);
 | |
| #       }
 | |
| #       
 | |
| #       if ($use_PESQ) {
 | |
| #         $cmd = "set_endp_flag $ep1 pesq 1";
 | |
| #                 doCmd($cmd);
 | |
| #       }
 | |
| #       
 | |
| #       $voip_phone++;
 | |
| #       $rtp_port += 2;
 | |
| #       $sound_file_idx++;
 | |
| #       
 | |
| #       # Now, add the cross-connects
 | |
| #       my $cx_name = "rtp-cx-${num[$cx]}";
 | |
| #       $cmd = "add_cx $cx_name $test_mgr $ep1 $ep2";
 | |
| #       doCmd($cmd);
 | |
| #       doCmd("set_cx_report_timer $test_mgr $cx_name $report_timer");
 | |
| #       
 | |
| #       $cx++;
 | |
| #       
 | |
| #       @cx_names = (@cx_names, $cx_name);
 | |
| #     }
 | |
| #     else {
 | |
| #       my $burst = "NO";
 | |
| #       if ($min_rate != $max_rate) {
 | |
| #         $burst = "YES";
 | |
| #       }
 | |
| #       my $szrnd = "NO";
 | |
| #       if ($min_pkt_szs[$i] != $max_pkt_szs[$i]) {
 | |
| #         $szrnd = "YES";
 | |
| #       }
 | |
| #       
 | |
| #       my $pattern = "increasing";
 | |
| #       if ($cx_types[$i] =~ /custom/) {
 | |
| #         $pattern = "custom";
 | |
| #       }
 | |
| #       
 | |
| #       my $ep1 = "l3e-${ep}-TX";
 | |
| #       $ep++;
 | |
| #       my $ep2 = "l3e-${ep}-RX";
 | |
| #       $ep++;
 | |
| #       
 | |
| #       @endpoint_names = (@endpoint_names, $ep1, $ep2);
 | |
| #       
 | |
| #       my $cmd = "add_endp $ep1 $shelf $lf1 " . $all_ports1[$j] . " " . @cx_types[$i] .
 | |
| #           " -1 $burst $min_rate $max_rate $szrnd " . $min_pkt_szs[$i] . " " . $max_pkt_szs[$i] .
 | |
| #           " $pattern NO";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       
 | |
| #       if ($lf2 == "") {
 | |
| #         die("Must lave lf2 defined if using non-l4 endpoints.");
 | |
| #       }
 | |
| #       
 | |
| #       $cmd =    "add_endp $ep2 $shelf $lf2 " . $all_ports2[$j] . " " . @cx_types[$i] .
 | |
| #           " -1 $burst $min_rate $max_rate $szrnd " . $min_pkt_szs[$i] . " " .
 | |
| #           $max_pkt_szs[$i] . " $pattern NO";
 | |
| #       doCmd($cmd);
 | |
| #       
 | |
| #       # Now, add the cross-connects
 | |
| #       my $cx_name = "l3-cx-${cx}";
 | |
| #       $cmd = "add_cx $cx_name $test_mgr $ep1 $ep2";
 | |
| #       doCmd($cmd);
 | |
| #       doCmd("set_cx_report_timer $test_mgr $cx_name $report_timer");
 | |
| #       
 | |
| #       $cx++;
 | |
| #       
 | |
| #       @cx_names = (@cx_names, $cx_name);
 | |
| #     }
 | |
| #   }#for all ports
 | |
| # }#one_cx_per_port
 | |
| # else {
 | |
|     my $j = 0;
 | |
|     for ($j ; $j<@all_ports1; $j++) {
 | |
| #      for ($i = 0; $i<@cx_types; $i++) {
 | |
| #       my $cxt = $cx_types[$i];
 | |
| #
 | |
| #       if ($cxt eq "l4") {
 | |
| #         # Create layer-4 endpoint
 | |
| #
 | |
| #         my $ep1 = "l4e-${ep}-TX";
 | |
| #         $ep++;
 | |
| #         my $ep2 = "D_l4e-${ep}-TX";
 | |
| #         $ep++;
 | |
| #
 | |
| #         @endpoint_names = (@endpoint_names, $ep1, $ep2);
 | |
| #
 | |
| #         # Add the dummy endpoint
 | |
| #         my $cmd = "add_l4_endp $ep2 $shelf $lf1 " . $all_ports1[$j] . " l4_generic  0 0 0 ' ' ' '";
 | |
| #         doCmd($cmd);
 | |
| #         $cmd = "set_endp_flag $ep2 unmanaged 1";
 | |
| #         doCmd($cmd);
 | |
| #
 | |
| #         $cmd = "add_l4_endp $ep1 $shelf $lf1 " . $all_ports1[$j] . " l4_generic 0 10000 100 '" .
 | |
| #              "dl $l4_url /tmp/$ep1' ' '";
 | |
| #         doCmd($cmd);
 | |
| #
 | |
| #         # Now, add the cross-connects
 | |
| #         my $cx_name = "l4-cx-${cx}";
 | |
| #         $cmd = "add_cx $cx_name $test_mgr $ep1 $ep2";
 | |
| #         doCmd($cmd);
 | |
| #         doCmd("set_cx_report_timer $test_mgr $cx_name $report_timer");
 | |
| #
 | |
| #         $cx++;
 | |
| #
 | |
| #         @cx_names = (@cx_names, $cx_name);
 | |
| #       } # cx type l4
 | |
| #       elsif ($cxt eq "voip") {
 | |
|           # Create VOIP endpoint
 | |
| 
 | |
|           my $ep1 = "RTPE-${num[$ep]}-TX";
 | |
|           $ep++;
 | |
|           my $ep2 = "RTPE-${num[$ep]}-RX";
 | |
|           $ep++;
 | |
| 
 | |
|           @endpoint_names = (@endpoint_names, $ep1, $ep2);
 | |
| 
 | |
|           my $cmd = "add_voip_endp $ep2 $shelf $lf2 " . $all_ports2[$j] .
 | |
|                     " $voip_phone $rtp_port AUTO " .
 | |
|                 $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
|                         " " . $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
|                 ".$ep2 $vad_timer $vad_fs";
 | |
|           doCmd($cmd);
 | |
|           $voip_phone++;
 | |
|           $rtp_port += 2;
 | |
|           $sound_file_idx++;
 | |
|           
 | |
|           $cmd = "set_voip_info $ep2 $start_dly $mn_icg $mx_icg NA $codec $vproto NA NA $min_call_duration $max_call_duration /dev/null 20000 $sip_port_b $pesq_server $pesq_server_port NA $jB_size";
 | |
|           doCmd($cmd);
 | |
| 
 | |
|           if ($i_sip_port_b != 0) {
 | |
|             $sip_port_b = $sip_port_b + $i_sip_port_b;
 | |
|           }
 | |
| 
 | |
|           $cmd = "set_endp_flag $ep2 SavePCM 0";
 | |
|           doCmd($cmd);
 | |
| 
 | |
|           $cmd = "set_endp_tos $ep2 ${tos} 0";
 | |
|           doCmd($cmd);
 | |
| 
 | |
|           if ($peer_to_peer_voip) {
 | |
|             $cmd = "set_endp_flag $ep2 DoNotRegister 1";
 | |
|             doCmd($cmd);
 | |
|             $cmd = "set_endp_flag $ep2 BindSIP 1";
 | |
|             doCmd($cmd);
 | |
|           }
 | |
| 
 | |
|               if ($no_send_rtp) {
 | |
|                 $cmd = "set_endp_flag $ep2 nosendrtp 1";
 | |
|                 doCmd($cmd);
 | |
|               }
 | |
| 
 | |
|           if ($use_VAD) {
 | |
|             $cmd = "set_endp_flag $ep2 VAD 1";
 | |
|             doCmd($cmd);
 | |
|           }
 | |
| 
 | |
|           if ($use_PESQ) {
 | |
|             $cmd = "set_endp_flag $ep2 pesq 1";
 | |
|             doCmd($cmd);
 | |
|           }
 | |
| 
 | |
|           my $cmd = "add_voip_endp $ep1 $shelf $lf1 " . $all_ports1[$j] .
 | |
|                     " $voip_phone $rtp_port AUTO " .
 | |
|                 $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
|                         " " . $src_sound_files[$sound_file_idx % @src_sound_files] .
 | |
|                 ".$ep1";
 | |
|           doCmd($cmd);
 | |
| 
 | |
|           $cmd = "set_voip_info $ep1 $start_dly $mn_icg $mx_icg NA $codec $vproto NA NA $min_call_duration $max_call_duration /dev/null 20000 $sip_port_a $pesq_server $pesq_server_port NA $jB_size";
 | |
|           doCmd($cmd);
 | |
| 
 | |
|           $start_dly += $start_dly_inc;
 | |
| 
 | |
|           if ($i_sip_port_a != 0) {
 | |
|             $sip_port_a = $sip_port_a + $i_sip_port_a;
 | |
|           }
 | |
| 
 | |
|           $cmd = "set_endp_flag $ep1 SavePCM 0";
 | |
|           doCmd($cmd);
 | |
| 
 | |
|           $cmd = "set_endp_tos $ep1 ${tos} 0";
 | |
|           doCmd($cmd);
 | |
| 
 | |
|           if ($peer_to_peer_voip) {
 | |
|             $cmd = "set_endp_flag $ep1 DoNotRegister 1";
 | |
|             doCmd($cmd);
 | |
|             $cmd = "set_endp_flag $ep1 BindSIP 1";
 | |
|             doCmd($cmd);
 | |
|           }
 | |
|               if ($no_send_rtp) {
 | |
|                 $cmd = "set_endp_flag $ep1 nosendrtp 1";
 | |
|                 doCmd($cmd);
 | |
|               }
 | |
| 
 | |
|           if ($use_VAD) {
 | |
|             $cmd = "set_endp_flag $ep1 VAD 1";
 | |
|             doCmd($cmd);
 | |
|           }
 | |
| 
 | |
|           if ($use_PESQ) {
 | |
|             $cmd = "set_endp_flag $ep1 pesq 1";
 | |
|             doCmd($cmd);
 | |
|           }
 | |
| 
 | |
|           $voip_phone++;
 | |
|           $rtp_port += 2;
 | |
|           $sound_file_idx++;
 | |
| 
 | |
|           # Now, add the cross-connects
 | |
|           my $cx_name = "rtp-cx-${num[$cx]}";
 | |
|           $cmd = "add_cx $cx_name $test_mgr $ep1 $ep2";
 | |
|           doCmd($cmd);
 | |
|           doCmd("set_cx_report_timer $test_mgr $cx_name $report_timer");
 | |
| 
 | |
|           $cx++;
 | |
| 
 | |
|           @cx_names = (@cx_names, $cx_name);
 | |
| #       }
 | |
| #       else {
 | |
| #         my $burst = "NO";
 | |
| #         if ($min_rate != $max_rate) {
 | |
| #           $burst = "YES";
 | |
| #         }
 | |
| #         my $szrnd = "NO";
 | |
| #         if ($min_pkt_szs[$i] != $max_pkt_szs[$i]) {
 | |
| #           $szrnd = "YES";
 | |
| #         }
 | |
| #
 | |
| #         my $pattern = "increasing";
 | |
| #         if ($cx_types[$i] =~ /custom/) {
 | |
| #           $pattern = "custom";
 | |
| #         }
 | |
| #
 | |
| #         my $ep1 = "l3e-${ep}-TX";
 | |
| #         $ep++;
 | |
| #         my $ep2 = "l3e-${ep}-RX";
 | |
| #         $ep++;
 | |
| #
 | |
| #         @endpoint_names = (@endpoint_names, $ep1, $ep2);
 | |
| #
 | |
| #         my $cmd = "add_endp $ep1 $shelf $lf1 " . $all_ports1[$j] . " " . @cx_types[$i] .
 | |
| #           " -1 $burst $min_rate $max_rate $szrnd " . $min_pkt_szs[$i] . " " . $max_pkt_szs[$i] .
 | |
| #             " $pattern NO";
 | |
| #         doCmd($cmd);
 | |
| #
 | |
| #         if ($lf2 == "") {
 | |
| #           die("Must lave lf2 defined if using non-l4 endpoints.");
 | |
| #         }
 | |
| #
 | |
| #         $cmd =    "add_endp $ep2 $shelf $lf2 " . $all_ports2[$j] . " " . @cx_types[$i] .
 | |
| #           " -1 $burst $min_rate $max_rate $szrnd " . $min_pkt_szs[$i] . " " .
 | |
| #             $max_pkt_szs[$i] . " $pattern NO";
 | |
| #         doCmd($cmd);
 | |
| #
 | |
| #         # Now, add the cross-connects
 | |
| #         my $cx_name = "l3-cx-${cx}";
 | |
| #         $cmd = "add_cx $cx_name $test_mgr $ep1 $ep2";
 | |
| #         doCmd($cmd);
 | |
| #         doCmd("set_cx_report_timer $test_mgr $cx_name $report_timer");
 | |
| #
 | |
| #         $cx++;
 | |
| #
 | |
| #         @cx_names = (@cx_names, $cx_name);
 | |
| #       }
 | |
| #     }#for cx types
 | |
|     }#for each port
 | |
| # }# each cx per port
 | |
| }#addCrossConnects
 | |
| 
 | |
| 
 | |
| sub doCmd {
 | |
|   my $cmd = shift;
 | |
| 
 | |
|   print ">>> $cmd\n";
 | |
| 
 | |
|   $t->print($cmd);
 | |
| 
 | |
|   my @rslt = $t->waitfor('/ \>\>RSLT:(.*)/');
 | |
|   print "**************\n @rslt ................\n\n";
 | |
|   #sleep(1);
 | |
| }
 | |
| 
 | |
| 
 | |
| sub printHelp {
 | |
|   print
 | |
|     "\n$script_name\n"
 | |
|   . "USAGE:  mgr=[ip-of-mgr] init=[0|1] speed=25\n"
 | |
|   . "        lf1=X lf2=Y\n"
 | |
|   . "        lf1_ports=[\"1 2 3\"|\"eth2 eth3\"] lf2_ports=[\"4 5 6\"|\"eth4 eth5\"]\n"
 | |
|   . "        start_mvl=X num_cxs=[N|0 num_mvl=Y]\n"
 | |
|   . "        mac3=0xf0 mac2=0xbe mac1=0xef\n"
 | |
|   . "        ip_base=192.168 ip_c=1 ip_lsb=2 ip_msk=255.255.0.0\n"
 | |
|   . "\n";
 | |
| 
 | |
| }
 | |
| 
 | |
| sub handleCmdLineArg {
 | |
|   my $arg = $_[0];
 | |
|   my $val = $_[1];
 | |
| 
 | |
|   if ($arg eq "mgr") {
 | |
|     $lfmgr_host = $val;
 | |
|   }
 | |
|   elsif ($arg eq "init") {
 | |
|     $INIT = $val;
 | |
|   }
 | |
|   elsif ($arg eq "speed") {
 | |
|     $script_speed = $val;
 | |
|   }
 | |
|   elsif ($arg eq "lf1") {
 | |
|     $lf1 = $val;
 | |
|   }
 | |
|   elsif ($arg eq "lf2") {
 | |
|     $lf2 = $val;
 | |
|     if ($lf1 == $lf2) {
 | |
|       print "\nINVALID: First and second resource are the same !!!\n\n";
 | |
|       exit (1);
 | |
|     }
 | |
|   }
 | |
|   elsif ($arg eq "mac3") {
 | |
|     $mac3 = $val;
 | |
|   }
 | |
|   elsif ($arg eq "mac2") {
 | |
|     $mac2 = $val;
 | |
|   }
 | |
|   elsif ($arg eq "mac1") {
 | |
|     $mac1 = $val;
 | |
|   }  
 | |
|   elsif ($arg eq "ip_base") {
 | |
|     $ip_base = $val;
 | |
|   }
 | |
|   elsif ($arg eq "ip_lsb") {
 | |
|     $ip_lsb = $val;
 | |
|   }
 | |
|   elsif ($arg eq "ip_c") {
 | |
|     $ip_c = $val;
 | |
|   }
 | |
|   elsif ($arg eq "ip_msk") {
 | |
|     $msk = $val;
 | |
|   }
 | |
|   elsif ($arg eq "lf1_ports") {
 | |
|     @lf1_ports = split(/ /, $val);
 | |
|   }
 | |
|   elsif ($arg eq "lf2_ports") {
 | |
|     if ($lf2 == "" || $lf1 == $lf2) {
 | |
|       print "\nINVALID: Either second resource is not defined\nor first and second resource are the same !!!\n\n";
 | |
|       exit (1);
 | |
|     }
 | |
|     else {
 | |
|       @lf2_ports = split(/ /, $val);
 | |
|     }
 | |
|   }
 | |
|   elsif ($arg eq "start_mvl") {
 | |
|     $start_mvlan = $val;
 | |
|   }
 | |
|   elsif ($arg eq "num_cxs") {
 | |
|     $num_cxs = $val;
 | |
|   }
 | |
|   elsif ($arg eq "num_mvl") {
 | |
|     $num_mvlans = $val;
 | |
|   }
 | |
|   else {
 | |
|     printHelp();
 | |
|     exit(1);
 | |
|   }
 | |
| } # handleCmdLineArg
 |