-
Notifications
You must be signed in to change notification settings - Fork 466
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
Invalid tile part index
error on some JPEG 2000 files
#1558
Comments
Looking more closely at the working vs. nonworking JP2 files, it seems the one that does not exhibit the bad behavior only has one tile-part per tile. The issue still exists, but there's now an easy explanation for why one file works and the other doesn't. |
Re-creating the “working” JP2 with multiple tile parts causes the error again, so it seems to be happening whenever there is more than one tile-part per tile. |
More data: I decided to see if the index order mattered, and found that while I could not read the tiles from |
I've created several more images with different numbers of tiles and different numbers of parts per tile. Unfortunately, the workaround mentioned above doesn't work for most of them. It does get farther into the image with that code than without it, but it always bombs out again partway through. |
Expected behavior and actual behavior
Expected behavior: Calling
opj_get_decoded_tile
for each tile in an image should allow decoding of each tile in turnActual behavior: On some (not all) images, decoding fails with
Invalid tile part index for tile number 1. Got 7, expected 0
. This appears to be because of the reset ofm_current_tile_part_number
taking place here.opj_decompress
has no trouble at all with the image (either the full image or a single tile), and jpylyzer reports that the image is compliant with the JPEG 2000 spec.The problem was first discovered trying to load certain jp2 files into libvips. The issue was reported and investigated in libvips/libvips#4205. There is much more detailed debugging output attached to that issue.
I managed to reproduce the issue outside libvips and create a minimal example.
Steps to reproduce the problem.
Use this code and sample images: tile_part_index_error.zip
Compile and link
main.c
against libopenjp2, and then run the resulting binary with the name of the file to decode.notworking.jp2
is the file that causes the errorworking.jp2
does not cause the error. It is the exact same file decompressed and recompressed using:Operating system
Both Linux (Fedora 36) and MacOS (Sequoia 15.0.1)
openjpeg version
v2.5.2
The text was updated successfully, but these errors were encountered: