diff options
| author | Kaleb S. KEITHLEY <kkeithle@redhat.com> | 2015-07-31 14:11:15 -0400 | 
|---|---|---|
| committer | Niels de Vos <ndevos@redhat.com> | 2015-09-24 07:37:42 -0700 | 
| commit | 1d82db506d1cd5b20d14820d89033de2e4a14210 (patch) | |
| tree | b4bc67f988b054d5e738884a91ce18c48244161a /xlators/features/bit-rot | |
| parent | 84367f0c9106f5a604ac05a02898d4521fa5c832 (diff) | |
build: export minimum symbols from xlators for correct resolution
We've been lucky that we haven't had any symbol collisions until now.
Now we have a collision between the snapview-client's svc_lookup() and
libntirpc's svc_lookup() with nfs-ganesha's FSAL_GLUSTER and libgfapi.
As a short term solution all the snapview-client's FOP methods were
changed to static scope. See http://review.gluster.org/11805. This
works in snapview-client because all the FOP methods are defined in
a single source file. This solution doesn't work for other xlators
with FOP methods defined in multiple source files.
To address this we link with libtool's '-export-symbols $symbol-file'
(a wrapper around `ld --version-script ...` --- on linux anyway) and
only export the minimum required symbols from the xlator sharedlib.
N.B. the libtool man page says that the symbol file should be named
foo.sym, thus the rename of *.exports to *.sym. While foo.exports
worked, we will follow the documentation.
Signed-off-by: Kaleb S. KEITHLEY <kkeithle@redhat.com>
BUG: 1248669
Change-Id: I1de68b3e3be58ae690d8bfb2168bfc019983627c
Reviewed-on: http://review.gluster.org/11814
Tested-by: NetBSD Build System <jenkins@build.gluster.org>
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: soumya k <skoduri@redhat.com>
Reviewed-by: Niels de Vos <ndevos@redhat.com>
Diffstat (limited to 'xlators/features/bit-rot')
| -rw-r--r-- | xlators/features/bit-rot/src/bitd/Makefile.am | 2 | ||||
| -rw-r--r-- | xlators/features/bit-rot/src/stub/Makefile.am | 2 | 
2 files changed, 2 insertions, 2 deletions
| diff --git a/xlators/features/bit-rot/src/bitd/Makefile.am b/xlators/features/bit-rot/src/bitd/Makefile.am index f06cf9eeaaa..b338d3cdd8f 100644 --- a/xlators/features/bit-rot/src/bitd/Makefile.am +++ b/xlators/features/bit-rot/src/bitd/Makefile.am @@ -1,7 +1,7 @@  xlator_LTLIBRARIES = bit-rot.la  xlatordir = $(libdir)/glusterfs/$(PACKAGE_VERSION)/xlator/features -bit_rot_la_LDFLAGS = -module -avoid-version +bit_rot_la_LDFLAGS = $(GF_XLATOR_DEFAULT_LDFLAGS)  AM_CPPFLAGS = $(GF_CPPFLAGS) -I$(top_srcdir)/libglusterfs/src \  		 -I$(top_srcdir)/rpc/xdr/src/ \ diff --git a/xlators/features/bit-rot/src/stub/Makefile.am b/xlators/features/bit-rot/src/stub/Makefile.am index 30e7ca72cb6..5b5253c4ad5 100644 --- a/xlators/features/bit-rot/src/stub/Makefile.am +++ b/xlators/features/bit-rot/src/stub/Makefile.am @@ -1,7 +1,7 @@  xlator_LTLIBRARIES = bitrot-stub.la  xlatordir = $(libdir)/glusterfs/$(PACKAGE_VERSION)/xlator/features -bitrot_stub_la_LDFLAGS = -module -avoid-version +bitrot_stub_la_LDFLAGS = $(GF_XLATOR_DEFAULT_LDFLAGS)  bitrot_stub_la_SOURCES = bit-rot-stub.c  bitrot_stub_la_LIBADD = $(top_builddir)/libglusterfs/src/libglusterfs.la | 
