From d66549f6f6097f1bb11e7b8b1be404c0ef1bb9de Mon Sep 17 00:00:00 2001 From: Prasanta Sadhukhan Date: Wed, 27 Jan 2016 14:12:05 +0530 Subject: [PATCH 001/115] 8147077: IllegalArgumentException thrown by api/java_awt/Component/FlipBufferStrategy/indexTGF_General Reviewed-by: flar, arapte --- .../unix/classes/sun/awt/X11GraphicsConfig.java | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java b/jdk/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java index 1b3c4fa2e23..27b97818dee 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java @@ -452,8 +452,12 @@ public class X11GraphicsConfig extends GraphicsConfiguration public VolatileImage createBackBufferImage(Component target, long backBuffer) { + // it is possible for the component to have size 0x0, adjust it to + // be at least 1x1 to avoid IAE + int w = Math.max(1, target.getWidth()); + int h = Math.max(1, target.getHeight()); return new SunVolatileImage(target, - target.getWidth(), target.getHeight(), + w, h, Long.valueOf(backBuffer)); } From a03c63e14607ae968353de58518f96ea9e3f0d19 Mon Sep 17 00:00:00 2001 From: Prasanta Sadhukhan Date: Wed, 27 Jan 2016 14:13:48 +0530 Subject: [PATCH 002/115] 8148127: IllegalArgumentException thrown by JCK test api/java_awt/Component/FlipBufferStrategy/indexTGF_General in opengl pipeline Reviewed-by: flar, arapte --- .../classes/sun/java2d/opengl/WGLGraphicsConfig.java | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/jdk/src/java.desktop/windows/classes/sun/java2d/opengl/WGLGraphicsConfig.java b/jdk/src/java.desktop/windows/classes/sun/java2d/opengl/WGLGraphicsConfig.java index ec42d3142ad..1e78384130c 100644 --- a/jdk/src/java.desktop/windows/classes/sun/java2d/opengl/WGLGraphicsConfig.java +++ b/jdk/src/java.desktop/windows/classes/sun/java2d/opengl/WGLGraphicsConfig.java @@ -323,8 +323,12 @@ public class WGLGraphicsConfig @Override public VolatileImage createBackBuffer(WComponentPeer peer) { Component target = (Component)peer.getTarget(); + // it is possible for the component to have size 0x0, adjust it to + // be at least 1x1 to avoid IAE + int w = Math.max(1, target.getWidth()); + int h = Math.max(1, target.getHeight()); return new SunVolatileImage(target, - target.getWidth(), target.getHeight(), + w, h, Boolean.TRUE); } From b0fddb9f8045cca10b4e757d8d187af7fb117405 Mon Sep 17 00:00:00 2001 From: Manajit Halder Date: Fri, 29 Jan 2016 15:21:55 +0530 Subject: [PATCH 003/115] 8075964: Test java/awt/Mouse/TitleBarDoubleClick/TitleBarDoubleClick.html fails intermittently with timeout error Reviewed-by: arapte, ssadetsky --- .../java/awt/Mouse/TitleBarDoubleClick/TitleBarDoubleClick.java | 1 - 1 file changed, 1 deletion(-) diff --git a/jdk/test/java/awt/Mouse/TitleBarDoubleClick/TitleBarDoubleClick.java b/jdk/test/java/awt/Mouse/TitleBarDoubleClick/TitleBarDoubleClick.java index 2f959ef73ab..53824a14ebf 100644 --- a/jdk/test/java/awt/Mouse/TitleBarDoubleClick/TitleBarDoubleClick.java +++ b/jdk/test/java/awt/Mouse/TitleBarDoubleClick/TitleBarDoubleClick.java @@ -71,7 +71,6 @@ public class TitleBarDoubleClick extends Applet implements MouseListener, frame.addMouseListener(this); frame.addWindowListener(this); frame.setVisible(true); - Util.waitForIdle(robot); }// start() // Move the mouse into the title bar and double click to maximize the From 25f9c2a19685cc4ce0b46c9ab9114a4d7cceaa9f Mon Sep 17 00:00:00 2001 From: Jayathirth D V Date: Mon, 1 Feb 2016 15:39:02 +0530 Subject: [PATCH 004/115] 8022640: ServiceRegistry (used by ImageIO) lack synchronization Reviewed-by: prr, psadhukhan --- .../javax/imageio/spi/ServiceRegistry.java | 24 ++-- .../imageio/spi/ServiceRegistrySyncTest.java | 131 ++++++++++++++++++ 2 files changed, 144 insertions(+), 11 deletions(-) create mode 100644 jdk/test/javax/imageio/spi/ServiceRegistrySyncTest.java diff --git a/jdk/src/java.desktop/share/classes/javax/imageio/spi/ServiceRegistry.java b/jdk/src/java.desktop/share/classes/javax/imageio/spi/ServiceRegistry.java index a68978d074d..abe85a2a79d 100644 --- a/jdk/src/java.desktop/share/classes/javax/imageio/spi/ServiceRegistry.java +++ b/jdk/src/java.desktop/share/classes/javax/imageio/spi/ServiceRegistry.java @@ -759,7 +759,7 @@ class SubRegistry { this.category = category; } - public boolean registerServiceProvider(Object provider) { + public synchronized boolean registerServiceProvider(Object provider) { Object oprovider = map.get(provider.getClass()); boolean present = oprovider != null; @@ -781,7 +781,7 @@ class SubRegistry { * * @return true if the provider was previously registered. */ - public boolean deregisterServiceProvider(Object provider) { + public synchronized boolean deregisterServiceProvider(Object provider) { Object oprovider = map.get(provider.getClass()); if (provider == oprovider) { @@ -797,22 +797,23 @@ class SubRegistry { return false; } - public boolean contains(Object provider) { + public synchronized boolean contains(Object provider) { Object oprovider = map.get(provider.getClass()); return oprovider == provider; } - public boolean setOrdering(Object firstProvider, - Object secondProvider) { + public synchronized boolean setOrdering(Object firstProvider, + Object secondProvider) { return poset.setOrdering(firstProvider, secondProvider); } - public boolean unsetOrdering(Object firstProvider, - Object secondProvider) { + public synchronized boolean unsetOrdering(Object firstProvider, + Object secondProvider) { return poset.unsetOrdering(firstProvider, secondProvider); } - public Iterator getServiceProviders(boolean useOrdering) { + public synchronized Iterator getServiceProviders + (boolean useOrdering) { if (useOrdering) { return poset.iterator(); } else { @@ -821,11 +822,12 @@ class SubRegistry { } @SuppressWarnings("unchecked") - public T getServiceProviderByClass(Class providerClass) { + public synchronized T getServiceProviderByClass + (Class providerClass) { return (T)map.get(providerClass); } - public void clear() { + public synchronized void clear() { Iterator iter = map.values().iterator(); while (iter.hasNext()) { Object provider = iter.next(); @@ -839,7 +841,7 @@ class SubRegistry { poset.clear(); } - public void finalize() { + public synchronized void finalize() { clear(); } } diff --git a/jdk/test/javax/imageio/spi/ServiceRegistrySyncTest.java b/jdk/test/javax/imageio/spi/ServiceRegistrySyncTest.java new file mode 100644 index 00000000000..5fa90a227bd --- /dev/null +++ b/jdk/test/javax/imageio/spi/ServiceRegistrySyncTest.java @@ -0,0 +1,131 @@ +/* + * Copyright (c) 2016, 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 8022640 + * @summary Test verifies whether ServiceProvider API's of + * ServiceRegistry are safe for concurrent access. + * @run main ServiceRegistrySyncTest + */ + +import java.io.File; +import java.io.IOException; +import java.util.ArrayList; +import java.util.Locale; +import javax.imageio.spi.ImageInputStreamSpi; +import javax.imageio.spi.ServiceRegistry; +import javax.imageio.stream.ImageInputStream; + +public class ServiceRegistrySyncTest { + public static void main(String[] args) throws InterruptedException { + + final ArrayList> services = new ArrayList>(); + services.add(ImageInputStreamSpi.class); + + final ServiceRegistry reg = new ServiceRegistry(services.iterator()); + + //create new thread for Registerer and Consumer Class + Thread registerer = new Thread(new Registerer(reg)); + Thread consumer = new Thread(new Consumer(reg)); + + //run both registerer and consumer thread parallely + registerer.start(); + consumer.start(); + } + + static class Consumer implements Runnable { + private final ServiceRegistry reg; + boolean go = true; + int duration; + long start, end; + + public Consumer(ServiceRegistry r) { + reg = r; + //set 5000ms duration to run the test + duration = 5000; + } + + @Override + public void run() { + start = System.currentTimeMillis(); + end = start + duration; + while (start < end) { + //access the ServiceProvider API + reg.getServiceProviders(ImageInputStreamSpi.class, true); + start = System.currentTimeMillis(); + } + } + } + + static class Registerer implements Runnable { + private final ServiceRegistry reg; + boolean go = true; + int duration; + long start, end; + + public Registerer(ServiceRegistry r) { + reg = r; + //set 5000ms duration to run the test + duration = 5000; + } + + @Override + public void run() { + final int N = 20; + + MyService[] services = new MyService[N]; + for (int i = 0; i < N; i++) { + services[i] = new MyService(); + } + start = System.currentTimeMillis(); + end = start + duration; + while (start < end) { + //access the ServiceProvider API's + for (int i = 0; i < N; i++) { + reg.registerServiceProvider(services[i]); + } + for (int i = 0; i < N; i++) { + reg.deregisterServiceProvider(services[i]); + } + start = System.currentTimeMillis(); + } + } + } +} + +class MyService extends ImageInputStreamSpi { + public MyService() { + } + + @Override + public String getDescription(Locale locale) { + return null; + } + + @Override + public ImageInputStream createInputStreamInstance + (Object input, boolean useCache, File cacheDir) throws IOException { + return null; + } +} From 8148b2b20393b7cd083d70d88b28c9712a43370a Mon Sep 17 00:00:00 2001 From: Jayathirth D V Date: Tue, 2 Feb 2016 11:50:24 +0530 Subject: [PATCH 005/115] 8147413: api/java_awt/Image/MultiResolutionImage/index.html\#MultiResolutionRenderingHints[test_VALUE_RESOLUTION_VARIANT_BASE] started to fail Reviewed-by: alexsch, flar --- .../java.desktop/share/classes/sun/java2d/SunGraphics2D.java | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/jdk/src/java.desktop/share/classes/sun/java2d/SunGraphics2D.java b/jdk/src/java.desktop/share/classes/sun/java2d/SunGraphics2D.java index 869271d1e0c..967077d6585 100644 --- a/jdk/src/java.desktop/share/classes/sun/java2d/SunGraphics2D.java +++ b/jdk/src/java.desktop/share/classes/sun/java2d/SunGraphics2D.java @@ -3118,8 +3118,7 @@ public final class SunGraphics2D invalidateTransform(); } return result; - } else if (resolutionVariantHint != SunHints.INTVAL_RESOLUTION_VARIANT_BASE - && (img instanceof MultiResolutionImage)) { + } else if (img instanceof MultiResolutionImage) { // get scaled destination image size int width = img.getWidth(observer); From c453a540b5e015254a551c9619b78bda24c084bb Mon Sep 17 00:00:00 2001 From: Ambarish Rapte Date: Tue, 2 Feb 2016 14:19:55 +0530 Subject: [PATCH 006/115] 6180449: PIT: Text in TextArea scrolls to its left one char when selecting the text from the end Reviewed-by: ssadetsky, psadhukhan --- .../native/libawt/windows/awt_TextArea.cpp | 3 - .../TextAreaScrolling/TextAreaScrolling.java | 107 ++++++++++++++++++ 2 files changed, 107 insertions(+), 3 deletions(-) create mode 100644 jdk/test/java/awt/TextArea/TextAreaScrolling/TextAreaScrolling.java diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp b/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp index 427a0b8e3e8..0b96ad99a4b 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_TextArea.cpp @@ -73,10 +73,7 @@ AwtTextArea* AwtTextArea::Create(jobject peer, jobject parent) } void AwtTextArea::EditSetSel(CHARRANGE &cr) { - // Fix for 5003402: added restoring/hiding selection to enable automatic scrolling - SendMessage(EM_HIDESELECTION, FALSE, TRUE); SendMessage(EM_EXSETSEL, 0, reinterpret_cast(&cr)); - SendMessage(EM_HIDESELECTION, TRUE, TRUE); // 6417581: force expected drawing if (IS_WINVISTA && cr.cpMin == cr.cpMax) { ::InvalidateRect(GetHWnd(), NULL, TRUE); diff --git a/jdk/test/java/awt/TextArea/TextAreaScrolling/TextAreaScrolling.java b/jdk/test/java/awt/TextArea/TextAreaScrolling/TextAreaScrolling.java new file mode 100644 index 00000000000..15508492d65 --- /dev/null +++ b/jdk/test/java/awt/TextArea/TextAreaScrolling/TextAreaScrolling.java @@ -0,0 +1,107 @@ +/* + * Copyright (c) 2016, 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 6180449 + @summary TextArea scrolls to its left when selecting the text from the end. + @run main TextAreaScrolling + */ + +import java.awt.Frame; +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.TextArea; +import java.awt.event.InputEvent; + +public class TextAreaScrolling { + Frame mainFrame; + TextArea textArea; + Robot robot; + + TextAreaScrolling() { + mainFrame = new Frame(); + mainFrame.setSize(200, 200); + mainFrame.setLocation(200, 200); + + textArea = new TextArea(); + textArea.setText("1234 5678"); + textArea.setSelectionStart(3); + textArea.setSelectionStart(4); + mainFrame.add(textArea); + mainFrame.setVisible(true); + textArea.requestFocusInWindow(); + + try { + robot = new Robot(); + robot.setAutoWaitForIdle(true); + } catch (Exception ex) { + dispose(); + System.exit(0); + throw new RuntimeException("Robot Creation Failed"); + } + } + + public void dispose() { + if (mainFrame != null) { + mainFrame.dispose(); + } + } + + public void performTest() { + Point loc = textArea.getLocationOnScreen(); + Rectangle textAreaBounds = new Rectangle(); + textArea.getBounds(textAreaBounds); + + // Move mouse at center in first row of TextArea. + robot.mouseMove(loc.x + textAreaBounds.width / 2, loc.y + 5); + + // Perform selection by scrolling to left from end of char sequence. + robot.mousePress(InputEvent.BUTTON1_MASK); + robot.mouseMove(textAreaBounds.x - 5, loc.y + 5); + robot.mouseRelease(InputEvent.BUTTON1_MASK); + + // Perform double click on beginning word of TextArea + robot.mouseMove(loc.x + 5, loc.y + 5); + robot.mousePress(InputEvent.BUTTON1_MASK); + robot.mouseRelease(InputEvent.BUTTON1_MASK); + robot.delay(100); + robot.mousePress(InputEvent.BUTTON1_MASK); + robot.mouseRelease(InputEvent.BUTTON1_MASK); + robot.delay(100); + + if (textArea.getSelectedText().contentEquals("5678")) { + dispose(); + throw new RuntimeException ("TextArea over scrolled towards left" + + "Expected selected text: '1234 ' and for mac '1234'" + + "Actual selected text: 5678"); + } + } + + public static void main(String argv[]) throws RuntimeException { + TextAreaScrolling test = new TextAreaScrolling(); + test.performTest(); + test.dispose(); + } +} From 51296cb329d18378ae868139d2276145aee6a047 Mon Sep 17 00:00:00 2001 From: Ajit Ghaisas Date: Tue, 2 Feb 2016 15:57:42 +0530 Subject: [PATCH 007/115] 8005918: [TESTBUG] There are no 'Frame Enter' messages for both frames, only 'Button Enter' message Reviewed-by: arapte, alexsch --- .../LightweightEventTest.java | 304 ++++++++++++++++++ 1 file changed, 304 insertions(+) create mode 100644 jdk/test/java/awt/LightweightComponent/LightweightEventTest/LightweightEventTest.java diff --git a/jdk/test/java/awt/LightweightComponent/LightweightEventTest/LightweightEventTest.java b/jdk/test/java/awt/LightweightComponent/LightweightEventTest/LightweightEventTest.java new file mode 100644 index 00000000000..4c729282101 --- /dev/null +++ b/jdk/test/java/awt/LightweightComponent/LightweightEventTest/LightweightEventTest.java @@ -0,0 +1,304 @@ +/* + * Copyright (c) 2016 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 + * @summary Test of mouse move messages to lightweight components + * @library ../../regtesthelpers + * @build Util + * @compile LightweightEventTest.java + * @run main LightweightEventTest + */ +import java.awt.BorderLayout; +import java.awt.Button; +import java.awt.Color; +import java.awt.Component; +import java.awt.Container; +import java.awt.Dimension; +import java.awt.FontMetrics; +import java.awt.Frame; +import java.awt.Graphics; +import java.awt.Insets; +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.AWTException; +import java.awt.event.MouseAdapter; +import java.awt.event.MouseEvent; +import javax.swing.SwingUtilities; +import test.java.awt.regtesthelpers.Util; + + +/* +There are 3 steps to this test : +1. Two frames are created one with heavy weight component and + another with light weight component. Each frame has a centrally placed + button +2. Mouse is dragged along diagonals of each window using Robot object +3. Events are noted for mouse in and out of frames & buttons and asserted +*/ + +public class LightweightEventTest { + + private static EventBug HeavyComponent; + private static EventBug LightComponent; + private static Robot testRobot; + + public static void main(String[] args) throws Throwable { + + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + constructTestUI(); + } + }); + + try { + testRobot = new Robot(); + } catch (AWTException ex) { + throw new RuntimeException("Could not initiate a drag operation"); + } + + testRobot.waitForIdle(); + + // Method performing auto test operation + boolean result = test(); + + disposeTestUI(); + + if (result == false) { + throw new RuntimeException("Test FAILED!"); + } + } + + private static boolean test() { + // Test events for HeavyComponent + Point loc = HeavyComponent.getLocationOnScreen(); + Dimension size = HeavyComponent.getSize(); + + Util.mouseMove(testRobot, + new Point((int) loc.x + 4, (int) loc.y + 4), + new Point((int) loc.x + size.width, (int) loc.y + size.height)); + + testRobot.waitForIdle(); + + boolean HeavyComponentAssert = HeavyComponent.assertEvents(2, 1); + + // Test events for LightComponent + loc = LightComponent.getLocationOnScreen(); + size = LightComponent.getSize(); + + Util.mouseMove(testRobot, + new Point((int) loc.x + 4, (int) loc.y + 4), + new Point((int) loc.x + size.width, (int) loc.y + size.height)); + + testRobot.waitForIdle(); + + boolean LightComponentAssert = LightComponent.assertEvents(2, 1); + + return (HeavyComponentAssert && LightComponentAssert); + } + + private static void constructTestUI() { + // here, create the items that will be tested for correct behavior + HeavyComponent = new EventBug(); + Button b = (Button) HeavyComponent.add("Center", new Button("Heavy")); + + LightComponent = new EventBug(); + BorderedLabel b1 = (BorderedLabel) LightComponent.add("Center", + new BorderedLabel("Lite")); + + HeavyComponent.addListeners(b); + LightComponent.addListeners(b1); + + LightComponent.setLocation(200, 0); + HeavyComponent.setVisible(true); + LightComponent.setVisible(true); + } + + private static void disposeTestUI() { + HeavyComponent.setVisible(false); + LightComponent.setVisible(false); + + HeavyComponent.dispose(); + LightComponent.dispose(); + } +} + +/* + * Lightweight component + */ +class BorderedLabel extends Component { + + boolean superIsButton = false; + String labelString; + + BorderedLabel(String labelString) { + this.labelString = labelString; + + Component thisComponent = this; + superIsButton = (thisComponent instanceof Button); + if (superIsButton) { + ((Button) thisComponent).setLabel(labelString); + } + } + + @Override + public Dimension getMinimumSize() { + Dimension minSize = new Dimension(); + + if (superIsButton) { + minSize = super.getMinimumSize(); + } else { + + Graphics g = getGraphics(); + FontMetrics metrics = g.getFontMetrics(); + + minSize.width = metrics.stringWidth(labelString) + 14; + minSize.height = metrics.getMaxAscent() + + metrics.getMaxDescent() + 9; + + g.dispose(); + g = null; + } + return minSize; + } + + @Override + public Dimension getPreferredSize() { + Dimension prefSize; + if (superIsButton) { + prefSize = super.getPreferredSize(); + } else { + prefSize = getMinimumSize(); + } + return prefSize; + } + + @Override + public void paint(Graphics g) { + + super.paint(g); + Rectangle bounds = getBounds(); + if (superIsButton) { + return; + } + Dimension size = getSize(); + Color oldColor = g.getColor(); + + // draw border + g.setColor(getBackground()); + g.fill3DRect(0, 0, size.width, size.height, false); + g.fill3DRect(3, 3, size.width - 6, size.height - 6, true); + + // draw text + FontMetrics metrics = g.getFontMetrics(); + int centerX = size.width / 2; + int centerY = size.height / 2; + int textX = centerX - (metrics.stringWidth(labelString) / 2); + int textY = centerY + + ((metrics.getMaxAscent() + metrics.getMaxDescent()) / 2); + g.setColor(getForeground()); + g.drawString(labelString, textX, textY); + + g.setColor(oldColor); + } +} // class BorderedLabel + +class EventBug extends Container { + + Frame testFrame; + int frameEnters = 0; + int frameExits = 0; + int buttonEnters = 0; + int buttonExits = 0; + + public EventBug() { + super(); + testFrame = new Frame(); + testFrame.setLayout(new BorderLayout()); + this.setLayout(new BorderLayout()); + testFrame.add("Center", this); + testFrame.pack(); + testFrame.setVisible(true); + } + + @Override + public Dimension getPreferredSize() { + return new Dimension(100, 100); + } + + @Override + public Insets getInsets() { + return new Insets(20, 20, 20, 20); + } + + public boolean assertEvents(int expectedFrameEnterEvents, + int expectedButtonEnterEvents) { + return (frameEnters == expectedFrameEnterEvents) + && (buttonEnters == expectedButtonEnterEvents); + } + + // Forward to the Window + @Override + public void setLocation(int x, int y) { + testFrame.setLocation(x, y); + } + + @Override + public void setVisible(boolean b) { + testFrame.setVisible(b); + } + + public void dispose() { + testFrame.dispose(); + } + + // Add listeners to Frame and button + public void addListeners(Component b) { + b.setName("Button"); + b.addMouseListener(new MouseAdapter() { + @Override + public void mouseEntered(MouseEvent e) { + buttonEnters++; + } + + @Override + public void mouseExited(MouseEvent e) { + buttonExits++; + } + + }); + testFrame.addMouseListener(new MouseAdapter() { + @Override + public void mouseEntered(MouseEvent e) { + frameEnters++; + } + + @Override + public void mouseExited(MouseEvent e) { + frameExits++; + } + }); + } +} // class EventBug From f7b4333c0b75c13bbb36d2edd589e593ca986167 Mon Sep 17 00:00:00 2001 From: Anton Litvinov Date: Tue, 2 Feb 2016 16:33:03 +0300 Subject: [PATCH 008/115] 8139581: AWT components are not drawn after removal and addition to a container Reviewed-by: ssadetsky, alexsch --- .../unix/classes/sun/awt/X11/XBaseWindow.java | 4 - ...ComponentIsNotDrawnAfterRemoveAddTest.java | 187 ++++++++++++++++++ 2 files changed, 187 insertions(+), 4 deletions(-) create mode 100644 jdk/test/java/awt/Paint/ComponentIsNotDrawnAfterRemoveAddTest/ComponentIsNotDrawnAfterRemoveAddTest.java diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XBaseWindow.java b/jdk/src/java.desktop/unix/classes/sun/awt/X11/XBaseWindow.java index c8534aa36e3..221093fa66b 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XBaseWindow.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/X11/XBaseWindow.java @@ -79,7 +79,6 @@ public class XBaseWindow { static enum InitialiseState { INITIALISING, - NOT_INITIALISED, INITIALISED, FAILED_INITIALISATION }; @@ -122,7 +121,6 @@ public class XBaseWindow { */ void instantPreInit(XCreateWindowParams params) { state_lock = new StateLock(); - initialising = InitialiseState.NOT_INITIALISED; } /** @@ -131,7 +129,6 @@ public class XBaseWindow { */ void preInit(XCreateWindowParams params) { state_lock = new StateLock(); - initialising = InitialiseState.NOT_INITIALISED; embedded = Boolean.TRUE.equals(params.get(EMBEDDED)); visible = Boolean.TRUE.equals(params.get(VISIBLE)); @@ -223,7 +220,6 @@ public class XBaseWindow { return false; } return true; - case NOT_INITIALISED: case FAILED_INITIALISATION: return false; default: diff --git a/jdk/test/java/awt/Paint/ComponentIsNotDrawnAfterRemoveAddTest/ComponentIsNotDrawnAfterRemoveAddTest.java b/jdk/test/java/awt/Paint/ComponentIsNotDrawnAfterRemoveAddTest/ComponentIsNotDrawnAfterRemoveAddTest.java new file mode 100644 index 00000000000..186b572df44 --- /dev/null +++ b/jdk/test/java/awt/Paint/ComponentIsNotDrawnAfterRemoveAddTest/ComponentIsNotDrawnAfterRemoveAddTest.java @@ -0,0 +1,187 @@ +/* + * Copyright (c) 2016, 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 8139581 + @summary AWT components are not drawn after removal and addition to a container + @author Anton Litvinov + */ + +import java.awt.Button; +import java.awt.Color; +import java.awt.Canvas; +import java.awt.Frame; +import java.awt.Graphics; +import java.awt.Panel; +import java.util.ArrayList; + +public class ComponentIsNotDrawnAfterRemoveAddTest { + private final Frame frame; + private final Panel panel; + private final ArrayList compList = new ArrayList(); + + public ComponentIsNotDrawnAfterRemoveAddTest() { + frame = new Frame("ComponentIsNotDrawnAfterRemoveAddTest"); + frame.setSize(500, 500); + frame.setLocation(200, 200); + frame.setLayout(null); + frame.setBackground(Color.RED); + + panel = new Panel(); + panel.setLayout(null); + panel.setBounds(25, 100, 455, 295); + panel.setBackground(Color.GREEN); + + for (int i = 0; i < 10; i++) { + TestCanvas canv1 = new TestCanvas(); + canv1.setBounds(i * 45 + 5, 15, 30 + i, 30 + i); + panel.add(canv1); + compList.add(canv1); + + TestButton btn1 = new TestButton(); + btn1.setBounds(i * 45 + 5, 60, 30 + i, 30 + i); + panel.add(btn1); + compList.add(btn1); + + TestCanvas canv2 = new TestCanvas(); + canv2.setBounds(i * 45 + 5, 105, 30 + i, 30 + i); + panel.add(canv2); + compList.add(canv2); + + TestButton btn2 = new TestButton(); + btn2.setBounds(i * 45 + 5, 150, 30 + i, 30 + i); + panel.add(btn2); + compList.add(btn2); + + TestCanvas canv3 = new TestCanvas(); + canv3.setBounds(i * 45 + 5, 195, 30 + i, 30 + i); + panel.add(canv3); + compList.add(canv3); + + TestButton btn3 = new TestButton(); + btn3.setBounds(i * 45 + 5, 240, 30 + i, 30 + i); + panel.add(btn3); + compList.add(btn3); + } + + frame.add(panel); + frame.setVisible(true); + } + + private void runTest() { + try { + doSleep(1500); + checkTestableComponents(); + + for (int i = 0; i < 5; i++) { + System.err.println(String.format("Test iteration #%d:", i)); + + frame.remove(panel); + frame.invalidate(); + frame.validate(); + frame.add(panel); + + doSleep(1500); + checkTestableComponents(); + } + } finally { + frame.dispose(); + } + } + + private void doSleep(long millis) { + try { + Thread.sleep(millis); + } catch (InterruptedException ie) { + ie.printStackTrace(); + } + } + + private void checkTestableComponents() throws RuntimeException { + int notDrawnCompsCount = 0; + for (Testable comp : compList) { + if (!comp.wasPaintCalled()) { + notDrawnCompsCount++; + } else { + comp.resetPaintCalledFlag(); + } + } + if (notDrawnCompsCount > 0) { + throw new RuntimeException(String.format( + "'paint' method of %d components was not called.", notDrawnCompsCount)); + } + } + + private interface Testable { + boolean wasPaintCalled(); + void resetPaintCalledFlag(); + } + + private static class TestCanvas extends Canvas implements Testable { + private volatile boolean paintWasCalled = false; + + @Override + public void paint(Graphics g) { + paintWasCalled = true; + super.paint(g); + g.setColor(Color.BLUE); + g.fillRect(0, 0, getWidth(), getHeight()); + } + + @Override + public boolean wasPaintCalled() { + return paintWasCalled; + } + + @Override + public void resetPaintCalledFlag() { + paintWasCalled = false; + } + } + + private static class TestButton extends Button implements Testable { + private volatile boolean paintWasCalled = false; + + @Override + public void paint(Graphics g) { + paintWasCalled = true; + super.paint(g); + g.setColor(Color.YELLOW); + g.fillRect(0, 0, 15, 15); + } + + @Override + public boolean wasPaintCalled() { + return paintWasCalled; + } + + @Override + public void resetPaintCalledFlag() { + paintWasCalled = false; + } + } + + public static void main(String[] args) { + new ComponentIsNotDrawnAfterRemoveAddTest().runTest(); + } +} From aedb4650c96c24a067949a57595134c81af7b5eb Mon Sep 17 00:00:00 2001 From: Max Ockner Date: Tue, 2 Feb 2016 17:14:00 -0500 Subject: [PATCH 009/115] 8079408: Reimplement TraceClassLoading, TraceClassUnloading, and TraceClassLoaderData with Unified Logging TraceClassLoading, TraceClassUnloading, and TraceClassLoaderData have been reimplemented using Unified logging. Reviewed-by: iklam, coleenp, dholmes, jiangli, hseigel, rprotacio --- jdk/test/java/lang/ClassLoader/deadlock/TestCrossDelegate.sh | 4 ++-- jdk/test/java/lang/ClassLoader/deadlock/TestOneWayDelegate.sh | 4 ++-- .../instrument/appendToClassLoaderSearch/ClassUnloadTest.sh | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/jdk/test/java/lang/ClassLoader/deadlock/TestCrossDelegate.sh b/jdk/test/java/lang/ClassLoader/deadlock/TestCrossDelegate.sh index a70e6019eaa..3872f813ffd 100644 --- a/jdk/test/java/lang/ClassLoader/deadlock/TestCrossDelegate.sh +++ b/jdk/test/java/lang/ClassLoader/deadlock/TestCrossDelegate.sh @@ -1,5 +1,5 @@ # -# Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2009, 2016, 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 @@ -106,7 +106,7 @@ done # run test ${TESTJAVA}${FS}bin${FS}java \ ${TESTVMOPTS} \ - -verbose:class -XX:+TraceClassLoading -cp . \ + -verbose:class -Xlog:classload -cp . \ -Dtest.classes=${TESTCLASSES} \ Starter cross # -XX:+UnlockDiagnosticVMOptions -XX:+UnsyncloadClass \ diff --git a/jdk/test/java/lang/ClassLoader/deadlock/TestOneWayDelegate.sh b/jdk/test/java/lang/ClassLoader/deadlock/TestOneWayDelegate.sh index 678b98e5be0..198cd70827a 100644 --- a/jdk/test/java/lang/ClassLoader/deadlock/TestOneWayDelegate.sh +++ b/jdk/test/java/lang/ClassLoader/deadlock/TestOneWayDelegate.sh @@ -1,5 +1,5 @@ # -# Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2009, 2016, 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 @@ -102,7 +102,7 @@ done # run test ${TESTJAVA}${FS}bin${FS}java \ ${TESTVMOPTS} \ - -verbose:class -XX:+TraceClassLoading -cp . \ + -verbose:class -Xlog:classload -cp . \ -Dtest.classes=${TESTCLASSES} \ Starter one-way # -XX:+UnlockDiagnosticVMOptions -XX:+UnsyncloadClass \ diff --git a/jdk/test/java/lang/instrument/appendToClassLoaderSearch/ClassUnloadTest.sh b/jdk/test/java/lang/instrument/appendToClassLoaderSearch/ClassUnloadTest.sh index 1b93b3043a9..f5bb3b83179 100644 --- a/jdk/test/java/lang/instrument/appendToClassLoaderSearch/ClassUnloadTest.sh +++ b/jdk/test/java/lang/instrument/appendToClassLoaderSearch/ClassUnloadTest.sh @@ -1,5 +1,5 @@ # -# Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2005, 2016, 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 @@ -80,5 +80,5 @@ $JAR ${TESTTOOLVMOPTS} -cfm "${TESTCLASSES}"/ClassUnloadTest.jar "${MANIFEST}" \ # Finally we run the test (cd "${TESTCLASSES}"; \ - $JAVA ${TESTVMOPTS} -Xverify:none -XX:+TraceClassUnloading \ + $JAVA ${TESTVMOPTS} -Xverify:none -Xlog:classunload \ -javaagent:ClassUnloadTest.jar ClassUnloadTest "${OTHERDIR}" Bar.jar) From 8e808d813de2d806ff87cd09ee77093e39e4af61 Mon Sep 17 00:00:00 2001 From: Aleksey Shipilev Date: Wed, 10 Feb 2016 15:58:11 +0300 Subject: [PATCH 010/115] 8149356: Leftover from JDK-8141044: UseNewCode usage Reviewed-by: vlivanov --- hotspot/src/share/vm/c1/c1_Canonicalizer.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp index e4976f18bc6..e06aa581833 100644 --- a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp +++ b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp @@ -730,7 +730,7 @@ void Canonicalizer::do_If(If* x) { } } else if (rt == objectNull && (l->as_NewInstance() || l->as_NewArray() || - (UseNewCode && l->as_Local() && l->as_Local()->is_receiver()))) { + (l->as_Local() && l->as_Local()->is_receiver()))) { if (x->cond() == Instruction::eql) { BlockBegin* sux = x->fsux(); set_canonical(new Goto(sux, x->state_before(), is_safepoint(x, sux))); From 45bd62d1f11408bc4ae5f18c2cc1dfb8c9bfa744 Mon Sep 17 00:00:00 2001 From: Jamsheed Mohammed Date: Wed, 10 Feb 2016 15:24:22 +0100 Subject: [PATCH 011/115] 8149123: [TESTBUG] compiler/loopopts/superword/SumRed* tests running on non-x86 platforms Restricted test execution to supported archs. Reviewed-by: kvn --- hotspot/test/compiler/loopopts/superword/ProdRed_Double.java | 1 + hotspot/test/compiler/loopopts/superword/ProdRed_Float.java | 1 + hotspot/test/compiler/loopopts/superword/ProdRed_Int.java | 1 + hotspot/test/compiler/loopopts/superword/ReductionPerf.java | 1 + hotspot/test/compiler/loopopts/superword/SumRedSqrt_Double.java | 2 +- hotspot/test/compiler/loopopts/superword/SumRed_Double.java | 1 + hotspot/test/compiler/loopopts/superword/SumRed_Float.java | 1 + hotspot/test/compiler/loopopts/superword/SumRed_Int.java | 1 + hotspot/test/compiler/loopopts/superword/SumRed_Long.java | 1 + 9 files changed, 9 insertions(+), 1 deletion(-) diff --git a/hotspot/test/compiler/loopopts/superword/ProdRed_Double.java b/hotspot/test/compiler/loopopts/superword/ProdRed_Double.java index 538c963f22b..37e9fca45d6 100644 --- a/hotspot/test/compiler/loopopts/superword/ProdRed_Double.java +++ b/hotspot/test/compiler/loopopts/superword/ProdRed_Double.java @@ -26,6 +26,7 @@ * @test * @bug 8074981 * @summary Add C2 x86 Superword support for scalar product reduction optimizations : float test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 ProdRed_Double * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 ProdRed_Double diff --git a/hotspot/test/compiler/loopopts/superword/ProdRed_Float.java b/hotspot/test/compiler/loopopts/superword/ProdRed_Float.java index 526e21ae472..b31cf10ea9c 100644 --- a/hotspot/test/compiler/loopopts/superword/ProdRed_Float.java +++ b/hotspot/test/compiler/loopopts/superword/ProdRed_Float.java @@ -26,6 +26,7 @@ * @test * @bug 8074981 * @summary Add C2 x86 Superword support for scalar product reduction optimizations : float test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 ProdRed_Float * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 ProdRed_Float diff --git a/hotspot/test/compiler/loopopts/superword/ProdRed_Int.java b/hotspot/test/compiler/loopopts/superword/ProdRed_Int.java index 155e54a4331..a1e8356714d 100644 --- a/hotspot/test/compiler/loopopts/superword/ProdRed_Int.java +++ b/hotspot/test/compiler/loopopts/superword/ProdRed_Int.java @@ -26,6 +26,7 @@ * @test * @bug 8074981 * @summary Add C2 x86 Superword support for scalar product reduction optimizations : int test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 ProdRed_Int * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 ProdRed_Int diff --git a/hotspot/test/compiler/loopopts/superword/ReductionPerf.java b/hotspot/test/compiler/loopopts/superword/ReductionPerf.java index c622396fdca..a91f70f83fd 100644 --- a/hotspot/test/compiler/loopopts/superword/ReductionPerf.java +++ b/hotspot/test/compiler/loopopts/superword/ReductionPerf.java @@ -26,6 +26,7 @@ * @test * @bug 8074981 * @summary Add C2 x86 Superword support for scalar product reduction optimizations : int test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:CompileThresholdScaling=0.1 -XX:CompileCommand=exclude,ReductionPerf::main ReductionPerf * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:CompileThresholdScaling=0.1 -XX:CompileCommand=exclude,ReductionPerf::main ReductionPerf diff --git a/hotspot/test/compiler/loopopts/superword/SumRedSqrt_Double.java b/hotspot/test/compiler/loopopts/superword/SumRedSqrt_Double.java index 429e30d6a09..ac9edd5dcc8 100644 --- a/hotspot/test/compiler/loopopts/superword/SumRedSqrt_Double.java +++ b/hotspot/test/compiler/loopopts/superword/SumRedSqrt_Double.java @@ -26,7 +26,7 @@ * @test * @bug 8135028 * @summary Add C2 x86 Superword support for scalar sum reduction optimizations : double sqrt test -* @requires os.arch=="x86" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" +* @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRedSqrt_Double * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRedSqrt_Double diff --git a/hotspot/test/compiler/loopopts/superword/SumRed_Double.java b/hotspot/test/compiler/loopopts/superword/SumRed_Double.java index 371635d20d1..b33ef59b897 100644 --- a/hotspot/test/compiler/loopopts/superword/SumRed_Double.java +++ b/hotspot/test/compiler/loopopts/superword/SumRed_Double.java @@ -26,6 +26,7 @@ * @test * @bug 8074981 * @summary Add C2 x86 Superword support for scalar sum reduction optimizations : double test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRed_Double * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRed_Double diff --git a/hotspot/test/compiler/loopopts/superword/SumRed_Float.java b/hotspot/test/compiler/loopopts/superword/SumRed_Float.java index ef632011424..2f02f3657b5 100644 --- a/hotspot/test/compiler/loopopts/superword/SumRed_Float.java +++ b/hotspot/test/compiler/loopopts/superword/SumRed_Float.java @@ -26,6 +26,7 @@ * @test * @bug 8074981 * @summary Add C2 x86 Superword support for scalar sum reduction optimizations : float test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRed_Float * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRed_Float diff --git a/hotspot/test/compiler/loopopts/superword/SumRed_Int.java b/hotspot/test/compiler/loopopts/superword/SumRed_Int.java index 33c5702bd45..c6c4b0b183b 100644 --- a/hotspot/test/compiler/loopopts/superword/SumRed_Int.java +++ b/hotspot/test/compiler/loopopts/superword/SumRed_Int.java @@ -26,6 +26,7 @@ * @test * @bug 8074981 * @summary Add C2 x86 Superword support for scalar sum reduction optimizations : int test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" | os.arch=="aarch64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRed_Int * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=2 -XX:CompileThresholdScaling=0.1 SumRed_Int diff --git a/hotspot/test/compiler/loopopts/superword/SumRed_Long.java b/hotspot/test/compiler/loopopts/superword/SumRed_Long.java index c11b6275f1c..503a11d5a74 100644 --- a/hotspot/test/compiler/loopopts/superword/SumRed_Long.java +++ b/hotspot/test/compiler/loopopts/superword/SumRed_Long.java @@ -26,6 +26,7 @@ * @test * @bug 8076276 * @summary Add C2 x86 Superword support for scalar sum reduction optimizations : long test + * @requires os.arch=="x86" | os.arch=="i386" | os.arch=="amd64" | os.arch=="x86_64" * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=4 -XX:CompileThresholdScaling=0.1 SumRed_Long * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-SuperWordReductions -XX:LoopUnrollLimit=250 -XX:LoopMaxUnroll=4 -XX:CompileThresholdScaling=0.1 SumRed_Long From 98bbb4efa05e66c4f7a53398782ef44a3548aa08 Mon Sep 17 00:00:00 2001 From: Christian Thalinger Date: Wed, 10 Feb 2016 11:23:17 -1000 Subject: [PATCH 012/115] 8149415: [AArch64] implement JVMCI CodeInstaller Reviewed-by: aph, kvn --- .../aarch64/vm/jvmciCodeInstaller_aarch64.cpp | 132 ++++++++++++++++-- .../src/cpu/aarch64/vm/nativeInst_aarch64.cpp | 44 +++++- .../src/cpu/aarch64/vm/nativeInst_aarch64.hpp | 29 +++- .../src/jdk/vm/ci/aarch64/AArch64.java | 79 ++++++----- .../aarch64/AArch64HotSpotRegisterConfig.java | 13 +- .../amd64/AMD64HotSpotRegisterConfig.java | 10 +- .../sparc/SPARCHotSpotRegisterConfig.java | 10 +- 7 files changed, 257 insertions(+), 60 deletions(-) diff --git a/hotspot/src/cpu/aarch64/vm/jvmciCodeInstaller_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/jvmciCodeInstaller_aarch64.cpp index c96bf597d80..9d3b04e50a8 100644 --- a/hotspot/src/cpu/aarch64/vm/jvmciCodeInstaller_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/jvmciCodeInstaller_aarch64.cpp @@ -30,39 +30,151 @@ #include "vmreg_aarch64.inline.hpp" jint CodeInstaller::pd_next_offset(NativeInstruction* inst, jint pc_offset, Handle method, TRAPS) { - Unimplemented(); - return 0; + if (inst->is_call() || inst->is_jump() || inst->is_blr()) { + return pc_offset + NativeCall::instruction_size; + } else if (inst->is_general_jump()) { + return pc_offset + NativeGeneralJump::instruction_size; + } else { + JVMCI_ERROR_0("unsupported type of instruction for call site"); + } } void CodeInstaller::pd_patch_OopConstant(int pc_offset, Handle constant, TRAPS) { - Unimplemented(); + address pc = _instructions->start() + pc_offset; + Handle obj = HotSpotObjectConstantImpl::object(constant); + jobject value = JNIHandles::make_local(obj()); + if (HotSpotObjectConstantImpl::compressed(constant)) { + int oop_index = _oop_recorder->find_index(value); + RelocationHolder rspec = oop_Relocation::spec(oop_index); + _instructions->relocate(pc, rspec, 1); + Unimplemented(); + } else { + NativeMovConstReg* move = nativeMovConstReg_at(pc); + move->set_data((intptr_t) value); + int oop_index = _oop_recorder->find_index(value); + RelocationHolder rspec = oop_Relocation::spec(oop_index); + _instructions->relocate(pc, rspec); + } } void CodeInstaller::pd_patch_MetaspaceConstant(int pc_offset, Handle constant, TRAPS) { - Unimplemented(); + address pc = _instructions->start() + pc_offset; + if (HotSpotMetaspaceConstantImpl::compressed(constant)) { + narrowKlass narrowOop = record_narrow_metadata_reference(constant, CHECK); + TRACE_jvmci_3("relocating (narrow metaspace constant) at " PTR_FORMAT "/0x%x", p2i(pc), narrowOop); + Unimplemented(); + } else { + NativeMovConstReg* move = nativeMovConstReg_at(pc); + Metadata* reference = record_metadata_reference(constant, CHECK); + move->set_data((intptr_t) reference); + TRACE_jvmci_3("relocating (metaspace constant) at " PTR_FORMAT "/" PTR_FORMAT, p2i(pc), p2i(reference)); + } } void CodeInstaller::pd_patch_DataSectionReference(int pc_offset, int data_offset) { - Unimplemented(); + address pc = _instructions->start() + pc_offset; + NativeInstruction* inst = nativeInstruction_at(pc); + if (inst->is_adr_aligned()) { + address dest = _constants->start() + data_offset; + _instructions->relocate(pc, section_word_Relocation::spec((address) dest, CodeBuffer::SECT_CONSTS)); + TRACE_jvmci_3("relocating at " PTR_FORMAT " (+%d) with destination at %d", p2i(pc), pc_offset, data_offset); + } else { + JVMCI_ERROR("unknown load or move instruction at " PTR_FORMAT, p2i(pc)); + } } void CodeInstaller::pd_relocate_ForeignCall(NativeInstruction* inst, jlong foreign_call_destination, TRAPS) { - Unimplemented(); + address pc = (address) inst; + if (inst->is_call()) { + NativeCall* call = nativeCall_at(pc); + call->set_destination((address) foreign_call_destination); + _instructions->relocate(call->instruction_address(), runtime_call_Relocation::spec()); + } else if (inst->is_jump()) { + NativeJump* jump = nativeJump_at(pc); + jump->set_jump_destination((address) foreign_call_destination); + _instructions->relocate(jump->instruction_address(), runtime_call_Relocation::spec()); + } else if (inst->is_general_jump()) { + NativeGeneralJump* jump = nativeGeneralJump_at(pc); + jump->set_jump_destination((address) foreign_call_destination); + _instructions->relocate(jump->instruction_address(), runtime_call_Relocation::spec()); + } else { + JVMCI_ERROR("unknown call or jump instruction at " PTR_FORMAT, p2i(pc)); + } + TRACE_jvmci_3("relocating (foreign call) at " PTR_FORMAT, p2i(inst)); } void CodeInstaller::pd_relocate_JavaMethod(Handle hotspot_method, jint pc_offset, TRAPS) { - Unimplemented(); +#ifdef ASSERT + Method* method = NULL; + // we need to check, this might also be an unresolved method + if (hotspot_method->is_a(HotSpotResolvedJavaMethodImpl::klass())) { + method = getMethodFromHotSpotMethod(hotspot_method()); + } +#endif + switch (_next_call_type) { + case INLINE_INVOKE: + break; + case INVOKEVIRTUAL: + case INVOKEINTERFACE: { + assert(method == NULL || !method->is_static(), "cannot call static method with invokeinterface"); + NativeCall* call = nativeCall_at(_instructions->start() + pc_offset); + call->set_destination(SharedRuntime::get_resolve_virtual_call_stub()); + _instructions->relocate(call->instruction_address(), virtual_call_Relocation::spec(_invoke_mark_pc)); + break; + } + case INVOKESTATIC: { + assert(method == NULL || method->is_static(), "cannot call non-static method with invokestatic"); + NativeCall* call = nativeCall_at(_instructions->start() + pc_offset); + call->set_destination(SharedRuntime::get_resolve_static_call_stub()); + _instructions->relocate(call->instruction_address(), relocInfo::static_call_type); + break; + } + case INVOKESPECIAL: { + assert(method == NULL || !method->is_static(), "cannot call static method with invokespecial"); + NativeCall* call = nativeCall_at(_instructions->start() + pc_offset); + call->set_destination(SharedRuntime::get_resolve_opt_virtual_call_stub()); + _instructions->relocate(call->instruction_address(), relocInfo::opt_virtual_call_type); + break; + } + default: + JVMCI_ERROR("invalid _next_call_type value"); + break; + } } void CodeInstaller::pd_relocate_poll(address pc, jint mark, TRAPS) { - Unimplemented(); + switch (mark) { + case POLL_NEAR: + JVMCI_ERROR("unimplemented"); + break; + case POLL_FAR: + _instructions->relocate(pc, relocInfo::poll_type); + break; + case POLL_RETURN_NEAR: + JVMCI_ERROR("unimplemented"); + break; + case POLL_RETURN_FAR: + _instructions->relocate(pc, relocInfo::poll_return_type); + break; + default: + JVMCI_ERROR("invalid mark value"); + break; + } } // convert JVMCI register indices (as used in oop maps) to HotSpot registers VMReg CodeInstaller::get_hotspot_reg(jint jvmci_reg, TRAPS) { - return NULL; + if (jvmci_reg < RegisterImpl::number_of_registers) { + return as_Register(jvmci_reg)->as_VMReg(); + } else { + jint floatRegisterNumber = jvmci_reg - RegisterImpl::number_of_registers; + if (floatRegisterNumber < FloatRegisterImpl::number_of_registers) { + return as_FloatRegister(floatRegisterNumber)->as_VMReg(); + } + JVMCI_ERROR_NULL("invalid register number: %d", jvmci_reg); + } } bool CodeInstaller::is_general_purpose_reg(VMReg hotspotRegister) { - return false; + return !hotspotRegister->is_FloatRegister(); } diff --git a/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.cpp index 919eaa9ad0d..e36434cc183 100644 --- a/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.cpp @@ -136,7 +136,7 @@ void NativeMovConstReg::set_data(intptr_t x) { MacroAssembler::pd_patch_instruction(instruction_address(), (address)x); ICache::invalidate_range(instruction_address(), instruction_size); } -}; +} void NativeMovConstReg::print() { tty->print_cr(PTR_FORMAT ": mov reg, " INTPTR_FORMAT, @@ -208,6 +208,32 @@ void NativeJump::set_jump_destination(address dest) { //------------------------------------------------------------------- +address NativeGeneralJump::jump_destination() const { + NativeMovConstReg* move = nativeMovConstReg_at(instruction_address()); + address dest = (address) move->data(); + + // We use jump to self as the unresolved address which the inline + // cache code (and relocs) know about + + // return -1 if jump to self + dest = (dest == (address) this) ? (address) -1 : dest; + return dest; +} + +void NativeGeneralJump::set_jump_destination(address dest) { + NativeMovConstReg* move = nativeMovConstReg_at(instruction_address()); + + // We use jump to self as the unresolved address which the inline + // cache code (and relocs) know about + if (dest == (address) -1) { + dest = instruction_address(); + } + + move->set_data((uintptr_t) dest); +}; + +//------------------------------------------------------------------- + bool NativeInstruction::is_safepoint_poll() { // a safepoint_poll is implemented in two steps as either // @@ -249,6 +275,22 @@ bool NativeInstruction::is_ldrw_to_zr(address instr) { Instruction_aarch64::extract(insn, 4, 0) == 0b11111); } +bool NativeInstruction::is_general_jump() { + if (is_movz()) { + NativeInstruction* inst1 = nativeInstruction_at(addr_at(instruction_size * 1)); + if (inst1->is_movk()) { + NativeInstruction* inst2 = nativeInstruction_at(addr_at(instruction_size * 2)); + if (inst2->is_movk()) { + NativeInstruction* inst3 = nativeInstruction_at(addr_at(instruction_size * 3)); + if (inst3->is_blr()) { + return true; + } + } + } + } + return false; +} + bool NativeInstruction::is_movz() { return Instruction_aarch64::extract(int_at(0), 30, 23) == 0b10100101; } diff --git a/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.hpp b/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.hpp index d6b0cb84298..72c3479659c 100644 --- a/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.hpp +++ b/hotspot/src/cpu/aarch64/vm/nativeInst_aarch64.hpp @@ -54,11 +54,22 @@ class NativeInstruction VALUE_OBJ_CLASS_SPEC { friend class Relocation; friend bool is_NativeCallTrampolineStub_at(address); public: - enum { instruction_size = 4 }; + enum { + instruction_size = 4 + }; + + juint encoding() const { + return uint_at(0); + } + + bool is_blr() const { return (encoding() & 0xfffffc1f) == 0xd63f0000; } + bool is_adr_aligned() const { return (encoding() & 0xff000000) == 0x10000000; } // adr Xn,