OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-3.0/] [packages/] [net/] [common/] [current/] [doc/] [running_nc_tests] - Rev 786

Compare with Previous | Blame | View Log

The network performance tests are split into two parts, one
[nc6_test_master] which runs on a host (like Linux or FreeBSD) and the
other [nc6_test_slave] which runs on the target platform.  Note that
these tests supplant older versions (nc_test_XXX) which did not
support IPv6 addressing.

To run the tests, start the slave part first.  On the target hardware,
run the program "nc6_test_slave".  It will display a set of information
on the console (use serial console only as using a network console
would severely impact the numbers) similar to this:

    RedBoot> lo ipv6.test;g
    Entry point: 0x00040040, address range: 0x00040000-0x000ae56c
    [cyg_net_init] Init: mbinit(0x00000000)
    [cyg_net_init] Init: cyg_net_init_devs(0x00000000)
    Init device 'cs8900a_eth0'
    [cyg_net_init] Init: loopattach(0x00000000)
    [cyg_net_init] Init: ifinit(0x00000000)
    IFP: 0x000acf1c, next: 0x00117a00
    IFP: 0x00117a00, next: 0x00000000
    eth0 XXX: driver didn't set ifq_maxlen
    [cyg_net_init] Init: domaininit(0x00000000)
    [cyg_net_init] Init: cyg_net_add_domain(0x000ad7f8)
    New domain internet6 at 0x00000000
    [cyg_net_init] Init: cyg_net_add_domain(0x000adfbc)
    New domain internet at 0x00000000
    [cyg_net_init] Init: cyg_net_add_domain(0x000ad314)
    New domain route at 0x00000000
    [cyg_net_init] Init: cyg_route_init(0x00000000)
    [cyg_net_init] Init: ip6_init2(0x00000000)
    [cyg_net_init] Done
    Start Network Characterization - SLAVE
    BOOTP[eth0] op: REQUEST
           htype: Ethernet
            hlen: 6
            hops: 0
             xid: 0xe194048b
            secs: 0
           flags: 0x80
           hw_addr: 00:30:d3:03:04:8b
         client IP: 0.0.0.0
             my IP: 192.168.1.52
         server IP: 192.168.1.101
        gateway IP: 0.0.0.0
            server: hermes.chez-thomas.org
              file: /tftpboot/192.168.1.52/zImage
      options:
            DHCP message: 3 REQUEST
            DHCP server id: 63.225.98.241
            DHCP time 51: -1
            DHCP time 58: 0
            DHCP time 59: 0
            subnet mask: 255.255.255.0
                gateway: 192.168.1.101
          domain server: 63.225.98.241, 206.196.128.1, 205.180.230.20, 205.180.230.21
            domain name: chez-thomas.org
           IP broadcast: 192.168.1.255
            DHCP option: 37/55.9: 54 51 58 59 1 3 6 15 28
            DHCP option: 39/57.2: 576
            DHCP requested ip: 192.168.1.52
    No load = 248826
    Set background load = 20% 
    Set background load = 0% 
    High Load[20] = 192089 => 23% 
    Set background load = 20% 
    Set background load = 0% 
    Load[10] = 220394 => 12% 
    Set background load = 20% 
    Set background load = 0% 
    Load[15] = 206082 => 18% 
    Set background load = 20% 
    Set background load = 0% 
    Final load[16] = 203142 => 19% 
    Start test for eth0
    Family: 2, Socket: 2, Addr: 0.0.0.0
    Family: 28, Socket: 2, Addr: ::

At this point, the slave is ready to accept commands.  The section with
lines like "Set background load = 20%" are the slave test self-calibrating
a background load level which is used later.

Once the slave is started, then on your host system (Linux), run the
'nc6_test_master' program like this:

    [root@ebsa2 gthomas]# ./nc6_test_master 3ffe:302:11:2::192.168.1.52

This command would test against the IPv6 slave.  You can also use an IPv4
address.

The master program will then run a sequence of tests.  Each test is accomplished
by sending a command "packet" to the slave which initiates a sequence of
I/O requests.  These are requests for UDP and TCP traffic patterns, adjusting
the slave background load, etc.  The results are displayed by the master
program as they are obtained.  For example:

    ================== No load, master at 100% ========================
    Start UDP echo [640,1024] - no delays
    UDP echo - 1280 bufs of 1024 bytes in 2.03 seconds - 630.54 KB/S - 5.1654 Mbit/S (M = 10^6)
       slave sent 640, recvd 640
    Start UDP send [640,1024] - no delays
    Packets out of sequence - recvd: 51, expected: 50
    Packets out of sequence - recvd: 103, expected: 102
    Packets out of sequence - recvd: 155, expected: 154
    Packets out of sequence - recvd: 207, expected: 206
    Packets out of sequence - recvd: 259, expected: 258
    Packets out of sequence - recvd: 311, expected: 310
    Packets out of sequence - recvd: 363, expected: 362
    Packets out of sequence - recvd: 415, expected: 414
    Packets out of sequence - recvd: 467, expected: 466
    Packets out of sequence - recvd: 519, expected: 518
    Packets out of sequence - recvd: 571, expected: 570
    Packets out of sequence - recvd: 623, expected: 622
    UDP send - 628 bufs of 1024 bytes in 1.46 seconds - 430.14 KB/S - 3.5237 Mbit/S (M = 10^6), 12 out of sequence
       slave sent 628, recvd 0
    Start UDP recv [640,1024] - no delays
    UDP recv - 640 bufs of 1024 bytes in 0.05 seconds - 12800.00 KB/S - 104.8576 Mbit/S (M = 10^6)
       slave sent 0, recvd 495
    Start TCP echo [640,1024] - no delays
    TCP echo - 1280 bufs of 1024 bytes in 2.16 seconds - 592.59 KB/S - 4.8545 Mbit/S (M = 10^6)
       slave sent 640, recvd 640
    Start TCP send [640,1024] - no delays
    TCP send - 640 bufs of 1024 bytes in 0.80 seconds - 800.00 KB/S - 6.5536 Mbit/S (M = 10^6)
       slave sent 640, recvd 0
    Start TCP recv [640,1024] - no delays
    TCP recv - 640 bufs of 1024 bytes in 0.65 seconds - 984.62 KB/S - 8.0660 Mbit/S (M = 10^6)
       slave sent 0, recvd 640
    Start TCP echo [64,10240] - no delays
    TCP echo - 128 bufs of 10240 bytes in 3.80 seconds - 336.84 KB/S - 2.7594 Mbit/S (M = 10^6)
       slave sent 64, recvd 64
    
    ====================== Various slave compute loads ===================
    >>>>>>>>>>>> slave processing load at 0%
    Start UDP echo [2048,1024] - no delays
    UDP echo - 4096 bufs of 1024 bytes in 6.51 seconds - 629.19 KB/S - 5.1543 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    Start TCP echo [2048,1024] - no delays
    TCP echo - 4096 bufs of 1024 bytes in 6.90 seconds - 593.62 KB/S - 4.8630 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    >>>>>>>>>>>> slave processing load at 10%
    Start UDP echo [2048,1024] - no delays
    UDP echo - 4096 bufs of 1024 bytes in 6.81 seconds - 601.47 KB/S - 4.9272 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    Start TCP echo [2048,1024] - no delays
    TCP echo - 4096 bufs of 1024 bytes in 7.00 seconds - 585.14 KB/S - 4.7935 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    >>>>>>>>>>>> slave processing load at 20%
    Start UDP echo [2048,1024] - no delays
    UDP echo - 4096 bufs of 1024 bytes in 6.81 seconds - 601.47 KB/S - 4.9272 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    Start TCP echo [2048,1024] - no delays
    TCP echo - 4096 bufs of 1024 bytes in 7.32 seconds - 559.56 KB/S - 4.5839 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    >>>>>>>>>>>> slave processing load at 30%
    Start UDP echo [2048,1024] - no delays
    UDP echo - 4096 bufs of 1024 bytes in 8.04 seconds - 509.45 KB/S - 4.1734 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    Start TCP echo [2048,1024] - no delays
    TCP echo - 4096 bufs of 1024 bytes in 8.78 seconds - 466.51 KB/S - 3.8217 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    >>>>>>>>>>>> slave processing load at 40%
    Start UDP echo [2048,1024] - no delays
    UDP echo - 4096 bufs of 1024 bytes in 10.22 seconds - 400.78 KB/S - 3.2832 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    Start TCP echo [2048,1024] - no delays
    TCP echo - 4096 bufs of 1024 bytes in 10.24 seconds - 400.00 KB/S - 3.2768 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    >>>>>>>>>>>> slave processing load at 50%
    Start UDP echo [2048,1024] - no delays
    UDP echo - 4096 bufs of 1024 bytes in 10.22 seconds - 400.78 KB/S - 3.2832 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    Start TCP echo [2048,1024] - no delays
    TCP echo - 4096 bufs of 1024 bytes in 10.24 seconds - 400.00 KB/S - 3.2768 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    
    ====================== Various master loads ===================
    Testing IDLE for 10 seconds
    IDLE - ticks: 1003, count: 1367315
    Start UDP echo [2048,1024] - no delays
    UDP echo - 4096 bufs of 1024 bytes in 10.22 seconds - 400.78 KB/S - 3.2832 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 1028, count: 641138, 45% idle
    Start TCP echo [2048,1024] - no delays
    TCP echo - 4096 bufs of 1024 bytes in 10.24 seconds - 400.00 KB/S - 3.2768 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 1330, count: 1004010, 55% idle
    Start UDP echo [2048,1024] - 10ms delay after 10 packets
    UDP echo - 4096 bufs of 1024 bytes in 13.01 seconds - 314.83 KB/S - 2.5791 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 1307, count: 1015862, 56% idle
    Start TCP echo [2048,1024] - 10ms delay after 10 packets
    TCP echo - 4096 bufs of 1024 bytes in 13.26 seconds - 308.90 KB/S - 2.5305 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 1633, count: 1410624, 63% idle
    Start UDP echo [2048,1024] - 50ms delay after 10 packets
    UDP echo - 4096 bufs of 1024 bytes in 21.00 seconds - 195.05 KB/S - 1.5978 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 2106, count: 2105817, 73% idle
    Start TCP echo [2048,1024] - 50ms delay after 10 packets
    TCP echo - 4096 bufs of 1024 bytes in 21.26 seconds - 192.66 KB/S - 1.5783 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 2434, count: 2471814, 74% idle
    Start UDP echo [2048,1024] - 100ms delay after 10 packets
    UDP echo - 4096 bufs of 1024 bytes in 31.28 seconds - 130.95 KB/S - 1.0727 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 3135, count: 3508880, 82% idle
    Start TCP echo [2048,1024] - 100ms delay after 10 packets
    TCP echo - 4096 bufs of 1024 bytes in 31.43 seconds - 130.32 KB/S - 1.0676 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 3451, count: 3859323, 82% idle
    Start UDP echo [2048,1024] - 10ms delay after 1 packet
    UDP echo - 4096 bufs of 1024 bytes in 40.94 seconds - 100.05 KB/S - 0.8196 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 4102, count: 4789770, 85% idle
    Start TCP echo [2048,1024] - 10ms delay after 1 packet
    TCP echo - 4096 bufs of 1024 bytes in 40.96 seconds - 100.00 KB/S - 0.8192 Mbit/S (M = 10^6)
       slave sent 2048, recvd 2048
    IDLE - ticks: 4407, count: 5147211, 85% idle
    ... Done

The slave will display lines like:
    UDP echo - 640 buffers, 1024 bytes
    UDP send - 640 buffers, 1024 bytes
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    sendto UDP data: No buffer space available
    UDP recv - 640 buffers, 1024 bytes
    Packets out of sequence - recvd: 508, expected: 492
    Packets out of sequence - recvd: 528, expected: 510
    recvfrom timeout, expecting seq #529
    recvfrom timeout, expecting seq #530
    recvfrom timeout, expecting seq #531
    recvfrom timeout, expecting seq #532
    recvfrom timeout, expecting seq #533
    recvfrom timeout, expecting seq #534
    ... giving up
    TCP echo - 640 buffers, 1024 bytes
    TCP - listen on IPv6/8770
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1085)
    TCP send - 640 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1086)
    TCP recv - 640 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1087)
    TCP echo - 64 buffers, 10240 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1088)
    Set background load = 0% 
    Set background load = 0% 
    UDP echo - 2048 buffers, 1024 bytes
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1089)
    Set background load = 10% 
    UDP echo - 2048 buffers, 1024 bytes
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1090)
    Set background load = 20% 
    UDP echo - 2048 buffers, 1024 bytes
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1091)
    Set background load = 30% 
    UDP echo - 2048 buffers, 1024 bytes
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1092)
    Set background load = 40% 
    UDP echo - 2048 buffers, 1024 bytes
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1093)
    Set background load = 50% 
    UDP echo - 2048 buffers, 1024 bytes
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1094)
    Start IDLE thread
    Stop IDLE thread
    Start IDLE thread
    UDP echo - 2048 buffers, 1024 bytes
    Stop IDLE thread
    Start IDLE thread
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1095)
    Stop IDLE thread
    Start IDLE thread
    UDP echo - 2048 buffers, 1024 bytes
    Stop IDLE thread
    Start IDLE thread
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1096)
    Stop IDLE thread
    Start IDLE thread
    UDP echo - 2048 buffers, 1024 bytes
    Stop IDLE thread
    Start IDLE thread
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1097)
    Stop IDLE thread
    Start IDLE thread
    UDP echo - 2048 buffers, 1024 bytes
    Stop IDLE thread
    Start IDLE thread
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1098)
    Stop IDLE thread
    Start IDLE thread
    UDP echo - 2048 buffers, 1024 bytes
    Stop IDLE thread
    Start IDLE thread
    TCP echo - 2048 buffers, 1024 bytes
    connection from 3ffe:302:11:2:290:27ff:fe8b:8e1d(1099)
    Stop IDLE thread

Notice that if the host and target are not well balanced (in this example,
the host is a fairly fast P-II running with a very good 10/100Mb ethernet
controller and the slave is a reasonable [not fast!] ARM board with a very
simplistic [read "slow"] network adaptor), then the UDP tests can have
synchronization problems.  This is the nature of UDP and is to be expected.

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.