Re: Build issues due to patch "gprofng: a new GNU profiler" – CLOCK_MONOTONIC_RAW not defined
Vladimir Mezentsev
vladimir.mezentsev@oracle.com
Mon Mar 14 18:16:45 GMT 2022
On 3/14/22 03:57, Tobias Burnus wrote:
> Hi Vladimir, hi Nick,
>
> Friday's commit "gprofng: a new GNU profiler",
> https://sourceware.org/git/?p=binutils-gdb.git;a=commit;h=bb368aad297fe3ad40cf397e6fc85aa471429a28
>
>
> broke the build here (build server using on purpose an older
> Linux/glibc):
>
> gprofng/libcollector/gethrtime.c:35:26: error: 'CLOCK_MONOTONIC_RAW'
> undeclared (first use in this function); did you mean 'CLOCK_MONOTONIC'?
> int r = clock_gettime (CLOCK_MONOTONIC_RAW, &tp);
> ^~~~~~~~~~~~~~~~~~~
> CLOCK_MONOTONIC
>
> According to https://linux.die.net/man/2/clock_gettime:
>
> CLOCK_MONOTONIC_RAW (since Linux 2.6.28; Linux-specific)
> Similar to CLOCK_MONOTONIC, but provides access to a raw
> hardware-based
> time that is not subject to NTP adjustments or the incremental
> adjustments performed by adjtime(3).
>
> Thus, it seems as if either a config check or a much
> simpler patch as the following is needed:
>
> --- a/gprofng/libcollector/gethrtime.c
> +++ b/gprofng/libcollector/gethrtime.c
> @@ -34,3 +34,7 @@ linux_gethrtime ()
> hrtime_t rc = 0;
> +#ifdef CLOCK_MONOTONIC_RAW
> int r = clock_gettime (CLOCK_MONOTONIC_RAW, &tp);
> +#else
> + int r = clock_gettime (CLOCK_MONOTONIC, &tp);
> +#endif
> if (r == 0)
>
> --- a/gprofng/src/gethrtime.c
> +++ b/gprofng/src/gethrtime.c
> @@ -161,3 +161,7 @@ gethrtime (void)
> */
> +#ifdef CLOCK_MONOTONIC_RAW
> int r = clock_gettime (CLOCK_MONOTONIC_RAW, &tp);
> +#else
> + int r = clock_gettime (CLOCK_MONOTONIC, &tp);
> +#endif
> if (r == 0)
>
> * * *
>
> Additionally, the build fails with the link error:
> gprofng/src/gethrtime.c:131: undefined reference to `clock_gettime'
>
> The problem seems to be what the 'clock_gettime(3)' man page states:
> Link with -lrt (only for glibc versions before 2.17).
>
> Please consider as fix to copy the following check from
> libbacktrace/configure.ac:
>
> # Check for the clock_gettime function.
> AC_CHECK_FUNCS(clock_gettime)
> ...
> AC_SUBST(CLOCK_GETTIME_LINK)
Hi Tobia,
Your fixes look good to me.
Could you apply these fixes.
I can prepare a patch but I cannot build on your configuration.
Thank you,
-Vladimir
>
>
> Thanks,
>
> Tobias
>
> -----------------
> Siemens Electronic Design Automation GmbH; Anschrift: Arnulfstraße
> 201, 80634 München; Gesellschaft mit beschränkter Haftung;
> Geschäftsführer: Thomas Heurung, Frank Thürauf; Sitz der Gesellschaft:
> München; Registergericht München, HRB 106955
More information about the Binutils
mailing list