mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-12-25 05:48:07 -05:00
1a244b7814
* gnu/packages/patches/p11-kit-hurd.patch: New file. * gnu/local.mk (dist_patch_DATA): Add it. * gnu/packages/tls.scm (p11-kit)[native-inputs]: Add autoconf, automake, gettext and libtool when targeting Hurd. [inputs]: Add libbsd and hurd-patch when targeting hurd. [arguments]: Add 'apply-hurd-patch and 'bootstrap phases when targeting Hurd.
46 lines
No EOL
1.1 KiB
Diff
46 lines
No EOL
1.1 KiB
Diff
Taken from: https://groups.google.com/g/linux.debian.bugs.dist/c/mX4GpUJih4k.
|
|
|
|
--- a/configure.ac
|
|
+++ b/configure.ac
|
|
@@ -132,6 +132,16 @@ if test "$os_unix" = "yes"; then
|
|
AC_CHECK_FUNCS([getpeereid])
|
|
AC_CHECK_FUNCS([getpeerucred])
|
|
AC_CHECK_FUNCS([issetugid])
|
|
+ case "$host_os" in
|
|
+ kfreebsd*-gnu | gnu*)
|
|
+ have_getpeereid=no
|
|
+ AC_CHECK_LIB(bsd, getpeereid, have_getpeereid=yes)
|
|
+ if test "x$have_getpeereid" = "xyes"; then
|
|
+ AC_DEFINE([HAVE_GETPEEREID], [1], [have getpeereid])
|
|
+ AC_SEARCH_LIBS([getpeereid], [bsd])
|
|
+ fi
|
|
+ ;;
|
|
+ esac
|
|
|
|
AC_CACHE_CHECK([for thread-local storage class],
|
|
[ac_cv_tls_keyword],
|
|
|
|
--- a/common/unix-peer.c
|
|
+++ b/common/unix-peer.c
|
|
@@ -47,6 +47,11 @@
|
|
# include <ucred.h>
|
|
#endif
|
|
|
|
+#ifdef HAVE_GETPEEREID
|
|
+/* Declare getpeereid from /usr/include/bsd/unistd.h */
|
|
+extern int getpeereid(int s, uid_t *euid, gid_t *egid);
|
|
+#endif
|
|
+
|
|
/* Returns the unix domain socket peer information.
|
|
* Returns zero on success.
|
|
*/
|
|
@@ -73,7 +78,8 @@ p11_get_upeer_id (int cfd, uid_t *uid, u
|
|
*pid = cr.pid;
|
|
|
|
#elif defined(HAVE_GETPEEREID)
|
|
- /* *BSD/MacOSX */
|
|
+ /* *BSD/MacOSX/kFreeBSD/Hurd */
|
|
+
|
|
uid_t euid;
|
|
gid_t egid;
|
|
|