xref: /minix3/minix/lib/liblwip/dist/src/include/lwip/apps/lwiperf.h (revision 5d5fbe79c1b60734f34c69330aec5496644e8651)
1*5d5fbe79SDavid van Moolenbroek /**
2*5d5fbe79SDavid van Moolenbroek  * @file
3*5d5fbe79SDavid van Moolenbroek  * lwIP iPerf server implementation
4*5d5fbe79SDavid van Moolenbroek  */
5*5d5fbe79SDavid van Moolenbroek 
6*5d5fbe79SDavid van Moolenbroek /*
7*5d5fbe79SDavid van Moolenbroek  * Copyright (c) 2014 Simon Goldschmidt
8*5d5fbe79SDavid van Moolenbroek  * All rights reserved.
9*5d5fbe79SDavid van Moolenbroek  *
10*5d5fbe79SDavid van Moolenbroek  * Redistribution and use in source and binary forms, with or without modification,
11*5d5fbe79SDavid van Moolenbroek  * are permitted provided that the following conditions are met:
12*5d5fbe79SDavid van Moolenbroek  *
13*5d5fbe79SDavid van Moolenbroek  * 1. Redistributions of source code must retain the above copyright notice,
14*5d5fbe79SDavid van Moolenbroek  *    this list of conditions and the following disclaimer.
15*5d5fbe79SDavid van Moolenbroek  * 2. Redistributions in binary form must reproduce the above copyright notice,
16*5d5fbe79SDavid van Moolenbroek  *    this list of conditions and the following disclaimer in the documentation
17*5d5fbe79SDavid van Moolenbroek  *    and/or other materials provided with the distribution.
18*5d5fbe79SDavid van Moolenbroek  * 3. The name of the author may not be used to endorse or promote products
19*5d5fbe79SDavid van Moolenbroek  *    derived from this software without specific prior written permission.
20*5d5fbe79SDavid van Moolenbroek  *
21*5d5fbe79SDavid van Moolenbroek  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
22*5d5fbe79SDavid van Moolenbroek  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
23*5d5fbe79SDavid van Moolenbroek  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
24*5d5fbe79SDavid van Moolenbroek  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25*5d5fbe79SDavid van Moolenbroek  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
26*5d5fbe79SDavid van Moolenbroek  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27*5d5fbe79SDavid van Moolenbroek  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28*5d5fbe79SDavid van Moolenbroek  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
29*5d5fbe79SDavid van Moolenbroek  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
30*5d5fbe79SDavid van Moolenbroek  * OF SUCH DAMAGE.
31*5d5fbe79SDavid van Moolenbroek  *
32*5d5fbe79SDavid van Moolenbroek  * This file is part of the lwIP TCP/IP stack.
33*5d5fbe79SDavid van Moolenbroek  *
34*5d5fbe79SDavid van Moolenbroek  * Author: Simon Goldschmidt
35*5d5fbe79SDavid van Moolenbroek  *
36*5d5fbe79SDavid van Moolenbroek  */
37*5d5fbe79SDavid van Moolenbroek #ifndef LWIP_HDR_APPS_LWIPERF_H
38*5d5fbe79SDavid van Moolenbroek #define LWIP_HDR_APPS_LWIPERF_H
39*5d5fbe79SDavid van Moolenbroek 
40*5d5fbe79SDavid van Moolenbroek #include "lwip/opt.h"
41*5d5fbe79SDavid van Moolenbroek #include "lwip/ip_addr.h"
42*5d5fbe79SDavid van Moolenbroek 
43*5d5fbe79SDavid van Moolenbroek #ifdef __cplusplus
44*5d5fbe79SDavid van Moolenbroek extern "C" {
45*5d5fbe79SDavid van Moolenbroek #endif
46*5d5fbe79SDavid van Moolenbroek 
47*5d5fbe79SDavid van Moolenbroek #define LWIPERF_TCP_PORT_DEFAULT  5001
48*5d5fbe79SDavid van Moolenbroek 
49*5d5fbe79SDavid van Moolenbroek /** lwIPerf test results */
50*5d5fbe79SDavid van Moolenbroek enum lwiperf_report_type
51*5d5fbe79SDavid van Moolenbroek {
52*5d5fbe79SDavid van Moolenbroek   /** The server side test is done */
53*5d5fbe79SDavid van Moolenbroek   LWIPERF_TCP_DONE_SERVER,
54*5d5fbe79SDavid van Moolenbroek   /** The client side test is done */
55*5d5fbe79SDavid van Moolenbroek   LWIPERF_TCP_DONE_CLIENT,
56*5d5fbe79SDavid van Moolenbroek   /** Local error lead to test abort */
57*5d5fbe79SDavid van Moolenbroek   LWIPERF_TCP_ABORTED_LOCAL,
58*5d5fbe79SDavid van Moolenbroek   /** Data check error lead to test abort */
59*5d5fbe79SDavid van Moolenbroek   LWIPERF_TCP_ABORTED_LOCAL_DATAERROR,
60*5d5fbe79SDavid van Moolenbroek   /** Transmit error lead to test abort */
61*5d5fbe79SDavid van Moolenbroek   LWIPERF_TCP_ABORTED_LOCAL_TXERROR,
62*5d5fbe79SDavid van Moolenbroek   /** Remote side aborted the test */
63*5d5fbe79SDavid van Moolenbroek   LWIPERF_TCP_ABORTED_REMOTE
64*5d5fbe79SDavid van Moolenbroek };
65*5d5fbe79SDavid van Moolenbroek 
66*5d5fbe79SDavid van Moolenbroek /** Prototype of a report function that is called when a session is finished.
67*5d5fbe79SDavid van Moolenbroek     This report function can show the test results.
68*5d5fbe79SDavid van Moolenbroek     @param report_type contains the test result */
69*5d5fbe79SDavid van Moolenbroek typedef void (*lwiperf_report_fn)(void *arg, enum lwiperf_report_type report_type,
70*5d5fbe79SDavid van Moolenbroek   const ip_addr_t* local_addr, u16_t local_port, const ip_addr_t* remote_addr, u16_t remote_port,
71*5d5fbe79SDavid van Moolenbroek   u32_t bytes_transferred, u32_t ms_duration, u32_t bandwidth_kbitpsec);
72*5d5fbe79SDavid van Moolenbroek 
73*5d5fbe79SDavid van Moolenbroek 
74*5d5fbe79SDavid van Moolenbroek void* lwiperf_start_tcp_server(const ip_addr_t* local_addr, u16_t local_port,
75*5d5fbe79SDavid van Moolenbroek                                lwiperf_report_fn report_fn, void* report_arg);
76*5d5fbe79SDavid van Moolenbroek void* lwiperf_start_tcp_server_default(lwiperf_report_fn report_fn, void* report_arg);
77*5d5fbe79SDavid van Moolenbroek void  lwiperf_abort(void* lwiperf_session);
78*5d5fbe79SDavid van Moolenbroek 
79*5d5fbe79SDavid van Moolenbroek 
80*5d5fbe79SDavid van Moolenbroek #ifdef __cplusplus
81*5d5fbe79SDavid van Moolenbroek }
82*5d5fbe79SDavid van Moolenbroek #endif
83*5d5fbe79SDavid van Moolenbroek 
84*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_HDR_APPS_LWIPERF_H */
85