6355567: AdobeMarkerSegment causes failure to read valid JPEG

Reviewed-by: prr, serb
This commit is contained in:
Liam Miller-Cushon 2023-07-13 19:36:36 +00:00
parent af7f95e24a
commit c7c6d47a07
3 changed files with 69 additions and 8 deletions

View File

@ -55,15 +55,17 @@ class AdobeMarkerSegment extends MarkerSegment {
AdobeMarkerSegment(JPEGBuffer buffer) throws IOException {
super(buffer);
buffer.bufPtr += ID_SIZE; // Skip the id
version = (buffer.buf[buffer.bufPtr++] & 0xff) << 8;
version |= buffer.buf[buffer.bufPtr++] & 0xff;
flags0 = (buffer.buf[buffer.bufPtr++] & 0xff) << 8;
flags0 |= buffer.buf[buffer.bufPtr++] & 0xff;
flags1 = (buffer.buf[buffer.bufPtr++] & 0xff) << 8;
flags1 |= buffer.buf[buffer.bufPtr++] & 0xff;
transform = buffer.buf[buffer.bufPtr++] & 0xff;
int markPtr = buffer.bufPtr;
markPtr += ID_SIZE; // Skip the id
version = (buffer.buf[markPtr++] & 0xff) << 8;
version |= buffer.buf[markPtr++] & 0xff;
flags0 = (buffer.buf[markPtr++] & 0xff) << 8;
flags0 |= buffer.buf[markPtr++] & 0xff;
flags1 = (buffer.buf[markPtr++] & 0xff) << 8;
flags1 |= buffer.buf[markPtr++] & 0xff;
transform = buffer.buf[markPtr++] & 0xff;
buffer.bufAvail -= length;
buffer.bufPtr += length;
}
AdobeMarkerSegment(Node node) throws IIOInvalidTreeException {

View File

@ -0,0 +1,59 @@
/*
* Copyright 2023 Alphabet LLC. 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 6355567
* @summary Verifies that AdobeMarkerSegment() keeps the available bytes
* and buffer pointer in sync, when a non-standard length Adobe
* marker is encountered.
*/
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.imageio.ImageReader;
import javax.imageio.stream.ImageInputStream;
public class LargeAdobeMarkerSegmentTest {
private static String fileName = "jdk_6355567.jpg";
public static void main(String[] args) throws IOException {
/*
* Open a JPEG image, and get the metadata. Without the fix for
* 6355567, a NegativeArraySizeException is thrown while reading
* the metadata from the JPEG below.
*/
String sep = System.getProperty("file.separator");
String dir = System.getProperty("test.src", ".");
String filePath = dir+sep+fileName;
System.out.println("Test file: " + filePath);
File f = new File(filePath);
ImageInputStream iis = ImageIO.createImageInputStream(f);
ImageReader r = ImageIO.getImageReaders(iis).next();
r.setInput(iis);
r.getImageMetadata(0);
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 671 B