123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263 |
- /** @file
- * @brief Network packet capture definitions
- *
- * Definitions for capturing network packets.
- */
- /*
- * Copyright (c) 2021 Intel Corporation
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #ifndef ZEPHYR_INCLUDE_NET_CAPTURE_H_
- #define ZEPHYR_INCLUDE_NET_CAPTURE_H_
- #include <zephyr.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @brief Network packet capture support functions
- * @defgroup net_capture Network packet capture
- * @ingroup networking
- * @{
- */
- /** @cond INTERNAL_HIDDEN */
- struct net_if;
- struct net_capture_interface_api {
- /** Cleanup the setup. This will also disable capturing. After this
- * call, the setup function can be called again.
- */
- int (*cleanup)(const struct device *dev);
- /** Enable / start capturing data */
- int (*enable)(const struct device *dev, struct net_if *iface);
- /** Disable / stop capturing data */
- int (*disable)(const struct device *dev);
- /** Is capturing enabled (returns true) or disabled (returns false).
- */
- bool (*is_enabled)(const struct device *dev);
- /** Send captured data */
- int (*send)(const struct device *dev, struct net_if *iface,
- struct net_pkt *pkt);
- };
- /** @endcond */
- /**
- * @brief Setup network packet capturing support.
- *
- * @param remote_addr The value tells the tunnel remote/outer endpoint
- * IP address. The IP address can be either IPv4 or IPv6 address.
- * This address is used to select the network interface where the tunnel
- * is created.
- * @param my_local_addr The local/inner IP address of the tunnel. Can contain
- * also port number which is used as UDP source port.
- * @param peer_addr The peer/inner IP address of the tunnel. Can contain
- * also port number which is used as UDP destination port.
- * @param dev Network capture device. This is returned to the caller.
- *
- * @return 0 if ok, <0 if network packet capture setup failed
- */
- int net_capture_setup(const char *remote_addr, const char *my_local_addr,
- const char *peer_addr, const struct device **dev);
- /**
- * @brief Cleanup network packet capturing support.
- *
- * @details This should be called after the capturing is done and resources
- * can be released.
- *
- * @param dev Network capture device. User must allocate using the
- * net_capture_setup() function.
- *
- * @return 0 if ok, <0 if network packet capture cleanup failed
- */
- static inline int net_capture_cleanup(const struct device *dev)
- {
- #if defined(CONFIG_NET_CAPTURE)
- const struct net_capture_interface_api *api =
- (const struct net_capture_interface_api *)dev->api;
- return api->cleanup(dev);
- #else
- ARG_UNUSED(dev);
- return -ENOTSUP;
- #endif
- }
- /**
- * @brief Enable network packet capturing support.
- *
- * @details This creates tunnel network interface where all the
- * captured packets are pushed. The captured network packets are
- * placed in UDP packets that are sent to tunnel peer.
- *
- * @param dev Network capture device
- * @param iface Network interface we are starting to capture packets.
- *
- * @return 0 if ok, <0 if network packet capture enable failed
- */
- static inline int net_capture_enable(const struct device *dev,
- struct net_if *iface)
- {
- #if defined(CONFIG_NET_CAPTURE)
- const struct net_capture_interface_api *api =
- (const struct net_capture_interface_api *)dev->api;
- return api->enable(dev, iface);
- #else
- ARG_UNUSED(dev);
- ARG_UNUSED(iface);
- return -ENOTSUP;
- #endif
- }
- /**
- * @brief Is network packet capture enabled or disabled.
- *
- * @param dev Network capture device
- *
- * @return True if enabled, False if network capture is disabled.
- */
- static inline bool net_capture_is_enabled(const struct device *dev)
- {
- #if defined(CONFIG_NET_CAPTURE)
- const struct net_capture_interface_api *api =
- (const struct net_capture_interface_api *)dev->api;
- return api->is_enabled(dev);
- #else
- ARG_UNUSED(dev);
- return false;
- #endif
- }
- /**
- * @brief Disable network packet capturing support.
- *
- * @param dev Network capture device
- *
- * @return 0 if ok, <0 if network packet capture disable failed
- */
- static inline int net_capture_disable(const struct device *dev)
- {
- #if defined(CONFIG_NET_CAPTURE)
- const struct net_capture_interface_api *api =
- (const struct net_capture_interface_api *)dev->api;
- return api->disable(dev);
- #else
- ARG_UNUSED(dev);
- return -ENOTSUP;
- #endif
- }
- /**
- * @brief Send captured packet.
- *
- * @param dev Network capture device
- * @param iface Network interface the packet is being sent
- * @param pkt The network packet that is sent
- *
- * @return 0 if ok, <0 if network packet capture send failed
- */
- static inline int net_capture_send(const struct device *dev,
- struct net_if *iface,
- struct net_pkt *pkt)
- {
- #if defined(CONFIG_NET_CAPTURE)
- const struct net_capture_interface_api *api =
- (const struct net_capture_interface_api *)dev->api;
- return api->send(dev, iface, pkt);
- #else
- ARG_UNUSED(dev);
- ARG_UNUSED(iface);
- ARG_UNUSED(pkt);
- return -ENOTSUP;
- #endif
- }
- /** @cond INTERNAL_HIDDEN */
- /**
- * @brief Check if the network packet needs to be captured or not.
- * This is called for every network packet being sent.
- *
- * @param iface Network interface the packet is being sent
- * @param pkt The network packet that is sent
- */
- #if defined(CONFIG_NET_CAPTURE)
- void net_capture_pkt(struct net_if *iface, struct net_pkt *pkt);
- #else
- static inline void net_capture_pkt(struct net_if *iface, struct net_pkt *pkt)
- {
- ARG_UNUSED(iface);
- ARG_UNUSED(pkt);
- }
- #endif
- struct net_capture_info {
- const struct device *capture_dev;
- struct net_if *capture_iface;
- struct net_if *tunnel_iface;
- struct sockaddr *peer;
- struct sockaddr *local;
- bool is_enabled;
- };
- /**
- * @typedef net_capture_cb_t
- * @brief Callback used while iterating over capture devices
- *
- * @param info Information about capture device
- * @param user_data A valid pointer to user data or NULL
- */
- typedef void (*net_capture_cb_t)(struct net_capture_info *info,
- void *user_data);
- /**
- * @brief Go through all the capture devices in order to get
- * information about them. This is mainly useful in
- * net-shell to print data about currently active
- * captures.
- *
- * @param cb Callback to call for each capture device
- * @param user_data User supplied data
- */
- #if defined(CONFIG_NET_CAPTURE)
- void net_capture_foreach(net_capture_cb_t cb, void *user_data);
- #else
- static inline void net_capture_foreach(net_capture_cb_t cb, void *user_data)
- {
- ARG_UNUSED(cb);
- ARG_UNUSED(user_data);
- }
- #endif
- /** @endcond */
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /* ZEPHYR_INCLUDE_NET_CAPTURE_H_ */
|