From: "Steven Rostedt (Google)" <rostedt@xxxxxxxxxxx> If the vals is NULL (which is valid), the traceeval_insert() macro calls traceeval_insert_size() with sizeof(vals)/sizeof(vals[0]) to get the number of vals in the array. But this does not make sense with a NULL value. Check for NULL and if vals is NULL then pass in zero. Cc: Ross Zwisler <zwisler@xxxxxxxxxx> Cc: Stevie Alvarez <stevie.6strings@xxxxxxxxx> Signed-off-by: Steven Rostedt (Google) <rostedt@xxxxxxxxxxx> --- Changse since v1: https://lore.kernel.org/linux-trace-devel/20230928051511.074ab689@xxxxxxxxxxxxxxxxxxxx - typecast "vals" to (void *) otherwise the compiler will warn that comparing a structure to != NULL will always be true. include/traceeval-hist.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/traceeval-hist.h b/include/traceeval-hist.h index 44d071f3231a..65a905034773 100644 --- a/include/traceeval-hist.h +++ b/include/traceeval-hist.h @@ -187,7 +187,7 @@ int traceeval_insert_size(struct traceeval *teval, #define traceeval_insert(teval, keys, vals) \ traceeval_insert_size(teval, keys, TRACEEVAL_ARRAY_SIZE(keys), \ - vals, TRACEEVAL_ARRAY_SIZE(vals)) + vals, (void *)vals == NULL ? 0 : TRACEEVAL_ARRAY_SIZE(vals)) int traceeval_remove_size(struct traceeval *teval, const struct traceeval_data *keys, size_t nr_keys); -- 2.40.1