Merge
authorlana
Wed, 26 Oct 2011 17:59:13 -0700
changeset 10864 17307b96ae38
parent 10779 5037da29fa26 (diff)
parent 10762 cc1f5ce8e504 (current diff)
child 10865 7f8dd1713604
Merge
hotspot/agent/src/os/solaris/dbx/Makefile
hotspot/agent/src/os/solaris/dbx/README
hotspot/agent/src/os/solaris/dbx/README-commands.txt
hotspot/agent/src/os/solaris/dbx/helloWorld.cpp
hotspot/agent/src/os/solaris/dbx/proc_service_2.h
hotspot/agent/src/os/solaris/dbx/shell_imp.h
hotspot/agent/src/os/solaris/dbx/svc_agent_dbx.cpp
hotspot/agent/src/os/solaris/dbx/svc_agent_dbx.hpp
hotspot/agent/src/os/win32/BasicList.hpp
hotspot/agent/src/os/win32/Buffer.cpp
hotspot/agent/src/os/win32/Buffer.hpp
hotspot/agent/src/os/win32/Dispatcher.cpp
hotspot/agent/src/os/win32/Dispatcher.hpp
hotspot/agent/src/os/win32/Handler.hpp
hotspot/agent/src/os/win32/IOBuf.cpp
hotspot/agent/src/os/win32/IOBuf.hpp
hotspot/agent/src/os/win32/LockableList.hpp
hotspot/agent/src/os/win32/Makefile
hotspot/agent/src/os/win32/Message.hpp
hotspot/agent/src/os/win32/Monitor.cpp
hotspot/agent/src/os/win32/Monitor.hpp
hotspot/agent/src/os/win32/README-commands.txt
hotspot/agent/src/os/win32/README.txt
hotspot/agent/src/os/win32/Reaper.cpp
hotspot/agent/src/os/win32/Reaper.hpp
hotspot/agent/src/os/win32/SwDbgSrv.cpp
hotspot/agent/src/os/win32/SwDbgSrv.dsp
hotspot/agent/src/os/win32/SwDbgSrv.dsw
hotspot/agent/src/os/win32/SwDbgSub.cpp
hotspot/agent/src/os/win32/SwDbgSub.dsp
hotspot/agent/src/os/win32/initWinsock.cpp
hotspot/agent/src/os/win32/initWinsock.hpp
hotspot/agent/src/os/win32/ioUtils.cpp
hotspot/agent/src/os/win32/ioUtils.hpp
hotspot/agent/src/os/win32/isNT4.cpp
hotspot/agent/src/os/win32/isNT4.hpp
hotspot/agent/src/os/win32/libInfo.cpp
hotspot/agent/src/os/win32/libInfo.hpp
hotspot/agent/src/os/win32/nt4internals.cpp
hotspot/agent/src/os/win32/nt4internals.hpp
hotspot/agent/src/os/win32/ports.h
hotspot/agent/src/os/win32/procList.cpp
hotspot/agent/src/os/win32/procList.hpp
hotspot/agent/src/os/win32/serverLists.cpp
hotspot/agent/src/os/win32/serverLists.hpp
hotspot/agent/src/os/win32/toolHelp.cpp
hotspot/agent/src/os/win32/toolHelp.hpp
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/DbxAddress.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/DbxDebugger.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/DbxDebuggerLocal.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/DbxOopHandle.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/DbxThreadFactory.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/sparc/DbxSPARCThread.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/sparc/DbxSPARCThreadContext.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/sparc/DbxSPARCThreadFactory.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/x86/DbxX86Thread.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/x86/DbxX86ThreadContext.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/dbx/x86/DbxX86ThreadFactory.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/AddressDataSource.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/DLL.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/TestDebugger.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/TestHelloWorld.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32Address.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32CDebugInfoBuilder.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32CDebugger.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32Debugger.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32DebuggerLocal.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32LDTEntry.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32LDTEntryConstants.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32OopHandle.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32Thread.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/win32/Win32ThreadContext.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/runtime/amd64/AMD64Frame.java
hotspot/agent/src/share/classes/sun/jvm/hotspot/runtime/amd64/AMD64RegisterMap.java
hotspot/make/solaris/makefiles/mapfile-vers-nonproduct
hotspot/make/templates/bsd-header
hotspot/src/share/vm/runtime/reflectionCompat.hpp
jdk/src/share/classes/java/util/XMLUtils.java
jdk/src/share/classes/sun/tools/jar/JarImageSource.java
langtools/src/share/classes/com/sun/tools/javac/Launcher.java
--- a/jdk/src/solaris/classes/sun/print/UnixPrintServiceLookup.java	Wed Jul 05 17:53:50 2017 +0200
+++ b/jdk/src/solaris/classes/sun/print/UnixPrintServiceLookup.java	Wed Oct 26 17:59:13 2011 -0700
@@ -189,7 +189,7 @@
         if (printServices == null) {
             return new PrintService[0];
         } else {
-            return printServices;
+            return (PrintService[])printServices.clone();
         }
     }
 
--- a/jdk/src/windows/classes/sun/java2d/d3d/D3DSurfaceData.java	Wed Jul 05 17:53:50 2017 +0200
+++ b/jdk/src/windows/classes/sun/java2d/d3d/D3DSurfaceData.java	Wed Oct 26 17:59:13 2011 -0700
@@ -486,7 +486,7 @@
             int dataType = 0;
             int scanStride = width;
 
-            if (dcm.getPixelSize() == 24 || dcm.getPixelSize() == 32) {
+            if (dcm.getPixelSize() > 16) {
                 dataType = DataBuffer.TYPE_INT;
             } else {
                 // 15, 16
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/jdk/test/sun/java2d/DirectX/DrawBitmaskToSurfaceTest.java	Wed Oct 26 17:59:13 2011 -0700
@@ -0,0 +1,104 @@
+/*
+ * Copyright (c) 2011, 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     6997116
+ * @summary Test verifies that rendering of images with bitmap transparency
+ *          to a D3D surface does not cause an ClassCastException.
+ *
+ * @run main/othervm -Dsun.java2d.d3d=True DrawBitmaskToSurfaceTest
+ */
+
+import java.awt.Graphics;
+import java.awt.Image;
+import java.awt.image.BufferedImage;
+import java.awt.image.IndexColorModel;
+import java.util.concurrent.CountDownLatch;
+import javax.swing.JFrame;
+
+public class DrawBitmaskToSurfaceTest extends JFrame {
+
+    private final Image src;
+    private static java.util.concurrent.CountDownLatch latch = null;
+    private static Throwable theError = null;
+
+    public DrawBitmaskToSurfaceTest() {
+        src = createTestImage();
+    }
+
+    private static Image createTestImage() {
+        byte[] r = new byte[]{(byte)0x00, (byte)0x80, (byte)0xff, (byte)0xff};
+        byte[] g = new byte[]{(byte)0x00, (byte)0x80, (byte)0xff, (byte)0x00};
+        byte[] b = new byte[]{(byte)0x00, (byte)0x80, (byte)0xff, (byte)0x00};
+
+        IndexColorModel icm = new IndexColorModel(2, 4, r, g, b, 3);
+
+        BufferedImage img = new BufferedImage(100, 100,
+                                              BufferedImage.TYPE_BYTE_INDEXED,
+                                              icm);
+        return img;
+    }
+
+    @Override
+    public void paint(final Graphics g) {
+        try {
+            System.err.println("paint frame....");
+            g.drawImage(src, 30, 30, this);
+        } catch (Throwable e) {
+            theError = e;
+        } finally {
+            if (latch != null) {
+                latch.countDown();
+            }
+        }
+    }
+
+    public static void main(final String[] args) throws Exception {
+        final JFrame frame = new DrawBitmaskToSurfaceTest();
+        frame.setBounds(10, 350, 200, 200);
+        frame.setVisible(true);
+
+        Thread.sleep(2000);
+
+        System.err.println("Change frame bounds...");
+        latch = new CountDownLatch(1);
+        frame.setBounds(10, 350, 90, 90);
+        frame.repaint();
+
+        try {
+            if (latch.getCount() > 0) {
+                latch.await();
+            }
+        } catch (InterruptedException e) {
+        }
+
+        frame.dispose();
+
+        if (theError != null) {
+            throw new RuntimeException("Test failed.", theError);
+        }
+
+        System.err.println("Test passed");
+    }
+}