xref: /freebsd/sys/contrib/openzfs/lib/Makefile.am (revision a4e5e0106ac7145f56eb39a691e302cabb4635be)
16ba2210eSMartin Matuska#
26ba2210eSMartin Matuska# Shown below is a simplified dependency graph of the OpenZFS provided
36ba2210eSMartin Matuska# libraries.  Administrative commands (`zfs`, `zpool`, etc) interface with
46ba2210eSMartin Matuska# the kernel modules using the `libzfs.so` and `libzfs_core.so` libraries.
56ba2210eSMartin Matuska# These libraries provide a stable ABI across OpenZFS point releases.
66ba2210eSMartin Matuska#
76ba2210eSMartin Matuska# The `libzpool.so` library is a user space build of the DMU and SPA layers
86ba2210eSMartin Matuska# used to implement debugging tools (zdb) and code validation tools (ztest).
96ba2210eSMartin Matuska# These library interfaces are subject to change at any time.
106ba2210eSMartin Matuska#
116ba2210eSMartin Matuska#
12*a4e5e010SMartin Matuska# CMDS:   zhack/ztest/                zfs/zpool/zed/
136ba2210eSMartin Matuska#        raidz_{test,bench}          zinject/zstream
146ba2210eSMartin Matuska#                |                          |
156ba2210eSMartin Matuska# LIBS:          |                          |              libzfsbootenv*
16*a4e5e010SMartin Matuska#                |--libzdb--zdb             |                    |
176ba2210eSMartin Matuska#                |                          |                    |
186ba2210eSMartin Matuska#             libzpool                   libzfs* ----------------+
196ba2210eSMartin Matuska#             | | |  \                  / | | |
206ba2210eSMartin Matuska#    libicp --/ | |   \                /  | | \------- libshare
216ba2210eSMartin Matuska#               | |    \              /   | |
226ba2210eSMartin Matuska#    libzstd ---/ |     \            /    | \--------- libuutil
236ba2210eSMartin Matuska#                 |      \          /     \              | |
246ba2210eSMartin Matuska#    libunicode --/       \        /       \             | |
256ba2210eSMartin Matuska#                          \      /         \            | |
266ba2210eSMartin Matuska#                          libzutil        libzfs_core*  | |
276ba2210eSMartin Matuska#                          | | | | \          |     |    | |
286ba2210eSMartin Matuska#                          | | | | |          |     |    | |
296ba2210eSMartin Matuska#                          | | | | |          |     |    | |
306ba2210eSMartin Matuska#    libtpool -------------/ | | | \---- libnvpair* |    | |
316ba2210eSMartin Matuska#                            | | |                  |    | |
326ba2210eSMartin Matuska#    libefi -----------------/ | \------ libavl* --------/ |
336ba2210eSMartin Matuska#                              |                    |      |
346ba2210eSMartin Matuska#                              \-------- libspl ----+------/
356ba2210eSMartin Matuska#
366ba2210eSMartin Matuska#
37eda14cbcSMatt Macy# NB: GNU Automake Manual, Chapter 8.3.5: Libtool Convenience Libraries
38eda14cbcSMatt Macy# These nine libraries are intermediary build components.
396ba2210eSMartin Matuska#
40716fd348SMartin Matuska# * - A stable ABI is provided for these libraries;
41716fd348SMartin Matuska# when performing an ABI check the following options are applied:
42716fd348SMartin Matuska#
43716fd348SMartin Matuska# --no-unreferenced-symbols: Exclude symbols which are not referenced by
44716fd348SMartin Matuska# any debug information.  Without this _init() and _fini() are incorrectly
45716fd348SMartin Matuska# reported on CentOS7 for libuutil.so.
46716fd348SMartin Matuska#
47716fd348SMartin Matuska# --headers-dir1: Limit ABI checks to public OpenZFS headers, otherwise
48716fd348SMartin Matuska# changes in public system headers are also reported.
49716fd348SMartin Matuska#
50716fd348SMartin Matuska# --suppressions: Honor a suppressions file for each library to provide
51716fd348SMartin Matuska# a mechanism for suppressing harmless warnings.
52716fd348SMartin Matuska#
53eda14cbcSMatt Macy
54716fd348SMartin Matuskanoinst_LTLIBRARIES =
55716fd348SMartin Matuskalib_LTLIBRARIES =
56716fd348SMartin Matuskapkgconfig_DATA =
57716fd348SMartin Matuskainclude $(srcdir)/%D%/libavl/Makefile.am
58716fd348SMartin Matuskainclude $(srcdir)/%D%/libicp/Makefile.am
59716fd348SMartin Matuskainclude $(srcdir)/%D%/libnvpair/Makefile.am
60716fd348SMartin Matuskainclude $(srcdir)/%D%/libshare/Makefile.am
61716fd348SMartin Matuskainclude $(srcdir)/%D%/libspl/Makefile.am
62716fd348SMartin Matuskainclude $(srcdir)/%D%/libtpool/Makefile.am
63716fd348SMartin Matuskainclude $(srcdir)/%D%/libunicode/Makefile.am
64716fd348SMartin Matuskainclude $(srcdir)/%D%/libuutil/Makefile.am
65*a4e5e010SMartin Matuskainclude $(srcdir)/%D%/libzdb/Makefile.am
66716fd348SMartin Matuskainclude $(srcdir)/%D%/libzfs_core/Makefile.am
67716fd348SMartin Matuskainclude $(srcdir)/%D%/libzfs/Makefile.am
68716fd348SMartin Matuskainclude $(srcdir)/%D%/libzfsbootenv/Makefile.am
69716fd348SMartin Matuskainclude $(srcdir)/%D%/libzpool/Makefile.am
70716fd348SMartin Matuskainclude $(srcdir)/%D%/libzstd/Makefile.am
71716fd348SMartin Matuskainclude $(srcdir)/%D%/libzutil/Makefile.am
72eda14cbcSMatt Macyif BUILD_LINUX
73716fd348SMartin Matuskainclude $(srcdir)/%D%/libefi/Makefile.am
74eda14cbcSMatt Macyendif
75eda14cbcSMatt Macy
762c48331dSMatt Macy
77716fd348SMartin MatuskaPHONY += lib
78716fd348SMartin Matuskalib: $(noinst_LTLIBRARIES) $(lib_LTLIBRARIES)
79eda14cbcSMatt Macy
807877fdebSMatt Macy
81716fd348SMartin MatuskaPHONY += checkabi storeabi check_libabi_version allow_libabi_only_for_x86_64
827877fdebSMatt Macy
83716fd348SMartin Matuskacheck_libabi_version:
84716fd348SMartin Matuska	if [ $$(abidw -v | $(SED) 's/[^0-9]//g') -lt 200 ]; then \
85716fd348SMartin Matuska		printf '%s\n' "" \
86716fd348SMartin Matuska		    "*** Please use libabigail 2.0.0 version or newer;" \
87716fd348SMartin Matuska		    "*** otherwise results are not consistent!" \
88716fd348SMartin Matuska		    "(or see https://github.com/openzfs/libabigail-docker)"; \
89716fd348SMartin Matuska		exit 1; \
90716fd348SMartin Matuska	fi
91716fd348SMartin Matuska
92716fd348SMartin Matuskaallow_libabi_only_for_x86_64:
93716fd348SMartin Matuska	echo '*** ABI definitions provided apply only to x86_64:'
94716fd348SMartin Matuska	echo '*** not checking or storing ABI and assuming success.'
95716fd348SMartin Matuska
96716fd348SMartin Matuskaif TARGET_CPU_X86_64
97716fd348SMartin Matuska# These should depend on $(lib_LTLIBRARIES), but this breaks on CI when bound into Docker
98716fd348SMartin Matuskacheckabi: check_libabi_version
99716fd348SMartin Matuska	err=0; \
100716fd348SMartin Matuska	for lib in $(lib_LTLIBRARIES); do \
101716fd348SMartin Matuska		lib=$${lib%.la}; \
102716fd348SMartin Matuska		[ -f $(srcdir)/lib/$$lib/$$lib.suppr ] || continue; \
103716fd348SMartin Matuska		echo $$lib:; \
104716fd348SMartin Matuska		abidiff --no-unreferenced-symbols \
105716fd348SMartin Matuska		    --headers-dir1 include \
106716fd348SMartin Matuska		    --suppressions $(srcdir)/lib/$$lib/$$lib.suppr \
107716fd348SMartin Matuska		    $(srcdir)/lib/$$lib/$$lib.abi .libs/$$lib.so || err=$$((err + 1)); \
108716fd348SMartin Matuska	done; \
109716fd348SMartin Matuska	exit $$err
110716fd348SMartin Matuska
111716fd348SMartin Matuskastoreabi: check_libabi_version
112716fd348SMartin Matuska	for lib in $(lib_LTLIBRARIES); do \
113716fd348SMartin Matuska		lib=$${lib%.la}; \
114716fd348SMartin Matuska		[ -f $(srcdir)/lib/$$lib/$$lib.suppr ] || continue; \
115716fd348SMartin Matuska		abidw --no-show-locs \
116716fd348SMartin Matuska		    --no-corpus-path \
117716fd348SMartin Matuska		    --no-comp-dir-path \
118716fd348SMartin Matuska		    --type-id-style hash \
119716fd348SMartin Matuska		    .libs/$$lib.so > $(srcdir)/lib/$$lib/$$lib.abi; \
1207877fdebSMatt Macy	done
121716fd348SMartin Matuskaelse
122716fd348SMartin Matuskacheckabi: allow_libabi_only_for_x86_64
123716fd348SMartin Matuskastoreabi: allow_libabi_only_for_x86_64
124716fd348SMartin Matuskaendif
125