/hg/icedtea6: Backport of 6918065 fix.

ptisnovs at icedtea.classpath.org ptisnovs at icedtea.classpath.org
Mon Jun 27 08:47:06 PDT 2011


changeset 562d984677e8 in /hg/icedtea6
details: http://icedtea.classpath.org/hg/icedtea6?cmd=changeset;node=562d984677e8
author: ptisnovs
date: Mon Jun 27 17:46:58 2011 +0200

	Backport of 6918065 fix.


diffstat:

 ChangeLog                                               |   7 ++
 Makefile.am                                             |   3 +-
 NEWS                                                    |   1 +
 patches/openjdk/6918065-Crash_in_Java2D_blit_loop.patch |  56 +++++++++++++++++
 4 files changed, 66 insertions(+), 1 deletions(-)

diffs (100 lines):

diff -r 6c45515ce78a -r 562d984677e8 ChangeLog
--- a/ChangeLog	Mon Jun 27 16:21:50 2011 +0200
+++ b/ChangeLog	Mon Jun 27 17:46:58 2011 +0200
@@ -1,3 +1,10 @@
+2011-06-27  Pavel Tisnovsky  <ptisnovs at redhat.com>
+
+	* Makefile.am: added new patch
+	* NEWS: updated with backport
+	* patches/openjdk/6918065-Crash_in_Java2D_blit_loop.patch:
+	Backport of 6918065 fix.
+
 2011-06-27  Xerxes RÃ¥nby  <xerxes at zafena.se>
 
 	JamVM
diff -r 6c45515ce78a -r 562d984677e8 Makefile.am
--- a/Makefile.am	Mon Jun 27 16:21:50 2011 +0200
+++ b/Makefile.am	Mon Jun 27 17:46:58 2011 +0200
@@ -365,7 +365,8 @@
 	patches/jtreg-MappedByteBuffer-Basic.patch \
 	patches/openjdk/7008106-WindowOpacity.patch \
 	patches/openjdk/6956668-misbehavior_of_XOR_operator_with_int.patch \
-	patches/openjdk/6699843-IllegalArgumentException_drawString.patch
+	patches/openjdk/6699843-IllegalArgumentException_drawString.patch \
+	patches/openjdk/6918065-Crash_in_Java2D_blit_loop.patch
 
 if WITH_ALT_HSBUILD
 ICEDTEA_PATCHES += \
diff -r 6c45515ce78a -r 562d984677e8 NEWS
--- a/NEWS	Mon Jun 27 16:21:50 2011 +0200
+++ b/NEWS	Mon Jun 27 17:46:58 2011 +0200
@@ -37,6 +37,7 @@
   - S7008106: com/sun/awt/Translucency/WindowOpacity.java test fails.
   - S6956668: misbehavior of XOR operator (^) with int
   - S6699843: IllegalArgumentException when using Graphics.drawString( "", 0, 0 )
+  - S6918065: Crash in Java2D blit loop (IntArgbToIntArgbPreSrcOverMaskBlit) in 64bit mode
 * Bug fixes
   - PR637: make check should exit with an error code if any regression test failed.
   - G356743: Support libpng 1.5.
diff -r 6c45515ce78a -r 562d984677e8 patches/openjdk/6918065-Crash_in_Java2D_blit_loop.patch
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/patches/openjdk/6918065-Crash_in_Java2D_blit_loop.patch	Mon Jun 27 17:46:58 2011 +0200
@@ -0,0 +1,58 @@
+# HG changeset patch
+# User minqi
+# Date 1268076930 28800
+# Node ID 1d7db2d5c4c5eeea61b23a6f6ca4d304dec8df10
+# Parent  840601ac5ab7cf49421e9de10c9c36c8f958d9cf
+6918065: Crash in Java2D blit loop (IntArgbToIntArgbPreSrcOverMaskBlit) in 64bit mode
+Reviewed-by: igor, bae
+
+diff -r 840601ac5ab7 -r 1d7db2d5c4c5 src/share/classes/java/awt/AlphaComposite.java
+--- openjdk.orig/jdk/src/share/classes/java/awt/AlphaComposite.java	Wed Mar 03 15:50:33 2010 +0100
++++ openjdk/jdk/src/share/classes/java/awt/AlphaComposite.java	Mon Mar 08 11:35:30 2010 -0800
+@@ -614,14 +614,15 @@
+     }
+ 
+     private AlphaComposite(int rule, float alpha) {
+-        if (alpha < 0.0f || alpha > 1.0f) {
+-            throw new IllegalArgumentException("alpha value out of range");
+-        }
+         if (rule < MIN_RULE || rule > MAX_RULE) {
+             throw new IllegalArgumentException("unknown composite rule");
+         }
+-        this.rule = rule;
+-        this.extraAlpha = alpha;
++        if (alpha >= 0.0f && alpha <= 1.0f) {
++            this.rule = rule;
++            this.extraAlpha = alpha;
++        } else {
++            throw new IllegalArgumentException("alpha value out of range");
++        }
+     }
+ 
+     /**
+diff -r 840601ac5ab7 -r 1d7db2d5c4c5 test/java/awt/AlphaComposite/TestAlphaCompositeForNaN.java
+--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
++++ openjdk/jdk/test/java/awt/AlphaComposite/TestAlphaCompositeForNaN.java	Mon Mar 08 11:35:30 2010 -0800
+@@ -0,0 +1,22 @@
++/*
++ * @test
++ * @bug 6918065
++ * @summary Test for passing NaN as alpha
++ *          should throw IllegalArgumentException
++ */
++
++import java.awt.*;
++
++public class TestAlphaCompositeForNaN {
++  public static void main(String[] args) {
++    try {
++      AlphaComposite a = AlphaComposite.getInstance(AlphaComposite.DST, Float.NaN);
++      System.out.println("Failed");
++      throw new RuntimeException(a + " failed to throw IllegalArgumentException for alpha = " + Float.NaN);
++    }
++    catch (IllegalArgumentException ie) {
++      System.out.println("Passed");
++      System.out.println("Caught " + ie);
++    }
++  }
++}



More information about the distro-pkg-dev mailing list