CVE-2026-33416

Published: March 26th, 2026
LIBPNG is a reference library for use in applications that read, create, and manipulate PNG (Portable Network Graphics) raster image files. In versions 1.2.1 through 1.6.55, `png_set_tRNS` and `png_set_PLTE` each alias a heap-allocated buffer between `png_struct` and `png_info`, sharing a single allocation across two structs with independent lifetimes. The `trans_alpha` aliasing has been present since at least libpng 1.0, and the `palette` aliasing since at least 1.2.1. Both affect all prior release lines `png_set_tRNS` sets `png_ptr->trans_alpha = info_ptr->trans_alpha` (256-byte buffer) and `png_set_PLTE` sets `info_ptr->palette = png_ptr->palette` (768-byte buffer). In both cases, calling `png_free_data` (with `PNG_FREE_TRNS` or `PNG_FREE_PLTE`) frees the buffer through `info_ptr` while the corresponding `png_ptr` pointer remains dangling. Subsequent row-transform functions dereference and, in some code paths, write to the freed memory. A second call to `png_set_tRNS` or `png_set_PLTE` has the same effect, because both functions call `png_free_data` internally before reallocating the `info_ptr` buffer. Version 1.6.56 fixes the issue.
HIGH
CVSS v3: 7.5

Status

DocFilters Release Package State Justification Comment
0.0.0.1 libpng (1.6.40) Needs Triage
26.1.1 libpng (1.6.40) Needs Triage
26.1 libpng (1.6.40) Needs Triage
25.4 libpng (1.6.40) Needs Triage
25.3 libpng (1.6.40) Needs Triage
25.2 libpng (1.6.40) Needs Triage
25.1.2 libpng (1.6.40) Needs Triage
25.1.1 libpng (1.6.40) Needs Triage
25.1 libpng (1.6.40) Needs Triage
24.4 libpng (1.6.40) Needs Triage
24.4.0 libpng (1.6.40) Needs Triage
24.3 libpng (1.6.40) Needs Triage
24.2.1 libpng (1.6.40) Needs Triage
24.2 libpng (1.6.40) Needs Triage
24.1 libpng (1.6.40) Needs Triage
23.3 libpng (1.6.40) Needs Triage
23.2.1 libpng (1.6.37) Needs Triage
23.2 libpng (1.6.37) Needs Triage
23.1 libpng (1.6.37) Needs Triage
22.4 libpng (1.6.37) Needs Triage
22.3 libpng (1.6.37) Needs Triage
22.2 libpng (1.6.37) Needs Triage
22.1 libpng (1.6.37) Needs Triage
21.11.1 libpng (1.6.37) Needs Triage
21.11 libpng (1.6.37) Needs Triage
21.8.1 libpng (1.6.37) Needs Triage
21.8 libpng (1.6.37) Needs Triage
21.5.1 libpng (1.6.37) Needs Triage
21.5.0 libpng (1.6.37) Needs Triage
21.2.0 libpng (1.6.37) Needs Triage
11.4.20 libpng (1.6.37) Needs Triage
11.4.19.3667 libpng (1.6.37) Needs Triage
11.4.18.3599 libpng (1.6.37) Needs Triage
11.4.17 libpng (1.6.37) Needs Triage
11.4.16.3445 libpng (1.6.28) Needs Triage
11.4.15.3368 libpng (1.6.28) Needs Triage
11.4.14.3263 libpng (1.6.28) Needs Triage
11.4.13.3179 libpng (1.6.28) Needs Triage
11.4.12.3054 libpng (1.6.28) Needs Triage
11.4.11.3040 libpng (1.6.28) Needs Triage
11.4.11.2990 libpng (1.6.28) Needs Triage
11.4.10.2934 libpng (1.6.28) Needs Triage
11.4.9.2878 libpng (1.6.28) Needs Triage
11.4.8.2822 libpng (1.6.28) Needs Triage

Severity score breakdown

Attack Complexity
HIGH
Attack Vector
NETWORK
Availability Impact
HIGH
Base Score
7.5
Base Severity
HIGH
Confidentiality Impact
HIGH
Integrity Impact
HIGH
Privileges Required
NONE
Scope
UNCHANGED
User Interaction
REQUIRED
Vector String
CVSS:3.1/AV:N/AC:H/PR:N/UI:R/S:U/C:H/I:H/A:H
Version
3.1

References