diff mbox series

tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu

Message ID 20241013173742.71882-1-atrajeev@linux.vnet.ibm.com (mailing list archive)
State New
Headers show
Series tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu | expand

Commit Message

Athira Rajeev Oct. 13, 2024, 5:37 p.m. UTC
perf fails to compile on systems with GCC version11
as below:

In file included from /usr/include/string.h:519,
                 from /home/athir/perf-tools-next/tools/include/linux/bitmap.h:5,
                 from /home/athir/perf-tools-next/tools/perf/util/pmu.h:5,
                 from /home/athir/perf-tools-next/tools/perf/util/evsel.h:14,
                 from /home/athir/perf-tools-next/tools/perf/util/evlist.h:14,
                 from tests/tool_pmu.c:3:
In function ‘strncpy’,
    inlined from ‘do_test’ at tests/tool_pmu.c:25:3:
/usr/include/bits/string_fortified.h:95:10: error: ‘__builtin_strncpy’ specified bound 128 equals destination size [-Werror=stringop-truncation]
   95 |   return __builtin___strncpy_chk (__dest, __src, __len,
      |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   96 |                                   __glibc_objsize (__dest));
      |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~

The compile error is from strncpy refernce in do_test:
	strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));

This behaviour is not observed with GCC version 8, but observed
with GCC version 11 . This is message from gcc for detecting
truncation while using strncpu. Use snprintf instead of strncpy
here to be safe.

Signed-off-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com>
---
 tools/perf/tests/tool_pmu.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Namhyung Kim Oct. 14, 2024, 5:26 p.m. UTC | #1
Hello Athira,

On Sun, Oct 13, 2024 at 11:07:42PM +0530, Athira Rajeev wrote:
> perf fails to compile on systems with GCC version11
> as below:
> 
> In file included from /usr/include/string.h:519,
>                  from /home/athir/perf-tools-next/tools/include/linux/bitmap.h:5,
>                  from /home/athir/perf-tools-next/tools/perf/util/pmu.h:5,
>                  from /home/athir/perf-tools-next/tools/perf/util/evsel.h:14,
>                  from /home/athir/perf-tools-next/tools/perf/util/evlist.h:14,
>                  from tests/tool_pmu.c:3:
> In function ‘strncpy’,
>     inlined from ‘do_test’ at tests/tool_pmu.c:25:3:
> /usr/include/bits/string_fortified.h:95:10: error: ‘__builtin_strncpy’ specified bound 128 equals destination size [-Werror=stringop-truncation]
>    95 |   return __builtin___strncpy_chk (__dest, __src, __len,
>       |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>    96 |                                   __glibc_objsize (__dest));
>       |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~
> 
> The compile error is from strncpy refernce in do_test:
> 	strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
> 
> This behaviour is not observed with GCC version 8, but observed
> with GCC version 11 . This is message from gcc for detecting
> truncation while using strncpu. Use snprintf instead of strncpy
> here to be safe.
> 
> Signed-off-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com>

I found this issue now and thanks for the quick fix.  I will push to
perf-tools-next soon.

Thanks,
Namhyung

> ---
>  tools/perf/tests/tool_pmu.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/tools/perf/tests/tool_pmu.c b/tools/perf/tests/tool_pmu.c
> index 94d0dd8fd3cb..297cc8c55579 100644
> --- a/tools/perf/tests/tool_pmu.c
> +++ b/tools/perf/tests/tool_pmu.c
> @@ -22,7 +22,7 @@ static int do_test(enum tool_pmu_event ev, bool with_pmu)
>  	if (with_pmu)
>  		snprintf(str, sizeof(str), "tool/%s/", tool_pmu__event_to_str(ev));
>  	else
> -		strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
> +		snprintf(str, sizeof(str), "%s", tool_pmu__event_to_str(ev));
>  
>  	parse_events_error__init(&err);
>  	ret = parse_events(evlist, str, &err);
> -- 
> 2.43.5
>
Namhyung Kim Oct. 14, 2024, 5:38 p.m. UTC | #2
On Sun, Oct 13, 2024 at 11:07:42PM +0530, Athira Rajeev wrote:
> perf fails to compile on systems with GCC version11
> as below:

I have one more build failure on 32 bit systems.  I'll carry this as
well.

Thanks,
Namhyung

---8<---
From 2e2c7ca3691d223d94ea383a6b688e35579d14d5 Mon Sep 17 00:00:00 2001
From: Namhyung Kim <namhyung@kernel.org>
Date: Mon, 14 Oct 2024 10:34:17 -0700
Subject: [PATCH] perf tools: Fix compiler error in util/tool_pmu.c

  util/tool_pmu.c: In function 'evsel__tool_pmu_read':
  util/tool_pmu.c:419:55: error: passing argument 2 of 'tool_pmu__read_event' from incompatible pointer type [-Werror=incompatible-pointer-types]
    419 |                         if (!tool_pmu__read_event(ev, &val)) {
        |                                                       ^~~~
        |                                                       |
        |                                                       long unsigned int *
  util/tool_pmu.c:335:56: note: expected 'u64 *' {aka 'long long unsigned int *'} but argument is of type 'long unsigned int *'
    335 | bool tool_pmu__read_event(enum tool_pmu_event ev, u64 *result)
        |                                                   ~~~~~^~~~~~

Signed-off-by: Namhyung Kim <namhyung@kernel.org>
---
 tools/perf/util/tool_pmu.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/tools/perf/util/tool_pmu.c b/tools/perf/util/tool_pmu.c
index ea9d50f0252023dc..bd1cee643eb506df 100644
--- a/tools/perf/util/tool_pmu.c
+++ b/tools/perf/util/tool_pmu.c
@@ -394,7 +394,7 @@ bool tool_pmu__read_event(enum tool_pmu_event ev, u64 *result)
 int evsel__tool_pmu_read(struct evsel *evsel, int cpu_map_idx, int thread)
 {
 	__u64 *start_time, cur_time, delta_start;
-	unsigned long val;
+	u64 val;
 	int fd, err = 0;
 	struct perf_counts_values *count, *old_count = NULL;
 	bool adjust = false;
Namhyung Kim Oct. 14, 2024, 5:43 p.m. UTC | #3
On Sun, 13 Oct 2024 23:07:42 +0530, Athira Rajeev wrote:

> perf fails to compile on systems with GCC version11
> as below:
> 
> In file included from /usr/include/string.h:519,
>                  from /home/athir/perf-tools-next/tools/include/linux/bitmap.h:5,
>                  from /home/athir/perf-tools-next/tools/perf/util/pmu.h:5,
>                  from /home/athir/perf-tools-next/tools/perf/util/evsel.h:14,
>                  from /home/athir/perf-tools-next/tools/perf/util/evlist.h:14,
>                  from tests/tool_pmu.c:3:
> In function ‘strncpy’,
>     inlined from ‘do_test’ at tests/tool_pmu.c:25:3:
> /usr/include/bits/string_fortified.h:95:10: error: ‘__builtin_strncpy’ specified bound 128 equals destination size [-Werror=stringop-truncation]
>    95 |   return __builtin___strncpy_chk (__dest, __src, __len,
>       |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>    96 |                                   __glibc_objsize (__dest));
>       |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~
> 
> [...]

Applied to perf-tools-next, thanks!

Best regards,
Namhyung
Athira Rajeev Oct. 16, 2024, 12:29 p.m. UTC | #4
> On 14 Oct 2024, at 10:56 PM, Namhyung Kim <namhyung@kernel.org> wrote:
> 
> Hello Athira,
> 
> On Sun, Oct 13, 2024 at 11:07:42PM +0530, Athira Rajeev wrote:
>> perf fails to compile on systems with GCC version11
>> as below:
>> 
>> In file included from /usr/include/string.h:519,
>>                 from /home/athir/perf-tools-next/tools/include/linux/bitmap.h:5,
>>                 from /home/athir/perf-tools-next/tools/perf/util/pmu.h:5,
>>                 from /home/athir/perf-tools-next/tools/perf/util/evsel.h:14,
>>                 from /home/athir/perf-tools-next/tools/perf/util/evlist.h:14,
>>                 from tests/tool_pmu.c:3:
>> In function ‘strncpy’,
>>    inlined from ‘do_test’ at tests/tool_pmu.c:25:3:
>> /usr/include/bits/string_fortified.h:95:10: error: ‘__builtin_strncpy’ specified bound 128 equals destination size [-Werror=stringop-truncation]
>>   95 |   return __builtin___strncpy_chk (__dest, __src, __len,
>>      |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>>   96 |                                   __glibc_objsize (__dest));
>>      |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~
>> 
>> The compile error is from strncpy refernce in do_test:
>> strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
>> 
>> This behaviour is not observed with GCC version 8, but observed
>> with GCC version 11 . This is message from gcc for detecting
>> truncation while using strncpu. Use snprintf instead of strncpy
>> here to be safe.
>> 
>> Signed-off-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com>
> 
> I found this issue now and thanks for the quick fix.  I will push to
> perf-tools-next soon.
> 
> Thanks,
> Namhyung
> 

Sure

Thanks Namhyung for pulling in the change

Athira
>> ---
>> tools/perf/tests/tool_pmu.c | 2 +-
>> 1 file changed, 1 insertion(+), 1 deletion(-)
>> 
>> diff --git a/tools/perf/tests/tool_pmu.c b/tools/perf/tests/tool_pmu.c
>> index 94d0dd8fd3cb..297cc8c55579 100644
>> --- a/tools/perf/tests/tool_pmu.c
>> +++ b/tools/perf/tests/tool_pmu.c
>> @@ -22,7 +22,7 @@ static int do_test(enum tool_pmu_event ev, bool with_pmu)
>> if (with_pmu)
>> snprintf(str, sizeof(str), "tool/%s/", tool_pmu__event_to_str(ev));
>> else
>> - strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
>> + snprintf(str, sizeof(str), "%s", tool_pmu__event_to_str(ev));
>> 
>> parse_events_error__init(&err);
>> ret = parse_events(evlist, str, &err);
>> -- 
>> 2.43.5
Ian Rogers Oct. 16, 2024, 3:06 p.m. UTC | #5
On Wed, Oct 16, 2024 at 5:30 AM Athira Rajeev
<atrajeev@linux.vnet.ibm.com> wrote:
>
>
>
> > On 14 Oct 2024, at 10:56 PM, Namhyung Kim <namhyung@kernel.org> wrote:
> >
> > Hello Athira,
> >
> > On Sun, Oct 13, 2024 at 11:07:42PM +0530, Athira Rajeev wrote:
> >> perf fails to compile on systems with GCC version11
> >> as below:
> >>
> >> In file included from /usr/include/string.h:519,
> >>                 from /home/athir/perf-tools-next/tools/include/linux/bitmap.h:5,
> >>                 from /home/athir/perf-tools-next/tools/perf/util/pmu.h:5,
> >>                 from /home/athir/perf-tools-next/tools/perf/util/evsel.h:14,
> >>                 from /home/athir/perf-tools-next/tools/perf/util/evlist.h:14,
> >>                 from tests/tool_pmu.c:3:
> >> In function ‘strncpy’,
> >>    inlined from ‘do_test’ at tests/tool_pmu.c:25:3:
> >> /usr/include/bits/string_fortified.h:95:10: error: ‘__builtin_strncpy’ specified bound 128 equals destination size [-Werror=stringop-truncation]
> >>   95 |   return __builtin___strncpy_chk (__dest, __src, __len,
> >>      |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> >>   96 |                                   __glibc_objsize (__dest));
> >>      |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~
> >>
> >> The compile error is from strncpy refernce in do_test:
> >> strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
> >>
> >> This behaviour is not observed with GCC version 8, but observed
> >> with GCC version 11 . This is message from gcc for detecting
> >> truncation while using strncpu. Use snprintf instead of strncpy
> >> here to be safe.
> >>
> >> Signed-off-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com>
> >
> > I found this issue now and thanks for the quick fix.  I will push to
> > perf-tools-next soon.
> >
> > Thanks,
> > Namhyung
> >
>
> Sure
>
> Thanks Namhyung for pulling in the change
>
> Athira

Thanks for the fixes. As this is test code I don't think performance,
style, etc. matter much. The GCC strncpy warnings are annoying imo,
I'm not sure it makes sense for them to be enabled. I see in the
kernel lots of "sizeof(foo)-1" as a workaround. strlcpy looks like a
better alternative but it gets a checkpatch warning as in the kernel
strscpy is preferred. Perhaps we should create a strscpy shim.

Thanks,
Ian

> >> ---
> >> tools/perf/tests/tool_pmu.c | 2 +-
> >> 1 file changed, 1 insertion(+), 1 deletion(-)
> >>
> >> diff --git a/tools/perf/tests/tool_pmu.c b/tools/perf/tests/tool_pmu.c
> >> index 94d0dd8fd3cb..297cc8c55579 100644
> >> --- a/tools/perf/tests/tool_pmu.c
> >> +++ b/tools/perf/tests/tool_pmu.c
> >> @@ -22,7 +22,7 @@ static int do_test(enum tool_pmu_event ev, bool with_pmu)
> >> if (with_pmu)
> >> snprintf(str, sizeof(str), "tool/%s/", tool_pmu__event_to_str(ev));
> >> else
> >> - strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
> >> + snprintf(str, sizeof(str), "%s", tool_pmu__event_to_str(ev));
> >>
> >> parse_events_error__init(&err);
> >> ret = parse_events(evlist, str, &err);
> >> --
> >> 2.43.5
>
>
Athira Rajeev Oct. 16, 2024, 6:23 p.m. UTC | #6
> On 16 Oct 2024, at 8:36 PM, Ian Rogers <irogers@google.com> wrote:
> 
> On Wed, Oct 16, 2024 at 5:30 AM Athira Rajeev
> <atrajeev@linux.vnet.ibm.com> wrote:
>> 
>> 
>> 
>>> On 14 Oct 2024, at 10:56 PM, Namhyung Kim <namhyung@kernel.org> wrote:
>>> 
>>> Hello Athira,
>>> 
>>> On Sun, Oct 13, 2024 at 11:07:42PM +0530, Athira Rajeev wrote:
>>>> perf fails to compile on systems with GCC version11
>>>> as below:
>>>> 
>>>> In file included from /usr/include/string.h:519,
>>>>                from /home/athir/perf-tools-next/tools/include/linux/bitmap.h:5,
>>>>                from /home/athir/perf-tools-next/tools/perf/util/pmu.h:5,
>>>>                from /home/athir/perf-tools-next/tools/perf/util/evsel.h:14,
>>>>                from /home/athir/perf-tools-next/tools/perf/util/evlist.h:14,
>>>>                from tests/tool_pmu.c:3:
>>>> In function ‘strncpy’,
>>>>   inlined from ‘do_test’ at tests/tool_pmu.c:25:3:
>>>> /usr/include/bits/string_fortified.h:95:10: error: ‘__builtin_strncpy’ specified bound 128 equals destination size [-Werror=stringop-truncation]
>>>>  95 |   return __builtin___strncpy_chk (__dest, __src, __len,
>>>>     |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>>>>  96 |                                   __glibc_objsize (__dest));
>>>>     |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~
>>>> 
>>>> The compile error is from strncpy refernce in do_test:
>>>> strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
>>>> 
>>>> This behaviour is not observed with GCC version 8, but observed
>>>> with GCC version 11 . This is message from gcc for detecting
>>>> truncation while using strncpu. Use snprintf instead of strncpy
>>>> here to be safe.
>>>> 
>>>> Signed-off-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com>
>>> 
>>> I found this issue now and thanks for the quick fix.  I will push to
>>> perf-tools-next soon.
>>> 
>>> Thanks,
>>> Namhyung
>>> 
>> 
>> Sure
>> 
>> Thanks Namhyung for pulling in the change
>> 
>> Athira
> 
> Thanks for the fixes. As this is test code I don't think performance,
> style, etc. matter much. The GCC strncpy warnings are annoying imo,
> I'm not sure it makes sense for them to be enabled. I see in the
> kernel lots of "sizeof(foo)-1" as a workaround. strlcpy looks like a
> better alternative but it gets a checkpatch warning as in the kernel
> strscpy is preferred. Perhaps we should create a strscpy shim.
> 

IIUC, strscpy is defined in kernel source and is currently not used in tools side.

Ian,
Your point here is that we can create an interface in tools side so that we can later safely use strscpy in cases like this ?

Thanks
Athira

> Thanks,
> Ian
> 
>>>> ---
>>>> tools/perf/tests/tool_pmu.c | 2 +-
>>>> 1 file changed, 1 insertion(+), 1 deletion(-)
>>>> 
>>>> diff --git a/tools/perf/tests/tool_pmu.c b/tools/perf/tests/tool_pmu.c
>>>> index 94d0dd8fd3cb..297cc8c55579 100644
>>>> --- a/tools/perf/tests/tool_pmu.c
>>>> +++ b/tools/perf/tests/tool_pmu.c
>>>> @@ -22,7 +22,7 @@ static int do_test(enum tool_pmu_event ev, bool with_pmu)
>>>> if (with_pmu)
>>>> snprintf(str, sizeof(str), "tool/%s/", tool_pmu__event_to_str(ev));
>>>> else
>>>> - strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
>>>> + snprintf(str, sizeof(str), "%s", tool_pmu__event_to_str(ev));
>>>> 
>>>> parse_events_error__init(&err);
>>>> ret = parse_events(evlist, str, &err);
>>>> --
>>>> 2.43.5
Ian Rogers Oct. 16, 2024, 7:04 p.m. UTC | #7
On Wed, Oct 16, 2024 at 11:23 AM Athira Rajeev
<atrajeev@linux.vnet.ibm.com> wrote:
>
>
>
> > On 16 Oct 2024, at 8:36 PM, Ian Rogers <irogers@google.com> wrote:
> >
> > On Wed, Oct 16, 2024 at 5:30 AM Athira Rajeev
> > <atrajeev@linux.vnet.ibm.com> wrote:
> >>
> >>
> >>
> >>> On 14 Oct 2024, at 10:56 PM, Namhyung Kim <namhyung@kernel.org> wrote:
> >>>
> >>> Hello Athira,
> >>>
> >>> On Sun, Oct 13, 2024 at 11:07:42PM +0530, Athira Rajeev wrote:
> >>>> perf fails to compile on systems with GCC version11
> >>>> as below:
> >>>>
> >>>> In file included from /usr/include/string.h:519,
> >>>>                from /home/athir/perf-tools-next/tools/include/linux/bitmap.h:5,
> >>>>                from /home/athir/perf-tools-next/tools/perf/util/pmu.h:5,
> >>>>                from /home/athir/perf-tools-next/tools/perf/util/evsel.h:14,
> >>>>                from /home/athir/perf-tools-next/tools/perf/util/evlist.h:14,
> >>>>                from tests/tool_pmu.c:3:
> >>>> In function ‘strncpy’,
> >>>>   inlined from ‘do_test’ at tests/tool_pmu.c:25:3:
> >>>> /usr/include/bits/string_fortified.h:95:10: error: ‘__builtin_strncpy’ specified bound 128 equals destination size [-Werror=stringop-truncation]
> >>>>  95 |   return __builtin___strncpy_chk (__dest, __src, __len,
> >>>>     |          ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> >>>>  96 |                                   __glibc_objsize (__dest));
> >>>>     |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~
> >>>>
> >>>> The compile error is from strncpy refernce in do_test:
> >>>> strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
> >>>>
> >>>> This behaviour is not observed with GCC version 8, but observed
> >>>> with GCC version 11 . This is message from gcc for detecting
> >>>> truncation while using strncpu. Use snprintf instead of strncpy
> >>>> here to be safe.
> >>>>
> >>>> Signed-off-by: Athira Rajeev <atrajeev@linux.vnet.ibm.com>
> >>>
> >>> I found this issue now and thanks for the quick fix.  I will push to
> >>> perf-tools-next soon.
> >>>
> >>> Thanks,
> >>> Namhyung
> >>>
> >>
> >> Sure
> >>
> >> Thanks Namhyung for pulling in the change
> >>
> >> Athira
> >
> > Thanks for the fixes. As this is test code I don't think performance,
> > style, etc. matter much. The GCC strncpy warnings are annoying imo,
> > I'm not sure it makes sense for them to be enabled. I see in the
> > kernel lots of "sizeof(foo)-1" as a workaround. strlcpy looks like a
> > better alternative but it gets a checkpatch warning as in the kernel
> > strscpy is preferred. Perhaps we should create a strscpy shim.
> >
>
> IIUC, strscpy is defined in kernel source and is currently not used in tools side.
>
> Ian,
> Your point here is that we can create an interface in tools side so that we can later safely use strscpy in cases like this ?

Yeah. Tbh the string code is a bit chaotic in the code base. There's
some stuff using char*s, some asprintf, there's strbuf then there all
the kernel ways of doing things. I lose track of why strscpy is
superior to strlcpy, but strlcpy will get you a checkpath warning.

The standard kernel solution to the GCC strncpy warning I've seen,
changing "strncpy(a, b, sizeof(a))" to "strncpy(a, b, sizeof(a) - 1)",
looks dodgy and possibly worse to me. The point of the warning I think
relates to strncpy not necessarily \0 terminating the string and you
need to reserve at least 1 character for this, while strlcpy
guarantees the \0 termination. Doing "sizeof(..) - 1" likely confuses
the checker making it give up, but now you have less space to copy a
potential \0 as well as not getting a \0.

Thanks,
Ian


> Thanks
> Athira
>
> > Thanks,
> > Ian
> >
> >>>> ---
> >>>> tools/perf/tests/tool_pmu.c | 2 +-
> >>>> 1 file changed, 1 insertion(+), 1 deletion(-)
> >>>>
> >>>> diff --git a/tools/perf/tests/tool_pmu.c b/tools/perf/tests/tool_pmu.c
> >>>> index 94d0dd8fd3cb..297cc8c55579 100644
> >>>> --- a/tools/perf/tests/tool_pmu.c
> >>>> +++ b/tools/perf/tests/tool_pmu.c
> >>>> @@ -22,7 +22,7 @@ static int do_test(enum tool_pmu_event ev, bool with_pmu)
> >>>> if (with_pmu)
> >>>> snprintf(str, sizeof(str), "tool/%s/", tool_pmu__event_to_str(ev));
> >>>> else
> >>>> - strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
> >>>> + snprintf(str, sizeof(str), "%s", tool_pmu__event_to_str(ev));
> >>>>
> >>>> parse_events_error__init(&err);
> >>>> ret = parse_events(evlist, str, &err);
> >>>> --
> >>>> 2.43.5
>
>
diff mbox series

Patch

diff --git a/tools/perf/tests/tool_pmu.c b/tools/perf/tests/tool_pmu.c
index 94d0dd8fd3cb..297cc8c55579 100644
--- a/tools/perf/tests/tool_pmu.c
+++ b/tools/perf/tests/tool_pmu.c
@@ -22,7 +22,7 @@  static int do_test(enum tool_pmu_event ev, bool with_pmu)
 	if (with_pmu)
 		snprintf(str, sizeof(str), "tool/%s/", tool_pmu__event_to_str(ev));
 	else
-		strncpy(str, tool_pmu__event_to_str(ev), sizeof(str));
+		snprintf(str, sizeof(str), "%s", tool_pmu__event_to_str(ev));
 
 	parse_events_error__init(&err);
 	ret = parse_events(evlist, str, &err);