{"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-24T18:29:23.651517286Z","published":"2026-03-16T18:16:10.070Z","related":["CGA-pc6g-f7g9-qmgw","SUSE-SU-2026:1206-1","SUSE-SU-2026:1292-1","SUSE-SU-2026:1296-1","SUSE-SU-2026:1345-1","SUSE-SU-2026:1349-1","SUSE-SU-2026:1354-1","SUSE-SU-2026:1376-1","SUSE-SU-2026:1385-1","SUSE-SU-2026:1417-1","SUSE-SU-2026:1530-1","SUSE-SU-2026:21104-1","SUSE-SU-2026:21178-1","SUSE-SU-2026:21254-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","openSUSE-SU-2026:20517-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/pull/145987"},{"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"}],"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":{"source":"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-4224.json","vanir_signatures":[{"id":"CVE-2026-4224-1145783a","deprecated":false,"signature_type":"Line","digest":{"line_hashes":["188701065149302744903292699815939793812","225112604898349987932848100452221761889","315809415081504763774448517983428726485","234914540900971060388551978657761406688","334434387846354955252424964748103718253","92577595777153794298516478920240755603","220091315152752251870431644921983823692","64594070633644744458452436427253528782","317766121439223777877272278202999281929","207218985360249766238393458459053155997","332414183342212578807926701123345884195","109262523303062075784881971480718115622","185133554727397008437595184375700314015","241729027528270989764462123400629416761","87231708530024391086675116251100217789","304617511761474051284935710059506449414"],"threshold":0.9},"source":"https://github.com/python/cpython/commit/196edfb06a7458377d4d0f4b3cd41724c1f3bd4a","target":{"file":"Modules/pyexpat.c"},"signature_version":"v1"},{"id":"CVE-2026-4224-53a4bf80","deprecated":false,"signature_type":"Line","digest":{"line_hashes":["188701065149302744903292699815939793812","225112604898349987932848100452221761889","315809415081504763774448517983428726485","234914540900971060388551978657761406688","256181770944853825150391622812763691914","39371432675593491274749294336343520315","145357374662543992351282271062565055495","64594070633644744458452436427253528782","317766121439223777877272278202999281929","207218985360249766238393458459053155997","332414183342212578807926701123345884195","109262523303062075784881971480718115622","185133554727397008437595184375700314015","241729027528270989764462123400629416761","87231708530024391086675116251100217789","304617511761474051284935710059506449414"],"threshold":0.9},"source":"https://github.com/python/cpython/commit/eb0e8be3a7e11b87d198a2c3af1ed0eccf532768","signature_version":"v1","target":{"file":"Modules/pyexpat.c"}},{"id":"CVE-2026-4224-a989f4f9","deprecated":false,"signature_type":"Line","digest":{"line_hashes":["188701065149302744903292699815939793812","225112604898349987932848100452221761889","315809415081504763774448517983428726485","234914540900971060388551978657761406688","256181770944853825150391622812763691914","39371432675593491274749294336343520315","145357374662543992351282271062565055495","64594070633644744458452436427253528782","317766121439223777877272278202999281929","207218985360249766238393458459053155997","332414183342212578807926701123345884195","109262523303062075784881971480718115622","185133554727397008437595184375700314015","241729027528270989764462123400629416761","87231708530024391086675116251100217789","304617511761474051284935710059506449414"],"threshold":0.9},"source":"https://github.com/python/cpython/commit/e0a8a6da90597a924b300debe045cdb4628ee1f3","target":{"file":"Modules/pyexpat.c"},"signature_version":"v1"}],"vanir_signatures_modified":"2026-04-14T23:08:50Z"}}],"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"}]}