mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2025-10-24 13:33:01 +03:00
Prevent integer-overflow in htmlSkipBlankChars() and xmlSkipBlankChars()
* HTMLparser.c: (htmlSkipBlankChars): * parser.c: (xmlSkipBlankChars): - Cap the return value at INT_MAX. - The commit range that OSS-Fuzz listed for the fix didn't make any changes to xmlSkipBlankChars(), so it seems like this issue may still exist. Found by OSS-Fuzz Issue 44803.
This commit is contained in:
6
parser.c
6
parser.c
@@ -2202,7 +2202,8 @@ xmlSkipBlankChars(xmlParserCtxtPtr ctxt) {
|
||||
ctxt->input->col++;
|
||||
}
|
||||
cur++;
|
||||
res++;
|
||||
if (res < INT_MAX)
|
||||
res++;
|
||||
if (*cur == 0) {
|
||||
ctxt->input->cur = cur;
|
||||
xmlParserInputGrow(ctxt->input, INPUT_CHUNK);
|
||||
@@ -2238,7 +2239,8 @@ xmlSkipBlankChars(xmlParserCtxtPtr ctxt) {
|
||||
* by the attachment of one leading and one following space (#x20)
|
||||
* character."
|
||||
*/
|
||||
res++;
|
||||
if (res < INT_MAX)
|
||||
res++;
|
||||
}
|
||||
}
|
||||
return(res);
|
||||
|
Reference in New Issue
Block a user