summaryrefslogtreecommitdiff
path: root/java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch
diff options
context:
space:
mode:
Diffstat (limited to 'java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch')
-rw-r--r--java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch194
1 files changed, 194 insertions, 0 deletions
diff --git a/java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch b/java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch
new file mode 100644
index 000000000000..24420ccfb189
--- /dev/null
+++ b/java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch
@@ -0,0 +1,194 @@
+# HG changeset patch
+# User mullan
+# Date 1287154559 14400
+# Fri Oct 15 10:55:59 2010 -0400
+# Node ID 5e3c766d18092d498d9019827c1058a32f1c4e2a
+# Parent e5a4a4ec7b21f3d092d0b29024ff903864d05543
+6954275: XML signatures with reference data larger 16KB and cacheRef on fails to validate
+Reviewed-by: xuelei
+
+diff -r e5a4a4ec7b21 -r 5e3c766d1809 src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java
+--- jdk/src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java Mon Oct 28 21:46:43 2013 +0000
++++ jdk/src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java Fri Oct 15 10:55:59 2010 -0400
+@@ -3,7 +3,7 @@
+ * DO NOT REMOVE OR ALTER!
+ */
+ /*
+- * Copyright 1999-2005 The Apache Software Foundation.
++ * Copyright 1999-2010 The Apache Software Foundation.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+@@ -23,66 +23,70 @@
+ import java.io.OutputStream;
+
+ /**
+- * A simple Unsynced ByteArryOutputStream
++ * A simple Unsynced ByteArrayOutputStream
+ * @author raul
+ *
+ */
+ public class UnsyncByteArrayOutputStream extends OutputStream {
+- private static ThreadLocal bufCahce = new ThreadLocal() {
++ private static final int INITIAL_SIZE = 8192;
++ private static ThreadLocal bufCache = new ThreadLocal() {
+ protected synchronized Object initialValue() {
+- return new byte[8*1024];
++ return new byte[INITIAL_SIZE];
+ }
+ };
+- byte[] buf;
+- int size=8*1024;//buf.length;
+- int pos=0;
+- public UnsyncByteArrayOutputStream() {
+- buf=(byte[])bufCahce.get();
++
++ private byte[] buf;
++ private int size = INITIAL_SIZE;
++ private int pos = 0;
++
++ public UnsyncByteArrayOutputStream() {
++ buf = (byte[])bufCache.get();
++ }
++
++ public void write(byte[] arg0) {
++ int newPos = pos + arg0.length;
++ if (newPos > size) {
++ expandSize(newPos);
+ }
+- /** @inheritDoc */
+- public void write(byte[] arg0) {
+- int newPos=pos+arg0.length;
+- if (newPos>size) {
+- expandSize();
+- }
+- System.arraycopy(arg0,0,buf,pos,arg0.length);
+- pos=newPos;
++ System.arraycopy(arg0, 0, buf, pos, arg0.length);
++ pos = newPos;
++ }
++
++ public void write(byte[] arg0, int arg1, int arg2) {
++ int newPos = pos + arg2;
++ if (newPos > size) {
++ expandSize(newPos);
+ }
+- /** @inheritDoc */
+- public void write(byte[] arg0, int arg1, int arg2) {
+- int newPos=pos+arg2;
+- if (newPos>size) {
+- expandSize();
+- }
+- System.arraycopy(arg0,arg1,buf,pos,arg2);
+- pos=newPos;
++ System.arraycopy(arg0, arg1, buf, pos, arg2);
++ pos = newPos;
++ }
++
++ public void write(int arg0) {
++ int newPos = pos + 1;
++ if (newPos > size) {
++ expandSize(newPos);
+ }
+- /** @inheritDoc */
+- public void write(int arg0) {
+- if (pos>=size) {
+- expandSize();
+- }
+- buf[pos++]=(byte)arg0;
++ buf[pos++] = (byte)arg0;
++ }
++
++ public byte[] toByteArray() {
++ byte result[] = new byte[pos];
++ System.arraycopy(buf, 0, result, 0, pos);
++ return result;
++ }
++
++ public void reset() {
++ pos = 0;
++ }
++
++ private void expandSize(int newPos) {
++ int newSize = size;
++ while (newPos > newSize) {
++ newSize = newSize<<2;
+ }
+- /** @inheritDoc */
+- public byte[] toByteArray() {
+- byte result[]=new byte[pos];
+- System.arraycopy(buf,0,result,0,pos);
+- return result;
+- }
+-
+- /** @inheritDoc */
+- public void reset() {
+- pos=0;
+- }
+-
+- /** @inheritDoc */
+- void expandSize() {
+- int newSize=size<<2;
+- byte newBuf[]=new byte[newSize];
+- System.arraycopy(buf,0,newBuf,0,pos);
+- buf=newBuf;
+- size=newSize;
+-
+- }
++ byte newBuf[] = new byte[newSize];
++ System.arraycopy(buf, 0, newBuf, 0, pos);
++ buf = newBuf;
++ size = newSize;
++ }
+ }
+diff -r e5a4a4ec7b21 -r 5e3c766d1809 test/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream/BufferOverflowTest.java
+--- /dev/null Thu Jan 01 00:00:00 1970 +0000
++++ jdk/test/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream/BufferOverflowTest.java Fri Oct 15 10:55:59 2010 -0400
+@@ -0,0 +1,47 @@
++/*
++ * Copyright (c) 2010, 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 %I% %E%
++ * @bug 6954275
++ * @summary Check that UnsyncByteArrayOutputStream does not
++ * throw ArrayIndexOutOfBoundsException
++ * @compile -XDignore.symbol.file BufferOverflowTest.java
++ * @run main BufferOverflowTest
++ */
++
++import com.sun.org.apache.xml.internal.security.utils.UnsyncByteArrayOutputStream;
++
++public class BufferOverflowTest {
++
++ public static void main(String[] args) throws Exception {
++ try {
++ UnsyncByteArrayOutputStream out = new UnsyncByteArrayOutputStream();
++ out.write(new byte[(8192) << 2 + 1]);
++ System.out.println("PASSED");
++ } catch (ArrayIndexOutOfBoundsException e) {
++ System.err.println("FAILED, got ArrayIndexOutOfBoundsException");
++ throw new Exception(e);
++ }
++ }
++}