selftests/bpf: Implement get_hw_ring_size function to retrieve current and max interf...
authorTushar Vyavahare <tushar.vyavahare@intel.com>
Tue, 2 Apr 2024 11:45:25 +0000 (11:45 +0000)
committerDaniel Borkmann <daniel@iogearbox.net>
Wed, 3 Apr 2024 14:03:37 +0000 (16:03 +0200)
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
tools/testing/selftests/bpf/network_helpers.c
tools/testing/selftests/bpf/network_helpers.h
tools/testing/selftests/bpf/prog_tests/flow_dissector.c
tools/testing/selftests/bpf/xdp_hw_metadata.c

index 6db27a9088e978b327351541b329a31312d2382c..1cab20020f94a62a82961b5cb69fa8ce602f060f 100644 (file)
@@ -497,3 +497,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;
+}
index 94b9be24e39bcb6b82fc796ab08e34f53fa8bbbb..de4d27d201cb853297e030b26169b691082c9386 100644 (file)
@@ -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
@@ -61,6 +64,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;
 /**
index c4773173a4e43764af2a6d2eccd664c8f51241a1..9e5f38739104bf540ae143fd4e663d44a8ffe4d8 100644 (file)
@@ -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>
 
index bdf5d8180067f8d2bfeb2ad520aae86134876a10..0859fe727da74367f37b460949173a70bf279c2c 100644 (file)
@@ -495,20 +495,6 @@ peek:
        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 = {