2010-08-26 11:22:58 -07:00
|
|
|
include $(top_srcdir)/config/Rules.am
|
|
|
|
|
2018-01-10 10:49:27 -08:00
|
|
|
# Get rid of compiler warning for unchecked truncating snprintfs on gcc 7.1.1
|
|
|
|
AM_CFLAGS += $(NO_FORMAT_TRUNCATION)
|
|
|
|
|
|
|
|
# Includes kernel code, generate warnings for large stack frames
|
|
|
|
AM_CFLAGS += $(FRAME_LARGER_THAN)
|
|
|
|
|
|
|
|
# Unconditionally enable ASSERTs
|
2017-09-13 14:48:05 -04:00
|
|
|
AM_CPPFLAGS += -DDEBUG -UNDEBUG
|
2010-08-26 11:22:58 -07:00
|
|
|
|
|
|
|
DEFAULT_INCLUDES += \
|
2010-09-04 13:26:23 -07:00
|
|
|
-I$(top_srcdir)/include \
|
|
|
|
-I$(top_srcdir)/lib/libspl/include
|
2010-08-26 11:22:58 -07:00
|
|
|
|
|
|
|
sbin_PROGRAMS = ztest
|
|
|
|
|
|
|
|
ztest_SOURCES = \
|
2014-06-09 23:55:31 +02:00
|
|
|
ztest.c
|
2010-08-26 11:22:58 -07:00
|
|
|
|
|
|
|
ztest_LDADD = \
|
|
|
|
$(top_builddir)/lib/libnvpair/libnvpair.la \
|
2013-11-17 11:47:50 +01:00
|
|
|
$(top_builddir)/lib/libzfs/libzfs.la \
|
2017-08-09 15:31:08 -07:00
|
|
|
$(top_builddir)/lib/libzpool/libzpool.la
|
2010-08-26 11:22:58 -07:00
|
|
|
|
Cleanup linking
I noticed during code review of zfsonlinux/zfs#4385 that the author of a
commit had peppered the various Makefile.am files with `$(TIRPC_LIBS)`
when putting it into `lib/libspl/Makefile.am` should have sufficed. Upon
further examination, it seems that he had copied what we do with
`$(ZLIB)`. We also have a bit of that with `-ldl` too. Unfortunately,
what we do is wrong, so lets fix it to set a good example for future
contributors.
In addition, we have multiple `-lz` and `-luuid` passed to the compiler
because each `AC_CHECK_LIB` adds it to `$LIBS`. That is somewhat
annoying to see, so we switch to `AC_SEARCH_LIBS` to avoid it. This is
consistent with the recommendation to use `AC_SEARCH_LIBS` over
`AC_CHECK_LIB` by autotools upstream:
https://www.gnu.org/software/autoconf/manual/autoconf-2.66/html_node/Libraries.html
In an ideal world, this would translate into improvements in ELF's
`DT_NEEDED` entries, but that is not the case because of a couple of
bugs in libtool.
The first bug causes libtool to overlink by using static link
dependencies for dynamic linking:
https://wiki.mageia.org/en/Overlinking_issues_in_packaging#libtool_issues
The workaround for this should be to pass `-Wl,--as-needed` in
`LDFLAGS`. That leads us to the second bug, where libtool passes
`LDFLAGS` after the libraries are specified and `ld` will only honor
`--as-needed` on libraries specified before it:
https://sigquit.wordpress.com/2011/02/16/why-asneeded-doesnt-work-as-expected-for-your-libraries-on-your-autotools-project/
There are a few possible workarounds for the second bug. One is to
either patch the compiler spec file to specify `-Wl,--as-needed` or pass
`-Wl,--as-needed` via `CC` like `CC='gcc -Wl,--as-needed'` so that it is
specified early. Another is to patch ltmain.sh like Gentoo does:
https://gitweb.gentoo.org/repo/gentoo.git/tree/eclass/ELT-patches/as-needed
Without one of those workarounds, this cleanup provides no benefit in
terms of `DT_NEEDED` entry generation. It should still be an improvement
because it nicely simplifies the code while encouraging good habits when
patching autotools scripts.
Signed-off-by: Richard Yao <ryao@gentoo.org>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #4426
2016-03-15 13:28:07 -04:00
|
|
|
ztest_LDADD += -lm
|
2017-08-09 15:31:08 -07:00
|
|
|
ztest_LDFLAGS = -pthread
|