mirror of
https://gitee.com/bianbu-linux/linux-6.6
synced 2025-04-24 14:07:52 -04:00
selftests/bpf: Implement get_hw_ring_size function to retrieve current and max interface size
[ Upstream commit 90a695c3d31e1c9f0adb8c4c80028ed4ea7ed5ab ] Introduce a new function called get_hw_size that retrieves both the current and maximum size of the interface and stores this information in the 'ethtool_ringparam' structure. Remove ethtool_channels struct from xdp_hw_metadata.c due to redefinition error. Remove unused linux/if.h include from flow_dissector BPF test to address CI pipeline failure. Signed-off-by: Tushar Vyavahare <tushar.vyavahare@intel.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Acked-by: Magnus Karlsson <magnus.karlsson@intel.com> Link: https://lore.kernel.org/bpf/20240402114529.545475-4-tushar.vyavahare@intel.com Stable-dep-of: 69f409469c9b ("selftests/bpf: Drop unneeded error.h includes") Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
7c877bad03
commit
c8c590f07a
4 changed files with 28 additions and 15 deletions
|
@ -465,3 +465,27 @@ int get_socket_local_port(int sock_fd)
|
|||
|
||||
return -1;
|
||||
}
|
||||
|
||||
int get_hw_ring_size(char *ifname, struct ethtool_ringparam *ring_param)
|
||||
{
|
||||
struct ifreq ifr = {0};
|
||||
int sockfd, err;
|
||||
|
||||
sockfd = socket(AF_INET, SOCK_DGRAM, 0);
|
||||
if (sockfd < 0)
|
||||
return -errno;
|
||||
|
||||
memcpy(ifr.ifr_name, ifname, sizeof(ifr.ifr_name));
|
||||
|
||||
ring_param->cmd = ETHTOOL_GRINGPARAM;
|
||||
ifr.ifr_data = (char *)ring_param;
|
||||
|
||||
if (ioctl(sockfd, SIOCETHTOOL, &ifr) < 0) {
|
||||
err = errno;
|
||||
close(sockfd);
|
||||
return -err;
|
||||
}
|
||||
|
||||
close(sockfd);
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -9,8 +9,11 @@ typedef __u16 __sum16;
|
|||
#include <linux/if_packet.h>
|
||||
#include <linux/ip.h>
|
||||
#include <linux/ipv6.h>
|
||||
#include <linux/ethtool.h>
|
||||
#include <linux/sockios.h>
|
||||
#include <netinet/tcp.h>
|
||||
#include <bpf/bpf_endian.h>
|
||||
#include <net/if.h>
|
||||
|
||||
#define MAGIC_VAL 0x1234
|
||||
#define NUM_ITER 100000
|
||||
|
@ -60,6 +63,7 @@ int make_sockaddr(int family, const char *addr_str, __u16 port,
|
|||
struct sockaddr_storage *addr, socklen_t *len);
|
||||
char *ping_command(int family);
|
||||
int get_socket_local_port(int sock_fd);
|
||||
int get_hw_ring_size(char *ifname, struct ethtool_ringparam *ring_param);
|
||||
|
||||
struct nstoken;
|
||||
/**
|
||||
|
|
|
@ -2,7 +2,6 @@
|
|||
#include <test_progs.h>
|
||||
#include <network_helpers.h>
|
||||
#include <error.h>
|
||||
#include <linux/if.h>
|
||||
#include <linux/if_tun.h>
|
||||
#include <sys/uio.h>
|
||||
|
||||
|
|
|
@ -288,20 +288,6 @@ static int verify_metadata(struct xsk *rx_xsk, int rxq, int server_fd, clockid_t
|
|||
return 0;
|
||||
}
|
||||
|
||||
struct ethtool_channels {
|
||||
__u32 cmd;
|
||||
__u32 max_rx;
|
||||
__u32 max_tx;
|
||||
__u32 max_other;
|
||||
__u32 max_combined;
|
||||
__u32 rx_count;
|
||||
__u32 tx_count;
|
||||
__u32 other_count;
|
||||
__u32 combined_count;
|
||||
};
|
||||
|
||||
#define ETHTOOL_GCHANNELS 0x0000003c /* Get no of channels */
|
||||
|
||||
static int rxq_num(const char *ifname)
|
||||
{
|
||||
struct ethtool_channels ch = {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue