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