Home

Description

HTSlib is a library for reading and writing bioinformatics file formats. CRAM is a compressed format which stores DNA sequence alignment data using a variety of encodings and compression methods. While most alignment records store DNA sequence and quality values, the format also allows them to omit this data in certain cases to save space. Due to some quirks of the CRAM format, it is necessary to handle these records carefully as they will actually store data that needs to be consumed and then discarded. Unfortunately the `CONST`, `XPACK` and `XRLE` encodings did not properly implement the interface needed to do this. Trying to decode records with omitted sequence or quality data using these encodings would result in an attempt to write to a NULL pointer. Exploiting this bug causes a NULL pointer dereference. Typically this will cause the program to crash. Versions 1.23.1, 1.22.2 and 1.21.1 include fixes for this issue. There is no workaround for this issue.

PUBLISHED Reserved 2026-03-10 | Published 2026-03-18 | Updated 2026-03-18 | Assigner GitHub_M




MEDIUM: 6.9CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:L/VA:L/SC:N/SI:N/SA:N

Problem types

CWE-476: NULL Pointer Dereference

Product status

< 1.21.1
affected

>= 1.22, < 1.22.2
affected

= 1.23
affected

References

github.com/...htslib/security/advisories/GHSA-5w97-85gf-86rm

github.com/...ommit/e64e68da567d2309509d059ace016d5d7fc7514f

cve.org (CVE-2026-31964)

nvd.nist.gov (CVE-2026-31964)

Download JSON