Hi,

On Wed, Jan 29, 2025 at 07:57:37AM +0000, parona wrote:
> On Monday, January 27th, 2025 at 10:40 PM, Mark Wielaard <m...@klomp.org> 
> wrote:
> > So maybe our configure check is wrong and it should just test whether
> > there is an error.h but also if you can link the result?
> 
> Included patch that checks if the symbol is available before
> defining HAVE_ERROR_H. This would also work, and wouldn't add a new
> automagic dependency on musl.

I definitely like this patch. But when doing an autoreconf -f -v -i
(autoconf 2.27) I get:

autoheader: warning: missing template: HAVE_ERROR_H
autoheader: warning: Use AC_DEFINE([HAVE_ERROR_H], [], [Description])
autoreconf: error: /usr/bin/autoheader failed with exit status: 1

So I had to redefine it as:

AC_CHECK_HEADER([error.h], [AC_CHECK_FUNC([error], AC_DEFINE([HAVE_ERROR_H], 
[1], [Define if error.h is usable]))])

Which results in:

checking for error.h... yes
checking for error... yes
checking for err.h... yes

And the following definition in config.h

/* Define if error.h is usable */
#define HAVE_ERROR_H 1

If this also works for you I'll check it in as attached.

Thanks,

Mark


>From 1d1739f1664964252d6b5cde233805f6a14459bf Mon Sep 17 00:00:00 2001
From: Alfred Wingate <par...@protonmail.com>
Date: Wed, 29 Jan 2025 09:32:49 +0200
Subject: [PATCH] Declare HAVE_ERROR_H only if error symbol is available

Musl doesn't provide error.h. But there exists a standalone implementation
that installs /usr/include/error.h but requires explicit linkage. This
leads linkage errors later on due to the assumption that error
symbols are provided by the libc.

Bug: https://bugs.gentoo.org/948878
Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=32548
Signed-off-by: Alfred Wingate <par...@protonmail.com>
---
 configure.ac | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/configure.ac b/configure.ac
index 1da2a12c0a00..e57d39275591 100644
--- a/configure.ac
+++ b/configure.ac
@@ -477,7 +477,7 @@ AC_CHECK_FUNCS([process_vm_readv mremap])
 AS_IF([test "x$ac_cv_func_mremap" = "xno"],
       [AC_MSG_WARN([elf_update needs mremap to support ELF_C_RDWR_MMAP])])
 
-AC_CHECK_HEADERS([error.h])
+AC_CHECK_HEADER([error.h], [AC_CHECK_FUNC([error], AC_DEFINE([HAVE_ERROR_H], 
[1], [Define if error.h is usable]))])
 AC_CHECK_HEADERS([err.h])
 
 dnl for debuginfod concurrency heuristics
-- 
2.48.1

Reply via email to