RESOLVED FIXED 209312
[LFC][IFC] Bail out when busy looping on partial content
https://bugs.webkit.org/show_bug.cgi?id=209312
Summary [LFC][IFC] Bail out when busy looping on partial content
zalan
Reported 2020-03-19 15:13:52 PDT
Attachments
Patch (6.49 KB, patch)
2020-03-19 20:01 PDT, zalan
no flags
Patch (6.49 KB, patch)
2020-03-20 07:32 PDT, zalan
no flags
zalan
Comment 1 2020-03-19 20:01:13 PDT
Simon Fraser (smfr)
Comment 2 2020-03-19 20:09:22 PDT
Comment on attachment 394059 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=394059&action=review > Source/WebCore/ChangeLog:3 > + [LFC][IFC] Bail out when busy looping on partial content "Avoid infinite loop when..." > Source/WebCore/ChangeLog:9 > + Speculative fix to address busy looping/running out of inline run vector capacity at InlineFormattingContext::setDisplayBoxesForLine. "busy looping" sounds like something that happens over time. Is it really an infinite loop? > Source/WebCore/layout/inlineformatting/InlineFormattingContext.cpp:162 > + // "sp<->litcontent" -> overflow length: 10 -> leading partial content length: 10. Weird comment. > Source/WebCore/layout/inlineformatting/InlineFormattingContext.cpp:175 > + ASSERT_NOT_REACHED(); > + // Move over to the next run if we are stuck on this partial content (when the overflow content length remains the same). > + // We certainly lose some content, but we would be busy looping anyway. > + previousLineEnd = PreviousLineEnd { trailingRunIndex, { } }; > + layoutRange.start = previousLineEnd->runIndex + 1; Weird to assert and then run code.
zalan
Comment 3 2020-03-20 07:32:57 PDT
EWS
Comment 4 2020-03-20 07:59:49 PDT
Committed r258761: <https://trac.webkit.org/changeset/258761> All reviewed patches have been landed. Closing bug and clearing flags on attachment 394081 [details].
Note You need to log in before you can comment on or make changes to this bug.