Index: core/src/fpdfapi/fpdf_parser/fpdf_parser_parser.cpp |
diff --git a/core/src/fpdfapi/fpdf_parser/fpdf_parser_parser.cpp b/core/src/fpdfapi/fpdf_parser/fpdf_parser_parser.cpp |
index 010b9b7c47213306e2d0d0a6ef1e50dbbd5cf9e5..08c63a65f52550c86b59648c78bea042337ffc0d 100644 |
--- a/core/src/fpdfapi/fpdf_parser/fpdf_parser_parser.cpp |
+++ b/core/src/fpdfapi/fpdf_parser/fpdf_parser_parser.cpp |
@@ -1191,6 +1191,11 @@ CPDF_Object* CPDF_Parser::ParseIndirectObject(CPDF_IndirectObjects* pObjList, |
if (!IsValidObjectNumber(objnum)) |
return nullptr; |
+ // Prevent circular parsing the same object. |
+ if (pdfium::ContainsKey(objnums_in_processing, objnum)) |
+ return nullptr; |
+ ScopedSetInsertion<FX_DWORD> local_insert(&objnums_in_processing, objnum); |
+ |
if (m_V5Type[objnum] == 1 || m_V5Type[objnum] == 255) { |
FX_FILESIZE pos = m_ObjectInfo[objnum].pos; |
if (pos <= 0) |