[OpenJDK 2D-Dev] RFR: JDK-8196218: [linux] libfontmanager should be linked against headless awt library

Severin Gehwolf sgehwolf at redhat.com
Tue Jan 30 17:05:19 UTC 2018


On Tue, 2018-01-30 at 08:36 -0800, Erik Joelsson wrote:
> I found your job and it's all successful. Something is up with the 
> service though. I'm pinging the relevant people here.

Phil, Erik: Where should I push this to? jdk or client?

http://hg.openjdk.java.net/jdk/client/

or

http://hg.openjdk.java.net/jdk/jdk/

Thanks,
Severin

> /Erik
> 
> 
> On 2018-01-30 00:42, Severin Gehwolf wrote:
> > On Mon, 2018-01-29 at 12:09 -0800, Phil Race wrote:
> > > It looks OK but have you tried running it through the new build
> > > system
> > > discussed here ?
> > > http://mail.openjdk.java.net/pipermail/jdk-dev/2018-January/00056
> > > 6.html
> > 
> > Thanks. I've submitted it yesterday, yes. No response - via email -
> > so
> > far, though.
> > 
> > Cheers,
> > Severin
> > 
> > > -phil.
> > > 
> > > On 01/29/2018 10:53 AM, Severin Gehwolf wrote:
> > > > Hi Phil,
> > > > 
> > > > Are you OK with the latest webrev as well?
> > > > http://cr.openjdk.java.net/~sgehwolf/webrevs/JDK-8196218/webrev
> > > > .02/
> > > > 
> > > > Thanks,
> > > > Severin
> > > > 
> > > > On Mon, 2018-01-29 at 08:29 -0800, Erik Joelsson wrote:
> > > > > This looks good to me. Good catch on the dependency
> > > > > declaration further
> > > > > down. I don't see any reason this would need a sponsor,
> > > > > jdk/jdk should
> > > > > be open.
> > > > > 
> > > > > /Erik
> > > > > 
> > > > > 
> > > > > On 2018-01-29 01:39, Severin Gehwolf wrote:
> > > > > > Hi,
> > > > > > 
> > > > > > Updated webrev which removes the linker flags filtering.
> > > > > > Linking with
> > > > > > the awt lib is being kept. ldd confirmed what Erik found
> > > > > > out elsewhere:
> > > > > > 
> > > > > > $ find build/linux-x86_64-normal-server-release/images/jdk
> > > > > > -name libfontmanager.so
> > > > > > build/linux-x86_64-normal-server-
> > > > > > release/images/jdk/lib/libfontmanager.so
> > > > > > $ ldd build/linux-x86_64-normal-server-
> > > > > > release/images/jdk/lib/libfontmanager.so
> > > > > > ldd: warning: you do not have execution permission for
> > > > > > `build/linux-x86_64-normal-server-
> > > > > > release/images/jdk/lib/libfontmanager.so'
> > > > > > 	linux-vdso.so.1 (0x00007ffe13cc5000)
> > > > > > 	libfreetype.so.6 => /lib64/libfreetype.so.6
> > > > > > (0x00007fb58e204000)
> > > > > > 	libawt.so => /disk/openjdk/upstream-sources/openjdk-
> > > > > > hs/build/linux-x86_64-normal-server-
> > > > > > release/images/jdk/lib/libawt.so (0x00007fb58df34000)
> > > > > > 	libjava.so => /disk/openjdk/upstream-sources/openjdk-
> > > > > > hs/build/linux-x86_64-normal-server-
> > > > > > release/images/jdk/lib/libjava.so (0x00007fb58dd07000)
> > > > > > 	libjvm.so => not found
> > > > > > 	libawt_headless.so => /disk/openjdk/upstream-
> > > > > > sources/openjdk-hs/build/linux-x86_64-normal-server-
> > > > > > release/images/jdk/lib/libawt_headless.so
> > > > > > (0x00007fb58dafe000)
> > > > > > 	libstdc++.so.6 => /lib64/libstdc++.so.6
> > > > > > (0x00007fb58d778000)
> > > > > > 	libm.so.6 => /lib64/libm.so.6 (0x00007fb58d423000)
> > > > > > 	libc.so.6 => /lib64/libc.so.6 (0x00007fb58d040000)
> > > > > > 	libgcc_s.so.1 => /lib64/libgcc_s.so.1
> > > > > > (0x00007fb58ce29000)
> > > > > > 	libbz2.so.1 => /lib64/libbz2.so.1 (0x00007fb58cc18000)
> > > > > > 	libpng16.so.16 => /lib64/libpng16.so.16
> > > > > > (0x00007fb58c9e5000)
> > > > > > 	libz.so.1 => /lib64/libz.so.1 (0x00007fb58c7ce000)
> > > > > > 	libjvm.so => not found
> > > > > > 	libdl.so.2 => /lib64/libdl.so.2 (0x00007fb58c5ca000)
> > > > > > 	libjvm.so => not found
> > > > > > 	libverify.so => /disk/openjdk/upstream-sources/openjdk-
> > > > > > hs/build/linux-x86_64-normal-server-
> > > > > > release/images/jdk/lib/libverify.so (0x00007fb58c3bb000)
> > > > > > 	/lib64/ld-linux-x86-64.so.2 (0x00007fb58e74f000)
> > > > > > 	libjvm.so => not found
> > > > > > 	libjvm.so => not found
> > > > > > 
> > > > > > http://cr.openjdk.java.net/~sgehwolf/webrevs/JDK-8196218/we
> > > > > > brev.02/
> > > > > > 
> > > > > > How does this look?
> > > > > > 
> > > > > > Do I need an Oracle sponsor for this or can I push this to
> > > > > > jdk/jdk
> > > > > > myself.
> > > > > > 
> > > > > > Thanks,
> > > > > > Severin
> > > > > > 
> > > > > > On Fri, 2018-01-26 at 09:44 -0800, Phil Race wrote:
> > > > > > >     > I could not remove -lawt however.
> > > > > > > 
> > > > > > > Ah yes, Erik sent me the errors and yes there are some 2D
> > > > > > > functions that are
> > > > > > > defined in libawt that fontmanager needs for text
> > > > > > > rendering support, so
> > > > > > > we can't remove that.
> > > > > > > 
> > > > > > > libawt on these platforms with separate headless and xawt
> > > > > > > libraries
> > > > > > > could have
> > > > > > > more aptly be called lib2d .. since most of the true AWT
> > > > > > > functionality
> > > > > > > is in the xawt library.
> > > > > > > 
> > > > > > > 
> > > > > > > -phil.
> > > > > > > 
> > > > > > > On 01/26/2018 09:23 AM, Erik Joelsson wrote:
> > > > > > > > This patch builds on Solaris:
> > > > > > > > 
> > > > > > > > diff -r 50cd89fe209f make/lib/Awt2dLibraries.gmk
> > > > > > > > --- a/make/lib/Awt2dLibraries.gmk
> > > > > > > > +++ b/make/lib/Awt2dLibraries.gmk
> > > > > > > > @@ -683,15 +683,15 @@
> > > > > > > >             hidevf w_novirtualdescr arrowrtn2, \
> > > > > > > >         DISABLED_WARNINGS_microsoft := 4267 4244 4018
> > > > > > > > 4090 4996 4146 4334
> > > > > > > > 4819 4101, \
> > > > > > > >         MAPFILE := $(BUILD_LIBFONTMANAGER_MAPFILE), \
> > > > > > > > -    LDFLAGS := $(subst -Wl$(COMMA)-
> > > > > > > > z$(COMMA)defs,,$(LDFLAGS_JDKLIB))
> > > > > > > > $(LDFLAGS_CXX_JDK) \
> > > > > > > > +    LDFLAGS := $(LDFLAGS_JDKLIB) $(LDFLAGS_CXX_JDK) \
> > > > > > > >             $(call SET_SHARED_LIBRARY_ORIGIN), \
> > > > > > > >         LDFLAGS_unix := -L$(INSTALL_LIBRARIES_HERE), \
> > > > > > > >         LDFLAGS_macosx := -undefined dynamic_lookup, \
> > > > > > > >         LIBS := $(BUILD_LIBFONTMANAGER_FONTLIB), \
> > > > > > > >         LIBS_unix := -lawt -ljava -ljvm $(LIBM)
> > > > > > > > $(LIBCXX), \
> > > > > > > > -    LIBS_linux := -lc, \
> > > > > > > > +    LIBS_linux := -lawt_headless -lc, \
> > > > > > > >         LIBS_solaris := -lawt_headless -lc, \
> > > > > > > >         LIBS_aix := -lawt_headless,\
> > > > > > > > 
> > > > > > > > I could not remove -lawt however.
> > > > > > > > 
> > > > > > > > /Erik
> > > > > > > > 
> > > > > > > > On 2018-01-26 09:15, Erik Joelsson wrote:
> > > > > > > > > On 2018-01-26 09:02, Severin Gehwolf wrote:
> > > > > > > > > > On Fri, 2018-01-26 at 08:54 -0800, Erik Joelsson
> > > > > > > > > > wrote:
> > > > > > > > > > > On 2018-01-26 08:44, Phil Race wrote:
> > > > > > > > > > > > When this was fixed for Solaris
> > > > > > > > > > > > https://bugs.openjdk.java.net/browse/JDK-807171
> > > > > > > > > > > > 0
> > > > > > > > > > > > the observed problem was not building (although
> > > > > > > > > > > > it could have been)
> > > > > > > > > > > > but at runtime.
> > > > > > > > > > > > I think you can verify what you've done with
> > > > > > > > > > > > "ldd" ..
> > > > > > > > > > > > 
> > > > > > > > > > > > This patch adds awt_headless.so, but does not
> > > > > > > > > > > > remove awt.so.
> > > > > > > > > > > > 
> > > > > > > > > > > > Perhaps the line
> > > > > > > > > > > > 
> > > > > > > > > > > > LIBS_unix := -lawt -ljava -ljvm $(LIBM)
> > > > > > > > > > > > $(LIBCXX)
> > > > > > > > > > > > After your fix I expect "ldd" should not need
> > > > > > > > > > > > to show awt .. just
> > > > > > > > > > > > awt_headless
> > > > > > > > > > > > 
> > > > > > > > > > > > ie linux should not have this -lawt dependency
> > > > > > > > > > > > any more and the -lawt
> > > > > > > > > > > > dependency should be specific to windows + mac
> > > > > > > > > > > > ..
> > > > > > > > > > 
> > > > > > > > > > Thanks for the review, Phil. I'll post an updated
> > > > > > > > > > webrev shortly.
> > > > > > > > > > 
> > > > > > > > > > Any thoughts on the LDFLAGS filtering? Shouldn't
> > > > > > > > > > this only be done on
> > > > > > > > > > platforms that need it? solaris, linux, aix should
> > > > > > > > > > already be fine
> > > > > > > > > > without filtering.
> > > > > > > > > 
> > > > > > > > > I would say try removing the filtering. The affected
> > > > > > > > > flags are
> > > > > > > > > currently only set on linux and solaris. I will do a
> > > > > > > > > test build on
> > > > > > > > > the latter and see if the filtering is actually
> > > > > > > > > needed.
> > > > > > > > > 
> > > > > > > > > /Erik
> > > > > > > > > > Thanks,
> > > > > > > > > > Severin
> > > > > > > > > > 
> > > > > > > > > > > So we already use -lawt_headless on solaris and
> > > > > > > > > > > aix, then I really
> > > > > > > > > > > can't
> > > > > > > > > > > see a reason not to do the same for linux.
> > > > > > > > > > > > On 01/26/2018 08:10 AM, Severin Gehwolf wrote:
> > > > > > > > > > > > > Hi,
> > > > > > > > > > > > > 
> > > > > > > > > > > > > Could I please get a review for this rather
> > > > > > > > > > > > > small patch which
> > > > > > > > > > > > > originally occurred for us on JDK 8 (Fedora)
> > > > > > > > > > > > > which recently
> > > > > > > > > > > > > switched to
> > > > > > > > > > > > > building with "-Wl,-z,defs" linker flags. The
> > > > > > > > > > > > > result was a build
> > > > > > > > > > > > > failure, due to unresolved symbols. Indeed
> > > > > > > > > > > > > libfontmanager.so should
> > > > > > > > > > > > > have -lawt_headless in the list of dependent
> > > > > > > > > > > > > libs as symbols such as
> > > > > > > > > > > > > AWTLoadFont come from libawt_headless.so, not
> > > > > > > > > > > > > libawt.so on Linux.
> > > > > > > > > > > > > Some
> > > > > > > > > > > > > more details are on the bug.
> > > > > > > > > > > > > 
> > > > > > > > > > > > > webrev:
> > > > > > > > > > > > > http://cr.openjdk.java.net/~sgehwolf/webrevs/
> > > > > > > > > > > > > JDK-8196218/webrev.01/
> > > > > > > > > > > > > Bug: https://bugs.openjdk.java.net/browse/JDK
> > > > > > > > > > > > > -8196218
> > > > > > > > > > > > > 
> > > > > > > > > > > > > Testing: Build fails with configure option
> > > > > > > > > > > > >               --with-extra-ldflags="-Xlinker
> > > > > > > > > > > > > -z -Xlinker defs"
> > > > > > > > > > > > >               prior the fix. Succeeds after.
> > > > > > > > > > > > > 
> > > > > > > > > > > > > Question for 2d-folks/build-dev folks:
> > > > > > > > > > > > 
> > > > > > > > > > > > I don't know about this, build folks probably
> > > > > > > > > > > > know.
> > > > > > > > > > > > 
> > > > > > > > > > > 
> > > > > > > > > > > This is from way ahead of my time. The filtering
> > > > > > > > > > > is simply the
> > > > > > > > > > > build-infra way of achieving the same thing as in
> > > > > > > > > > > the old build
> > > > > > > > > > > system.
> > > > > > > > > > > Here is the corresponding code in jdk7:
> > > > > > > > > > > 
> > > > > > > > > > > $ hg annotate make/sun/font/Makefile
> > > > > > > > > > > ...
> > > > > > > > > > >         0: #
> > > > > > > > > > >         0: # Created without -z defs on linux
> > > > > > > > > > >         0: #
> > > > > > > > > > >         0: ifeq ($(PLATFORM), linux)
> > > > > > > > > > >         0:   LDFLAGS_DEFS_OPTION =
> > > > > > > > > > >         0: endif
> > > > > > > > > > > ...
> > > > > > > > > > > 
> > > > > > > > > > > /Erik
> > > > > > > > > > > 
> > > > > > > > > > > > -phil.
> > > > > > > > > > > > > There is this snippet in the libfontmanager
> > > > > > > > > > > > > block in
> > > > > > > > > > > > > make/lib/Awt2dLibraries.gmk, line 686:
> > > > > > > > > > > > > 
> > > > > > > > > > > > >          LDFLAGS := $(subst
> > > > > > > > > > > > > -Wl$(COMMA)-z$(COMMA)defs,,$(LDFLAGS_JDKLIB))
> > > > > > > > > > > > > $(LDFLAGS_CXX_JDK) \
> > > > > > > > > > > > >              $(call
> > > > > > > > > > > > > SET_SHARED_LIBRARY_ORIGIN), \
> > > > > > > > > > > > > 
> > > > > > > > > > > > > It's my understanding that this is supposed
> > > > > > > > > > > > > to filter "-Wl,-z,defs"
> > > > > > > > > > > > > from LDFLAGS_JDKLIB. Does anybody know why it
> > > > > > > > > > > > > does so? Is there a
> > > > > > > > > > > > > legit
> > > > > > > > > > > > > reason when unresolved symbols at link time
> > > > > > > > > > > > > are OK? Besides, why
> > > > > > > > > > > > > does
> > > > > > > > > > > > > it not also filter "-Xlinker -z -Xlinker
> > > > > > > > > > > > > defs"? FWIW, in JDK 8
> > > > > > > > > > > > > it's the
> > > > > > > > > > > > > other way round. Xlinker flags are filtered,
> > > > > > > > > > > > > but -Wl,-z,defs is not.
> > > > > > > > > > > > > Thoughts?
> > > > > > > > > > > > > 
> > > > > > > > > > > > > Thanks,
> > > > > > > > > > > > > Severin
> 
> 



More information about the build-dev mailing list