/* Copyright (C) 2007 Hewlett-Packard Company */ /* This file contains the test-specific definitions for netperf's SDP */ /* sockets tests */ /* one of these days, this should not be required */ #ifndef AF_INET_SDP #define AF_INET_SDP 27 #define PF_INET_SDP AF_INET_SDP #endif struct sdp_stream_request_struct { int send_buf_size; int recv_buf_size; /* how big does the client want it - the */ /* receive socket buffer that is */ int receive_size; /* how many bytes do we want to receive at one */ /* time? */ int recv_alignment; /* what is the alignment of the receive */ /* buffer? */ int recv_offset; /* and at what offset from that alignment? */ int no_delay; /* do we disable the nagle algorithm for send */ /* coalescing? */ int measure_cpu; /* does the client want server cpu utilization */ /* measured? */ float cpu_rate; /* do we know how fast the cpu is already? */ int test_length; /* how long is the test? */ int so_rcvavoid; /* do we want the remote to avoid copies on */ /* receives? */ int so_sndavoid; /* do we want the remote to avoid send copies? */ int dirty_count; /* how many integers in the receive buffer */ /* should be made dirty before calling recv? */ int clean_count; /* how many integers should be read from the */ /* recv buffer before calling recv? */ int port; /* the to port to which recv side should bind to allow netperf to run through firewalls */ int ipfamily; /* address family of ipaddress */ int non_blocking; /* run the test in non-blocking mode */ }; struct sdp_stream_response_struct { int recv_buf_size; /* how big does the client want it */ int receive_size; int no_delay; int measure_cpu; /* does the client want server cpu */ int test_length; /* how long is the test? */ int send_buf_size; int data_port_number; /* connect to me here */ float cpu_rate; /* could we measure */ int so_rcvavoid; /* could the remote avoid receive copies? */ int so_sndavoid; /* could the remote avoid send copies? */ int non_blocking; /* run the test in non-blocking mode */ }; struct sdp_stream_results_struct { double bytes_received; unsigned int recv_calls; float elapsed_time; /* how long the test ran */ float cpu_util; /* -1 if not measured */ float serv_dem; /* -1 if not measured */ int cpu_method; /* how was cpu util measured? */ int num_cpus; /* how many CPUs had the remote? */ }; struct sdp_rr_request_struct { int recv_buf_size; /* how big does the client want it */ int send_buf_size; int recv_alignment; int recv_offset; int send_alignment; int send_offset; int request_size; int response_size; int no_delay; int measure_cpu; /* does the client want server cpu */ float cpu_rate; /* do we know how fast the cpu is? */ int test_length; /* how long is the test? */ int so_rcvavoid; /* do we want the remote to avoid receive */ /* copies? */ int so_sndavoid; /* do we want the remote to avoid send copies? */ int port; /* the to port to which recv side should bind to allow netperf to run through firewalls */ int ipfamily; /* address family of ipaddress */ int non_blocking; /* run the test in non-blocking mode */ }; struct sdp_rr_response_struct { int recv_buf_size; /* how big does the client want it */ int no_delay; int measure_cpu; /* does the client want server cpu */ int test_length; /* how long is the test? */ int send_buf_size; int data_port_number; /* connect to me here */ float cpu_rate; /* could we measure */ int so_rcvavoid; /* could the remote avoid receive copies? */ int so_sndavoid; /* could the remote avoid send copies? */ int non_blocking; /* run the test in non-blocking mode */ }; struct sdp_rr_results_struct { unsigned int bytes_received; /* ignored initially */ unsigned int recv_calls; /* ignored initially */ unsigned int trans_received; /* not ignored */ float elapsed_time; /* how long the test ran */ float cpu_util; /* -1 if not measured */ float serv_dem; /* -1 if not measured */ int cpu_method; /* how was cpu util measured? */ int num_cpus; /* how many CPUs had the remote? */ }; struct sdp_maerts_request_struct { int send_buf_size; int recv_buf_size; /* how big does the client want it - the */ /* receive socket buffer that is */ int send_size; /* how many bytes do we want netserver to send at one time? */ int send_alignment; /* what is the alignment of the send */ /* buffer? */ int send_offset; /* and at what offset from that alignment? */ int no_delay; /* do we disable the nagle algorithm for send */ /* coalescing? */ int measure_cpu; /* does the client want server cpu utilization */ /* measured? */ float cpu_rate; /* do we know how fast the cpu is already? */ int test_length; /* how long is the test? */ int so_rcvavoid; /* do we want the remote to avoid copies on */ /* receives? */ int so_sndavoid; /* do we want the remote to avoid send copies? */ int dirty_count; /* how many integers in the send buffer */ /* should be made dirty before calling recv? */ int clean_count; /* how many integers should be read from the */ /* recv buffer before calling recv? */ int port; /* the port to which the recv side should bind to allow netperf to run through those evil firewall things */ int ipfamily; }; struct sdp_maerts_response_struct { int recv_buf_size; /* how big does the client want it */ int send_size; int no_delay; int measure_cpu; /* does the client want server cpu */ int test_length; /* how long is the test? */ int send_buf_size; int data_port_number; /* connect to me here */ float cpu_rate; /* could we measure */ int so_rcvavoid; /* could the remote avoid receive copies? */ int so_sndavoid; /* could the remote avoid send copies? */ }; struct sdp_maerts_results_struct { double bytes_sent; unsigned int send_calls; float elapsed_time; /* how long the test ran */ float cpu_util; /* -1 if not measured */ float serv_dem; /* -1 if not measured */ int cpu_method; /* how was cpu util measured? */ int num_cpus; /* how many CPUs had the remote? */ }; extern void send_sdp_stream(); extern void send_sdp_rr(); extern void recv_sdp_stream(); extern void recv_sdp_rr(); extern void loc_cpu_rate(); extern void rem_cpu_rate();