https://sourceware.org/bugzilla/show_bug.cgi?id=33168

--- Comment #6 from Sourceware Commits <cvs-commit at gcc dot gnu.org> ---
The master branch has been updated by Rainer Orth <[email protected]>:

https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=13793e39831c1aaf8b430e5d6002bd3aebf25fc3

commit 13793e39831c1aaf8b430e5d6002bd3aebf25fc3
Author: Rainer Orth <[email protected]>
Date:   Fri Sep 12 09:50:34 2025 +0200

    libsframe: testsuite: Fix testsuite build on Solaris [PR33168]

    As reported in PR libsframe/33168, the libsframe tests don't build on
    Solaris.  The failure is

    In file included from
libsframe/testsuite/libsframe.decode/be-flipping.c:28:
    /usr/include/dejagnu.h:48:1: error: conflicting types for âwaitâ; have
âvoid(void)â
       48 | wait (void)
          | ^~~~
    In file included from /usr/include/stdlib.h:16,
                     from
libsframe/testsuite/libsframe.decode/be-flipping.c:21:
    /usr/include/sys/wait.h:85:14: note: previous declaration of âwaitâ
with type âpid_t(int *)â {aka âlong int(int *)â}
       85 | extern pid_t wait(int *);
          |              ^~~~

    We have a combination of two factors here:

    * Solaris <stdlib.h> has

      and configure.ac predefines __EXTENSIONS__ due to the use of
      AC_USE_SYSTEM_EXTENSIONS.

    * This conflicts with <dejagnu.h>'s definition

    void
    wait (void)
    {
    ...
    }

    While this version of wait was removed in upstream DejaGnu, the removal
    only happened after the latest release, 1.6.3.

    To avoid this, I've moved all testsuite includes into a new
    sframe-test.h, adding a workaround for the wait conflict.

    -Wall and -I$(srcdir) have been removed from AM_CPPFLAGS since they
    don't seem to be needed.  To fix the Makefile fragment duplication, the
    local.mk files now use $(testsuite_LDADD) and $(testsuite_CPPFLAGS)
    throughout.

    Tested on {i386,amd64}-pc-solaris2.11, {sparc,sparcv9}-sun-solaris2.11,
    {x86_64,i686}-pc-linux-gnu, and amd64-pc-freebsd14.0.

    Coauthored-By: Alan Modra <[email protected]>

    2025-08-31  Rainer Orth  <[email protected]>
                Alan Modra  <[email protected]>

            libsframe:
            PR libsframe/33168
            * testsuite/sframe-test.h: New file.
            * testsuite/libsframe.decode/be-flipping.c: Replace includes by
            sframe-test.h.
            * testsuite/libsframe.decode/frecnt-1.c: Likewise.
            * testsuite/libsframe.decode/frecnt-2.c: Likewise.
            * testsuite/libsframe.encode/encode-1.c: Likewise.
            * testsuite/libsframe.find/findfre-1.c: Likewise.
            * testsuite/libsframe.find/findfunc-1.c: Likewise.
            * testsuite/libsframe.find/plt-findfre-1.c: Likewise.
            * testsuite/libsframe.find/plt-findfre-2.c: Likewise.

            * Makefile.am (AM_CPPFLAGS): Remove -I$(srcdir).
            * Makefile.in: Regenerate.
            * testsuite/local.mk (testsuite_LDADD): New variable.
            (testsuite_CPPFLAGS): Likewise.
            * testsuite/libsframe.decode/local.mk: Use $(testsuite_LDADD),
            $(testsuite_CPPFLAGS).
            * testsuite/libsframe.encode/local.mk: Likewise.
            * testsuite/libsframe.find/local.mk: Likewise.

-- 
You are receiving this mail because:
You are on the CC list for the bug.

Reply via email to