{"id":"CVE-2026-4224","details":"When an Expat parser with a registered ElementDeclHandler parses an inline\ndocument type definition containing a deeply nested content model a C stack\noverflow occurs.","aliases":["PSF-2026-12"],"modified":"2026-04-11T03:13:12.364835Z","published":"2026-03-16T18:16:10.070Z","related":["CGA-pc6g-f7g9-qmgw","SUSE-SU-2026:1206-1","openSUSE-SU-2026:10469-1","openSUSE-SU-2026:10477-1","openSUSE-SU-2026:10478-1","openSUSE-SU-2026:10479-1","openSUSE-SU-2026:10480-1","openSUSE-SU-2026:10481-1"],"references":[{"type":"WEB","url":"https://mail.python.org/archives/list/security-announce@python.org/thread/5M7CGUW3XBRY7II4DK43KF7NQQ3TPZ6R/"},{"type":"WEB","url":"http://www.openwall.com/lists/oss-security/2026/03/16/4"},{"type":"REPORT","url":"https://github.com/python/cpython/issues/145986"},{"type":"FIX","url":"https://github.com/python/cpython/commit/196edfb06a7458377d4d0f4b3cd41724c1f3bd4a"},{"type":"FIX","url":"https://github.com/python/cpython/commit/e0a8a6da90597a924b300debe045cdb4628ee1f3"},{"type":"FIX","url":"https://github.com/python/cpython/commit/eb0e8be3a7e11b87d198a2c3af1ed0eccf532768"},{"type":"FIX","url":"https://github.com/python/cpython/pull/145987"}],"affected":[{"ranges":[{"type":"GIT","repo":"https://github.com/python/cpython","events":[{"introduced":"0"},{"fixed":"196edfb06a7458377d4d0f4b3cd41724c1f3bd4a"}]},{"type":"GIT","repo":"https://github.com/python/cpython","events":[{"introduced":"0"},{"fixed":"e0a8a6da90597a924b300debe045cdb4628ee1f3"}]},{"type":"GIT","repo":"https://github.com/python/cpython","events":[{"introduced":"0"},{"fixed":"eb0e8be3a7e11b87d198a2c3af1ed0eccf532768"}]}],"versions":["v0.9.8","v0.9.9","v1.0.1","v1.0.2","v1.1","v1.1.1","v1.2","v1.2b1","v1.2b2","v1.2b3","v1.2b4","v1.3","v1.3b1","v1.4","v1.4b1","v1.4b2","v1.4b3","v1.5","v1.5.1","v1.5.2","v1.5.2a1","v1.5.2a2","v1.5.2b1","v1.5.2b2","v1.5.2c1","v1.5a1","v1.5a2","v1.5a3","v1.5a4","v1.5b1","v1.5b2","v1.6a1","v1.6a2","v2.0","v2.0b1","v2.0b2","v2.0c1","v2.1","v2.1a1","v2.1a2","v2.1b1","v2.1b2","v2.1c1","v2.1c2","v2.2a3","v2.3c1","v2.3c2","v2.4","v2.4a1","v2.4a2","v2.4a3","v2.4b1","v2.4b2","v2.4c1","v3.0a1","v3.0a2","v3.0a3","v3.0a4","v3.0a5","v3.0b1","v3.0b2","v3.0b3","v3.0rc1","v3.0rc2","v3.0rc3","v3.1","v3.10.0a1","v3.10.0a7","v3.11.0a3","v3.11.0a4","v3.11.0a5","v3.11.0a6","v3.11.0a7","v3.11.0b1","v3.12.0a1","v3.12.0a2","v3.12.0a3","v3.12.0a4","v3.12.0a5","v3.12.0a6","v3.12.0a7","v3.12.0b1","v3.13.0","v3.13.0a1","v3.13.0a2","v3.13.0a3","v3.13.0a4","v3.13.0a5","v3.13.0a6","v3.13.0b1","v3.13.0b2","v3.13.0b3","v3.13.0b4","v3.13.0rc1","v3.13.0rc2","v3.13.0rc3","v3.13.1","v3.13.10","v3.13.11","v3.13.12","v3.13.2","v3.13.3","v3.13.4","v3.13.5","v3.13.6","v3.13.7","v3.13.8","v3.14.0","v3.14.0a1","v3.14.0a2","v3.14.0a3","v3.14.0a4","v3.14.0a5","v3.14.0a6","v3.14.0a7","v3.14.0b1","v3.14.0b2","v3.14.0b3","v3.14.0b4","v3.14.0rc1","v3.14.0rc2","v3.14.0rc3","v3.14.1","v3.14.2","v3.14.3","v3.15.0a1","v3.15.0a2","v3.15.0a3","v3.15.0a4","v3.15.0a5","v3.15.0a6","v3.15.0a7","v3.1a1","v3.1a2","v3.1b1","v3.1rc1","v3.1rc2","v3.2a1","v3.2a2","v3.2a3","v3.2a4","v3.2b1","v3.2b2","v3.2rc1","v3.2rc2","v3.2rc3","v3.3.0a2","v3.3.0a3","v3.3.0a4","v3.3.0b1","v3.3.0b2","v3.3.0rc1","v3.3.0rc2","v3.3.0rc3","v3.4.0a1","v3.4.0a2","v3.4.0a3","v3.4.0a4","v3.4.0b1","v3.4.0b2","v3.4.0b3","v3.5.0a1","v3.5.0a2","v3.5.0a3","v3.5.0a4","v3.5.0b1","v3.6.0a3","v3.6.0b1","v3.7.0a2","v3.9.0a2"],"database_specific":{"vanir_signatures":[{"target":{"file":"Modules/pyexpat.c"},"id":"CVE-2026-4224-1145783a","deprecated":false,"digest":{"threshold":0.9,"line_hashes":["188701065149302744903292699815939793812","225112604898349987932848100452221761889","315809415081504763774448517983428726485","234914540900971060388551978657761406688","334434387846354955252424964748103718253","92577595777153794298516478920240755603","220091315152752251870431644921983823692","64594070633644744458452436427253528782","317766121439223777877272278202999281929","207218985360249766238393458459053155997","332414183342212578807926701123345884195","109262523303062075784881971480718115622","185133554727397008437595184375700314015","241729027528270989764462123400629416761","87231708530024391086675116251100217789","304617511761474051284935710059506449414"]},"signature_version":"v1","signature_type":"Line","source":"https://github.com/python/cpython/commit/196edfb06a7458377d4d0f4b3cd41724c1f3bd4a"},{"target":{"file":"Modules/pyexpat.c"},"id":"CVE-2026-4224-53a4bf80","deprecated":false,"digest":{"threshold":0.9,"line_hashes":["188701065149302744903292699815939793812","225112604898349987932848100452221761889","315809415081504763774448517983428726485","234914540900971060388551978657761406688","256181770944853825150391622812763691914","39371432675593491274749294336343520315","145357374662543992351282271062565055495","64594070633644744458452436427253528782","317766121439223777877272278202999281929","207218985360249766238393458459053155997","332414183342212578807926701123345884195","109262523303062075784881971480718115622","185133554727397008437595184375700314015","241729027528270989764462123400629416761","87231708530024391086675116251100217789","304617511761474051284935710059506449414"]},"signature_version":"v1","signature_type":"Line","source":"https://github.com/python/cpython/commit/eb0e8be3a7e11b87d198a2c3af1ed0eccf532768"},{"target":{"file":"Modules/pyexpat.c"},"id":"CVE-2026-4224-a989f4f9","deprecated":false,"digest":{"threshold":0.9,"line_hashes":["188701065149302744903292699815939793812","225112604898349987932848100452221761889","315809415081504763774448517983428726485","234914540900971060388551978657761406688","256181770944853825150391622812763691914","39371432675593491274749294336343520315","145357374662543992351282271062565055495","64594070633644744458452436427253528782","317766121439223777877272278202999281929","207218985360249766238393458459053155997","332414183342212578807926701123345884195","109262523303062075784881971480718115622","185133554727397008437595184375700314015","241729027528270989764462123400629416761","87231708530024391086675116251100217789","304617511761474051284935710059506449414"]},"signature_version":"v1","signature_type":"Line","source":"https://github.com/python/cpython/commit/e0a8a6da90597a924b300debe045cdb4628ee1f3"}],"vanir_signatures_modified":"2026-04-11T03:13:12Z","source":"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-4224.json"}}],"schema_version":"1.7.5","severity":[{"type":"CVSS_V4","score":"CVSS:4.0/AV:N/AC:L/AT:P/PR:L/UI:N/VC:N/VI:N/VA:H/SC:N/SI:N/SA:N/E:X/CR:X/IR:X/AR:X/MAV:X/MAC:X/MAT:X/MPR:X/MUI:X/MVC:X/MVI:X/MVA:X/MSC:X/MSI:X/MSA:X/S:X/AU:X/R:X/V:X/RE:X/U:X"}]}