xref: /iperf/src/iperf_api.h (revision 11fadc3f)
1540d2ae4SBrian Tierney /*
276bd67f6SSarah Larsen  * iperf, Copyright (c) 2014-2022, The Regents of the University of
3da9f046fSBruce A. Mah  * California, through Lawrence Berkeley National Laboratory (subject
4da9f046fSBruce A. Mah  * to receipt of any required approvals from the U.S. Dept. of
5da9f046fSBruce A. Mah  * Energy).  All rights reserved.
67d375156SJon Dugan  *
7da9f046fSBruce A. Mah  * If you have questions about your rights to use or distribute this
8da9f046fSBruce A. Mah  * software, please contact Berkeley Lab's Technology Transfer
9da9f046fSBruce A. Mah  * Department at [email protected].
10da9f046fSBruce A. Mah  *
11da9f046fSBruce A. Mah  * NOTICE.  This software is owned by the U.S. Department of Energy.
12da9f046fSBruce A. Mah  * As such, the U.S. Government has been granted for itself and others
13da9f046fSBruce A. Mah  * acting on its behalf a paid-up, nonexclusive, irrevocable,
14da9f046fSBruce A. Mah  * worldwide license in the Software to reproduce, prepare derivative
15da9f046fSBruce A. Mah  * works, and perform publicly and display publicly.  Beginning five
16da9f046fSBruce A. Mah  * (5) years after the date permission to assert copyright is obtained
17da9f046fSBruce A. Mah  * from the U.S. Department of Energy, and subject to any subsequent
18da9f046fSBruce A. Mah  * five (5) year renewals, the U.S. Government is granted for itself
19da9f046fSBruce A. Mah  * and others acting on its behalf a paid-up, nonexclusive,
20da9f046fSBruce A. Mah  * irrevocable, worldwide license in the Software to reproduce,
21da9f046fSBruce A. Mah  * prepare derivative works, distribute copies to the public, perform
22da9f046fSBruce A. Mah  * publicly and display publicly, and to permit others to do so.
23da9f046fSBruce A. Mah  *
24da9f046fSBruce A. Mah  * This code is distributed under a BSD style license, see the LICENSE
25da9f046fSBruce A. Mah  * file for complete information.
26540d2ae4SBrian Tierney  */
27982c704aSsethdelliott #ifndef        __IPERF_API_H
28982c704aSsethdelliott #define        __IPERF_API_H
29c0c797b0SBrian Tierney 
307c9b553cSBruce A. Mah #include <sys/socket.h>
31621a152bSHavard Eidnes #include <sys/time.h>
3266ce7ad4Ssethdelliott #include <setjmp.h>
33acb4c4c9SKenneth Wong #include <stdio.h>
34acb4c4c9SKenneth Wong #ifdef HAVE_STDINT_H
35acb4c4c9SKenneth Wong #include <stdint.h>
36acb4c4c9SKenneth Wong #endif
37acb4c4c9SKenneth Wong #ifdef __cplusplus
38acb4c4c9SKenneth Wong extern "C" { /* open extern "C" */
39acb4c4c9SKenneth Wong #endif
40acb4c4c9SKenneth Wong 
4198ce496bSjef 
4298ce496bSjef struct iperf_test;
4398ce496bSjef struct iperf_stream_result;
4498ce496bSjef struct iperf_interval_results;
4598ce496bSjef struct iperf_stream;
46cde81d76SBen Fox-Moore struct iperf_time;
4798ce496bSjef 
4870c85f62SBruce A. Mah #if !defined(__IPERF_H)
49a0c6f0ecSDavid Bar-On typedef uint64_t iperf_size_t;
5070c85f62SBruce A. Mah #endif // __IPERF_H
51a0c6f0ecSDavid Bar-On 
5298ce496bSjef /* default settings */
5398ce496bSjef #define Ptcp SOCK_STREAM
5498ce496bSjef #define Pudp SOCK_DGRAM
5560bd98a5SBruce A. Mah #define Psctp 12
560fd60a36SBruce A. Mah #define DEFAULT_UDP_BLKSIZE 1460 /* default is dynamically set, else this */
5798ce496bSjef #define DEFAULT_TCP_BLKSIZE (128 * 1024)  /* default read/write block size */
58ede8dabbSBruce A. Mah #define DEFAULT_SCTP_BLKSIZE (64 * 1024)
598ffe72e2SDavid Bar-On #define DEFAULT_PACING_TIMER 1000
608ffe72e2SDavid Bar-On #define DEFAULT_NO_MSG_RCVD_TIMEOUT 120000
618ffe72e2SDavid Bar-On #define MIN_NO_MSG_RCVD_TIMEOUT 100
6298ce496bSjef 
63a071a8c8SBruce A. Mah #define WARN_STR_LEN 128
64a071a8c8SBruce A. Mah 
6560bd98a5SBruce A. Mah /* short option equivalents, used to support options that only have long form */
6660bd98a5SBruce A. Mah #define OPT_SCTP 1
67aeb6938dSBruce A. Mah #define OPT_LOGFILE 2
68ba8d6e62SBruce A. Mah #define OPT_GET_SERVER_OUTPUT 3
69329523a5SBruce A. Mah #define OPT_UDP_COUNTERS_64BIT 4
70499b1222SKevin Constantine #define OPT_CLIENT_PORT 5
71e1420625SBruce A. Mah #define OPT_NUMSTREAMS 6
7208a2de45SQuaSoft #define OPT_FORCEFLUSH 7
73a094d9feSBruce A. Mah #define OPT_NO_FQ_SOCKET_PACING 9 /* UNUSED */
74a094d9feSBruce A. Mah #define OPT_FQ_RATE 10
7505600c20SBruce A. Mah #define OPT_DSCP 11
76a51045deSralcini #define OPT_CLIENT_USERNAME 12
77a51045deSralcini #define OPT_CLIENT_RSA_PUBLIC_KEY 13
78a51045deSralcini #define OPT_SERVER_RSA_PRIVATE_KEY 14
79a51045deSralcini #define OPT_SERVER_AUTHORIZED_USERS 15
80cba8584bSBruce A. Mah #define OPT_PACING_TIMER 16
819d7d60acSBruce A. Mah #define OPT_CONNECT_TIMEOUT 17
82cbea72b6SPhil Levchenko #define OPT_REPEATING_PAYLOAD 18
83829d619aSBruce A. Mah #define OPT_EXTRA_DATA 19
840778f04cSBoris Okunev #define OPT_BIDIRECTIONAL 20
85a0c6f0ecSDavid Bar-On #define OPT_SERVER_BITRATE_LIMIT 21
861a908ce1SBruce A. Mah #define OPT_TIMESTAMPS 22
87bd143779Sralcini #define OPT_SERVER_SKEW_THRESHOLD 23
8821581a72SBruce A. Mah #define OPT_BIND_DEV 24
89be66b575SDavid Bar-On #define OPT_IDLE_TIMEOUT 25
9049a5771aSDavid Bar-On #define OPT_DONT_FRAGMENT 26
918ffe72e2SDavid Bar-On #define OPT_RCV_TIMEOUT 27
9260bd98a5SBruce A. Mah #define OPT_SND_TIMEOUT 28
9398ce496bSjef 
9498ce496bSjef /* states */
9598ce496bSjef #define TEST_START 1
9663ae6635SBruce A. Mah #define TEST_RUNNING 2
9798ce496bSjef #define RESULT_REQUEST 3 /* not used */
9863ae6635SBruce A. Mah #define TEST_END 4
9963ae6635SBruce A. Mah #define STREAM_BEGIN 5 /* not used */
10063ae6635SBruce A. Mah #define STREAM_RUNNING 6 /* not used */
10163ae6635SBruce A. Mah #define STREAM_END 7 /* not used */
10298ce496bSjef #define ALL_STREAMS_END 8 /* not used */
10398ce496bSjef #define PARAM_EXCHANGE 9
10498ce496bSjef #define CREATE_STREAMS 10
10598ce496bSjef #define SERVER_TERMINATE 11
10698ce496bSjef #define CLIENT_TERMINATE 12
10798ce496bSjef #define EXCHANGE_RESULTS 13
10898ce496bSjef #define DISPLAY_RESULTS 14
10998ce496bSjef #define IPERF_START 15
11098ce496bSjef #define IPERF_DONE 16
11198ce496bSjef #define ACCESS_DENIED (-1)
11298ce496bSjef #define SERVER_ERROR (-2)
11398ce496bSjef 
114ba51358fSJef Poskanzer /* Getter routines for some fields inside iperf_test. */
115d7613a8eSJef Poskanzer int	iperf_get_verbose( struct iperf_test* ipt );
11657892604SJef Poskanzer int	iperf_get_control_socket( struct iperf_test* ipt );
11798ce496bSjef int	iperf_get_test_omit( struct iperf_test* ipt );
11898ce496bSjef int	iperf_get_test_duration( struct iperf_test* ipt );
119cb6347fbSJef Poskanzer char	iperf_get_test_role( struct iperf_test* ipt );
12098ce496bSjef int	iperf_get_test_reverse( struct iperf_test* ipt );
1212939863bSBruce A. Mah int	iperf_get_test_blksize( struct iperf_test* ipt );
12298ce496bSjef FILE*	iperf_get_test_outfile( struct iperf_test* ipt );
12302e16f67SSam Hooke uint64_t iperf_get_test_rate( struct iperf_test* ipt );
12402e16f67SSam Hooke int iperf_get_test_pacing_timer( struct iperf_test* ipt );
12502e16f67SSam Hooke uint64_t iperf_get_test_bytes( struct iperf_test* ipt );
126bdf5335cSJef Poskanzer uint64_t iperf_get_test_blocks( struct iperf_test* ipt );
12798ce496bSjef int     iperf_get_test_burst( struct iperf_test* ipt );
12898ce496bSjef int	iperf_get_test_socket_bufsize( struct iperf_test* ipt );
12998ce496bSjef double	iperf_get_test_reporter_interval( struct iperf_test* ipt );
13098ce496bSjef double	iperf_get_test_stats_interval( struct iperf_test* ipt );
1318fc10fa3Ssrgnk int	iperf_get_test_num_streams( struct iperf_test* ipt );
1321a908ce1SBruce A. Mah int	iperf_get_test_repeating_payload( struct iperf_test* ipt );
1331a908ce1SBruce A. Mah int	iperf_get_test_timestamps( struct iperf_test* ipt );
134*11fadc3fSWatcherOfTheSkies const char* iperf_get_test_timestamp_format( struct iperf_test* ipt );
13598ce496bSjef int	iperf_get_test_bind_port( struct iperf_test* ipt );
13698ce496bSjef int	iperf_get_test_server_port( struct iperf_test* ipt );
1379a377509SR0CKSTAR char*	iperf_get_test_server_hostname( struct iperf_test* ipt );
13898ce496bSjef char*	iperf_get_test_template( struct iperf_test* ipt );
13950a45ea4SJef Poskanzer int	iperf_get_test_protocol_id( struct iperf_test* ipt );
1402939863bSBruce A. Mah int	iperf_get_test_json_output( struct iperf_test* ipt );
141a5621dd9SJef Poskanzer char*	iperf_get_test_json_output_string ( struct iperf_test* ipt );
142ba8d6e62SBruce A. Mah int	iperf_get_test_zerocopy( struct iperf_test* ipt );
14385bf6a17SMatt Johnson int	iperf_get_test_get_server_output( struct iperf_test* ipt );
144e0d039eaSBruce A. Mah char	iperf_get_test_unit_format(struct iperf_test *ipt);
145329523a5SBruce A. Mah char*	iperf_get_test_bind_address ( struct iperf_test* ipt );
146dba611dbSBruce A. Mah int	iperf_get_test_udp_counters_64bit( struct iperf_test* ipt );
147c0a44175SKai Borowiak int	iperf_get_test_one_off( struct iperf_test* ipt );
148829d619aSBruce A. Mah int iperf_get_test_tos( struct iperf_test* ipt );
149beac6881SRollingSlack char*	iperf_get_extra_data( struct iperf_test* ipt );
150a9af2b51Ssrgnk char*	iperf_get_iperf_version(void);
151de848cffSBruce A. Mah int	iperf_get_test_no_delay( struct iperf_test* ipt );
15249a5771aSDavid Bar-On int	iperf_get_test_connect_timeout( struct iperf_test* ipt );
1534e526a1aSHamid Anvari int	iperf_get_dont_fragment( struct iperf_test* ipt );
154515b6e9eSWatcherOfTheSkies char*   iperf_get_test_congestion_control(struct iperf_test* ipt);
15598ce496bSjef int iperf_get_test_mss(struct iperf_test* ipt);
15698ce496bSjef 
157ba51358fSJef Poskanzer /* Setter routines for some fields inside iperf_test. */
158d7613a8eSJef Poskanzer void	iperf_set_verbose( struct iperf_test* ipt, int verbose );
15957892604SJef Poskanzer void	iperf_set_control_socket( struct iperf_test* ipt, int ctrl_sck );
16098ce496bSjef void	iperf_set_test_omit( struct iperf_test* ipt, int omit );
16198ce496bSjef void	iperf_set_test_duration( struct iperf_test* ipt, int duration );
16298ce496bSjef void	iperf_set_test_reporter_interval( struct iperf_test* ipt, double reporter_interval );
1632944aaa0SJef Poskanzer void	iperf_set_test_stats_interval( struct iperf_test* ipt, double stats_interval );
16498ce496bSjef void	iperf_set_test_state( struct iperf_test* ipt, signed char state );
1653888e044SDavid Bar-On void	iperf_set_test_blksize( struct iperf_test* ipt, int blksize );
16698ce496bSjef void	iperf_set_test_logfile( struct iperf_test* ipt, const char *logfile );
16702e16f67SSam Hooke void	iperf_set_test_rate( struct iperf_test* ipt, uint64_t rate );
16802e16f67SSam Hooke void    iperf_set_test_pacing_timer( struct iperf_test* ipt, int pacing_timer );
16902e16f67SSam Hooke void    iperf_set_test_bytes( struct iperf_test* ipt, uint64_t bytes );
170bdf5335cSJef Poskanzer void    iperf_set_test_blocks( struct iperf_test* ipt, uint64_t blocks );
171*11fadc3fSWatcherOfTheSkies void	iperf_set_test_burst( struct iperf_test* ipt, int burst );
17298ce496bSjef void	iperf_set_test_bind_port( struct iperf_test* ipt, int bind_port );
17398ce496bSjef void	iperf_set_test_server_port( struct iperf_test* ipt, int server_port );
17498ce496bSjef void	iperf_set_test_socket_bufsize( struct iperf_test* ipt, int socket_bufsize );
1758fc10fa3Ssrgnk void	iperf_set_test_num_streams( struct iperf_test* ipt, int num_streams );
1761a908ce1SBruce A. Mah void	iperf_set_test_repeating_payload( struct iperf_test* ipt, int repeating_payload );
1771a908ce1SBruce A. Mah void	iperf_set_test_timestamps( struct iperf_test* ipt, int timestamps );
17898ce496bSjef void	iperf_set_test_timestamp_format( struct iperf_test*, const char *tf );
1793888e044SDavid Bar-On void	iperf_set_test_role( struct iperf_test* ipt, char role );
1803888e044SDavid Bar-On void	iperf_set_test_server_hostname( struct iperf_test* ipt, const char* server_hostname );
181cb6347fbSJef Poskanzer void    iperf_set_test_template( struct iperf_test *ipt, const char *tmp_template );
18250a45ea4SJef Poskanzer void	iperf_set_test_reverse( struct iperf_test* ipt, int reverse );
183a5621dd9SJef Poskanzer void	iperf_set_test_json_output( struct iperf_test* ipt, int json_output );
184a5621dd9SJef Poskanzer int	iperf_has_zerocopy( void );
185ba8d6e62SBruce A. Mah void	iperf_set_test_zerocopy( struct iperf_test* ipt, int zerocopy );
18685bf6a17SMatt Johnson void	iperf_set_test_get_server_output( struct iperf_test* ipt, int get_server_output );
1873888e044SDavid Bar-On void	iperf_set_test_unit_format(struct iperf_test *ipt, char unit_format);
188329523a5SBruce A. Mah void	iperf_set_test_bind_address( struct iperf_test* ipt, const char *bind_address );
189dba611dbSBruce A. Mah void	iperf_set_test_udp_counters_64bit( struct iperf_test* ipt, int udp_counters_64bit );
190c0a44175SKai Borowiak void	iperf_set_test_one_off( struct iperf_test* ipt, int one_off );
1913888e044SDavid Bar-On void    iperf_set_test_tos( struct iperf_test* ipt, int tos );
1920778f04cSBoris Okunev void	iperf_set_test_extra_data( struct iperf_test* ipt, const char *dat );
193a9af2b51Ssrgnk void    iperf_set_test_bidirectional( struct iperf_test* ipt, int bidirectional);
19449a5771aSDavid Bar-On void    iperf_set_test_no_delay( struct iperf_test* ipt, int no_delay);
1954e526a1aSHamid Anvari void    iperf_set_dont_fragment( struct iperf_test* ipt, int dont_fragment );
196515b6e9eSWatcherOfTheSkies void    iperf_set_test_congestion_control(struct iperf_test* ipt, char* cc);
1975212846fSkaustubhprabhu void    iperf_set_test_mss(struct iperf_test* ipt, int mss);
198e28f12c7Sralcini 
1993888e044SDavid Bar-On #if defined(HAVE_SSL)
2003888e044SDavid Bar-On void    iperf_set_test_client_username(struct iperf_test *ipt, const char *client_username);
2013888e044SDavid Bar-On void    iperf_set_test_client_password(struct iperf_test *ipt, const char *client_password);
2023888e044SDavid Bar-On void    iperf_set_test_client_rsa_pubkey(struct iperf_test *ipt, const char *client_rsa_pubkey_base64);
203bd143779Sralcini void    iperf_set_test_server_authorized_users(struct iperf_test *ipt, const char *server_authorized_users);
2043888e044SDavid Bar-On void    iperf_set_test_server_skew_threshold(struct iperf_test *ipt, int server_skew_threshold);
205e28f12c7Sralcini void    iperf_set_test_server_rsa_privkey(struct iperf_test *ipt, const char *server_rsa_privkey_base64);
206e28f12c7Sralcini #endif // HAVE_SSL
207de848cffSBruce A. Mah 
208de848cffSBruce A. Mah void	iperf_set_test_connect_timeout(struct iperf_test *ipt, int ct);
2095212846fSkaustubhprabhu 
2105212846fSkaustubhprabhu /**
2115212846fSkaustubhprabhu  * exchange_parameters - handles the param_Exchange part for client
2125212846fSkaustubhprabhu  *
213e088d2d3SJon Dugan  */
2145212846fSkaustubhprabhu int      iperf_exchange_parameters(struct iperf_test * test);
2155212846fSkaustubhprabhu 
216d44c04d4SBrian Tierney /**
2175212846fSkaustubhprabhu  * add_to_interval_list -- adds new interval to the interval_list
2185212846fSkaustubhprabhu  *
219d44c04d4SBrian Tierney  */
2205212846fSkaustubhprabhu void      add_to_interval_list(struct iperf_stream_result * rp, struct iperf_interval_results *temp);
2215212846fSkaustubhprabhu 
2225212846fSkaustubhprabhu /**
2235212846fSkaustubhprabhu  * connect_msg -- displays connection message
2245212846fSkaustubhprabhu  * denoting senfer/receiver details
2255212846fSkaustubhprabhu  *
2265212846fSkaustubhprabhu  */
2275212846fSkaustubhprabhu void      connect_msg(struct iperf_stream * sp);
2285212846fSkaustubhprabhu 
2295212846fSkaustubhprabhu /**
2305212846fSkaustubhprabhu  * iperf_stats_callback -- handles the statistic gathering
2315212846fSkaustubhprabhu  *
232ff385f98Ssethdelliott  */
2335212846fSkaustubhprabhu void     iperf_stats_callback(struct iperf_test * test);
2345212846fSkaustubhprabhu 
2355212846fSkaustubhprabhu /**
2365212846fSkaustubhprabhu  * iperf_reporter_callback -- handles the report printing
2375212846fSkaustubhprabhu  *
238ccb08657Ssethdelliott  */
2395212846fSkaustubhprabhu void     iperf_reporter_callback(struct iperf_test * test);
2405212846fSkaustubhprabhu 
241c2b87ef8SJon Dugan /**
242ff5411c6SJon Dugan  * iperf_new_test -- return a new iperf_test with default values
243ff5411c6SJon Dugan  *
244ff5411c6SJon Dugan  * returns NULL on failure
245ff5411c6SJon Dugan  *
2465ab2132cSGabriel Ganne  */
24724b42564Skaustubhprabhu struct iperf_test *iperf_new_test(void);
24866ce7ad4Ssethdelliott 
249ff5411c6SJon Dugan int      iperf_defaults(struct iperf_test * testp);
250ff5411c6SJon Dugan 
251c2b87ef8SJon Dugan /**
252ff5411c6SJon Dugan  * iperf_free_test -- free resources used by test, calls iperf_free_stream to
253ff5411c6SJon Dugan  * free streams
254ff5411c6SJon Dugan  *
255c2b87ef8SJon Dugan  */
256ff5411c6SJon Dugan void      iperf_free_test(struct iperf_test * testp);
257ff5411c6SJon Dugan 
258c2b87ef8SJon Dugan /**
259ff5411c6SJon Dugan  * iperf_new_stream -- return a net iperf_stream with default values
260ff5411c6SJon Dugan  *
261ff5411c6SJon Dugan  * returns NULL on failure
262ff5411c6SJon Dugan  *
2630778f04cSBoris Okunev  */
264ff5411c6SJon Dugan struct iperf_stream *iperf_new_stream(struct iperf_test *, int, int);
265ff5411c6SJon Dugan 
266ff5411c6SJon Dugan /**
267ff5411c6SJon Dugan  * iperf_add_stream -- add a stream to a test
268ff5411c6SJon Dugan  *
2693118b420Ssethdelliott  */
270ff5411c6SJon Dugan void      iperf_add_stream(struct iperf_test * test, struct iperf_stream * stream);
271ff5411c6SJon Dugan 
272ff5411c6SJon Dugan /**
273ff5411c6SJon Dugan  * iperf_init_stream -- init resources associated with test
274ff5411c6SJon Dugan  *
2759a599d5fSsethdelliott  */
276ff5411c6SJon Dugan int       iperf_init_stream(struct iperf_stream *, struct iperf_test *);
277ff5411c6SJon Dugan 
278c2b87ef8SJon Dugan /**
279ff5411c6SJon Dugan  * iperf_free_stream -- free resources associated with test
280ff5411c6SJon Dugan  *
281a36921c2SBrian Tierney  */
282c0c797b0SBrian Tierney void      iperf_free_stream(struct iperf_stream * sp);
2836b7db8f7Sjef 
2846b7db8f7Sjef int has_tcpinfo(void);
2856b7db8f7Sjef int has_tcpinfo_retransmits(void);
286dcd7b32bSBruce A. Mah void save_tcpinfo(struct iperf_stream *sp, struct iperf_interval_results *irp);
287dcd7b32bSBruce A. Mah long get_total_retransmits(struct iperf_interval_results *irp);
28847985d7fSShuo Chen long get_snd_cwnd(struct iperf_interval_results *irp);
289432ef7ebSBruce A. Mah long get_snd_wnd(struct iperf_interval_results *irp);
2905d14d106STran Viet Hoang long get_rtt(struct iperf_interval_results *irp);
29152375c10SBruce A. Mah long get_rttvar(struct iperf_interval_results *irp);
2926b7db8f7Sjef long get_pmtu(struct iperf_interval_results *irp);
293a1eb8922SBrian Tierney void print_tcpinfo(struct iperf_test *test);
29466ce7ad4Ssethdelliott void build_tcpinfo_message(struct iperf_interval_results *r, char *message);
2952944aaa0SJef Poskanzer 
296cde81d76SBen Fox-Moore int iperf_set_send_state(struct iperf_test *test, signed char state);
297231c5629SJef Poskanzer void iperf_check_throttle(struct iperf_stream *sp, struct iperf_time *nowP);
2986177a7f1SJef Poskanzer int iperf_send(struct iperf_test *, fd_set *) /* __attribute__((hot)) */;
299afe6222aSJef Poskanzer int iperf_recv(struct iperf_test *, fd_set *);
300afe6222aSJef Poskanzer void iperf_catch_sigend(void (*handler)(int));
3015ab2132cSGabriel Ganne void iperf_got_sigend(struct iperf_test *test) __attribute__ ((noreturn));
3025ab2132cSGabriel Ganne void usage(void);
3033888e044SDavid Bar-On void usage_long(FILE * f);
304181d61afSsethdelliott void warning(const char *);
305b60a49ddSsethdelliott int iperf_exchange_results(struct iperf_test *);
3068bdc8fffSJef Poskanzer int iperf_init_test(struct iperf_test *);
3078430ad49Ssethdelliott int iperf_create_send_timers(struct iperf_test *);
308255a9c71Ssrgnk int iperf_parse_arguments(struct iperf_test *, int, char **);
3090bd8d9daSsethdelliott int iperf_open_logfile(struct iperf_test *);
310c9693599SJef Poskanzer void iperf_reset_test(struct iperf_test *);
311c0c797b0SBrian Tierney void iperf_reset_stats(struct iperf_test * test);
31266ce7ad4Ssethdelliott 
31366ce7ad4Ssethdelliott struct protocol *get_protocol(struct iperf_test *, int);
31466ce7ad4Ssethdelliott int set_protocol(struct iperf_test *, int);
3154df383f6Ssethdelliott 
3164df383f6Ssethdelliott void iperf_on_new_stream(struct iperf_stream *);
3174df383f6Ssethdelliott void iperf_on_test_start(struct iperf_test *);
3184df383f6Ssethdelliott void iperf_on_connect(struct iperf_test *);
3194df383f6Ssethdelliott void iperf_on_test_finish(struct iperf_test *);
32066ce7ad4Ssethdelliott 
32166ce7ad4Ssethdelliott extern jmp_buf env;
32298ce496bSjef 
32398ce496bSjef /* Client routines. */
32498ce496bSjef int iperf_run_client(struct iperf_test *);
3250778f04cSBoris Okunev int iperf_connect(struct iperf_test *);
32698ce496bSjef int iperf_create_streams(struct iperf_test *, int sender);
32798ce496bSjef int iperf_handle_message_client(struct iperf_test *);
328c0c797b0SBrian Tierney int iperf_client_end(struct iperf_test *);
32998ce496bSjef 
33098ce496bSjef /* Server routines. */
33198ce496bSjef int iperf_run_server(struct iperf_test *);
33298ce496bSjef int iperf_server_listen(struct iperf_test *);
33398ce496bSjef int iperf_accept(struct iperf_test *);
334441d8b75SBruce A. Mah int iperf_handle_message_server(struct iperf_test *);
335441d8b75SBruce A. Mah int iperf_create_pidfile(struct iperf_test *);
336a0c6f0ecSDavid Bar-On int iperf_delete_pidfile(struct iperf_test *);
33798ce496bSjef void iperf_check_total_rate(struct iperf_test *, iperf_size_t);
3389bfb54c0SJef Poskanzer 
3399bfb54c0SJef Poskanzer /* JSON output routines. */
3409bfb54c0SJef Poskanzer int iperf_json_start(struct iperf_test *);
3419bfb54c0SJef Poskanzer int iperf_json_finish(struct iperf_test *);
3428a7e01ebSJef Poskanzer 
343deefb95fSBruce A. Mah /* CPU affinity routines */
344deefb95fSBruce A. Mah int iperf_setaffinity(struct iperf_test *, int affinity);
3458a7e01ebSJef Poskanzer int iperf_clearaffinity(struct iperf_test *);
346d38ab4c8SJef Poskanzer 
347ad2a706fSNevo Hed /* Custom printf routine. */
348aeb6938dSBruce A. Mah int iperf_printf(struct iperf_test *test, const char *format, ...) __attribute__ ((format(printf,2,3)));
349d38ab4c8SJef Poskanzer int iflush(struct iperf_test *test);
35098ce496bSjef 
351b5e0751fSJef Poskanzer /* Error routines. */
352b5e0751fSJef Poskanzer void iperf_err(struct iperf_test *test, const char *format, ...) __attribute__ ((format(printf,2,3)));
35398ce496bSjef void iperf_errexit(struct iperf_test *test, const char *format, ...) __attribute__ ((format(printf,2,3),noreturn));
35498ce496bSjef char *iperf_strerror(int);
35598ce496bSjef extern int i_errno;
35698ce496bSjef enum {
35798ce496bSjef     IENONE = 0,             // No error
35898ce496bSjef     /* Parameter errors */
35998ce496bSjef     IESERVCLIENT = 1,       // Iperf cannot be both server and client
360987b4323SJef Poskanzer     IENOROLE = 2,           // Iperf must either be a client (-c) or server (-s)
361987b4323SJef Poskanzer     IESERVERONLY = 3,       // This option is server only
362987b4323SJef Poskanzer     IECLIENTONLY = 4,       // This option is client only
363987b4323SJef Poskanzer     IEDURATION = 5,         // test duration too long. Maximum value = %dMAX_TIME
364987b4323SJef Poskanzer     IENUMSTREAMS = 6,       // Number of parallel streams too large. Maximum value = %dMAX_STREAMS
365987b4323SJef Poskanzer     IEBLOCKSIZE = 7,        // Block size too large. Maximum value = %dMAX_BLOCKSIZE
36656536642SJef Poskanzer     IEBUFSIZE = 8,          // Socket buffer size too large. Maximum value = %dMAX_TCP_BUFFER
367987b4323SJef Poskanzer     IEINTERVAL = 9,         // Invalid report interval (min = %gMIN_INTERVAL, max = %gMAX_INTERVAL seconds)
368987b4323SJef Poskanzer     IEMSS = 10,             // MSS too large. Maximum value = %dMAX_MSS
36957892604SJef Poskanzer     IENOSENDFILE = 11,      // This OS does not support sendfile
370c9693599SJef Poskanzer     IEOMIT = 12,            // Bogus value for --omit
371e32a7bcdSJef Poskanzer     IEUNIMP = 13,           // Not implemented yet
372bdf5335cSJef Poskanzer     IEFILE = 14,            // -F file couldn't be opened
373f11d3fa3SJef Poskanzer     IEBURST = 15,           // Invalid burst count. Maximum value = %dMAX_BURST
374aeb6938dSBruce A. Mah     IEENDCONDITIONS = 16,   // Only one test end condition (-t, -n, -k) may be specified
375cd81de3cSBruce A. Mah     IELOGFILE = 17,	    // Can't open log file
376e7aa59b6SBruce A. Mah     IENOSCTP = 18,	    // No SCTP support available
37703224c9fSBruce A. Mah     IEBIND = 19,	    // UNUSED:  Local port specified with no local bind option
378956d1158SBruce A. Mah     IEUDPBLOCKSIZE = 20,    // Block size invalid
379a51045deSralcini     IEBADTOS = 21,	    // Bad TOS value
380a51045deSralcini     IESETCLIENTAUTH = 22,   // Bad configuration of client authentication
38137d913dfSBruce A. Mah     IESETSERVERAUTH = 23,   // Bad configuration of server authentication
3820778f04cSBoris Okunev     IEBADFORMAT = 24,	    // Bad format argument to -f
3836c783462SBruce A. Mah     IEREVERSEBIDIR = 25,    // Iperf cannot be both reverse and bidirectional
384a0c6f0ecSDavid Bar-On     IEBADPORT = 26,	    // Bad port number
385a0c6f0ecSDavid Bar-On     IETOTALRATE = 27,       // Total required bandwidth is larger than server's limit
386bd143779Sralcini     IETOTALINTERVAL = 28,   // Invalid time interval for calculating average data rate
387be66b575SDavid Bar-On     IESKEWTHRESHOLD = 29,   // Invalid value specified as skew threshold
3888ffe72e2SDavid Bar-On     IEIDLETIMEOUT = 30,     // Invalid value specified as idle state timeout
3898ffe72e2SDavid Bar-On     IERCVTIMEOUT = 31,      // Illegal message receive timeout
39098ce496bSjef     IERVRSONLYRCVTIMEOUT = 32,  // Client receive timeout is valid only in reverse mode
391987b4323SJef Poskanzer     IESNDTIMEOUT = 33,      // Illegal message send timeout
392987b4323SJef Poskanzer     /* Test errors */
393987b4323SJef Poskanzer     IENEWTEST = 100,        // Unable to create a new test (check perror)
394987b4323SJef Poskanzer     IEINITTEST = 101,       // Test initialization failed (check perror)
395987b4323SJef Poskanzer     IELISTEN = 102,         // Unable to listen for connections (check perror)
396987b4323SJef Poskanzer     IECONNECT = 103,        // Unable to connect to server (check herror/perror) [from netdial]
397987b4323SJef Poskanzer     IEACCEPT = 104,         // Unable to accept connection from client (check herror/perror)
398987b4323SJef Poskanzer     IESENDCOOKIE = 105,     // Unable to send cookie to server (check perror)
399987b4323SJef Poskanzer     IERECVCOOKIE = 106,     // Unable to receive cookie from client (check perror)
400987b4323SJef Poskanzer     IECTRLWRITE = 107,      // Unable to write to the control socket (check perror)
401987b4323SJef Poskanzer     IECTRLREAD = 108,       // Unable to read from the control socket (check perror)
402987b4323SJef Poskanzer     IECTRLCLOSE = 109,      // Control socket has closed unexpectedly
403987b4323SJef Poskanzer     IEMESSAGE = 110,        // Received an unknown message
404987b4323SJef Poskanzer     IESENDMESSAGE = 111,    // Unable to send control message to client/server (check perror)
405987b4323SJef Poskanzer     IERECVMESSAGE = 112,    // Unable to receive control message from client/server (check perror)
406987b4323SJef Poskanzer     IESENDPARAMS = 113,     // Unable to send parameters to server (check perror)
407987b4323SJef Poskanzer     IERECVPARAMS = 114,     // Unable to receive parameters from client (check perror)
408987b4323SJef Poskanzer     IEPACKAGERESULTS = 115, // Unable to package results (check perror)
409987b4323SJef Poskanzer     IESENDRESULTS = 116,    // Unable to send results to client/server (check perror)
410987b4323SJef Poskanzer     IERECVRESULTS = 117,    // Unable to receive results from client/server (check perror)
411987b4323SJef Poskanzer     IESELECT = 118,         // Select failed (check perror)
412987b4323SJef Poskanzer     IECLIENTTERM = 119,     // The client has terminated
413e1420625SBruce A. Mah     IESERVERTERM = 120,     // The server has terminated
414e1420625SBruce A. Mah     IEACCESSDENIED = 121,   // The server is busy running a test. Try again later.
415987b4323SJef Poskanzer     IESETNODELAY = 122,     // Unable to set TCP/SCTP NODELAY (check perror)
416987b4323SJef Poskanzer     IESETMSS = 123,         // Unable to set TCP/SCTP MSS (check perror)
417987b4323SJef Poskanzer     IESETBUF = 124,         // Unable to set socket buffer size (check perror)
418c687db9dSJef Poskanzer     IESETTOS = 125,         // Unable to set IP TOS (check perror)
419c687db9dSJef Poskanzer     IESETCOS = 126,         // Unable to set IPv6 traffic class (check perror)
420c687db9dSJef Poskanzer     IESETFLOW = 127,        // Unable to set IPv6 flow label
421c687db9dSJef Poskanzer     IEREUSEADDR = 128,      // Unable to set reuse address on socket (check perror)
422c687db9dSJef Poskanzer     IENONBLOCKING = 129,    // Unable to set socket to non-blocking (check perror)
4238a7e01ebSJef Poskanzer     IESETWINDOWSIZE = 130,  // Unable to set socket window size (check perror)
424fe4a13abSBruce A. Mah     IEPROTOCOL = 131,       // Protocol does not exist
42562bfa88cSJef Poskanzer     IEAFFINITY = 132,       // Unable to set CPU affinity (check perror)
426441d8b75SBruce A. Mah     IEDAEMON = 133,	    // Unable to become a daemon process
4274addea85SBruce A. Mah     IESETCONGESTION = 134,  // Unable to set TCP_CONGESTION
42860bd98a5SBruce A. Mah     IEPIDFILE = 135,	    // Unable to write PID file
429e1420625SBruce A. Mah     IEV6ONLY = 136,  	    // Unable to set/unset IPV6_V6ONLY (check perror)
430e1420625SBruce A. Mah     IESETSCTPDISABLEFRAG = 137, // Unable to set SCTP Fragmentation (check perror)
4319915746aSBruce A. Mah     IESETSCTPNSTREAM= 138,  //  Unable to set SCTP number of streams (check perror)
432d2202ee3SBruce A. Mah     IESETSCTPBINDX= 139,    // Unable to process sctp_bindx() parameters
433a51045deSralcini     IESETPACING= 140,       // Unable to set socket pacing rate
43421581a72SBruce A. Mah     IESETBUF2= 141,	    // Socket buffer size incorrect (written value != read value)
435be66b575SDavid Bar-On     IEAUTHTEST = 142,       // Test authorization failed
43649a5771aSDavid Bar-On     IEBINDDEV = 143,        // Unable to bind-to-device (check perror, maybe permissions?)
437f54b6b4bSDavid Bar-On     IENOMSG = 144,          // No message was received for NO_MSG_RCVD_TIMEOUT time period
438f54b6b4bSDavid Bar-On     IESETDONTFRAGMENT = 145,   // Unable to set IP Do-Not-Fragment
43998ce496bSjef     IEBINDDEVNOSUPPORT = 146,  // `ip%%dev` is not supported as system does not support bind to device
440987b4323SJef Poskanzer     IEHOSTDEV = 147,        // host device name (ip%%<dev>) is supported (and required) only for IPv6 link-local address
441987b4323SJef Poskanzer     IESETUSERTIMEOUT = 148, // Unable to set TCP USER_TIMEOUT (check perror)
442987b4323SJef Poskanzer     /* Stream errors */
443987b4323SJef Poskanzer     IECREATESTREAM = 200,   // Unable to create a new stream (check herror/perror)
444987b4323SJef Poskanzer     IEINITSTREAM = 201,     // Unable to initialize stream (check herror/perror)
445987b4323SJef Poskanzer     IESTREAMLISTEN = 202,   // Unable to start stream listener (check perror)
446987b4323SJef Poskanzer     IESTREAMCONNECT = 203,  // Unable to connect stream (check herror/perror)
447987b4323SJef Poskanzer     IESTREAMACCEPT = 204,   // Unable to accepte stream connection (check perror)
448987b4323SJef Poskanzer     IESTREAMWRITE = 205,    // Unable to write to stream socket (check perror)
44998ce496bSjef     IESTREAMREAD = 206,     // Unable to read from stream (check perror)
450987b4323SJef Poskanzer     IESTREAMCLOSE = 207,    // Stream has closed unexpectedly
451987b4323SJef Poskanzer     IESTREAMID = 208,       // Stream has invalid ID
45298ce496bSjef     /* Timer errors */
45398ce496bSjef     IENEWTIMER = 300,       // Unable to create new timer (check perror)
454acb4c4c9SKenneth Wong     IEUPDATETIMER = 301,    // Unable to update timer (check perror)
455acb4c4c9SKenneth Wong };
456acb4c4c9SKenneth Wong 
457acb4c4c9SKenneth Wong 
458acb4c4c9SKenneth Wong #ifdef __cplusplus
459acb4c4c9SKenneth Wong } /* close extern "C" */
46098ce496bSjef #endif
461 
462 
463 #endif /* !__IPERF_API_H */
464