xref: /aosp_15_r20/external/iperf3/src/iperf_api.h (revision 7ab6e6ace082586527a400463bc693a412a40341)
1*7ab6e6acSAndroid Build Coastguard Worker /*
2*7ab6e6acSAndroid Build Coastguard Worker  * iperf, Copyright (c) 2014-2020, The Regents of the University of
3*7ab6e6acSAndroid Build Coastguard Worker  * California, through Lawrence Berkeley National Laboratory (subject
4*7ab6e6acSAndroid Build Coastguard Worker  * to receipt of any required approvals from the U.S. Dept. of
5*7ab6e6acSAndroid Build Coastguard Worker  * Energy).  All rights reserved.
6*7ab6e6acSAndroid Build Coastguard Worker  *
7*7ab6e6acSAndroid Build Coastguard Worker  * If you have questions about your rights to use or distribute this
8*7ab6e6acSAndroid Build Coastguard Worker  * software, please contact Berkeley Lab's Technology Transfer
9*7ab6e6acSAndroid Build Coastguard Worker  * Department at [email protected].
10*7ab6e6acSAndroid Build Coastguard Worker  *
11*7ab6e6acSAndroid Build Coastguard Worker  * NOTICE.  This software is owned by the U.S. Department of Energy.
12*7ab6e6acSAndroid Build Coastguard Worker  * As such, the U.S. Government has been granted for itself and others
13*7ab6e6acSAndroid Build Coastguard Worker  * acting on its behalf a paid-up, nonexclusive, irrevocable,
14*7ab6e6acSAndroid Build Coastguard Worker  * worldwide license in the Software to reproduce, prepare derivative
15*7ab6e6acSAndroid Build Coastguard Worker  * works, and perform publicly and display publicly.  Beginning five
16*7ab6e6acSAndroid Build Coastguard Worker  * (5) years after the date permission to assert copyright is obtained
17*7ab6e6acSAndroid Build Coastguard Worker  * from the U.S. Department of Energy, and subject to any subsequent
18*7ab6e6acSAndroid Build Coastguard Worker  * five (5) year renewals, the U.S. Government is granted for itself
19*7ab6e6acSAndroid Build Coastguard Worker  * and others acting on its behalf a paid-up, nonexclusive,
20*7ab6e6acSAndroid Build Coastguard Worker  * irrevocable, worldwide license in the Software to reproduce,
21*7ab6e6acSAndroid Build Coastguard Worker  * prepare derivative works, distribute copies to the public, perform
22*7ab6e6acSAndroid Build Coastguard Worker  * publicly and display publicly, and to permit others to do so.
23*7ab6e6acSAndroid Build Coastguard Worker  *
24*7ab6e6acSAndroid Build Coastguard Worker  * This code is distributed under a BSD style license, see the LICENSE
25*7ab6e6acSAndroid Build Coastguard Worker  * file for complete information.
26*7ab6e6acSAndroid Build Coastguard Worker  */
27*7ab6e6acSAndroid Build Coastguard Worker #ifndef        __IPERF_API_H
28*7ab6e6acSAndroid Build Coastguard Worker #define        __IPERF_API_H
29*7ab6e6acSAndroid Build Coastguard Worker 
30*7ab6e6acSAndroid Build Coastguard Worker #include <sys/socket.h>
31*7ab6e6acSAndroid Build Coastguard Worker #include <sys/time.h>
32*7ab6e6acSAndroid Build Coastguard Worker #include <setjmp.h>
33*7ab6e6acSAndroid Build Coastguard Worker #include <stdio.h>
34*7ab6e6acSAndroid Build Coastguard Worker #ifdef HAVE_STDINT_H
35*7ab6e6acSAndroid Build Coastguard Worker #include <stdint.h>
36*7ab6e6acSAndroid Build Coastguard Worker #endif
37*7ab6e6acSAndroid Build Coastguard Worker #ifdef __cplusplus
38*7ab6e6acSAndroid Build Coastguard Worker extern "C" { /* open extern "C" */
39*7ab6e6acSAndroid Build Coastguard Worker #endif
40*7ab6e6acSAndroid Build Coastguard Worker 
41*7ab6e6acSAndroid Build Coastguard Worker 
42*7ab6e6acSAndroid Build Coastguard Worker struct iperf_test;
43*7ab6e6acSAndroid Build Coastguard Worker struct iperf_stream_result;
44*7ab6e6acSAndroid Build Coastguard Worker struct iperf_interval_results;
45*7ab6e6acSAndroid Build Coastguard Worker struct iperf_stream;
46*7ab6e6acSAndroid Build Coastguard Worker struct iperf_time;
47*7ab6e6acSAndroid Build Coastguard Worker 
48*7ab6e6acSAndroid Build Coastguard Worker #if !defined(__IPERF_H)
49*7ab6e6acSAndroid Build Coastguard Worker typedef uint64_t iperf_size_t;
50*7ab6e6acSAndroid Build Coastguard Worker #endif // __IPERF_H
51*7ab6e6acSAndroid Build Coastguard Worker 
52*7ab6e6acSAndroid Build Coastguard Worker /* default settings */
53*7ab6e6acSAndroid Build Coastguard Worker #define Ptcp SOCK_STREAM
54*7ab6e6acSAndroid Build Coastguard Worker #define Pudp SOCK_DGRAM
55*7ab6e6acSAndroid Build Coastguard Worker #define Psctp 12
56*7ab6e6acSAndroid Build Coastguard Worker #define DEFAULT_UDP_BLKSIZE 1460 /* default is dynamically set, else this */
57*7ab6e6acSAndroid Build Coastguard Worker #define DEFAULT_TCP_BLKSIZE (128 * 1024)  /* default read/write block size */
58*7ab6e6acSAndroid Build Coastguard Worker #define DEFAULT_SCTP_BLKSIZE (64 * 1024)
59*7ab6e6acSAndroid Build Coastguard Worker 
60*7ab6e6acSAndroid Build Coastguard Worker /* short option equivalents, used to support options that only have long form */
61*7ab6e6acSAndroid Build Coastguard Worker #define OPT_SCTP 1
62*7ab6e6acSAndroid Build Coastguard Worker #define OPT_LOGFILE 2
63*7ab6e6acSAndroid Build Coastguard Worker #define OPT_GET_SERVER_OUTPUT 3
64*7ab6e6acSAndroid Build Coastguard Worker #define OPT_UDP_COUNTERS_64BIT 4
65*7ab6e6acSAndroid Build Coastguard Worker #define OPT_CLIENT_PORT 5
66*7ab6e6acSAndroid Build Coastguard Worker #define OPT_NUMSTREAMS 6
67*7ab6e6acSAndroid Build Coastguard Worker #define OPT_FORCEFLUSH 7
68*7ab6e6acSAndroid Build Coastguard Worker #define OPT_NO_FQ_SOCKET_PACING 9 /* UNUSED */
69*7ab6e6acSAndroid Build Coastguard Worker #define OPT_FQ_RATE 10
70*7ab6e6acSAndroid Build Coastguard Worker #define OPT_DSCP 11
71*7ab6e6acSAndroid Build Coastguard Worker #define OPT_CLIENT_USERNAME 12
72*7ab6e6acSAndroid Build Coastguard Worker #define OPT_CLIENT_RSA_PUBLIC_KEY 13
73*7ab6e6acSAndroid Build Coastguard Worker #define OPT_SERVER_RSA_PRIVATE_KEY 14
74*7ab6e6acSAndroid Build Coastguard Worker #define OPT_SERVER_AUTHORIZED_USERS 15
75*7ab6e6acSAndroid Build Coastguard Worker #define OPT_PACING_TIMER 16
76*7ab6e6acSAndroid Build Coastguard Worker #define OPT_CONNECT_TIMEOUT 17
77*7ab6e6acSAndroid Build Coastguard Worker #define OPT_REPEATING_PAYLOAD 18
78*7ab6e6acSAndroid Build Coastguard Worker #define OPT_EXTRA_DATA 19
79*7ab6e6acSAndroid Build Coastguard Worker #define OPT_BIDIRECTIONAL 20
80*7ab6e6acSAndroid Build Coastguard Worker #define OPT_SERVER_BITRATE_LIMIT 21
81*7ab6e6acSAndroid Build Coastguard Worker #define OPT_TIMESTAMPS 22
82*7ab6e6acSAndroid Build Coastguard Worker 
83*7ab6e6acSAndroid Build Coastguard Worker /* states */
84*7ab6e6acSAndroid Build Coastguard Worker #define TEST_START 1
85*7ab6e6acSAndroid Build Coastguard Worker #define TEST_RUNNING 2
86*7ab6e6acSAndroid Build Coastguard Worker #define RESULT_REQUEST 3 /* not used */
87*7ab6e6acSAndroid Build Coastguard Worker #define TEST_END 4
88*7ab6e6acSAndroid Build Coastguard Worker #define STREAM_BEGIN 5 /* not used */
89*7ab6e6acSAndroid Build Coastguard Worker #define STREAM_RUNNING 6 /* not used */
90*7ab6e6acSAndroid Build Coastguard Worker #define STREAM_END 7 /* not used */
91*7ab6e6acSAndroid Build Coastguard Worker #define ALL_STREAMS_END 8 /* not used */
92*7ab6e6acSAndroid Build Coastguard Worker #define PARAM_EXCHANGE 9
93*7ab6e6acSAndroid Build Coastguard Worker #define CREATE_STREAMS 10
94*7ab6e6acSAndroid Build Coastguard Worker #define SERVER_TERMINATE 11
95*7ab6e6acSAndroid Build Coastguard Worker #define CLIENT_TERMINATE 12
96*7ab6e6acSAndroid Build Coastguard Worker #define EXCHANGE_RESULTS 13
97*7ab6e6acSAndroid Build Coastguard Worker #define DISPLAY_RESULTS 14
98*7ab6e6acSAndroid Build Coastguard Worker #define IPERF_START 15
99*7ab6e6acSAndroid Build Coastguard Worker #define IPERF_DONE 16
100*7ab6e6acSAndroid Build Coastguard Worker #define ACCESS_DENIED (-1)
101*7ab6e6acSAndroid Build Coastguard Worker #define SERVER_ERROR (-2)
102*7ab6e6acSAndroid Build Coastguard Worker 
103*7ab6e6acSAndroid Build Coastguard Worker /* Getter routines for some fields inside iperf_test. */
104*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_verbose( struct iperf_test* ipt );
105*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_control_socket( struct iperf_test* ipt );
106*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_omit( struct iperf_test* ipt );
107*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_duration( struct iperf_test* ipt );
108*7ab6e6acSAndroid Build Coastguard Worker char	iperf_get_test_role( struct iperf_test* ipt );
109*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_reverse( struct iperf_test* ipt );
110*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_blksize( struct iperf_test* ipt );
111*7ab6e6acSAndroid Build Coastguard Worker FILE*	iperf_get_test_outfile( struct iperf_test* ipt );
112*7ab6e6acSAndroid Build Coastguard Worker uint64_t iperf_get_test_rate( struct iperf_test* ipt );
113*7ab6e6acSAndroid Build Coastguard Worker int iperf_get_test_pacing_timer( struct iperf_test* ipt );
114*7ab6e6acSAndroid Build Coastguard Worker uint64_t iperf_get_test_bytes( struct iperf_test* ipt );
115*7ab6e6acSAndroid Build Coastguard Worker uint64_t iperf_get_test_blocks( struct iperf_test* ipt );
116*7ab6e6acSAndroid Build Coastguard Worker int     iperf_get_test_burst( struct iperf_test* ipt );
117*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_socket_bufsize( struct iperf_test* ipt );
118*7ab6e6acSAndroid Build Coastguard Worker double	iperf_get_test_reporter_interval( struct iperf_test* ipt );
119*7ab6e6acSAndroid Build Coastguard Worker double	iperf_get_test_stats_interval( struct iperf_test* ipt );
120*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_num_streams( struct iperf_test* ipt );
121*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_repeating_payload( struct iperf_test* ipt );
122*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_timestamps( struct iperf_test* ipt );
123*7ab6e6acSAndroid Build Coastguard Worker const char* iperf_get_test_timestamp_format( struct iperf_test* ipt );
124*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_server_port( struct iperf_test* ipt );
125*7ab6e6acSAndroid Build Coastguard Worker char*	iperf_get_test_server_hostname( struct iperf_test* ipt );
126*7ab6e6acSAndroid Build Coastguard Worker char*	iperf_get_test_template( struct iperf_test* ipt );
127*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_protocol_id( struct iperf_test* ipt );
128*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_json_output( struct iperf_test* ipt );
129*7ab6e6acSAndroid Build Coastguard Worker char*	iperf_get_test_json_output_string ( struct iperf_test* ipt );
130*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_zerocopy( struct iperf_test* ipt );
131*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_get_server_output( struct iperf_test* ipt );
132*7ab6e6acSAndroid Build Coastguard Worker char*	iperf_get_test_bind_address ( struct iperf_test* ipt );
133*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_udp_counters_64bit( struct iperf_test* ipt );
134*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_one_off( struct iperf_test* ipt );
135*7ab6e6acSAndroid Build Coastguard Worker int iperf_get_test_tos( struct iperf_test* ipt );
136*7ab6e6acSAndroid Build Coastguard Worker char*	iperf_get_extra_data( struct iperf_test* ipt );
137*7ab6e6acSAndroid Build Coastguard Worker char*	iperf_get_iperf_version(void);
138*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_no_delay( struct iperf_test* ipt );
139*7ab6e6acSAndroid Build Coastguard Worker int	iperf_get_test_connect_timeout( struct iperf_test* ipt );
140*7ab6e6acSAndroid Build Coastguard Worker 
141*7ab6e6acSAndroid Build Coastguard Worker /* Setter routines for some fields inside iperf_test. */
142*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_verbose( struct iperf_test* ipt, int verbose );
143*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_control_socket( struct iperf_test* ipt, int ctrl_sck );
144*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_omit( struct iperf_test* ipt, int omit );
145*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_duration( struct iperf_test* ipt, int duration );
146*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_reporter_interval( struct iperf_test* ipt, double reporter_interval );
147*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_stats_interval( struct iperf_test* ipt, double stats_interval );
148*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_state( struct iperf_test* ipt, signed char state );
149*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_blksize( struct iperf_test* ipt, int blksize );
150*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_logfile( struct iperf_test* ipt, const char *logfile );
151*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_rate( struct iperf_test* ipt, uint64_t rate );
152*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_pacing_timer( struct iperf_test* ipt, int pacing_timer );
153*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_bytes( struct iperf_test* ipt, uint64_t bytes );
154*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_blocks( struct iperf_test* ipt, uint64_t blocks );
155*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_burst( struct iperf_test* ipt, int burst );
156*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_server_port( struct iperf_test* ipt, int server_port );
157*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_socket_bufsize( struct iperf_test* ipt, int socket_bufsize );
158*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_num_streams( struct iperf_test* ipt, int num_streams );
159*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_repeating_payload( struct iperf_test* ipt, int repeating_payload );
160*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_timestamps( struct iperf_test* ipt, int timestamps );
161*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_timestamp_format( struct iperf_test*, const char *tf );
162*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_role( struct iperf_test* ipt, char role );
163*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_server_hostname( struct iperf_test* ipt, const char* server_hostname );
164*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_template( struct iperf_test *ipt, const char *tmp_template );
165*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_reverse( struct iperf_test* ipt, int reverse );
166*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_json_output( struct iperf_test* ipt, int json_output );
167*7ab6e6acSAndroid Build Coastguard Worker int	iperf_has_zerocopy( void );
168*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_zerocopy( struct iperf_test* ipt, int zerocopy );
169*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_get_server_output( struct iperf_test* ipt, int get_server_output );
170*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_bind_address( struct iperf_test* ipt, const char *bind_address );
171*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_udp_counters_64bit( struct iperf_test* ipt, int udp_counters_64bit );
172*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_one_off( struct iperf_test* ipt, int one_off );
173*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_tos( struct iperf_test* ipt, int tos );
174*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_extra_data( struct iperf_test* ipt, const char *dat );
175*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_bidirectional( struct iperf_test* ipt, int bidirectional);
176*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_no_delay( struct iperf_test* ipt, int no_delay);
177*7ab6e6acSAndroid Build Coastguard Worker 
178*7ab6e6acSAndroid Build Coastguard Worker #if defined(HAVE_SSL)
179*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_client_username(struct iperf_test *ipt, const char *client_username);
180*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_client_password(struct iperf_test *ipt, const char *client_password);
181*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_client_rsa_pubkey(struct iperf_test *ipt, const char *client_rsa_pubkey_base64);
182*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_server_authorized_users(struct iperf_test *ipt, const char *server_authorized_users);
183*7ab6e6acSAndroid Build Coastguard Worker void    iperf_set_test_server_rsa_privkey(struct iperf_test *ipt, const char *server_rsa_privkey_base64);
184*7ab6e6acSAndroid Build Coastguard Worker #endif // HAVE_SSL
185*7ab6e6acSAndroid Build Coastguard Worker 
186*7ab6e6acSAndroid Build Coastguard Worker void	iperf_set_test_connect_timeout(struct iperf_test *ipt, int ct);
187*7ab6e6acSAndroid Build Coastguard Worker 
188*7ab6e6acSAndroid Build Coastguard Worker /**
189*7ab6e6acSAndroid Build Coastguard Worker  * exchange_parameters - handles the param_Exchange part for client
190*7ab6e6acSAndroid Build Coastguard Worker  *
191*7ab6e6acSAndroid Build Coastguard Worker  */
192*7ab6e6acSAndroid Build Coastguard Worker int      iperf_exchange_parameters(struct iperf_test * test);
193*7ab6e6acSAndroid Build Coastguard Worker 
194*7ab6e6acSAndroid Build Coastguard Worker /**
195*7ab6e6acSAndroid Build Coastguard Worker  * add_to_interval_list -- adds new interval to the interval_list
196*7ab6e6acSAndroid Build Coastguard Worker  *
197*7ab6e6acSAndroid Build Coastguard Worker  */
198*7ab6e6acSAndroid Build Coastguard Worker void      add_to_interval_list(struct iperf_stream_result * rp, struct iperf_interval_results *temp);
199*7ab6e6acSAndroid Build Coastguard Worker 
200*7ab6e6acSAndroid Build Coastguard Worker /**
201*7ab6e6acSAndroid Build Coastguard Worker  * connect_msg -- displays connection message
202*7ab6e6acSAndroid Build Coastguard Worker  * denoting senfer/receiver details
203*7ab6e6acSAndroid Build Coastguard Worker  *
204*7ab6e6acSAndroid Build Coastguard Worker  */
205*7ab6e6acSAndroid Build Coastguard Worker void      connect_msg(struct iperf_stream * sp);
206*7ab6e6acSAndroid Build Coastguard Worker 
207*7ab6e6acSAndroid Build Coastguard Worker /**
208*7ab6e6acSAndroid Build Coastguard Worker  * iperf_stats_callback -- handles the statistic gathering
209*7ab6e6acSAndroid Build Coastguard Worker  *
210*7ab6e6acSAndroid Build Coastguard Worker  */
211*7ab6e6acSAndroid Build Coastguard Worker void     iperf_stats_callback(struct iperf_test * test);
212*7ab6e6acSAndroid Build Coastguard Worker 
213*7ab6e6acSAndroid Build Coastguard Worker /**
214*7ab6e6acSAndroid Build Coastguard Worker  * iperf_reporter_callback -- handles the report printing
215*7ab6e6acSAndroid Build Coastguard Worker  *
216*7ab6e6acSAndroid Build Coastguard Worker  */
217*7ab6e6acSAndroid Build Coastguard Worker void     iperf_reporter_callback(struct iperf_test * test);
218*7ab6e6acSAndroid Build Coastguard Worker 
219*7ab6e6acSAndroid Build Coastguard Worker /**
220*7ab6e6acSAndroid Build Coastguard Worker  * iperf_new_test -- return a new iperf_test with default values
221*7ab6e6acSAndroid Build Coastguard Worker  *
222*7ab6e6acSAndroid Build Coastguard Worker  * returns NULL on failure
223*7ab6e6acSAndroid Build Coastguard Worker  *
224*7ab6e6acSAndroid Build Coastguard Worker  */
225*7ab6e6acSAndroid Build Coastguard Worker struct iperf_test *iperf_new_test(void);
226*7ab6e6acSAndroid Build Coastguard Worker 
227*7ab6e6acSAndroid Build Coastguard Worker int      iperf_defaults(struct iperf_test * testp);
228*7ab6e6acSAndroid Build Coastguard Worker 
229*7ab6e6acSAndroid Build Coastguard Worker /**
230*7ab6e6acSAndroid Build Coastguard Worker  * iperf_free_test -- free resources used by test, calls iperf_free_stream to
231*7ab6e6acSAndroid Build Coastguard Worker  * free streams
232*7ab6e6acSAndroid Build Coastguard Worker  *
233*7ab6e6acSAndroid Build Coastguard Worker  */
234*7ab6e6acSAndroid Build Coastguard Worker void      iperf_free_test(struct iperf_test * testp);
235*7ab6e6acSAndroid Build Coastguard Worker 
236*7ab6e6acSAndroid Build Coastguard Worker /**
237*7ab6e6acSAndroid Build Coastguard Worker  * iperf_new_stream -- return a net iperf_stream with default values
238*7ab6e6acSAndroid Build Coastguard Worker  *
239*7ab6e6acSAndroid Build Coastguard Worker  * returns NULL on failure
240*7ab6e6acSAndroid Build Coastguard Worker  *
241*7ab6e6acSAndroid Build Coastguard Worker  */
242*7ab6e6acSAndroid Build Coastguard Worker struct iperf_stream *iperf_new_stream(struct iperf_test *, int, int);
243*7ab6e6acSAndroid Build Coastguard Worker 
244*7ab6e6acSAndroid Build Coastguard Worker /**
245*7ab6e6acSAndroid Build Coastguard Worker  * iperf_add_stream -- add a stream to a test
246*7ab6e6acSAndroid Build Coastguard Worker  *
247*7ab6e6acSAndroid Build Coastguard Worker  */
248*7ab6e6acSAndroid Build Coastguard Worker void      iperf_add_stream(struct iperf_test * test, struct iperf_stream * stream);
249*7ab6e6acSAndroid Build Coastguard Worker 
250*7ab6e6acSAndroid Build Coastguard Worker /**
251*7ab6e6acSAndroid Build Coastguard Worker  * iperf_init_stream -- init resources associated with test
252*7ab6e6acSAndroid Build Coastguard Worker  *
253*7ab6e6acSAndroid Build Coastguard Worker  */
254*7ab6e6acSAndroid Build Coastguard Worker int       iperf_init_stream(struct iperf_stream *, struct iperf_test *);
255*7ab6e6acSAndroid Build Coastguard Worker 
256*7ab6e6acSAndroid Build Coastguard Worker /**
257*7ab6e6acSAndroid Build Coastguard Worker  * iperf_free_stream -- free resources associated with test
258*7ab6e6acSAndroid Build Coastguard Worker  *
259*7ab6e6acSAndroid Build Coastguard Worker  */
260*7ab6e6acSAndroid Build Coastguard Worker void      iperf_free_stream(struct iperf_stream * sp);
261*7ab6e6acSAndroid Build Coastguard Worker 
262*7ab6e6acSAndroid Build Coastguard Worker int has_tcpinfo(void);
263*7ab6e6acSAndroid Build Coastguard Worker int has_tcpinfo_retransmits(void);
264*7ab6e6acSAndroid Build Coastguard Worker void save_tcpinfo(struct iperf_stream *sp, struct iperf_interval_results *irp);
265*7ab6e6acSAndroid Build Coastguard Worker long get_total_retransmits(struct iperf_interval_results *irp);
266*7ab6e6acSAndroid Build Coastguard Worker long get_snd_cwnd(struct iperf_interval_results *irp);
267*7ab6e6acSAndroid Build Coastguard Worker long get_rtt(struct iperf_interval_results *irp);
268*7ab6e6acSAndroid Build Coastguard Worker long get_rttvar(struct iperf_interval_results *irp);
269*7ab6e6acSAndroid Build Coastguard Worker long get_pmtu(struct iperf_interval_results *irp);
270*7ab6e6acSAndroid Build Coastguard Worker void print_tcpinfo(struct iperf_test *test);
271*7ab6e6acSAndroid Build Coastguard Worker void build_tcpinfo_message(struct iperf_interval_results *r, char *message);
272*7ab6e6acSAndroid Build Coastguard Worker 
273*7ab6e6acSAndroid Build Coastguard Worker int iperf_set_send_state(struct iperf_test *test, signed char state);
274*7ab6e6acSAndroid Build Coastguard Worker void iperf_check_throttle(struct iperf_stream *sp, struct iperf_time *nowP);
275*7ab6e6acSAndroid Build Coastguard Worker int iperf_send(struct iperf_test *, fd_set *) /* __attribute__((hot)) */;
276*7ab6e6acSAndroid Build Coastguard Worker int iperf_recv(struct iperf_test *, fd_set *);
277*7ab6e6acSAndroid Build Coastguard Worker void iperf_catch_sigend(void (*handler)(int));
278*7ab6e6acSAndroid Build Coastguard Worker void iperf_got_sigend(struct iperf_test *test) __attribute__ ((noreturn));
279*7ab6e6acSAndroid Build Coastguard Worker void usage(void);
280*7ab6e6acSAndroid Build Coastguard Worker void usage_long(FILE * f);
281*7ab6e6acSAndroid Build Coastguard Worker void warning(const char *);
282*7ab6e6acSAndroid Build Coastguard Worker int iperf_exchange_results(struct iperf_test *);
283*7ab6e6acSAndroid Build Coastguard Worker int iperf_init_test(struct iperf_test *);
284*7ab6e6acSAndroid Build Coastguard Worker int iperf_create_send_timers(struct iperf_test *);
285*7ab6e6acSAndroid Build Coastguard Worker int iperf_parse_arguments(struct iperf_test *, int, char **);
286*7ab6e6acSAndroid Build Coastguard Worker int iperf_open_logfile(struct iperf_test *);
287*7ab6e6acSAndroid Build Coastguard Worker void iperf_reset_test(struct iperf_test *);
288*7ab6e6acSAndroid Build Coastguard Worker void iperf_reset_stats(struct iperf_test * test);
289*7ab6e6acSAndroid Build Coastguard Worker 
290*7ab6e6acSAndroid Build Coastguard Worker struct protocol *get_protocol(struct iperf_test *, int);
291*7ab6e6acSAndroid Build Coastguard Worker int set_protocol(struct iperf_test *, int);
292*7ab6e6acSAndroid Build Coastguard Worker 
293*7ab6e6acSAndroid Build Coastguard Worker void iperf_on_new_stream(struct iperf_stream *);
294*7ab6e6acSAndroid Build Coastguard Worker void iperf_on_test_start(struct iperf_test *);
295*7ab6e6acSAndroid Build Coastguard Worker void iperf_on_connect(struct iperf_test *);
296*7ab6e6acSAndroid Build Coastguard Worker void iperf_on_test_finish(struct iperf_test *);
297*7ab6e6acSAndroid Build Coastguard Worker 
298*7ab6e6acSAndroid Build Coastguard Worker extern jmp_buf env;
299*7ab6e6acSAndroid Build Coastguard Worker 
300*7ab6e6acSAndroid Build Coastguard Worker /* Client routines. */
301*7ab6e6acSAndroid Build Coastguard Worker int iperf_run_client(struct iperf_test *);
302*7ab6e6acSAndroid Build Coastguard Worker int iperf_connect(struct iperf_test *);
303*7ab6e6acSAndroid Build Coastguard Worker int iperf_create_streams(struct iperf_test *, int sender);
304*7ab6e6acSAndroid Build Coastguard Worker int iperf_handle_message_client(struct iperf_test *);
305*7ab6e6acSAndroid Build Coastguard Worker int iperf_client_end(struct iperf_test *);
306*7ab6e6acSAndroid Build Coastguard Worker 
307*7ab6e6acSAndroid Build Coastguard Worker /* Server routines. */
308*7ab6e6acSAndroid Build Coastguard Worker int iperf_run_server(struct iperf_test *);
309*7ab6e6acSAndroid Build Coastguard Worker int iperf_server_listen(struct iperf_test *);
310*7ab6e6acSAndroid Build Coastguard Worker int iperf_accept(struct iperf_test *);
311*7ab6e6acSAndroid Build Coastguard Worker int iperf_handle_message_server(struct iperf_test *);
312*7ab6e6acSAndroid Build Coastguard Worker int iperf_create_pidfile(struct iperf_test *);
313*7ab6e6acSAndroid Build Coastguard Worker int iperf_delete_pidfile(struct iperf_test *);
314*7ab6e6acSAndroid Build Coastguard Worker void iperf_check_total_rate(struct iperf_test *, iperf_size_t);
315*7ab6e6acSAndroid Build Coastguard Worker 
316*7ab6e6acSAndroid Build Coastguard Worker /* JSON output routines. */
317*7ab6e6acSAndroid Build Coastguard Worker int iperf_json_start(struct iperf_test *);
318*7ab6e6acSAndroid Build Coastguard Worker int iperf_json_finish(struct iperf_test *);
319*7ab6e6acSAndroid Build Coastguard Worker 
320*7ab6e6acSAndroid Build Coastguard Worker /* CPU affinity routines */
321*7ab6e6acSAndroid Build Coastguard Worker int iperf_setaffinity(struct iperf_test *, int affinity);
322*7ab6e6acSAndroid Build Coastguard Worker int iperf_clearaffinity(struct iperf_test *);
323*7ab6e6acSAndroid Build Coastguard Worker 
324*7ab6e6acSAndroid Build Coastguard Worker /* Custom printf routine. */
325*7ab6e6acSAndroid Build Coastguard Worker int iperf_printf(struct iperf_test *test, const char *format, ...) __attribute__ ((format(printf,2,3)));
326*7ab6e6acSAndroid Build Coastguard Worker int iflush(struct iperf_test *test);
327*7ab6e6acSAndroid Build Coastguard Worker 
328*7ab6e6acSAndroid Build Coastguard Worker /* Error routines. */
329*7ab6e6acSAndroid Build Coastguard Worker void iperf_err(struct iperf_test *test, const char *format, ...) __attribute__ ((format(printf,2,3)));
330*7ab6e6acSAndroid Build Coastguard Worker void iperf_errexit(struct iperf_test *test, const char *format, ...) __attribute__ ((format(printf,2,3),noreturn));
331*7ab6e6acSAndroid Build Coastguard Worker char *iperf_strerror(int);
332*7ab6e6acSAndroid Build Coastguard Worker extern int i_errno;
333*7ab6e6acSAndroid Build Coastguard Worker enum {
334*7ab6e6acSAndroid Build Coastguard Worker     IENONE = 0,             // No error
335*7ab6e6acSAndroid Build Coastguard Worker     /* Parameter errors */
336*7ab6e6acSAndroid Build Coastguard Worker     IESERVCLIENT = 1,       // Iperf cannot be both server and client
337*7ab6e6acSAndroid Build Coastguard Worker     IENOROLE = 2,           // Iperf must either be a client (-c) or server (-s)
338*7ab6e6acSAndroid Build Coastguard Worker     IESERVERONLY = 3,       // This option is server only
339*7ab6e6acSAndroid Build Coastguard Worker     IECLIENTONLY = 4,       // This option is client only
340*7ab6e6acSAndroid Build Coastguard Worker     IEDURATION = 5,         // test duration too long. Maximum value = %dMAX_TIME
341*7ab6e6acSAndroid Build Coastguard Worker     IENUMSTREAMS = 6,       // Number of parallel streams too large. Maximum value = %dMAX_STREAMS
342*7ab6e6acSAndroid Build Coastguard Worker     IEBLOCKSIZE = 7,        // Block size too large. Maximum value = %dMAX_BLOCKSIZE
343*7ab6e6acSAndroid Build Coastguard Worker     IEBUFSIZE = 8,          // Socket buffer size too large. Maximum value = %dMAX_TCP_BUFFER
344*7ab6e6acSAndroid Build Coastguard Worker     IEINTERVAL = 9,         // Invalid report interval (min = %gMIN_INTERVAL, max = %gMAX_INTERVAL seconds)
345*7ab6e6acSAndroid Build Coastguard Worker     IEMSS = 10,             // MSS too large. Maximum value = %dMAX_MSS
346*7ab6e6acSAndroid Build Coastguard Worker     IENOSENDFILE = 11,      // This OS does not support sendfile
347*7ab6e6acSAndroid Build Coastguard Worker     IEOMIT = 12,            // Bogus value for --omit
348*7ab6e6acSAndroid Build Coastguard Worker     IEUNIMP = 13,           // Not implemented yet
349*7ab6e6acSAndroid Build Coastguard Worker     IEFILE = 14,            // -F file couldn't be opened
350*7ab6e6acSAndroid Build Coastguard Worker     IEBURST = 15,           // Invalid burst count. Maximum value = %dMAX_BURST
351*7ab6e6acSAndroid Build Coastguard Worker     IEENDCONDITIONS = 16,   // Only one test end condition (-t, -n, -k) may be specified
352*7ab6e6acSAndroid Build Coastguard Worker     IELOGFILE = 17,	    // Can't open log file
353*7ab6e6acSAndroid Build Coastguard Worker     IENOSCTP = 18,	    // No SCTP support available
354*7ab6e6acSAndroid Build Coastguard Worker     IEBIND = 19,	    // UNUSED:  Local port specified with no local bind option
355*7ab6e6acSAndroid Build Coastguard Worker     IEUDPBLOCKSIZE = 20,    // Block size invalid
356*7ab6e6acSAndroid Build Coastguard Worker     IEBADTOS = 21,	    // Bad TOS value
357*7ab6e6acSAndroid Build Coastguard Worker     IESETCLIENTAUTH = 22,   // Bad configuration of client authentication
358*7ab6e6acSAndroid Build Coastguard Worker     IESETSERVERAUTH = 23,   // Bad configuration of server authentication
359*7ab6e6acSAndroid Build Coastguard Worker     IEBADFORMAT = 24,	    // Bad format argument to -f
360*7ab6e6acSAndroid Build Coastguard Worker     IEREVERSEBIDIR = 25,    // Iperf cannot be both reverse and bidirectional
361*7ab6e6acSAndroid Build Coastguard Worker     IEBADPORT = 26,	    // Bad port number
362*7ab6e6acSAndroid Build Coastguard Worker     IETOTALRATE = 27,       // Total required bandwidth is larger than server's limit
363*7ab6e6acSAndroid Build Coastguard Worker     IETOTALINTERVAL = 28,   // Invalid time interval for calculating average data rate
364*7ab6e6acSAndroid Build Coastguard Worker     /* Test errors */
365*7ab6e6acSAndroid Build Coastguard Worker     IENEWTEST = 100,        // Unable to create a new test (check perror)
366*7ab6e6acSAndroid Build Coastguard Worker     IEINITTEST = 101,       // Test initialization failed (check perror)
367*7ab6e6acSAndroid Build Coastguard Worker     IELISTEN = 102,         // Unable to listen for connections (check perror)
368*7ab6e6acSAndroid Build Coastguard Worker     IECONNECT = 103,        // Unable to connect to server (check herror/perror) [from netdial]
369*7ab6e6acSAndroid Build Coastguard Worker     IEACCEPT = 104,         // Unable to accept connection from client (check herror/perror)
370*7ab6e6acSAndroid Build Coastguard Worker     IESENDCOOKIE = 105,     // Unable to send cookie to server (check perror)
371*7ab6e6acSAndroid Build Coastguard Worker     IERECVCOOKIE = 106,     // Unable to receive cookie from client (check perror)
372*7ab6e6acSAndroid Build Coastguard Worker     IECTRLWRITE = 107,      // Unable to write to the control socket (check perror)
373*7ab6e6acSAndroid Build Coastguard Worker     IECTRLREAD = 108,       // Unable to read from the control socket (check perror)
374*7ab6e6acSAndroid Build Coastguard Worker     IECTRLCLOSE = 109,      // Control socket has closed unexpectedly
375*7ab6e6acSAndroid Build Coastguard Worker     IEMESSAGE = 110,        // Received an unknown message
376*7ab6e6acSAndroid Build Coastguard Worker     IESENDMESSAGE = 111,    // Unable to send control message to client/server (check perror)
377*7ab6e6acSAndroid Build Coastguard Worker     IERECVMESSAGE = 112,    // Unable to receive control message from client/server (check perror)
378*7ab6e6acSAndroid Build Coastguard Worker     IESENDPARAMS = 113,     // Unable to send parameters to server (check perror)
379*7ab6e6acSAndroid Build Coastguard Worker     IERECVPARAMS = 114,     // Unable to receive parameters from client (check perror)
380*7ab6e6acSAndroid Build Coastguard Worker     IEPACKAGERESULTS = 115, // Unable to package results (check perror)
381*7ab6e6acSAndroid Build Coastguard Worker     IESENDRESULTS = 116,    // Unable to send results to client/server (check perror)
382*7ab6e6acSAndroid Build Coastguard Worker     IERECVRESULTS = 117,    // Unable to receive results from client/server (check perror)
383*7ab6e6acSAndroid Build Coastguard Worker     IESELECT = 118,         // Select failed (check perror)
384*7ab6e6acSAndroid Build Coastguard Worker     IECLIENTTERM = 119,     // The client has terminated
385*7ab6e6acSAndroid Build Coastguard Worker     IESERVERTERM = 120,     // The server has terminated
386*7ab6e6acSAndroid Build Coastguard Worker     IEACCESSDENIED = 121,   // The server is busy running a test. Try again later.
387*7ab6e6acSAndroid Build Coastguard Worker     IESETNODELAY = 122,     // Unable to set TCP/SCTP NODELAY (check perror)
388*7ab6e6acSAndroid Build Coastguard Worker     IESETMSS = 123,         // Unable to set TCP/SCTP MSS (check perror)
389*7ab6e6acSAndroid Build Coastguard Worker     IESETBUF = 124,         // Unable to set socket buffer size (check perror)
390*7ab6e6acSAndroid Build Coastguard Worker     IESETTOS = 125,         // Unable to set IP TOS (check perror)
391*7ab6e6acSAndroid Build Coastguard Worker     IESETCOS = 126,         // Unable to set IPv6 traffic class (check perror)
392*7ab6e6acSAndroid Build Coastguard Worker     IESETFLOW = 127,        // Unable to set IPv6 flow label
393*7ab6e6acSAndroid Build Coastguard Worker     IEREUSEADDR = 128,      // Unable to set reuse address on socket (check perror)
394*7ab6e6acSAndroid Build Coastguard Worker     IENONBLOCKING = 129,    // Unable to set socket to non-blocking (check perror)
395*7ab6e6acSAndroid Build Coastguard Worker     IESETWINDOWSIZE = 130,  // Unable to set socket window size (check perror)
396*7ab6e6acSAndroid Build Coastguard Worker     IEPROTOCOL = 131,       // Protocol does not exist
397*7ab6e6acSAndroid Build Coastguard Worker     IEAFFINITY = 132,       // Unable to set CPU affinity (check perror)
398*7ab6e6acSAndroid Build Coastguard Worker     IEDAEMON = 133,	    // Unable to become a daemon process
399*7ab6e6acSAndroid Build Coastguard Worker     IESETCONGESTION = 134,  // Unable to set TCP_CONGESTION
400*7ab6e6acSAndroid Build Coastguard Worker     IEPIDFILE = 135,	    // Unable to write PID file
401*7ab6e6acSAndroid Build Coastguard Worker     IEV6ONLY = 136,  	    // Unable to set/unset IPV6_V6ONLY (check perror)
402*7ab6e6acSAndroid Build Coastguard Worker     IESETSCTPDISABLEFRAG = 137, // Unable to set SCTP Fragmentation (check perror)
403*7ab6e6acSAndroid Build Coastguard Worker     IESETSCTPNSTREAM= 138,  //  Unable to set SCTP number of streams (check perror)
404*7ab6e6acSAndroid Build Coastguard Worker     IESETSCTPBINDX= 139,    // Unable to process sctp_bindx() parameters
405*7ab6e6acSAndroid Build Coastguard Worker     IESETPACING= 140,       // Unable to set socket pacing rate
406*7ab6e6acSAndroid Build Coastguard Worker     IESETBUF2= 141,	    // Socket buffer size incorrect (written value != read value)
407*7ab6e6acSAndroid Build Coastguard Worker     IEAUTHTEST = 142,       // Test authorization failed
408*7ab6e6acSAndroid Build Coastguard Worker     /* Stream errors */
409*7ab6e6acSAndroid Build Coastguard Worker     IECREATESTREAM = 200,   // Unable to create a new stream (check herror/perror)
410*7ab6e6acSAndroid Build Coastguard Worker     IEINITSTREAM = 201,     // Unable to initialize stream (check herror/perror)
411*7ab6e6acSAndroid Build Coastguard Worker     IESTREAMLISTEN = 202,   // Unable to start stream listener (check perror)
412*7ab6e6acSAndroid Build Coastguard Worker     IESTREAMCONNECT = 203,  // Unable to connect stream (check herror/perror)
413*7ab6e6acSAndroid Build Coastguard Worker     IESTREAMACCEPT = 204,   // Unable to accepte stream connection (check perror)
414*7ab6e6acSAndroid Build Coastguard Worker     IESTREAMWRITE = 205,    // Unable to write to stream socket (check perror)
415*7ab6e6acSAndroid Build Coastguard Worker     IESTREAMREAD = 206,     // Unable to read from stream (check perror)
416*7ab6e6acSAndroid Build Coastguard Worker     IESTREAMCLOSE = 207,    // Stream has closed unexpectedly
417*7ab6e6acSAndroid Build Coastguard Worker     IESTREAMID = 208,       // Stream has invalid ID
418*7ab6e6acSAndroid Build Coastguard Worker     /* Timer errors */
419*7ab6e6acSAndroid Build Coastguard Worker     IENEWTIMER = 300,       // Unable to create new timer (check perror)
420*7ab6e6acSAndroid Build Coastguard Worker     IEUPDATETIMER = 301,    // Unable to update timer (check perror)
421*7ab6e6acSAndroid Build Coastguard Worker };
422*7ab6e6acSAndroid Build Coastguard Worker 
423*7ab6e6acSAndroid Build Coastguard Worker 
424*7ab6e6acSAndroid Build Coastguard Worker #ifdef __cplusplus
425*7ab6e6acSAndroid Build Coastguard Worker } /* close extern "C" */
426*7ab6e6acSAndroid Build Coastguard Worker #endif
427*7ab6e6acSAndroid Build Coastguard Worker 
428*7ab6e6acSAndroid Build Coastguard Worker 
429*7ab6e6acSAndroid Build Coastguard Worker #endif /* !__IPERF_API_H */
430