Merge pull request #892 from libexpat/taiyou-nextscaffoldpart-overflow

[CVE-2024-45492] lib: Detect integer overflow in function `nextScaffoldPart` (fixes #889)
This commit is contained in:
Sebastian Pipping 2024-09-03 18:18:03 +02:00 committed by GitHub
commit 29ef43a0ba
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -7569,6 +7569,15 @@ nextScaffoldPart(XML_Parser parser) {
int next;
if (! dtd->scaffIndex) {
/* Detect and prevent integer overflow.
* The preprocessor guard addresses the "always false" warning
* from -Wtype-limits on platforms where
* sizeof(unsigned int) < sizeof(size_t), e.g. on x86_64. */
#if UINT_MAX >= SIZE_MAX
if (parser->m_groupSize > ((size_t)(-1) / sizeof(int))) {
return -1;
}
#endif
dtd->scaffIndex = (int *)MALLOC(parser, parser->m_groupSize * sizeof(int));
if (! dtd->scaffIndex)
return -1;