* [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu @ 2024-10-13 17:37 Athira Rajeev 2024-10-14 17:26 ` Namhyung Kim ` (2 more replies) 0 siblings, 3 replies; 8+ messages in thread From: Athira Rajeev @ 2024-10-13 17:37 UTC (permalink / raw) To: acme, jolsa, adrian.hunter, irogers, namhyung Cc: linux-perf-users, linuxppc-dev, akanksha, maddy, atrajeev, kjain, disgoel, hbathini 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(-) 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 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu 2024-10-13 17:37 [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu Athira Rajeev @ 2024-10-14 17:26 ` Namhyung Kim 2024-10-16 12:29 ` Athira Rajeev 2024-10-14 17:38 ` Namhyung Kim 2024-10-14 17:43 ` Namhyung Kim 2 siblings, 1 reply; 8+ messages in thread From: Namhyung Kim @ 2024-10-14 17:26 UTC (permalink / raw) To: Athira Rajeev Cc: acme, jolsa, adrian.hunter, irogers, linux-perf-users, linuxppc-dev, akanksha, maddy, kjain, disgoel, hbathini 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 > ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu 2024-10-14 17:26 ` Namhyung Kim @ 2024-10-16 12:29 ` Athira Rajeev 2024-10-16 15:06 ` Ian Rogers 0 siblings, 1 reply; 8+ messages in thread From: Athira Rajeev @ 2024-10-16 12:29 UTC (permalink / raw) To: Namhyung Kim Cc: acme, jolsa, adrian.hunter, irogers, linux-perf-users, linuxppc-dev, akanksha, maddy, kjain, disgoel, hbathini > 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 ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu 2024-10-16 12:29 ` Athira Rajeev @ 2024-10-16 15:06 ` Ian Rogers 2024-10-16 18:23 ` Athira Rajeev 0 siblings, 1 reply; 8+ messages in thread From: Ian Rogers @ 2024-10-16 15:06 UTC (permalink / raw) To: Athira Rajeev Cc: Namhyung Kim, acme, jolsa, adrian.hunter, linux-perf-users, linuxppc-dev, akanksha, maddy, kjain, disgoel, hbathini 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 > > ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu 2024-10-16 15:06 ` Ian Rogers @ 2024-10-16 18:23 ` Athira Rajeev 2024-10-16 19:04 ` Ian Rogers 0 siblings, 1 reply; 8+ messages in thread From: Athira Rajeev @ 2024-10-16 18:23 UTC (permalink / raw) To: Ian Rogers Cc: Namhyung Kim, acme, jolsa, adrian.hunter, linux-perf-users, linuxppc-dev, akanksha, maddy, kjain, disgoel, hbathini > 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 ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu 2024-10-16 18:23 ` Athira Rajeev @ 2024-10-16 19:04 ` Ian Rogers 0 siblings, 0 replies; 8+ messages in thread From: Ian Rogers @ 2024-10-16 19:04 UTC (permalink / raw) To: Athira Rajeev Cc: Namhyung Kim, acme, jolsa, adrian.hunter, linux-perf-users, linuxppc-dev, akanksha, maddy, kjain, disgoel, hbathini 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 > > ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu 2024-10-13 17:37 [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu Athira Rajeev 2024-10-14 17:26 ` Namhyung Kim @ 2024-10-14 17:38 ` Namhyung Kim 2024-10-14 17:43 ` Namhyung Kim 2 siblings, 0 replies; 8+ messages in thread From: Namhyung Kim @ 2024-10-14 17:38 UTC (permalink / raw) To: Athira Rajeev Cc: acme, jolsa, adrian.hunter, irogers, linux-perf-users, linuxppc-dev, akanksha, maddy, kjain, disgoel, hbathini 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; -- 2.47.0.rc1.288.g06298d1525-goog ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu 2024-10-13 17:37 [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu Athira Rajeev 2024-10-14 17:26 ` Namhyung Kim 2024-10-14 17:38 ` Namhyung Kim @ 2024-10-14 17:43 ` Namhyung Kim 2 siblings, 0 replies; 8+ messages in thread From: Namhyung Kim @ 2024-10-14 17:43 UTC (permalink / raw) To: acme, jolsa, adrian.hunter, irogers, Athira Rajeev Cc: linux-perf-users, linuxppc-dev, akanksha, maddy, kjain, disgoel, hbathini 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 ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2024-10-16 19:05 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-10-13 17:37 [PATCH] tools/perf/tests: Fix compilation error with strncpy in tests/tool_pmu Athira Rajeev 2024-10-14 17:26 ` Namhyung Kim 2024-10-16 12:29 ` Athira Rajeev 2024-10-16 15:06 ` Ian Rogers 2024-10-16 18:23 ` Athira Rajeev 2024-10-16 19:04 ` Ian Rogers 2024-10-14 17:38 ` Namhyung Kim 2024-10-14 17:43 ` Namhyung Kim
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).