/*--------------------------------------------------------------- * Copyright (c) 1999,2000,2001,2002,2003 * The Board of Trustees of the University of Illinois * All Rights Reserved. *--------------------------------------------------------------- * Permission is hereby granted, free of charge, to any person * obtaining a copy of this software (Iperf) and associated * documentation files (the "Software"), to deal in the Software * without restriction, including without limitation the * rights to use, copy, modify, merge, publish, distribute, * sublicense, and/or sell copies of the Software, and to permit * persons to whom the Software is furnished to do * so, subject to the following conditions: * * * Redistributions of source code must retain the above * copyright notice, this list of conditions and * the following disclaimers. * * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimers in the documentation and/or other materials * provided with the distribution. * * * Neither the names of the University of Illinois, NCSA, * nor the names of its contributors may be used to endorse * or promote products derived from this Software without * specific prior written permission. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE CONTIBUTORS OR COPYRIGHT * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, * ARISING FROM, OUT OF OR IN CONNECTION WITH THE * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * ________________________________________________________________ * National Laboratory for Applied Network Research * National Center for Supercomputing Applications * University of Illinois at Urbana-Champaign * http://www.ncsa.uiuc.edu * ________________________________________________________________ * * Locale.c * by Ajay Tirumala * & Mark Gates * ------------------------------------------------------------------- * Strings and other stuff that is locale specific. * ------------------------------------------------------------------- */ #include "headers.h" #include "version.h" #ifdef __cplusplus extern "C" { #endif /* ------------------------------------------------------------------- * usage * ------------------------------------------------------------------- */ const char usage_short[] = "\ Usage: %s [-s|-c host] [options]\n\ Try `%s --help' for more information.\n"; const char usage_long1[] = "\ Usage: iperf [-s|-c host] [options]\n\ iperf [-h|--help] [-v|--version]\n\ \n\ Client/Server:\n\ -b, --bandwidth #[kmgKMG | pps] bandwidth to read/send at in bits/sec or packets/sec\n\ -e, --enhanced use enhanced reporting giving more tcp/udp and traffic information\n\ -f, --format [kmgKMG] format to report: Kbits, Mbits, KBytes, MBytes\n\ --hide-ips hide ip addresses and host names within outputs\n\ -i, --interval # seconds between periodic bandwidth reports\n\ -l, --len #[kmKM] length of buffer in bytes to read or write (Defaults: TCP=128K, v4 UDP=1470, v6 UDP=1450)\n\ -m, --print_mss print TCP maximum segment size\n\ -o, --output output the report or error message to this specified file\n\ -p, --port # client/server port to listen/send on and to connect\n\ --permit-key permit key to be used to verify client and server (TCP only)\n\ --sum-only output sum only reports\n\ -u, --udp use UDP rather than TCP\n\ --utc use coordinated universal time (UTC) with time output\n\ -w, --window #[KM] TCP window size (socket buffer size)\n" #ifdef HAVE_SCHED_SETSCHEDULER " -z, --realtime request realtime scheduler\n" #endif " -B, --bind [:][%] bind to , ip addr (including multicast address) and optional port and device\n\ -C, --compatibility for use with older versions does not sent extra msgs\n\ --NUM_REPORT_STRUCTS increase the shared memory between the traffic threads and the reporter thread (default is 10,000 entries)\n\ -M, --mss # set TCP maximum segment size using TCP_MAXSEG\n\ -N, --nodelay set TCP no delay, disabling Nagle's Algorithm\n\ -S, --tos # set the socket's IP_TOS (byte) field\n\ -Z, --tcp-congestion set TCP congestion control algorithm (Linux only)\n\ \n\ Server specific:\n\ -p, --port #[-#] server port(s) to listen on/connect to\n\ -s, --server run in server mode\n\ -1, --singleclient run one server at a time\n\ --histograms enable latency histograms\n\ --jitter-histograms enable jitter histograms\n\ --permit-key-timeout set the timeout for a permit key in seconds\n\ --tcp-rx-window-clamp set the TCP receive window clamp size in bytes\n\ --tap-dev #[] use TAP device to receive at L2 layer\n\ -t, --time # time in seconds to listen for new connections as well as to receive traffic (default not set)\n\ -B, --bind [%] bind to multicast address and optional device\n\ -U, --single_udp run in single threaded UDP mode\n\ --sum-dstip sum traffic threads based upon destination ip address (default is src ip)\n\ -D, --daemon run the server as a daemon\n" #ifdef WIN32 " -R, --remove remove service in win32\n" #endif " -V, --ipv6_domain Enable IPv6 reception by setting the domain and socket to AF_INET6 (Can receive on both IPv4 and IPv6)\n" ; const char usage_long2[] = "\ \n\ Client specific:\n\ --bounceback request a bounceback test (use -l for size, defaults to 100 bytes)\n\ --bounceback-hold request the server to insert a delay of n milliseconds between its read and write\n\ --bounceback-period request the client schedule a send every n milliseconds\n\ --bounceback-no-quickack request the server not set the TCP_QUICKACK socket option (disabling TCP ACK delays) during a bounceback test\n\ -c, --client run in client mode, connecting to \n\ --connect-only run a connect only test\n\ --connect-retries # number of times to retry tcp connect\n\ -d, --dualtest Do a bidirectional test simultaneously (multiple sockets)\n\ --fq-rate #[kmgKMG] bandwidth to socket pacing\n\ --full-duplex run full duplex test using same socket\n\ --ipg set the the interpacket gap (milliseconds) for packets within an isochronous frame\n\ --isochronous :, send traffic in bursts (frames - emulate video traffic)\n\ --incr-dstip Increment the destination ip with parallel (-P) traffic threads\n\ --incr-dstport Increment the destination port with parallel (-P) traffic threads\n\ --incr-srcip Increment the source ip with parallel (-P) traffic threads\n\ --incr-srcport Increment the source port with parallel (-P) traffic threads\n\ --local-only Set don't route on socket\n\ --near-congestion=[w] Use a weighted write delay per the sampled TCP RTT (experimental)\n\ --no-connect-sync No sychronization after connect when -P or parallel traffic threads\n\ --no-udp-fin No final server to client stats at end of UDP test\n\ -n, --num #[kmgKMG] number of bytes to transmit (instead of -t)\n\ -r, --tradeoff Do a fullduplexectional test individually\n\ --tcp-quickack set the socket's TCP_QUICKACK option (off by default)\n\ --tcp-write-prefetch set the socket's TCP_NOTSENT_LOWAT value in bytes and use event based writes\n\ --tcp-write-times measure the socket write times at the application level\n\ -t, --time # time in seconds to transmit for (default 10 secs)\n\ --trip-times enable end to end measurements (requires client and server clock sync)\n\ --txdelay-time time in seconds to hold back after connect and before first write\n\ --txstart-time unix epoch time to schedule first write and start traffic\n\ -B, --bind [ | ] bind ip (and optional port) from which to source traffic\n\ -F, --fileinput input the data to be transmitted from a file\n\ -H, --ssm-host set the SSM source, use with -B for (S,G) \n\ -I, --stdin input the data to be transmitted from stdin\n\ -L, --listenport # port to receive fullduplexectional tests back on\n\ -P, --parallel # number of parallel client threads to run\n" #ifndef WIN32 " -R, --reverse reverse the test (client receives, server sends)\n" #else " -R Remove the windows service\n" " --reverse reverse the test (client receives, server sends)\n" #endif " -S, --tos IP DSCP or tos settings\n\ -T, --ttl # time-to-live, for multicast (default 1)\n\ --working-load request a concurrent TCP stream\n\ -V, --ipv6_domain Set the domain to IPv6 (send packets over IPv6)\n\ -X, --peer-detect perform server version detection and version exchange\n\ \n\ Miscellaneous:\n\ -x, --reportexclude [CDMSV] exclude C(connection) D(data) M(multicast) S(settings) V(server) reports\n\ -y, --reportstyle C report as a Comma-Separated Values\n\ -h, --help print this message and quit\n\ -v, --version print version information and quit\n\ \n\ [kmgKMG] Indicates options that support a k,m,g,K,M or G suffix\n\ Lowercase format characters are 10^3 based and uppercase are 2^n based\n\ (e.g. 1k = 1000, 1K = 1024, 1m = 1,000,000 and 1M = 1,048,576)\n\ \n\ Accepted tos values are: af11, af12, af13, af21, af22, af23, af31, af32, af33, af41, af42, af43,\n\ cs0, cs1, cs2, cs3, cs4, cs5, cs6, cs7, ef, le, nqb, nqb2, ac_be, ac_bk, ac_vi, ac_vo, lowdelay, throughput,\n\ reliability, or a numeric value.\n\ \n\ The TCP window size option can be set by the environment variable\n\ TCP_WINDOW_SIZE. Most other options can be set by an environment variable\n\ IPERF_, such as IPERF_BANDWIDTH.\n\ \n\ Source at \n\ Report bugs to \n"; // include a description of the threading in the version #if defined( HAVE_POSIX_THREAD ) #define IPERF_THREADS "pthreads" #elif defined( HAVE_WIN32_THREAD ) #define IPERF_THREADS "win32 threads" #else #define IPERF_THREADS "single threaded" #endif const char version[] = "iperf version " IPERF_VERSION " (" IPERF_VERSION_DATE ") " IPERF_THREADS "\n"; /* ------------------------------------------------------------------- * settings * ------------------------------------------------------------------- */ const char separator_line[] = "------------------------------------------------------------\n"; const char server_port[] = "Server listening on %s port %d\n"; const char client_port[] = "Client connecting to %s, %s port %d\n"; const char server_pid_port[] = "Server listening on %s port %d with pid %d\n"; const char server_pid_portrange[] = "Server listening on %s ports %d-%d with pid %d\n"; const char client_pid_port[] = "Client connecting to %s, %s port %d with pid %d (%d flows)\n"; const char client_pid_port_dev[] = "Client connecting to %s, %s port %d with pid %d via %s (%d flows)\n"; const char bind_address[] = "Binding to local address %s\n"; const char bind_address_iface[] = "Binding to local address %s and iface %s\n"; const char bind_address_iface_taptun[] = "Using virtual iface %s (AF_PACKET & SOCK_RAW)\n"; const char multicast_ttl[] = "Setting multicast TTL to %d\n"; const char join_multicast[] = "Joining multicast group %s\n"; const char join_multicast_sg[] = "Joining multicast (S,G)=%s,%s\n"; const char join_multicast_starg_dev[] = "Joining multicast (*,G)=*,%s w/iface %s\n"; const char join_multicast_sg_dev[] = "Joining multicast (S,G)=%s,%s w/iface %s\n"; const char client_datagram_size[] = "Sending %d byte datagrams, IPG target: %.2f us\n"; const char client_datagram_size_kalman[] = "Sending %d byte datagrams, IPG target: %.2f us (kalman adjust)\n"; const char server_datagram_size[] = "Receiving %d byte datagrams\n"; const char tcp_window_size[] = "TCP window size"; const char udp_buffer_size[] = "UDP buffer size"; const char window_default[] = "(default)"; const char wait_server_threads[] = "Waiting for server threads to complete. Interrupt again to force quit.\n"; const char client_isochronous[] = "Isochronous: %0.2f frames/sec mean=%s/s, stddev=%s/s, Period/IPG=%0.2f/%.3f ms\n"; const char client_burstperiod[] = "Bursting: %s every %0.2f second(s)\n"; const char client_burstperiodcount[] = "Bursting: %s writes %d times every %0.2f second(s)\n"; const char client_bounceback[] = "Bounce-back test (size=%s) (server hold req=%d usecs & tcp_quickack)\n"; const char client_bounceback_noqack[] = "Bounce-back test (size=%s) (server hold req=%d usecs)\n"; const char server_burstperiod[] = "Burst wait timeout set to (2 * %0.2f) seconds (use --burst-period= to change)\n"; const char client_fq_pacing [] = "fair-queue socket pacing set to %s/s\n"; /* ------------------------------------------------------------------- * Legacy reports * ------------------------------------------------------------------- */ const char report_bw_header[] = "[ ID] Interval Transfer Bandwidth\n"; const char report_bw_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec\n"; const char report_sum_bw_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec\n"; const char report_sumcnt_bw_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec\n"; const char report_bw_jitter_loss_header[] = "[ ID] Interval Transfer Bandwidth Jitter Lost/Total Datagrams\n"; const char report_bw_jitter_loss_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%)\n"; const char report_sum_bw_jitter_loss_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " (%.2g%%)\n"; const char report_sumcnt_bw_jitter_loss_header[] = "[SUM-cnt] Interval Transfer Bandwidth Lost/Total PPS\n"; const char report_sumcnt_bw_jitter_loss_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %8.0f pps\n"; /* ------------------------------------------------------------------- * Enhanced reports (per -e) * ------------------------------------------------------------------- */ const char report_sumcnt_bw_header[] = "[SUM-cnt] Interval Transfer Bandwidth\n"; const char client_report_epoch_start_current[] = "[%3d] Client traffic to start in %d seconds at %s current time is %s\n"; const char client_write_size[] = "Write buffer size"; const char server_read_size[] = "Read buffer size"; const char report_bw_enhanced_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec\n"; const char report_sum_bw_enhanced_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec\n"; const char report_bw_read_enhanced_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Reads=Dist\n"; const char report_bw_read_enhanced_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; const char report_sumcnt_bw_read_enhanced_header[] = "[SUM-cnt] Interval" IPERFTimeSpace "Transfer Bandwidth Reads=Dist\n"; const char report_sumcnt_bw_read_enhanced_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; const char report_sumcnt_bw_read_triptime_header[] = "[SUM-cnt] Interval" IPERFTimeSpace "Transfer Bandwidth InP Reads=Dist\n"; const char report_sumcnt_bw_read_triptime_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %s %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; const char report_bw_read_enhanced_netpwr_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Burst Latency avg/min/max/stdev (cnt/size) inP NetPwr Reads=Dist\n"; const char report_bw_read_enhanced_netpwr_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %.3f/%.3f/%.3f/%.3f ms (%d/%d) %s %s %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; const char report_bw_isoch_enhanced_netpwr_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Burst Latency avg/min/max/stdev (cnt/size) NetPwr Reads=Dist\n"; const char report_bw_isoch_enhanced_netpwr_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %.3f/%.3f/%.3f/%.3f ms (%d/%d) %s %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; const char report_sum_bw_read_enhanced_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; const char report_triptime_enhanced_format[] = "%s" IPERFTimeFrmt " trip-time (3WHS done->fin+finack) = %.4f sec\n"; #if HAVE_TCP_STATS const char report_client_bb_bw_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth BB cnt=avg/min/max/stdev Rtry Cwnd/RTT RPS\n"; const char report_client_bb_bw_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "=%.3f/%.3f/%.3f/%.3f ms %4d %4dK/%u us %s rps\n"; #else const char report_client_bb_bw_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth BB cnt=avg/min/max/stdev RPS\n"; const char report_client_bb_bw_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "=%.3f/%.3f/%.3f/%.3f ms %s rps\n"; #endif const char report_client_bb_bw_triptime_format[] = "%s" IPERFTimeFrmt " sec OWD Delays (ms) Cnt=%" PRIdMAX " To=%.3f/%.3f/%.3f/%.3f From=%.3f/%.3f/%.3f/%.3f Asymmetry=%.3f/%.3f/%.3f/%.3f %s rps\n"; const char report_write_enhanced_write_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err Rtry Cwnd/RTT NetPwr write-times avg/min/max/stdev (cnt)\n"; const char report_write_enhanced_write_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %10" PRIdMAX "%8dK/%u us %s %.3f/%.3f/%.3f/%.3f ms (%" PRIdMAX ")\n"; const char report_write_enhanced_nocwnd_write_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %10" PRIdMAX " NA/%u us %s %.3f/%.3f/%.3f/%.3f ms (%" PRIdMAX ")\n"; #if HAVE_TCP_STATS const char report_bw_write_enhanced_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err Rtry Cwnd/RTT(var) NetPwr\n"; const char report_sum_bw_write_enhanced_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "%10" PRIdMAX "\n"; const char report_bw_write_enhanced_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "%10" PRIdMAX " %8dK/%u(%u) us %s\n"; const char report_bw_write_enhanced_nocwnd_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %10" PRIdMAX " NA/%u us %s\n"; const char report_write_enhanced_isoch_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err Rtry Cwnd/RTT isoch:tx/miss/slip NetPwr\n"; const char report_write_enhanced_isoch_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %8d %8dK/%u us %9" PRIuMAX "/%" PRIuMAX "/%" PRIuMAX " %s\n"; const char report_write_enhanced_isoch_nocwnd_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %10" PRIdMAX " NA/%u us %9" PRIuMAX "/%" PRIuMAX "/%" PRIuMAX " %s\n"; #else const char report_bw_write_enhanced_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err\n"; const char report_bw_write_enhanced_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "\n"; const char report_sum_bw_write_enhanced_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "\n"; const char report_write_enhanced_isoch_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err isoch:tx/miss/slip\n"; const char report_write_enhanced_isoch_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "%9" PRIuMAX "/%" PRIuMAX "/%" PRIuMAX "\n"; #endif const char report_sumcnt_bw_write_enhanced_header[] = "[SUM-cnt] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err Rtry\n"; const char report_sumcnt_bw_write_enhanced_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "%10" PRIdMAX "\n"; const char report_bw_pps_enhanced_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err PPS\n"; const char report_bw_pps_enhanced_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %8.0f pps\n"; const char report_sumcnt_bw_pps_enhanced_header[] = "[SUM-cnt] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err PPS\n"; const char report_sumcnt_bw_pps_enhanced_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %8.0f pps\n"; const char report_sumcnt_udp_enhanced_header[] = "[SUM-cnt] Interval" IPERFTimeSpace "Transfer Bandwidth Lost/Total PPS\n"; const char report_sumcnt_udp_enhanced_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %8.0f pps\n"; const char report_sumcnt_udp_triptime_header[] = "[SUM-cnt] Interval" IPERFTimeSpace "Transfer Bandwidth Lost/Total Rx/inP PPS\n"; const char report_sumcnt_udp_triptime_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX " %" PRIdMAX "/%.0f %8.0f pps\n"; const char report_bw_pps_enhanced_isoch_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Write/Err PPS isoch:tx/miss/slip\n"; const char report_bw_pps_enhanced_isoch_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "%8.0f pps %3" PRIuMAX "/%" PRIuMAX "/%" PRIuMAX "\n"; const char report_sum_bw_pps_enhanced_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "/%" PRIdMAX "%8.0f pps\n"; const char report_bw_jitter_loss_pps_header[] = "[ ID] Interval Transfer Bandwidth Jitter Lost/Total Datagrams PPS\n"; const char report_bw_jitter_loss_pps_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) %8.0f pps\n"; const char report_bw_jitter_loss_enhanced_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Jitter Lost/Total \ Latency avg/min/max/stdev PPS NetPwr\n"; const char report_bw_jitter_loss_enhanced_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) %.3f/%.3f/%.3f/%.3f ms %.0f pps %s\n"; const char report_bw_jitter_loss_enhanced_triptime_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Jitter Lost/Total \ Latency avg/min/max/stdev PPS Rx/inP NetPwr\n"; const char report_bw_jitter_loss_enhanced_triptime_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) %.3f/%.3f/%.3f/%.3f ms %.0f pps %" PRIdMAX "/%s %s\n"; const char report_bw_jitter_loss_enhanced_isoch_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Jitter Lost/Total \ Latency avg/min/max/stdev PPS NetPwr Isoch:rx/lost\n"; const char report_bw_jitter_loss_enhanced_isoch_triptime_header[] = "[ ID] Interval" IPERFTimeSpace "Transfer Bandwidth Jitter Lost/Total \ Latency avg/min/max/stdev PPS Frame:rx/lost Frame-latency avg/min/max/stdev NetPwr\n"; const char report_bw_jitter_loss_enhanced_isoch_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) %.3f/%.3f/%.3f/%.3f ms %.0f pps %3d/%d %.3f/%.3f/%.3f/%.3f ms %s\n"; const char report_sum_bw_jitter_loss_enhanced_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) %.0f pps\n"; const char report_sumcnt_bw_jitter_loss_enhanced_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) %.0f pps\n"; const char report_bw_jitter_loss_suppress_enhanced_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) -/-/-/- ms %.0f pps\n"; /* * Frame interval reports */ #define IPERFFTimeFrmt "%4.4f-%4.4f" #define IPERFFTimeSpace " " const char report_frame_jitter_loss_enhanced_header[] = "[ ID] Interval(f-transit)" IPERFFTimeSpace "Transfer Bandwidth FrameID Jitter Lost/Total \ Latency avg/min/max/stdev PPS inP NetPwr\n"; const char report_frame_jitter_loss_enhanced_format[] = "%s" IPERFFTimeFrmt "(%0.4f) sec %ss %ss/sec %" PRIdMAX " %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) %.3f/%.3f/%.3f/%.3f ms %.0f pps %2.0f pkts %s\n"; const char report_frame_jitter_loss_suppress_enhanced_format[] = "%s" IPERFTimeFrmt "(%0.4f) sec %" PRIdMAX " %ss %ss/sec %" PRIdMAX " %6.3f ms %" PRIdMAX "/%" PRIdMAX " (%.2g%%) -/-/-/- ms %.0f pps\n"; const char report_frame_tcp_enhanced_header[] = "[ ID] Interval(f-transit)" IPERFFTimeSpace "Transfer Bandwidth FrameID\n"; const char report_burst_read_tcp_header[] = "[ ID] Burst (start-end)" IPERFFTimeSpace "Transfer Bandwidth XferTime (DC%) Reads=Dist NetPwr\n"; const char report_burst_read_tcp_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms (%.2g%%) %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d %s\n"; const char report_burst_read_tcp_final_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %.3f/%.3f/%.3f/%.3f ms %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; #if HAVE_TCP_STATS const char report_burst_write_tcp_header[] = "[ ID] Burst (start-end)" IPERFFTimeSpace "Transfer Bandwidth XferTime Write/Err Rtry Cwnd/RTT NetPwr\n"; const char report_burst_write_tcp_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX "%10" PRIdMAX "%8dK/%u %s\n"; #else const char report_burst_write_tcp_header[] = "[ ID] Burst (start-end)" IPERFFTimeSpace "Transfer Bandwidth XferTime Write/Err\n"; const char report_burst_write_tcp_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX"\n"; #endif const char report_burst_write_tcp_nocwnd_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %6.3f ms %" PRIdMAX "/%" PRIdMAX "%10" PRIdMAX "NA/%u %s\n"; const char report_burst_write_tcp_final_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "=%d:%d:%d:%d:%d:%d:%d:%d\n"; /* ------------------------------------------------------------------- * Fullduplex reports * ------------------------------------------------------------------- */ const char report_bw_sum_fullduplex_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec\n"; const char report_bw_sum_fullduplex_enhanced_format[] = "[FD%d] " IPERFTimeFrmt " sec %ss %ss/sec\n"; const char report_udp_fullduplex_header[] = "[ ID] Interval Transfer Bandwidth Datagrams PPS\n"; const char report_sumcnt_udp_fullduplex_header[] = "[SUM-cnt] Interval Transfer Bandwidth Datagrams PPS\n"; const char report_sumcnt_udp_fullduplex_format[] = "[SUM-%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "%8.0f pps\n"; const char report_udp_fullduplex_format[] = "%s" IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "%8.0f pps\n"; const char report_udp_fullduplex_enhanced_format[] = "[FD%d] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "%8.0f pps\n"; const char report_udp_fullduplex_sum_format[] = "[SUM] " IPERFTimeFrmt " sec %ss %ss/sec %" PRIdMAX "%8.0f pps\n"; /* ------------------------------------------------------------------- * Misc reports * ------------------------------------------------------------------- */ const char report_outoforder[] = "%s" IPERFTimeFrmt " sec %d datagrams received out-of-order\n"; const char report_sumcnt_outoforder[] = "[SUM-%d] " IPERFTimeFrmt " sec %d datagrams received out-of-order\n"; const char report_l2statistics[] = "%s" IPERFTimeFrmt " sec L2 processing detected errors, total(length/checksum/unknown) = %" PRIdMAX "(%" PRIdMAX "/%" PRIdMAX "/%" PRIdMAX ")\n"; const char report_sum_outoforder[] = "[SUM] " IPERFTimeFrmt " sec %d datagrams received out-of-order\n"; const char report_peer [] = "%slocal %s port %u connected with %s port %u%s\n"; const char report_peer_dev [] = "%slocal %s%%%s port %u connected with %s port %u%s\n"; const char report_peer_fail [] = "[drop] local %s port %u connection with %s port %u%s (permit key fail)\n"; const char report_mss_unsupported[] = "%sMSS and MTU size unknown (TCP_MAXSEG not supported)\n"; const char report_default_mss[] = "MSS size %d bytes\n"; const char report_mss[] = "MSS req size %d bytes (per TCP_MAXSEG)\n"; const char report_datagrams[] = "[%3d] Sent %d datagrams\n"; const char report_sumcnt_datagrams[] = "[SUM-%d] Sent %d datagrams\n"; const char report_sum_datagrams[] = "[SUM] Sent %d datagrams\n"; const char server_reporting[] = "[%3d] Server Report:\n"; const char reportCSV_peer[] = "%s,%u,%s,%u"; const char report_l2length_error[] = "%s" IPERFTimeFrmt " sec %d datagrams received out-of-order\n"; /*------------------------------------------------------------------- * CSV outputs *------------------------------------------------------------------*/ const char reportCSV_bw_format[] = "%s,%s,%d,%.1f-%.1f,%" PRIdMAX ",%" PRIdMAX "\n"; const char reportCSV_bw_read_enhanced_format[] = "%s,%s,%d,%.1f-%.1f,%" PRIdMAX ",%" PRIdMAX ",%" PRIdMAX ",%d,%d,%d,%d,%d,%d,%d,%d\n"; const char reportCSV_bw_write_enhanced_format[] = "%s,%s,%d,%.1f-%.1f,%" PRIdMAX ",%" PRIdMAX ",%" PRIdMAX ",%" PRIdMAX ",%" PRIdMAX ",%d,%u,%u\n"; const char reportCSV_bw_jitter_loss_format[] = "%s,%s,%d,%.1f-%.1f,%" PRIdMAX ",%" PRIdMAX ",%.3f,%" PRIdMAX ",%" PRIdMAX ",%.3f,%" PRIdMAX "\n"; const char reportCSV_bw_jitter_loss_pps_format[] = "%s,%s,%d,%.1f-%.1f,%" PRIdMAX ",%" PRIdMAX ",%.3f,%" PRIdMAX ",%" PRIdMAX ",%.3f,%" PRIdMAX ",%" PRIdMAX ",%" PRIdMAX ",%f\n"; /* ------------------------------------------------------------------- * warnings * ------------------------------------------------------------------- */ const char warn_window_requested[] = " (WARNING: requested %s)"; const char warn_window_small[] = "\ WARNING: TCP window size set to %d bytes. A small window size\n\ will give poor performance. See the Iperf documentation.\n"; const char warn_delay_large[] = "WARNING: delay too large, reducing from %.1f to 1.0 seconds.\n"; const char warn_no_pathmtu[] = "WARNING: Path MTU Discovery may not be enabled.\n"; const char warn_no_ack[]= "[%3d] WARNING: did not receive ack of last datagram after %d tries.\n"; const char warn_ack_failed[]= "[%3d] WARNING: ack of last datagram failed.\n"; const char warn_fileopen_failed[]= "WARNING: Unable to open file stream for transfer\n\ Using default data stream. \n"; const char unable_to_change_win[]= "WARNING: Unable to change the window size\n"; const char opt_estimate[]= "Optimal Estimate\n"; #ifdef HAVE_FASTSAMPLING const char report_interval_small[] = "WARNING: interval too small, increasing to %3.4f milliseconds.\n"; #else const char report_interval_small[] = "WARNING: interval too small, increasing to %3.3f milliseconds.\n"; #endif const char warn_invalid_server_option[] = "WARNING: option -%c is not valid for server mode\n"; const char warn_invalid_client_option[] = "WARNING: option -%c is not valid for client mode\n"; const char warn_invalid_compatibility_option[] = "WARNING: option -%c is not valid in compatibility mode\n"; const char warn_implied_udp[] = "WARNING: option -%c implies udp testing\n"; const char warn_implied_compatibility[] = "WARNING: option -%c has implied compatibility mode\n"; const char warn_buffer_too_small[] = "WARNING: %s socket buffer size (-l value) increased to %d bytes for proper operation\n"; const char warn_invalid_single_threaded[] = "WARNING: option -%c is not valid in single threaded versions\n"; const char warn_invalid_report_style[] = "WARNING: unknown reporting style \"%s\", switching to default\n"; const char warn_invalid_report[] = "WARNING: unknown reporting type \"%c\", ignored\n valid options are:\n\t exclude: C(connection) D(data) M(multicast) S(settings) V(server) report\n\n"; const char warn_server_old[] = "WARNING: iperf server version is likely very old\n"; const char warn_test_exchange_failed[] = "WARNING: client/server version exchange failed\n"; const char warn_len_too_small_peer_exchange[] = "WARNING: %s option -l value of %d is too small for peer exchange (suggested min value is %d bytes)\n"; const char warn_compat_and_peer_exchange[] = "WARNING: Options of '-C' '--compatibility' AND '-X' '--peerdetect' are mutually exclusive, --peerdetect ignored\n"; const char warn_start_before_now[] = "[%3d] WARNING: --txstart-time (%" PRIdMAX ".%" PRIdMAX ") %s is before now %s\n"; const char error_starttime_exceeds[] = "ERROR: --txstart-time (%" PRIdMAX ".%" PRIdMAX ") %s exceeds max scheduled delay of %d secs\n"; const char error_delaytime_exceeds[] = "ERROR: --txdelay-time of %d seconds is more than the supported delay of %d seconds\n"; #ifdef __cplusplus } /* end extern "C" */ #endif