CVE-2026-33636

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.6.36 through 1.6.55, an out-of-bounds read and write exists in libpng's ARM/AArch64 Neon-optimized palette expansion path. When expanding 8-bit paletted rows to RGB or RGBA, the Neon loop processes a final partial chunk without verifying that enough input pixels remain. Because the implementation works backward from the end of the row, the final iteration dereferences pointers before the start of the row buffer (OOB read) and writes expanded pixel data to the same underflowed positions (OOB write). This is reachable via normal decoding of attacker-controlled PNG input if Neon is enabled. Version 1.6.56 fixes the issue.
HIGH
CVSS v3: 7.6

Status

DocFilters Release Package State Justification Comment
26.2 libpng (1.6.40) Resolved Code Not Present Patched applied from https://github.com/pnggroup/libpng/commit/aba9f18eba870d14fb52c5ba5d73451349e339c3
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 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 libpng (1.6.40) Needs Triage
24.1 libpng (1.6.40) Needs Triage
23.3 libpng (1.6.40) 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 libpng (1.6.37) Needs Triage
21.8 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.19.3667 libpng (1.6.37) Needs Triage
11.4.18.3599 libpng (1.6.37) Needs Triage
11.4.16.3445 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.15.3368 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.14.3263 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.13.3179 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.12.3054 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.11.3040 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.11.2990 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.10.2934 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.9.2878 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.
11.4.8.2822 libpng (1.6.28) Not Affected Code Not Present 1.6.28 does not match CVE configuration.

Severity score breakdown

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

References