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