From: Thorsten Blum Date: Sun, 13 Apr 2025 10:41:09 +0000 (+0200) Subject: perf/x86/intel/bts: Replace offsetof() with struct_size() X-Git-Tag: v6.16-rc1~196^2~47 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5c3627b6f0595f1ec27e6f5df903bd072e9b9136;p=thirdparty%2Flinux.git perf/x86/intel/bts: Replace offsetof() with struct_size() Use struct_size() to calculate the number of bytes to allocate for a new bts_buffer. Compared to offsetof(), struct_size() provides additional compile-time checks (e.g., __must_be_array()). Signed-off-by: Thorsten Blum Signed-off-by: Ingo Molnar Cc: Peter Zijlstra Link: https://lore.kernel.org/r/20250413104108.49142-2-thorsten.blum@linux.dev --- diff --git a/arch/x86/events/intel/bts.c b/arch/x86/events/intel/bts.c index da03f53bfa184..16bc89c8023b3 100644 --- a/arch/x86/events/intel/bts.c +++ b/arch/x86/events/intel/bts.c @@ -101,7 +101,7 @@ bts_buffer_setup_aux(struct perf_event *event, void **pages, if (overwrite && nr_buf > 1) return NULL; - bb = kzalloc_node(offsetof(struct bts_buffer, buf[nr_buf]), GFP_KERNEL, node); + bb = kzalloc_node(struct_size(bb, buf, nr_buf), GFP_KERNEL, node); if (!bb) return NULL;