# HG changeset patch # User andrew # Date 1584325203 0 # Mon Mar 16 02:20:03 2020 +0000 # Node ID f51349214262b9759ee735ba8e48f939f0dc1752 # Parent 8b460560248c95d54fcd558179103e9efa50ff43 # Parent 83bbe56ecea176ca716f0990ffcd9af5d4c3738e Merge jdk8u252-b06 diff --git a/.hgtags b/.hgtags --- a/.hgtags +++ b/.hgtags @@ -1203,3 +1203,4 @@ c4cd14a9f1037d9d3131a686c2f5dfb39d1772f3 aarch64-shenandoah-jdk8u252-b04 b959971e0a5a609453c3a122755fc987c36f0566 jdk8u252-b05 54226283cd89a1058ea9b41ad5ddabf6996a33e1 aarch64-shenandoah-jdk8u252-b05 +6f7370a85071d54772615abab532264dba461c51 jdk8u252-b06 diff --git a/src/share/classes/java/lang/ClassLoader.java b/src/share/classes/java/lang/ClassLoader.java --- a/src/share/classes/java/lang/ClassLoader.java +++ b/src/share/classes/java/lang/ClassLoader.java @@ -1,6 +1,5 @@ /* * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2019, Azul Systems, Inc. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1468,17 +1467,6 @@ } } - /* - * Initialize default paths for native libraries search. - * Must be done early as JDK may load libraries during bootstrap. - * - * @see java.lang.System#initPhase1 - */ - static void initLibraryPaths() { - usr_paths = initializePath("java.library.path"); - sys_paths = initializePath("sun.boot.library.path"); - } - // Returns true if the specified class loader can be found in this class // loader's delegation chain. boolean isAncestor(ClassLoader cl) { @@ -1821,9 +1809,10 @@ boolean isAbsolute) { ClassLoader loader = (fromClass == null) ? null : fromClass.getClassLoader(); - assert sys_paths != null : "should be initialized at this point"; - assert usr_paths != null : "should be initialized at this point"; - + if (sys_paths == null) { + usr_paths = initializePath("java.library.path"); + sys_paths = initializePath("sun.boot.library.path"); + } if (isAbsolute) { if (loadLibrary0(fromClass, new File(name))) { return; @@ -1913,14 +1902,13 @@ name + " already loaded in another classloader"); } - /* - * When a library is being loaded, JNI_OnLoad function can cause - * another loadLibrary invocation that should succeed. + /* If the library is being loaded (must be by the same thread, + * because Runtime.load and Runtime.loadLibrary are + * synchronous). The reason is can occur is that the JNI_OnLoad + * function can cause another loadLibrary invocation. * - * We use a static stack to hold the list of libraries we are - * loading because this can happen only when called by the - * same thread because Runtime.load and Runtime.loadLibrary - * are synchronous. + * Thus we can use a static stack to hold the list of libraries + * we are loading. * * If there is a pending load operation for the library, we * immediately return success; otherwise, we raise diff --git a/src/share/classes/java/lang/Runtime.java b/src/share/classes/java/lang/Runtime.java --- a/src/share/classes/java/lang/Runtime.java +++ b/src/share/classes/java/lang/Runtime.java @@ -1,6 +1,5 @@ /* * Copyright (c) 1995, 2013, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2019, Azul Systems, Inc. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -798,7 +797,7 @@ load0(Reflection.getCallerClass(), filename); } - void load0(Class<?> fromClass, String filename) { + synchronized void load0(Class<?> fromClass, String filename) { SecurityManager security = System.getSecurityManager(); if (security != null) { security.checkLink(filename); @@ -859,14 +858,14 @@ loadLibrary0(Reflection.getCallerClass(), libname); } - void loadLibrary0(Class<?> fromClass, String libname) { + synchronized void loadLibrary0(Class<?> fromClass, String libname) { SecurityManager security = System.getSecurityManager(); if (security != null) { security.checkLink(libname); } if (libname.indexOf((int)File.separatorChar) != -1) { throw new UnsatisfiedLinkError( - "Directory separator should not appear in library name: " + libname); + "Directory separator should not appear in library name: " + libname); } ClassLoader.loadLibrary(fromClass, libname, false); } diff --git a/src/share/classes/java/lang/System.java b/src/share/classes/java/lang/System.java --- a/src/share/classes/java/lang/System.java +++ b/src/share/classes/java/lang/System.java @@ -1195,8 +1195,6 @@ setOut0(newPrintStream(fdOut, props.getProperty("sun.stdout.encoding"))); setErr0(newPrintStream(fdErr, props.getProperty("sun.stderr.encoding"))); - ClassLoader.initLibraryPaths(); - // Load the zip library now in order to keep java.util.zip.ZipFile // from trying to use itself to load this library later. loadLibrary("zip"); diff --git a/src/share/classes/javax/swing/text/html/ImageView.java b/src/share/classes/javax/swing/text/html/ImageView.java --- a/src/share/classes/javax/swing/text/html/ImageView.java +++ b/src/share/classes/javax/swing/text/html/ImageView.java @@ -741,11 +741,18 @@ appropriately. */ if (getLoadsSynchronously()) { - Dimension d = adjustWidthHeight(image.getWidth(imageObserver), - image.getHeight(imageObserver)); - newWidth = d.width; - newHeight = d.height; - newState |= (WIDTH_FLAG | HEIGHT_FLAG); + Image img; + synchronized(this) { + img = image; + } + int w = img.getWidth(imageObserver); + int h = img.getHeight(imageObserver); + if (w > 0 && h > 0) { + Dimension d = adjustWidthHeight(w, h); + newWidth = d.width; + newHeight = d.height; + newState |= (WIDTH_FLAG | HEIGHT_FLAG); + } } // Make sure the image starts loading: diff --git a/test/java/lang/Runtime/loadLibrary/LoadLibraryTest.java b/test/java/lang/Runtime/loadLibrary/LoadLibraryTest.java deleted file mode 100644 --- a/test/java/lang/Runtime/loadLibrary/LoadLibraryTest.java +++ /dev/null @@ -1,156 +0,0 @@ -/* - * Copyright (c) 2018, Amazon and/or its affiliates. All rights reserved. - * Copyright (c) 2019, Azul Systems, Inc. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * @test - * @bug 8231584 - * @library /lib/testlibrary - * @run main/othervm LoadLibraryTest - */ - -import java.nio.file.FileSystems; -import java.nio.file.Files; -import java.nio.file.Paths; -import java.nio.file.Path; -import java.net.MalformedURLException; -import java.net.URLClassLoader; -import java.net.URL; - -public class LoadLibraryTest { - static Thread thread1 = null; - static Thread thread2 = null; - - static volatile boolean thread1Ready = false; - - private static final String TEST_SRC = System.getProperty("test.src"); - private static final Path SRC_DIR = Paths.get(TEST_SRC, "src"); - private static final Path CLS_DIR = Paths.get("classes"); - - static TestClassLoader loader; - static void someLibLoad() { - try { -/* - FileSystems.getDefault(); - - // jdk/jdk: loads directly from Bootstrap Classloader (doesn't take lock on Runtime) - java.net.NetworkInterface.getNetworkInterfaces(); - - System.out.println(jdk.net.ExtendedSocketOptions.SO_FLOW_SLA); -*/ - Class c = Class.forName("Target2", true, loader); - } catch (Exception e) { - throw new RuntimeException(e); - } - } - - static class TestClassLoader extends URLClassLoader { - boolean passed = false; - - public boolean passed() { - return passed; - } - - TestClassLoader() throws MalformedURLException { - super(new URL[] { new URL("file://" + CLS_DIR.toAbsolutePath().toString() + '/') }); - } - - public String findLibrary(String name) { - System.out.println("findLibrary " + name); - - if ("someLibrary".equals(name)) { - try { - synchronized(thread1) { - while(!thread1Ready) { - thread1.wait(); - } - thread1.notifyAll(); - } - - Thread.sleep(10000); - - System.out.println("Thread2 load"); - someLibLoad(); - - // no deadlock happened - passed = true; - } catch (Exception e) { - throw new RuntimeException(e); - } - return null; - } - - return super.findLibrary(name); - } - } - - - public static void main(String[] args) throws Exception { - loader = new TestClassLoader(); - - if (!CompilerUtils.compile(SRC_DIR, CLS_DIR)) { - throw new Exception("Can't compile"); - } - - thread1 = new Thread() { - public void run() { - try { - synchronized(this) { - thread1Ready = true; - thread1.notifyAll(); - thread1.wait(); - } - } catch(InterruptedException e) { - throw new RuntimeException(e); - } - - System.out.println("Thread1 load"); - someLibLoad(); - }; - }; - - thread2 = new Thread() { - public void run() { - try { - Class c = Class.forName("Target", true, loader); - System.out.println(c); - } catch (Exception e) { - throw new RuntimeException(e); - } - }; - }; - - thread1.setDaemon(true); - thread2.setDaemon(true); - - thread1.start(); - thread2.start(); - - thread1.join(); - thread2.join(); - - if (!loader.passed()) { - throw new RuntimeException("FAIL"); - } - } -} diff --git a/test/java/lang/Runtime/loadLibrary/src/Target.java b/test/java/lang/Runtime/loadLibrary/src/Target.java deleted file mode 100644 --- a/test/java/lang/Runtime/loadLibrary/src/Target.java +++ /dev/null @@ -1,34 +0,0 @@ -/* - * Copyright (c) 2019, Azul Systems, Inc. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -class Target { - static { - try { - System.loadLibrary("someLibrary"); - throw new RuntimeException("someLibrary was loaded"); - } catch (UnsatisfiedLinkError e) { - // expected: we do not have a someLibrary - } - } -} - diff --git a/test/java/lang/Runtime/loadLibrary/src/Target2.java b/test/java/lang/Runtime/loadLibrary/src/Target2.java deleted file mode 100644 --- a/test/java/lang/Runtime/loadLibrary/src/Target2.java +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Copyright (c) 2019, Azul Systems, Inc. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -class Target2 { - static { - System.loadLibrary("awt"); - } -} - diff --git a/test/javax/swing/text/html/TestJLabelWithHTMLText.java b/test/javax/swing/text/html/TestJLabelWithHTMLText.java new file mode 100644 --- /dev/null +++ b/test/javax/swing/text/html/TestJLabelWithHTMLText.java @@ -0,0 +1,51 @@ +/* + * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/** + * @test + * @bug 8230235 8235744 + * @summary Tests if JLabel with HTML text having empty img tag and + * documentBaseKey set renders properly without NPE + * @run main TestJLabelWithHTMLText + */ +import java.net.MalformedURLException; +import java.net.URL; +import javax.swing.JLabel; +import javax.swing.SwingUtilities; +import javax.swing.plaf.basic.BasicHTML; + +public class TestJLabelWithHTMLText { + + public static void main(String[] args) throws Exception { + SwingUtilities.invokeAndWait(() -> { + JLabel label = new JLabel(); + try { + label.putClientProperty(BasicHTML.documentBaseKey, + new URL("http://localhost")); + } catch (MalformedURLException e) { + e.printStackTrace(); + } + label.setText("<html><img src=''></html>"); + }); + } +} diff --git a/test/sun/security/lib/cacerts/VerifyCACerts.java b/test/sun/security/lib/cacerts/VerifyCACerts.java --- a/test/sun/security/lib/cacerts/VerifyCACerts.java +++ b/test/sun/security/lib/cacerts/VerifyCACerts.java @@ -262,6 +262,12 @@ add("utnuserfirstobjectca [jdk]"); // Valid until: Tue May 26 00:00:00 GMT 2020 add("keynectisrootca [jdk]"); + // Valid until: Sat May 30 10:38:31 GMT 2020 + add("addtrustexternalca [jdk]"); + // Valid until: Sat May 30 10:48:38 GMT 2020 + add("addtrustclass1ca [jdk]"); + // Valid until: Sat May 30 10:44:50 GMT 2020 + add("addtrustqualifiedca [jdk]"); } };