Skip to content

Commit

Permalink
Revert "Tiff decoding robustness improvements (#2550)"
Browse files Browse the repository at this point in the history
(accidental push to unprotected branch)
  • Loading branch information
antonfirsov committed Oct 16, 2023
1 parent f65ffaa commit d0a024f
Show file tree
Hide file tree
Showing 7 changed files with 31 additions and 75 deletions.
45 changes: 25 additions & 20 deletions src/ImageSharp/Compression/Zlib/ZlibInflateStream.cs
Original file line number Diff line number Diff line change
Expand Up @@ -161,25 +161,29 @@ public override int Read(byte[] buffer, int offset, int count)
bytesToRead = Math.Min(count - totalBytesRead, this.currentDataRemaining);
this.currentDataRemaining -= bytesToRead;
bytesRead = this.innerStream.Read(buffer, offset, bytesToRead);
if (bytesRead == 0)
{
return totalBytesRead;
}

totalBytesRead += bytesRead;
}

return totalBytesRead;
}

/// <inheritdoc/>
public override long Seek(long offset, SeekOrigin origin) => throw new NotSupportedException();
public override long Seek(long offset, SeekOrigin origin)
{
throw new NotSupportedException();
}

/// <inheritdoc/>
public override void SetLength(long value) => throw new NotSupportedException();
public override void SetLength(long value)
{
throw new NotSupportedException();
}

/// <inheritdoc/>
public override void Write(byte[] buffer, int offset, int count) => throw new NotSupportedException();
public override void Write(byte[] buffer, int offset, int count)
{
throw new NotSupportedException();
}

/// <inheritdoc/>
protected override void Dispose(bool disposing)
Expand Down Expand Up @@ -242,17 +246,22 @@ private bool InitializeInflateStream(bool isCriticalChunk)
// CINFO is not defined in this specification for CM not equal to 8.
throw new ImageFormatException($"Invalid window size for ZLIB header: cinfo={cinfo}");
}

return false;
else
{
return false;
}
}
}
else if (isCriticalChunk)
{
throw new ImageFormatException($"Bad method for ZLIB header: cmf={cmf}");
}
else
{
return false;
if (isCriticalChunk)
{
throw new ImageFormatException($"Bad method for ZLIB header: cmf={cmf}");
}
else
{
return false;
}
}

// The preset dictionary.
Expand All @@ -261,11 +270,7 @@ private bool InitializeInflateStream(bool isCriticalChunk)
{
// We don't need this for inflate so simply skip by the next four bytes.
// https://tools.ietf.org/html/rfc1950#page-6
if (this.innerStream.Read(ChecksumBuffer, 0, 4) != 4)
{
return false;
}

this.innerStream.Read(ChecksumBuffer, 0, 4);
this.currentDataRemaining -= 4;
}

Expand Down
22 changes: 6 additions & 16 deletions src/ImageSharp/Formats/Tiff/Ifd/DirectoryReader.cs
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ public DirectoryReader(Stream stream, MemoryAllocator allocator)
public IList<ExifProfile> Read()
{
this.ByteOrder = ReadByteOrder(this.stream);
HeaderReader headerReader = new(this.stream, this.ByteOrder);
var headerReader = new HeaderReader(this.stream, this.ByteOrder);
headerReader.ReadFileHeader();

this.nextIfdOffset = headerReader.FirstIfdOffset;
Expand All @@ -52,12 +52,7 @@ public IList<ExifProfile> Read()
private static ByteOrder ReadByteOrder(Stream stream)
{
Span<byte> headerBytes = stackalloc byte[2];

if (stream.Read(headerBytes) != 2)
{
throw TiffThrowHelper.ThrowInvalidHeader();
}

stream.Read(headerBytes);
if (headerBytes[0] == TiffConstants.ByteOrderLittleEndian && headerBytes[1] == TiffConstants.ByteOrderLittleEndian)
{
return ByteOrder.LittleEndian;
Expand All @@ -73,10 +68,10 @@ private static ByteOrder ReadByteOrder(Stream stream)

private IList<ExifProfile> ReadIfds(bool isBigTiff)
{
List<EntryReader> readers = new();
var readers = new List<EntryReader>();
while (this.nextIfdOffset != 0 && this.nextIfdOffset < (ulong)this.stream.Length)
{
EntryReader reader = new(this.stream, this.ByteOrder, this.allocator);
var reader = new EntryReader(this.stream, this.ByteOrder, this.allocator);
reader.ReadTags(isBigTiff, this.nextIfdOffset);

if (reader.BigValues.Count > 0)
Expand All @@ -90,11 +85,6 @@ private IList<ExifProfile> ReadIfds(bool isBigTiff)
}
}

if (this.nextIfdOffset >= reader.NextIfdOffset && reader.NextIfdOffset != 0)
{
TiffThrowHelper.ThrowImageFormatException("TIFF image contains circular directory offsets");
}

this.nextIfdOffset = reader.NextIfdOffset;
readers.Add(reader);

Expand All @@ -104,11 +94,11 @@ private IList<ExifProfile> ReadIfds(bool isBigTiff)
}
}

List<ExifProfile> list = new(readers.Count);
var list = new List<ExifProfile>(readers.Count);
foreach (EntryReader reader in readers)
{
reader.ReadBigValues();
ExifProfile profile = new(reader.Values, reader.InvalidTags);
var profile = new ExifProfile(reader.Values, reader.InvalidTags);
list.Add(profile);
}

Expand Down
28 changes: 0 additions & 28 deletions tests/ImageSharp.Tests/Formats/Tiff/TiffDecoderTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@

// ReSharper disable InconsistentNaming
using System.Runtime.InteropServices;
using System.Runtime.Intrinsics.X86;
using SixLabors.ImageSharp.Formats;
using SixLabors.ImageSharp.Formats.Tiff;
using SixLabors.ImageSharp.Metadata;
Expand Down Expand Up @@ -687,33 +686,6 @@ public void TiffDecoder_ThrowsException_WithTooManyDirectories<TPixel>(TestImage
public void TiffDecoder_CanDecode_Fax4CompressedWithStrips<TPixel>(TestImageProvider<TPixel> provider)
where TPixel : unmanaged, IPixel<TPixel> => TestTiffDecoder(provider);


[Theory]
[WithFile(JpegCompressedGray0000539558, PixelTypes.Rgba32)]
public void TiffDecoder_ThrowsException_WithCircular_IFD_Offsets<TPixel>(TestImageProvider<TPixel> provider)
where TPixel : unmanaged, IPixel<TPixel>
=> Assert.Throws<ImageFormatException>(
() =>
{
using (provider.GetImage(TiffDecoder.Instance))
{
}
});

[Theory]
[WithFile(Tiled0000023664, PixelTypes.Rgba32)]
public void TiffDecoder_CanDecode_TiledWithBadZlib<TPixel>(TestImageProvider<TPixel> provider)
where TPixel : unmanaged, IPixel<TPixel>
{
using Image<TPixel> image = provider.GetImage(TiffDecoder.Instance);

// ImageMagick cannot decode this image.
image.DebugSave(provider);
image.CompareToReferenceOutput(
ImageComparer.Exact,
provider,
appendPixelTypeToFileName: false);
}
[Theory]
[WithFileCollection(nameof(MultiframeTestImages), PixelTypes.Rgba32)]
public void DecodeMultiframe<TPixel>(TestImageProvider<TPixel> provider)
Expand Down
2 changes: 0 additions & 2 deletions tests/ImageSharp.Tests/TestImages.cs
Original file line number Diff line number Diff line change
Expand Up @@ -965,8 +965,6 @@ public static class Tiff
public const string Issues2123 = "Tiff/Issues/Issue2123.tiff";
public const string Issues2149 = "Tiff/Issues/Group4CompressionWithStrips.tiff";
public const string Issues2255 = "Tiff/Issues/Issue2255.png";
public const string JpegCompressedGray0000539558 = "Tiff/Issues/JpegCompressedGray-0000539558.tiff";
public const string Tiled0000023664 = "Tiff/Issues/tiled-0000023664.tiff";

public const string SmallRgbDeflate = "Tiff/rgb_small_deflate.tiff";
public const string SmallRgbLzw = "Tiff/rgb_small_lzw.tiff";
Expand Down

This file was deleted.

This file was deleted.

3 changes: 0 additions & 3 deletions tests/Images/Input/Tiff/Issues/tiled-0000023664.tiff

This file was deleted.

0 comments on commit d0a024f

Please sign in to comment.