For calling memcpy when the source and destination addresses are the same, there is a small probability that there will be a copy error issue in some environments, resulting in a failure to connect.
This patch uses memmove instead of memcpy to avoid this issue. Fixes: b80fe1805eee ("telemetry: introduce backward compatibility") Cc: sta...@dpdk.org Signed-off-by: Zhichao Zeng <zhichaox.z...@intel.com> --- lib/telemetry/telemetry_legacy.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/telemetry/telemetry_legacy.c b/lib/telemetry/telemetry_legacy.c index 4c1d1c353a..578230732c 100644 --- a/lib/telemetry/telemetry_legacy.c +++ b/lib/telemetry/telemetry_legacy.c @@ -94,7 +94,7 @@ register_client(const char *cmd __rte_unused, const char *params, } #ifndef RTE_EXEC_ENV_WINDOWS strlcpy(data, strchr(params, ':'), sizeof(data)); - memcpy(data, &data[strlen(":\"")], strlen(data)); + memmove(data, &data[strlen(":\"")], strlen(data)); if (!strchr(data, '\"')) { fprintf(stderr, "Invalid client data\n"); return -1; -- 2.34.1