summaryrefslogtreecommitdiffstats
path: root/config/user-libtirpc.m4
diff options
context:
space:
mode:
authorBrian Behlendorf <[email protected]>2016-04-26 17:24:41 -0700
committerBrian Behlendorf <[email protected]>2016-04-28 09:27:40 -0700
commit1ab3678b5d671b4561a2d63958d56b2f7ca1b69e (patch)
tree9b7574024aed4a38e2d0e699f7a4361656ddc6bf /config/user-libtirpc.m4
parent463a8cfe2b293934edd2ee79115b20c4598353d6 (diff)
Add support for libtirpc
While OpenSolaris libc and glibc both include XDR support, the musl libc does not in favor of depending on the BSD-licensed libtirpc library. Adding support is a simple matter of detecting the library, including the headers and linking against it. By default libtirpc will be checked for and if available used. Otherwise, configure will fall back to using the xdr implementation provided by libc if available. The options --with-tirpc/--without-tirpc can be used to disable this checking. In addition, the xdr_control() function has been simplied to only handle ZFSs specific use case. Original-patch-by: stf <[email protected]> Original-patch-by: Richard Yao <[email protected]> Signed-off-by: Brian Behlendorf <[email protected]> Signed-off-by: Signed-off-by: Carlo Landmeter <[email protected]> Closes #2254 Closes #4559
Diffstat (limited to 'config/user-libtirpc.m4')
-rw-r--r--config/user-libtirpc.m430
1 files changed, 30 insertions, 0 deletions
diff --git a/config/user-libtirpc.m4 b/config/user-libtirpc.m4
new file mode 100644
index 000000000..5f929061f
--- /dev/null
+++ b/config/user-libtirpc.m4
@@ -0,0 +1,30 @@
+dnl #
+dnl # Check for libtirpc - may be needed for xdr functionality
+dnl #
+AC_DEFUN([ZFS_AC_CONFIG_USER_LIBTIRPC], [
+ AC_ARG_WITH([tirpc],
+ [AS_HELP_STRING([--with-tirpc],
+ [use tirpc for xdr encoding @<:@default=check@:>@])],
+ [],
+ [with_tirpc=check])
+
+ LIBTIRPC=
+ LIBTIRPC_CFLAGS=
+
+ AS_IF([test "x$with_tirpc" != xno],
+ [AC_CHECK_LIB([tirpc], [xdrmem_create],
+ [AC_SUBST([LIBTIRPC], [-ltirpc])
+ AC_SUBST([LIBTIRPC_CFLAGS], [-I/usr/include/tirpc])
+ AC_DEFINE([HAVE_LIBTIRPC], [1], [Define if you have libtirpc])
+ ],
+ [if test "x$with_tirpc" != xcheck; then
+ AC_MSG_FAILURE(
+ [--with-tirpc was given, but test for tirpc failed])
+ fi
+ AC_SEARCH_LIBS([xdrmem_create], [tirpc], [], [
+ AC_MSG_FAILURE([xdrmem_create() requires tirpc or libc])])
+ ])],
+ [AC_SEARCH_LIBS([xdrmem_create], [tirpc], [], [
+ AC_MSG_FAILURE([xdrmem_create() requires libc])])
+ ])
+])