Zephyr Project API 4.0.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
icmp.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2023 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
18#ifndef ZEPHYR_INCLUDE_NET_ICMP_H_
19#define ZEPHYR_INCLUDE_NET_ICMP_H_
20
21#include <stddef.h>
22
23#include <zephyr/kernel.h>
24#include <zephyr/types.h>
25#include <zephyr/net/net_ip.h>
26#include <zephyr/net/net_if.h>
27#include <zephyr/net/net_pkt.h>
28
29#ifdef __cplusplus
30extern "C" {
31#endif
32
33#define NET_ICMPV4_ECHO_REQUEST 8
34#define NET_ICMPV4_ECHO_REPLY 0
35#define NET_ICMPV6_ECHO_REQUEST 128
36#define NET_ICMPV6_ECHO_REPLY 129
38struct net_icmp_ctx;
39struct net_icmp_ip_hdr;
41
52typedef int (*net_icmp_handler_t)(struct net_icmp_ctx *ctx,
53 struct net_pkt *pkt,
54 struct net_icmp_ip_hdr *ip_hdr,
55 struct net_icmp_hdr *icmp_hdr,
56 void *user_data);
57
75 struct net_if *iface,
76 struct sockaddr *dst,
77 struct net_icmp_ping_params *params,
78 void *user_data);
79
102
107 union {
109 struct net_ipv4_hdr *ipv4;
110
112 struct net_ipv6_hdr *ipv6;
113 };
114
117};
118
153
164int net_icmp_init_ctx(struct net_icmp_ctx *ctx, uint8_t type, uint8_t code,
165 net_icmp_handler_t handler);
166
174
189 struct net_if *iface,
190 struct sockaddr *dst,
191 struct net_icmp_ping_params *params,
192 void *user_data);
193
213 struct net_if *iface,
214 struct sockaddr *dst,
215 struct net_icmp_ping_params *params,
216 void *user_data);
217
238
252 struct net_if *iface,
254
263
278 net_icmp_handler_t *resp_handler);
279
280#ifdef __cplusplus
281}
282#endif
283
284#endif /* ZEPHYR_INCLUDE_NET_ICMP_H */
285
int net_icmp_send_echo_request(struct net_icmp_ctx *ctx, struct net_if *iface, struct sockaddr *dst, struct net_icmp_ping_params *params, void *user_data)
Send ICMP echo request message.
int(* net_icmp_offload_ping_handler_t)(struct net_icmp_ctx *ctx, struct net_if *iface, struct sockaddr *dst, struct net_icmp_ping_params *params, void *user_data)
Handler function that is called when an Echo-Request is sent to offloaded device.
Definition icmp.h:74
int net_icmp_send_echo_request_no_wait(struct net_icmp_ctx *ctx, struct net_if *iface, struct sockaddr *dst, struct net_icmp_ping_params *params, void *user_data)
Send ICMP echo request message without waiting during send.
int net_icmp_register_offload_ping(struct net_icmp_offload *ctx, struct net_if *iface, net_icmp_offload_ping_handler_t ping_handler)
Register a handler function that is called when an Echo-Request is sent to the offloaded device.
int net_icmp_unregister_offload_ping(struct net_icmp_offload *ctx)
Unregister the offload handler.
int net_icmp_cleanup_ctx(struct net_icmp_ctx *ctx)
Cleanup the ICMP context structure.
int net_icmp_get_offload_rsp_handler(struct net_icmp_offload *ctx, net_icmp_handler_t *resp_handler)
Get a ICMP response handler function for an offloaded device.
int net_icmp_init_ctx(struct net_icmp_ctx *ctx, uint8_t type, uint8_t code, net_icmp_handler_t handler)
Initialize the ICMP context structure.
int(* net_icmp_handler_t)(struct net_icmp_ctx *ctx, struct net_pkt *pkt, struct net_icmp_ip_hdr *ip_hdr, struct net_icmp_hdr *icmp_hdr, void *user_data)
Handler function that is called when ICMP response is received.
Definition icmp.h:52
unsigned short int sa_family_t
Socket address family type.
Definition net_ip.h:168
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:39
Public kernel APIs.
Public API for network interface.
IPv6 and IPv4 definitions.
Network packet buffer descriptor API.
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
ICMP context structure.
Definition icmp.h:83
void * user_data
Opaque user supplied data.
Definition icmp.h:94
sys_snode_t node
List node.
Definition icmp.h:85
struct net_if * iface
Network interface where the ICMP request was sent.
Definition icmp.h:91
uint8_t code
ICMP code of the response type we are waiting.
Definition icmp.h:100
net_icmp_handler_t handler
ICMP response handler.
Definition icmp.h:88
uint8_t type
ICMP type of the response we are waiting.
Definition icmp.h:97
Struct presents either IPv4 or IPv6 header in ICMP response message.
Definition icmp.h:106
struct net_ipv4_hdr * ipv4
IPv4 header in response message.
Definition icmp.h:109
sa_family_t family
Is the header IPv4 or IPv6 one.
Definition icmp.h:116
struct net_ipv6_hdr * ipv6
IPv6 header in response message.
Definition icmp.h:112
ICMP offload context structure.
Definition icmp.h:221
net_icmp_handler_t handler
ICMP response handler.
Definition icmp.h:230
net_icmp_offload_ping_handler_t ping_handler
ICMP offloaded ping handler.
Definition icmp.h:233
sys_snode_t node
List node.
Definition icmp.h:223
struct net_if * iface
Offloaded network interface.
Definition icmp.h:236
Struct presents parameters that are needed when sending Echo-Request (ping) messages.
Definition icmp.h:123
uint16_t identifier
An identifier to aid in matching Echo Replies to this Echo Request.
Definition icmp.h:127
size_t data_size
Size of the Payload Data in bytes.
Definition icmp.h:151
uint16_t sequence
A sequence number to aid in matching Echo Replies to this Echo Request.
Definition icmp.h:132
int priority
Network packet priority.
Definition icmp.h:140
uint8_t tc_tos
Can be either IPv4 Type-of-service field value, or IPv6 Traffic Class field value.
Definition icmp.h:137
const void * data
Arbitrary payload data that will be included in the Echo Reply verbatim.
Definition icmp.h:145
Network Interface structure.
Definition net_if.h:692
Network packet.
Definition net_pkt.h:91
Generic sockaddr struct.
Definition net_ip.h:408