Search code examples
pngzlibchecksum

Adler-32 checksum(s) in a PNG file


I am currently writing a C program that builds a PNG image from a data file generated by another. The image is a palette type.

Is the Adler-32 checksum calculated on the uncompressed data for...

a) each compressed block within an IDAT data chunk?

b) all compressed blocks within an IDAT data chunk?

c) all compressed blocks spanning all IDAT data chunks?

From the documents at http://www.w3.org/TR/PNG/, https://www.rfc-editor.org/rfc/rfc1950 and rfc1951 (at the same address as previuos) I am of the opinion that it is case 'c' above, allowing one's deflate implementation to chop and change how the data are compressed for each block and disregard how the compressed blocks are split between consecutive IDAT chunks.

Is this correct?


Solution

  • There can be only one compressed image data stream in a PNG file, and that is a single zlib stream with a single Adler-32 check at the end that is the Adler-32 of all of the uncompressed data (as pre-processed by the filters and interlacing). That zlib stream may or may not be broken up into multiple IDAT chunks. Each IDAT chunk has its own CRC-32, which is the CRC-32 of the chunk type code "IDAT" and the compressed data within.

    I'm not sure what you mean by "allowing one's deflate implementation to chop and change how the data are compressed for each block". The deflate implementation for a valid PNG file must compress all of the filtered image data as a single zlib stream.

    After you've compressed it as a single zlib stream, you can break up that stream however you like into a series of IDAT chunks, or as a single IDAT chunk.