Skip to content

Commit

Permalink
avifpng.c: Fix overflows in multiply with rowBytes
Browse files Browse the repository at this point in the history
Replace multiplication with rgb.rowBytes with addition of rgb.rowBytes
to a row pointer in a loop.

Related to AOMediaCodec#2271.
  • Loading branch information
wantehchang committed Jul 26, 2024
1 parent d1f5e66 commit 227293d
Showing 1 changed file with 13 additions and 9 deletions.
22 changes: 13 additions & 9 deletions apps/shared/avifpng.c
Original file line number Diff line number Diff line change
Expand Up @@ -484,8 +484,10 @@ avifBool avifPNGRead(const char * inputFilename,
fprintf(stderr, "avifPNGRead internal error: memory allocation failure");
goto cleanup;
}
uint8_t * rgbRow = rgb.pixels;
for (uint32_t y = 0; y < rgb.height; ++y) {
rowPointers[y] = &rgb.pixels[y * rgb.rowBytes];
rowPointers[y] = rgbRow;
rgbRow += rgb.rowBytes;
}
png_read_image(png, rowPointers);
if (avifImageRGBToYUV(avif, &rgb) != AVIF_RESULT_OK) {
Expand Down Expand Up @@ -712,16 +714,18 @@ avifBool avifPNGWrite(const char * outputFilename, const avifImage * avif, uint3
fprintf(stderr, "Error writing PNG: memory allocation failure");
goto cleanup;
}
uint8_t * row;
uint32_t rowBytes;
if (monochrome8bit) {
uint8_t * yPlane = avif->yuvPlanes[AVIF_CHAN_Y];
uint32_t yRowBytes = avif->yuvRowBytes[AVIF_CHAN_Y];
for (uint32_t y = 0; y < avif->height; ++y) {
rowPointers[y] = &yPlane[y * yRowBytes];
}
row = avif->yuvPlanes[AVIF_CHAN_Y];
rowBytes = avif->yuvRowBytes[AVIF_CHAN_Y];
} else {
for (uint32_t y = 0; y < avif->height; ++y) {
rowPointers[y] = &rgb.pixels[y * rgb.rowBytes];
}
row = rgb.pixels;
rowBytes = rgb.rowBytes;
}
for (uint32_t y = 0; y < avif->height; ++y) {
rowPointers[y] = row;
row += rowBytes;
}
if (avifImageGetExifOrientationFromIrotImir(avif) != 1) {
// TODO(yguyon): Rotate the samples.
Expand Down

0 comments on commit 227293d

Please sign in to comment.