* [PATCH 1/2] eal: add strsep() for Windows builds
@ 2025-05-16 13:22 Andre Muezerie
2025-05-16 13:22 ` [PATCH 2/2] test/strsep: add tests for function strsep() Andre Muezerie
0 siblings, 1 reply; 2+ messages in thread
From: Andre Muezerie @ 2025-05-16 13:22 UTC (permalink / raw)
To: Dmitry Kozlyuk, Tyler Retzlaff; +Cc: dev, Andre Muezerie
Function strsep() is used by DPDK code but is not available on Windows.
This patch adds an implementation from NetBSD, unblocking code depending
on it from being compiled on Windows.
Signed-off-by: Andre Muezerie <andremue@linux.microsoft.com>
---
lib/eal/windows/include/rte_os_shim.h | 1 +
lib/eal/windows/include/strsep.h | 9 +++++
lib/eal/windows/meson.build | 1 +
lib/eal/windows/strsep.c | 47 +++++++++++++++++++++++++++
4 files changed, 58 insertions(+)
create mode 100644 lib/eal/windows/include/strsep.h
create mode 100644 lib/eal/windows/strsep.c
diff --git a/lib/eal/windows/include/rte_os_shim.h b/lib/eal/windows/include/rte_os_shim.h
index 0e74eb19c7..9c3da554da 100644
--- a/lib/eal/windows/include/rte_os_shim.h
+++ b/lib/eal/windows/include/rte_os_shim.h
@@ -7,6 +7,7 @@
#include <rte_os.h>
#include <rte_windows.h>
+#include <strsep.h>
/**
* @file
diff --git a/lib/eal/windows/include/strsep.h b/lib/eal/windows/include/strsep.h
new file mode 100644
index 0000000000..d5d2860d48
--- /dev/null
+++ b/lib/eal/windows/include/strsep.h
@@ -0,0 +1,9 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright (c) 1990, 1993
+ * The Regents of the University of California. All rights reserved.
+ */
+
+#pragma once
+
+char *
+strsep(char **stringp, const char *delim);
diff --git a/lib/eal/windows/meson.build b/lib/eal/windows/meson.build
index 7756d417be..eadecd473c 100644
--- a/lib/eal/windows/meson.build
+++ b/lib/eal/windows/meson.build
@@ -19,6 +19,7 @@ sources += files(
'eal_timer.c',
'getopt.c',
'rte_thread.c',
+ 'strsep.c',
)
dpdk_conf.set10('RTE_EAL_NUMA_AWARE_HUGEPAGES', true)
diff --git a/lib/eal/windows/strsep.c b/lib/eal/windows/strsep.c
new file mode 100644
index 0000000000..fdc0688a07
--- /dev/null
+++ b/lib/eal/windows/strsep.c
@@ -0,0 +1,47 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright (c) 1990, 1993
+ * The Regents of the University of California. All rights reserved.
+ */
+
+#include <string.h>
+
+#include "strsep.h"
+
+/* Get next token from string *stringp, where tokens are possibly empty
+ * strings separated by characters from delim.
+ *
+ * Writes NULLs into the string at *stringp to end tokens.
+ * delim need not remain constant from call to call.
+ * On return, *stringp points past the last NULL written (if there might
+ * be further tokens), or is NULL (if there are definitely no more tokens).
+ *
+ * If *stringp is NULL, strsep returns NULL.
+ */
+char *
+strsep(char **stringp, const char *delim)
+{
+ char *s;
+ const char *spanp;
+ int c, sc;
+ char *tok;
+
+ s = *stringp;
+ if (s == NULL)
+ return NULL;
+ for (tok = s;;) {
+ c = *s++;
+ spanp = delim;
+ do {
+ sc = *spanp++;
+ if (sc == c) {
+ if (c == 0)
+ s = NULL;
+ else
+ s[-1] = 0;
+ *stringp = s;
+ return tok;
+ }
+ } while (sc != 0);
+ }
+ /* NOTREACHED */
+}
--
2.49.0.vfs.0.3
^ permalink raw reply [flat|nested] 2+ messages in thread
* [PATCH 2/2] test/strsep: add tests for function strsep()
2025-05-16 13:22 [PATCH 1/2] eal: add strsep() for Windows builds Andre Muezerie
@ 2025-05-16 13:22 ` Andre Muezerie
0 siblings, 0 replies; 2+ messages in thread
From: Andre Muezerie @ 2025-05-16 13:22 UTC (permalink / raw)
Cc: dev, Andre Muezerie
This patch adds tests for the strsep() function.
Signed-off-by: Andre Muezerie <andremue@linux.microsoft.com>
---
app/test/meson.build | 1 +
app/test/test_strsep.c | 108 +++++++++++++++++++++++++++++++++++++++++
2 files changed, 109 insertions(+)
create mode 100644 app/test/test_strsep.c
diff --git a/app/test/meson.build b/app/test/meson.build
index b6285a6b45..ec5a1fbae3 100644
--- a/app/test/meson.build
+++ b/app/test/meson.build
@@ -184,6 +184,7 @@ source_file_deps = {
'test_stack.c': ['stack'],
'test_stack_perf.c': ['stack'],
'test_string_fns.c': [],
+ 'test_strsep.c': [],
'test_table.c': ['table', 'pipeline', 'port'],
'test_table_acl.c': ['net', 'table', 'pipeline', 'port'],
'test_table_combined.c': ['table', 'pipeline', 'port'],
diff --git a/app/test/test_strsep.c b/app/test/test_strsep.c
new file mode 100644
index 0000000000..19df8f31ee
--- /dev/null
+++ b/app/test/test_strsep.c
@@ -0,0 +1,108 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright (C) 2025 Microsoft Corporation
+ */
+
+#include <string.h>
+#include <rte_os_shim.h>
+
+#include "test.h"
+
+static int
+test_strsep_helper(const char *str, const char *delim,
+ const char * const expected_tokens[], size_t expected_tokens_count)
+{
+ char *s = str != NULL ? strdup(str) : NULL;
+ const char *token;
+ for (size_t i = 0; i < expected_tokens_count; i++) {
+ token = strsep(&s, delim);
+ if (token == NULL) {
+ printf("Expected token '%s', got NULL\n", expected_tokens[i]);
+ free(s);
+ return TEST_FAILED;
+ }
+ if (strcmp(expected_tokens[i], token) != 0) {
+ printf("Expected '%s', got '%s'\n", expected_tokens[i], token);
+ free(s);
+ return TEST_FAILED;
+ }
+ }
+ /* Check that there are no more tokens left */
+ token = strsep(&s, delim);
+ if (token != NULL) {
+ printf("Expected NULL, got '%s'\n", token);
+ free(s);
+ return TEST_FAILED;
+ }
+ free(s);
+ return TEST_SUCCESS;
+}
+
+static int
+test_strsep_single_delimiter(void)
+{
+ const char *str = "hello,world";
+ const char *delim = ",";
+ static const char * const expected_tokens[] = { "hello", "world" };
+ const size_t expected_tokens_count = RTE_DIM(expected_tokens);
+ return test_strsep_helper(str, delim, expected_tokens, expected_tokens_count);
+}
+
+static int
+test_strsep_multiple_delimiters(void)
+{
+ const char *str = "hello,world;this:is;a:test";
+ const char *delim = ",;:";
+ static const char * const expected_tokens[] = {"hello", "world", "this", "is", "a", "test"};
+ const size_t expected_tokens_count = RTE_DIM(expected_tokens);
+ return test_strsep_helper(str, delim, expected_tokens, expected_tokens_count);
+}
+
+static int
+test_strsep_string_with_no_delimiters(void)
+{
+ const char *str = "helloworld";
+ const char *delim = ",";
+ static const char * const expected_tokens[] = {"helloworld"};
+ const size_t expected_tokens_count = RTE_DIM(expected_tokens);
+ return test_strsep_helper(str, delim, expected_tokens, expected_tokens_count);
+}
+
+static int
+test_strsep_empty_string(void)
+{
+ const char *str = "";
+ const char *delim = ",";
+ static const char * const expected_tokens[] = {""};
+ const size_t expected_tokens_count = RTE_DIM(expected_tokens);
+ return test_strsep_helper(str, delim, expected_tokens, expected_tokens_count);
+}
+
+static int
+test_strsep_null(void)
+{
+ const char *str = NULL;
+ const char *delim = ",";
+ static const char * const expected_tokens[] = {""};
+ const size_t expected_tokens_count = 0;
+ return test_strsep_helper(str, delim, expected_tokens, expected_tokens_count);
+}
+
+static struct unit_test_suite test_suite = {
+ .suite_name = "Strsep test suite",
+ .unit_test_cases = {
+ TEST_CASE(test_strsep_single_delimiter),
+ TEST_CASE(test_strsep_multiple_delimiters),
+ TEST_CASE(test_strsep_string_with_no_delimiters),
+ TEST_CASE(test_strsep_empty_string),
+ TEST_CASE(test_strsep_null),
+ TEST_CASES_END()
+ }
+};
+
+static int
+test_strsep(void)
+{
+ return unit_test_suite_runner(&test_suite);
+}
+
+REGISTER_FAST_TEST(strsep_autotest, true, true, test_strsep);
--
2.49.0.vfs.0.3
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2025-05-16 13:22 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-05-16 13:22 [PATCH 1/2] eal: add strsep() for Windows builds Andre Muezerie
2025-05-16 13:22 ` [PATCH 2/2] test/strsep: add tests for function strsep() Andre Muezerie
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).