[8u] 8226392: Launcher should not enable legacy stdio streams on GNU/Linux (glibc)
Andrew John Hughes
gnu.andrew at redhat.com
Mon Jun 24 14:13:29 UTC 2019
On 24/06/2019 14:48, Severin Gehwolf wrote:
> Hi,
>
> Could I please get reviews for this 8u only change? The JDK 8u build
> logic for launcher files includes linker version script files (a.k.a
> mapfiles). The script file for x86 (32bit) marks symbol _IO_stdin_used
> as local. When the symbol is not visible to the dynamic loader, glibc
> will use a legacy stdio implementation instead. This is a historic, x86
> (32bit) only glibc issue, I've been told.
>
> The suggested fix is to mark _IO_stdin_used as global in the linker
> version script on x86 (32bit) so that the non-legacy implementation of
> stdio will be used for launcher files of OpenJDK 8u.
>
> Bug: https://bugs.openjdk.java.net/browse/JDK-8226392
> webrev: http://cr.openjdk.java.net/~sgehwolf/webrevs/JDK-8226392/01/webrev/
>
> Testing: "eu-readelf --symbols=.dynsym /path/to/java | grep _IO". I.e. manual
> on a x86 build.
>
> Note that JDK 11+ have _IO_stin_used visible already.
>
> I can add the same to other arches map files if that's preferred (it
> should be harmless). For now, I've opted to add it to x86 only where we
> know this is a problem.
>
> Thanks,
> Severin
>
Looks good.
Please flag the bug with jdk8u-fix-request to request approval.
Thanks,
--
Andrew :)
Senior Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)
PGP Key: ed25519/0xCFDA0F9B35964222 (hkp://keys.gnupg.net)
Fingerprint = 5132 579D D154 0ED2 3E04 C5A0 CFDA 0F9B 3596 4222
https://keybase.io/gnu_andrew
More information about the jdk8u-dev
mailing list