mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
So far drop monitor supported only one alert mode in which a summary of locations in which packets were recently dropped was sent to user space. This alert mode is sufficient in order to understand that packets were dropped, but lacks information to perform a more detailed analysis. Add a new alert mode in which the dropped packet itself is passed to user space along with metadata: The drop location (as program counter and resolved symbol), ingress netdevice and drop timestamp. More metadata can be added in the future. To avoid performing expensive operations in the context in which kfree_skb() is invoked (can be hard IRQ), the dropped skb is cloned and queued on per-CPU skb drop list. Then, in process context the netlink message is allocated, prepared and finally sent to user space. The per-CPU skb drop list is limited to 1000 skbs to prevent exhausting the system's memory. Subsequent patches will make this limit configurable and also add a counter that indicates how many skbs were tail dropped. Signed-off-by: Ido Schimmel <idosch@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
101 lines
2 KiB
C
101 lines
2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
#ifndef __NET_DROPMON_H
|
|
#define __NET_DROPMON_H
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/netlink.h>
|
|
|
|
struct net_dm_drop_point {
|
|
__u8 pc[8];
|
|
__u32 count;
|
|
};
|
|
|
|
#define is_drop_point_hw(x) do {\
|
|
int ____i, ____j;\
|
|
for (____i = 0; ____i < 8; i ____i++)\
|
|
____j |= x[____i];\
|
|
____j;\
|
|
} while (0)
|
|
|
|
#define NET_DM_CFG_VERSION 0
|
|
#define NET_DM_CFG_ALERT_COUNT 1
|
|
#define NET_DM_CFG_ALERT_DELAY 2
|
|
#define NET_DM_CFG_MAX 3
|
|
|
|
struct net_dm_config_entry {
|
|
__u32 type;
|
|
__u64 data __attribute__((aligned(8)));
|
|
};
|
|
|
|
struct net_dm_config_msg {
|
|
__u32 entries;
|
|
struct net_dm_config_entry options[0];
|
|
};
|
|
|
|
struct net_dm_alert_msg {
|
|
__u32 entries;
|
|
struct net_dm_drop_point points[0];
|
|
};
|
|
|
|
struct net_dm_user_msg {
|
|
union {
|
|
struct net_dm_config_msg user;
|
|
struct net_dm_alert_msg alert;
|
|
} u;
|
|
};
|
|
|
|
|
|
/* These are the netlink message types for this protocol */
|
|
|
|
enum {
|
|
NET_DM_CMD_UNSPEC = 0,
|
|
NET_DM_CMD_ALERT,
|
|
NET_DM_CMD_CONFIG,
|
|
NET_DM_CMD_START,
|
|
NET_DM_CMD_STOP,
|
|
NET_DM_CMD_PACKET_ALERT,
|
|
_NET_DM_CMD_MAX,
|
|
};
|
|
|
|
#define NET_DM_CMD_MAX (_NET_DM_CMD_MAX - 1)
|
|
|
|
/*
|
|
* Our group identifiers
|
|
*/
|
|
#define NET_DM_GRP_ALERT 1
|
|
|
|
enum net_dm_attr {
|
|
NET_DM_ATTR_UNSPEC,
|
|
|
|
NET_DM_ATTR_ALERT_MODE, /* u8 */
|
|
NET_DM_ATTR_PC, /* u64 */
|
|
NET_DM_ATTR_SYMBOL, /* string */
|
|
NET_DM_ATTR_IN_PORT, /* nested */
|
|
NET_DM_ATTR_TIMESTAMP, /* struct timespec */
|
|
NET_DM_ATTR_PROTO, /* u16 */
|
|
NET_DM_ATTR_PAYLOAD, /* binary */
|
|
NET_DM_ATTR_PAD,
|
|
|
|
__NET_DM_ATTR_MAX,
|
|
NET_DM_ATTR_MAX = __NET_DM_ATTR_MAX - 1
|
|
};
|
|
|
|
/**
|
|
* enum net_dm_alert_mode - Alert mode.
|
|
* @NET_DM_ALERT_MODE_SUMMARY: A summary of recent drops is sent to user space.
|
|
* @NET_DM_ALERT_MODE_PACKET: Each dropped packet is sent to user space along
|
|
* with metadata.
|
|
*/
|
|
enum net_dm_alert_mode {
|
|
NET_DM_ALERT_MODE_SUMMARY,
|
|
NET_DM_ALERT_MODE_PACKET,
|
|
};
|
|
|
|
enum {
|
|
NET_DM_ATTR_PORT_NETDEV_IFINDEX, /* u32 */
|
|
|
|
__NET_DM_ATTR_PORT_MAX,
|
|
NET_DM_ATTR_PORT_MAX = __NET_DM_ATTR_PORT_MAX - 1
|
|
};
|
|
|
|
#endif
|