Bug 158011

Summary: [JSC] RegExp with deeply nested subexpressions overflow the stack in Yarr
Product: WebKit Reporter: Benjamin Poulain <benjamin>
Component: New BugsAssignee: Benjamin Poulain <benjamin>
Status: RESOLVED FIXED    
Severity: Normal CC: commit-queue, keith_miller, mark.lam, msaboff, saam
Priority: P2    
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch for landing
none
Archive of layout-test-results from webkit-cq-01 for mac-yosemite none

Benjamin Poulain
Reported 2016-05-23 21:14:45 PDT
[JSC] RegExp with deeply nested subexpressions overflow the stack in Yarr
Attachments
Patch (19.27 KB, patch)
2016-05-23 21:19 PDT, Benjamin Poulain
no flags
Patch for landing (19.28 KB, patch)
2016-05-25 17:50 PDT, Benjamin Poulain
no flags
Archive of layout-test-results from webkit-cq-01 for mac-yosemite (1.29 MB, application/zip)
2016-05-25 18:36 PDT, WebKit Commit Bot
no flags
Benjamin Poulain
Comment 1 2016-05-23 21:19:02 PDT
Alex Christensen
Comment 2 2016-05-23 22:42:38 PDT
Comment on attachment 279622 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=279622&action=review > Source/JavaScriptCore/yarr/YarrPattern.cpp:915 > return 0; nullptr > LayoutTests/js/script-tests/stack-overflow-regexp.js:13 > + recursiveCall(depth + 1); Does the maximum depth of the regex we can compile without throwing an error changes with the amount of stack we have used with the JavaScript stack? Also, can running the compiled regex cause unchecked stack overflows?
Saam Barati
Comment 3 2016-05-23 22:57:33 PDT
Comment on attachment 279622 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=279622&action=review r=me with comments > Source/JavaScriptCore/yarr/YarrPattern.cpp:653 > + if (!setupDisjunctionOffsets(term.parentheses.disjunction, currentCallFrameSize, currentInputPosition.unsafeGet(), currentCallFrameSize)) A way to hide away manually writing these branches is to add a macro called failIfStackOverflow which can just return if we've stack overflowed. The JS parser uses this paradigm and I think it's nicer to read. When we stack overflow you can set a bit in the class, and the macro can just query that bit. I'm not 100% tied to this style but I think it's nicer than the in-out parameter and branching on a bool result >> LayoutTests/js/script-tests/stack-overflow-regexp.js:13 >> + recursiveCall(depth + 1); > > Does the maximum depth of the regex we can compile without throwing an error changes with the amount of stack we have used with the JavaScript stack? > Also, can running the compiled regex cause unchecked stack overflows? Yeah the stack we have available for compilation is dependent on how much JS stack is use. Not sure about the answer to your second question but I suspect not because I don't think the YARR JIT will recurse in the code it emits.
Benjamin Poulain
Comment 4 2016-05-25 17:50:00 PDT
Created attachment 279845 [details] Patch for landing
Benjamin Poulain
Comment 5 2016-05-25 17:52:26 PDT
(In reply to comment #3) > Comment on attachment 279622 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=279622&action=review > > r=me with comments > > > Source/JavaScriptCore/yarr/YarrPattern.cpp:653 > > + if (!setupDisjunctionOffsets(term.parentheses.disjunction, currentCallFrameSize, currentInputPosition.unsafeGet(), currentCallFrameSize)) > > A way to hide away manually writing these branches is to add a macro called > failIfStackOverflow which can just return if we've stack overflowed. The JS > parser > uses this paradigm and I think it's nicer to read. When we stack overflow > you can > set a bit in the class, and the macro can just query that bit. I'm not 100% > tied to this style > but I think it's nicer than the in-out parameter and branching on a bool > result I went forward without this change. I think it does not generalize as well here. The overflow is only handled in a specific path of the builder, not thorough. Unlike the parser, adding a state seems like adding complexity.
WebKit Commit Bot
Comment 6 2016-05-25 18:36:43 PDT
Comment on attachment 279845 [details] Patch for landing Rejecting attachment 279845 [details] from commit-queue. Number of test failures exceeded the failure limit. Full output: http://webkit-queues.webkit.org/results/1383045
WebKit Commit Bot
Comment 7 2016-05-25 18:36:46 PDT
Created attachment 279847 [details] Archive of layout-test-results from webkit-cq-01 for mac-yosemite The attached test failures were seen while running run-webkit-tests on the commit-queue. Bot: webkit-cq-01 Port: mac-yosemite Platform: Mac OS X 10.10.5
WebKit Commit Bot
Comment 8 2016-05-25 20:17:57 PDT
Comment on attachment 279845 [details] Patch for landing Clearing flags on attachment: 279845 Committed r201412: <http://trac.webkit.org/changeset/201412>
WebKit Commit Bot
Comment 9 2016-05-25 20:18:04 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.