From: Vincent Jardin via buildroot <buildroot@buildroot.org>
To: buildroot@buildroot.org
Cc: thomas.petazzoni@bootlin.com, Vincent Jardin <vjardin@free.fr>
Subject: [Buildroot] [PATCH v3 1/1] package/dot1ag-utils: new package
Date: Sun, 18 Jan 2026 23:21:15 +0100 [thread overview]
Message-ID: <20260118222115.71411-2-vjardin@free.fr> (raw)
In-Reply-To: <20260118222115.71411-1-vjardin@free.fr>
dot1ag-utils provides tools for IEEE 802.1ag Connectivity Fault
Management (CFM) protocol testing and debugging.
https://github.com/Bumblebee-Networks/dot1ag-utils
Signed-off-by: Vincent Jardin <vjardin@free.fr>
---
DEVELOPERS | 1 +
package/Config.in | 1 +
...0001-fix-strncpy-truncation-warnings.patch | 60 +++++++++++++++++++
package/dot1ag-utils/Config.in | 11 ++++
package/dot1ag-utils/dot1ag-utils.hash | 3 +
package/dot1ag-utils/dot1ag-utils.mk | 14 +++++
6 files changed, 90 insertions(+)
create mode 100644 package/dot1ag-utils/0001-fix-strncpy-truncation-warnings.patch
create mode 100644 package/dot1ag-utils/Config.in
create mode 100644 package/dot1ag-utils/dot1ag-utils.hash
create mode 100644 package/dot1ag-utils/dot1ag-utils.mk
diff --git a/DEVELOPERS b/DEVELOPERS
index f982e3123a..f5d82280dc 100644
--- a/DEVELOPERS
+++ b/DEVELOPERS
@@ -3356,6 +3356,7 @@ N: Vincent Jardin <vjardin@free.fr>
F: board/nvidia/bf3/
F: configs/nvidia_bf3_defconfig
F: package/bfscripts/
+F: package/dot1ag-utils/
F: package/dpdk/
F: package/libecoli/
F: package/libyang-cpp/
diff --git a/package/Config.in b/package/Config.in
index def3db0e50..918c82550e 100644
--- a/package/Config.in
+++ b/package/Config.in
@@ -176,6 +176,7 @@ menu "Development tools"
source "package/cvs/Config.in"
source "package/cxxtest/Config.in"
source "package/diffutils/Config.in"
+ source "package/dot1ag-utils/Config.in"
source "package/dos2unix/Config.in"
source "package/fd/Config.in"
source "package/findutils/Config.in"
diff --git a/package/dot1ag-utils/0001-fix-strncpy-truncation-warnings.patch b/package/dot1ag-utils/0001-fix-strncpy-truncation-warnings.patch
new file mode 100644
index 0000000000..a3b370a808
--- /dev/null
+++ b/package/dot1ag-utils/0001-fix-strncpy-truncation-warnings.patch
@@ -0,0 +1,60 @@
+From: Vincent Jardin <vjardin@free.fr>
+Date: Tue, 7 Jan 2026 11:00:00 +0100
+Subject: [PATCH] dot1ag_eth: fix strncpy truncation warnings with modern GCC
+
+Modern GCC with -Werror fails when strncpy size equals the destination
+buffer size, as it may not null-terminate the string:
+
+ error: '__builtin_strncpy' specified bound 16 equals destination size
+ [-Werror=stringop-truncation]
+
+Fix by using sizeof(dest) - 1 to leave room for the null terminator.
+The structures are already zeroed with memset() before strncpy, so the
+last byte remains '\0'.
+
+Signed-off-by: Vincent Jardin <vjardin@free.fr>
+Upstream: not yet submitted
+---
+ src/dot1ag_eth.c | 8 ++++----
+ 1 file changed, 4 insertions(+), 4 deletions(-)
+
+diff --git a/src/dot1ag_eth.c b/src/dot1ag_eth.c
+index 1111111..2222222 100644
+--- a/src/dot1ag_eth.c
++++ b/src/dot1ag_eth.c
+@@ -122,7 +122,7 @@ get_local_mac(uint8_t *ea, const char *ifname) {
+ }
+
+ /* bind BPF to the outgoing interface */
+- strncpy(ifc.ifr_name, ifname, IFNAMSIZ);
++ strncpy(ifc.ifr_name, ifname, IFNAMSIZ - 1);
+ if (ioctl(bpf, BIOCSETIF, &ifc) > 0) {
+ perror("BIOCSETIF");
+ exit(EXIT_FAILURE);
+@@ -159,7 +159,7 @@ send_packet(const char *dev, const uint8_t *buf, size_t size) {
+
+ /* get interface index */
+ memset(&req, 0, sizeof(req));
+- strncpy(req.ifr_name, dev, sizeof(req.ifr_name));
++ strncpy(req.ifr_name, dev, sizeof(req.ifr_name) - 1);
+
+ /* get MAC address of interface */
+ if (ioctl(s, SIOCGIFHWADDR, &req)) {
+@@ -202,7 +202,7 @@ send_packet_old(const char *ifname, const uint8_t *buf, size_t size) {
+
+ /* Get interface index once */
+ memset(&req, 0, sizeof(req));
+- strncpy(req.ifr_name, ifname, sizeof(req.ifr_name));
++ strncpy(req.ifr_name, ifname, sizeof(req.ifr_name) - 1);
+ if (ioctl(s, SIOCGIFINDEX, &req) < 0) {
+ perror(ifname);
+ exit(EXIT_FAILURE);
+@@ -250,7 +250,7 @@ send_packet_old(const char *ifname, const uint8_t *buf, size_t size) {
+
+ /* get interface index */
+ memset(&req, 0, sizeof(req));
+- strncpy(req.ifr_name, ifname, sizeof(req.ifr_name));
++ strncpy(req.ifr_name, ifname, sizeof(req.ifr_name) - 1);
+ if (ioctl(s, SIOCGIFINDEX, &req)) {
+ perror(ifname);
+ exit(EXIT_FAILURE);
diff --git a/package/dot1ag-utils/Config.in b/package/dot1ag-utils/Config.in
new file mode 100644
index 0000000000..2dc906f7d7
--- /dev/null
+++ b/package/dot1ag-utils/Config.in
@@ -0,0 +1,11 @@
+config BR2_PACKAGE_DOT1AG_UTILS
+ bool "dot1ag-utils"
+ select BR2_PACKAGE_LIBPCAP
+ help
+ 802.1ag Ethernet OAM utilities: ethping, ethtrace,
+ dot1agd, dot1ag_ccd, etc.
+
+ User-space implementation of IEEE 802.1ag, useful to test
+ Ethernet OAM / CFM connectivity (L2 ping/trace).
+
+ https://github.com/Bumblebee-Networks/dot1ag-utils
diff --git a/package/dot1ag-utils/dot1ag-utils.hash b/package/dot1ag-utils/dot1ag-utils.hash
new file mode 100644
index 0000000000..5d0b3b8346
--- /dev/null
+++ b/package/dot1ag-utils/dot1ag-utils.hash
@@ -0,0 +1,3 @@
+# Locally computed
+sha256 2dcec34d4c9849b7d15a88aedb65eb6911a813e7f1535222513f4c7abecacc49 dot1ag-utils-4886d70ba83166bd1333eb04df8198a8ddfc5680.tar.gz
+sha256 08f7c06906976be9ee27339b268a57a85900928bcb394633382a73268fdc3868 LICENSE
diff --git a/package/dot1ag-utils/dot1ag-utils.mk b/package/dot1ag-utils/dot1ag-utils.mk
new file mode 100644
index 0000000000..7d433aa498
--- /dev/null
+++ b/package/dot1ag-utils/dot1ag-utils.mk
@@ -0,0 +1,14 @@
+################################################################################
+#
+# dot1ag-utils
+#
+################################################################################
+
+DOT1AG_UTILS_VERSION = 4886d70ba83166bd1333eb04df8198a8ddfc5680
+DOT1AG_UTILS_SITE = $(call github,Bumblebee-Networks,dot1ag-utils,$(DOT1AG_UTILS_VERSION))
+DOT1AG_UTILS_LICENSE = BSD-2-Clause
+DOT1AG_UTILS_LICENSE_FILES = LICENSE
+DOT1AG_UTILS_DEPENDENCIES = libpcap
+DOT1AG_UTILS_AUTORECONF = YES
+
+$(eval $(autotools-package))
--
2.43.0
_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot
prev parent reply other threads:[~2026-01-18 22:21 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-07 17:53 [Buildroot] [PATCH v1 0/1] package/dot1ag-utils: new package Vincent Jardin via buildroot
2026-01-07 17:53 ` [Buildroot] [PATCH v1 1/1] " Vincent Jardin via buildroot
2026-01-07 22:36 ` Thomas Petazzoni via buildroot
2026-01-18 22:12 ` [Buildroot] [PATCH v2 0/1] " Vincent Jardin via buildroot
2026-01-18 22:12 ` [Buildroot] [PATCH v2 1/1] " Vincent Jardin via buildroot
2026-01-18 22:21 ` [Buildroot] [PATCH v3 0/1] " Vincent Jardin via buildroot
2026-01-18 22:21 ` Vincent Jardin via buildroot [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260118222115.71411-2-vjardin@free.fr \
--to=buildroot@buildroot.org \
--cc=thomas.petazzoni@bootlin.com \
--cc=vjardin@free.fr \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox