tracing: Always use memcpy() in histogram add_to_key()
authorSteven Rostedt <rostedt@goodmis.org>
Fri, 4 Apr 2025 01:06:37 +0000 (21:06 -0400)
committerSteven Rostedt (Google) <rostedt@goodmis.org>
Tue, 6 May 2025 15:35:34 +0000 (11:35 -0400)
The add_to_key() function tests if the key is a string or some data. If
it's a string it does some further calculations of the string size (still
truncating it to the max size it can be), and calls strncpy().

If the key isn't as string it calls memcpy(). The interesting point is
that both use the exact same parameters:

                strncpy(compound_key + key_field->offset, (char *)key, size);
        } else
                memcpy(compound_key + key_field->offset, key, size);

As strncpy() is being used simply as a memcpy() for a string, and since
strncpy() is deprecated, just call memcpy() for both memory and string
keys.

Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Cc: Kees Cook <keescook@chromium.org>
Link: https://lore.kernel.org/20250403210637.1c477d4a@gandalf.local.home
Acked-by: Masami Hiramatsu (Google) <mhiramat@kernel.org>
Reviewed-by: Tom Zanussi <zanussi@kernel.org>
Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>
kernel/trace/trace_events_hist.c

index 1260c23cfa5fc4d829e62c4532ff31d60e4bf47b..e139b58c3a4304d3c8262639448bc2f43052fd3d 100644 (file)
@@ -5224,10 +5224,8 @@ static inline void add_to_key(char *compound_key, void *key,
                /* ensure NULL-termination */
                if (size > key_field->size - 1)
                        size = key_field->size - 1;
-
-               strncpy(compound_key + key_field->offset, (char *)key, size);
-       } else
-               memcpy(compound_key + key_field->offset, key, size);
+       }
+       memcpy(compound_key + key_field->offset, key, size);
 }
 
 static void