-
Notifications
You must be signed in to change notification settings - Fork 31
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PNG: extend roundtrip fuzzing to low bit depths #76
Comments
I've taken a stab at this, but the expansion function is tied to the rest of the decoding in not entirely trivial ways, so it's not just a matter of adding a wrapper that's only exposed when fuzzing as I hoped: #[cfg(fuzzing)]
pub fn some_function() {
some_function()
} |
It's tied in only one way that makes it annoying to handle small bit depths. It's And another annoying thing is that the spec contradicts itself Images with lower bit depths < 8 and PLTE chunks exists for which the spec says we use entries from 0-(2^bitdepth)-1 Png with small bit depths look like, assuming a bit depth of 4, look like So in order to read pLTE chunks correctly, we have to shift AAAA, load it's plTE chunk, get the value, and pack it back into That is a lot of work, and I'd prefer that we have the slogan I'd prefer I take this one on since you mentioned it is tied to the rest of the steps, it may not be easy and I may punt up and write a expansion to reduction pass instead, will close this when done. |
FWIW so far I'm looking at fuzzing the images with low bit depths but without a palette; e.g. 1-bit black-and-white ones. I haven't considered paletted images yet. Although another contributor has opened a PR for the |
I've been slowly working on this and it dawned to me that there is no fast way to do this and 8 bit/16 bit jpegs I'll add a pass to convert 8 bit images to low bit depths after I finish the alloc friendly png decoder |
Signed-off-by: caleb <[email protected]>
Just reading this thread a bit, you may be misunderstanding how the PLTE chunk works. When bit depth is lower there's fewer entries but each entry is stil r8g8b8. Lower bit depths affect how you get each index, but once you have the index it's just |
That was the initial confusion I had , but I did come to learn about it as you did But still, the problem again is that if you get the information from the ihdr chunk it reports < 8 bits, but then the PLTE chunk uses 8 bits. So then meaning the headers would report < 8bpp but the image would be 8 bpp for you to get any meaningful image.
No need for unwraping btw, bad for speed, just set it to black also allowed, the crate does it like zune-image/zune-png/src/decoder.rs Lines 1126 to 1163 in a30c3e1
|
That's just a natural part of all image format decoding. It's the same thing with BMP files. More specifically it's how all paletted image systems work. "bits per pixel" with paletted color means "bits per palette index" (because each pixel is one index), and the actual palette entries are essentially always going to be some format that's bigger than the index itself (because that's the point). EDIT: the thing with the palette is neat, I'll try using that soon. |
Cool, didn't know bmp works like that too. But again I don't see a use-case for supporting < 8bpp images since they make other parts slower as they have to take into consideration that hence why I explicitly expand to 8bpp.
Another cool feature of it is that the palette is 4 entries, which is 4*u8 = u32, hence for four component output, theoretically the compiler should optimize it to a single load and store but it fails on it |
I'd agree that, in general, the in-memory version of an image doesn't need to be less than 8 bits per channel. You really only need to support less than 8 bits per channel for storage on disk (either encoding or decoding). (the exception here would be for systems that actually use data that's less than 8 bits per channel directly, but those are relatively rare these days) |
Signed-off-by: caleb <[email protected]>
Signed-off-by: caleb <[email protected]>
Right now roundtrip fuzzing in PNG is disabled for bit depths lower than 8:
zune-image/zune-png/fuzz/fuzz_targets/roundtrip.rs
Line 17 in 008f02a
As noted here, zune-png expands the low bit depths up to 8 bits, but the fuzz target doesn't account for that.
The text was updated successfully, but these errors were encountered: