Zephyr API Documentation 4.1.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
zperf.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2016 Intel Corporation
3 * Copyright (c) 2022 Nordic Semiconductor ASA
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
19#ifndef ZEPHYR_INCLUDE_NET_ZPERF_H_
20#define ZEPHYR_INCLUDE_NET_ZPERF_H_
21
22#include <zephyr/net/net_ip.h>
23#include <zephyr/net/socket.h>
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
31enum zperf_status {
32 ZPERF_SESSION_STARTED,
33 ZPERF_SESSION_PERIODIC_RESULT,
34 ZPERF_SESSION_FINISHED,
35 ZPERF_SESSION_ERROR
36} __packed;
37
38struct zperf_upload_params {
39 struct sockaddr peer_addr;
40 uint32_t duration_ms;
41 uint32_t rate_kbps;
42 uint16_t packet_size;
43 char if_name[IFNAMSIZ];
44 struct {
45 uint8_t tos;
46 int tcp_nodelay;
47 int priority;
48#ifdef CONFIG_ZPERF_SESSION_PER_THREAD
49 int thread_priority;
50 bool wait_for_start;
51#endif
52 uint32_t report_interval_ms;
53 } options;
54};
55
56struct zperf_download_params {
57 uint16_t port;
58 struct sockaddr addr;
59 char if_name[IFNAMSIZ];
60};
61
77
85typedef void (*zperf_callback)(enum zperf_status status,
86 struct zperf_results *result,
87 void *user_data);
88
98int zperf_udp_upload(const struct zperf_upload_params *param,
99 struct zperf_results *result);
100
110int zperf_tcp_upload(const struct zperf_upload_params *param,
111 struct zperf_results *result);
112
125int zperf_udp_upload_async(const struct zperf_upload_params *param,
126 zperf_callback callback, void *user_data);
127
140int zperf_tcp_upload_async(const struct zperf_upload_params *param,
141 zperf_callback callback, void *user_data);
142
154int zperf_udp_download(const struct zperf_download_params *param,
155 zperf_callback callback, void *user_data);
156
168int zperf_tcp_download(const struct zperf_download_params *param,
169 zperf_callback callback, void *user_data);
170
177
184
185#ifdef __cplusplus
186}
187#endif
188
193#endif /* ZEPHYR_INCLUDE_NET_ZPERF_H_ */
#define IFNAMSIZ
Network interface name length.
Definition socket.h:816
int zperf_tcp_upload_async(const struct zperf_upload_params *param, zperf_callback callback, void *user_data)
Asynchronous TCP upload operation.
int zperf_tcp_upload(const struct zperf_upload_params *param, struct zperf_results *result)
Synchronous TCP upload operation.
int zperf_udp_download_stop(void)
Stop UDP server.
int zperf_udp_upload(const struct zperf_upload_params *param, struct zperf_results *result)
Synchronous UDP upload operation.
int zperf_tcp_download(const struct zperf_download_params *param, zperf_callback callback, void *user_data)
Start TCP server.
int zperf_udp_download(const struct zperf_download_params *param, zperf_callback callback, void *user_data)
Start UDP server.
int zperf_tcp_download_stop(void)
Stop TCP server.
int zperf_udp_upload_async(const struct zperf_upload_params *param, zperf_callback callback, void *user_data)
Asynchronous UDP upload operation.
void(* zperf_callback)(enum zperf_status status, struct zperf_results *result, void *user_data)
Zperf callback function used for asynchronous operations.
Definition zperf.h:85
BSD Sockets compatible API definitions.
IPv6 and IPv4 definitions.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Generic sockaddr struct.
Definition net_ip.h:408
Performance results.
Definition zperf.h:65
uint64_t total_len
Total length of the transferred data.
Definition zperf.h:70
uint64_t client_time_in_us
Client connection time in microseconds.
Definition zperf.h:73
uint32_t nb_packets_errors
Number of packet errors.
Definition zperf.h:75
uint32_t packet_size
Packet size.
Definition zperf.h:74
uint32_t nb_packets_outorder
Number of packets out of order.
Definition zperf.h:69
uint64_t time_in_us
Total time of the transfer in microseconds.
Definition zperf.h:71
uint32_t nb_packets_lost
Number of packets lost.
Definition zperf.h:68
uint32_t nb_packets_rcvd
Number of packets received.
Definition zperf.h:67
uint32_t nb_packets_sent
Number of packets sent.
Definition zperf.h:66
uint32_t jitter_in_us
Jitter in microseconds.
Definition zperf.h:72