Bug 150434

Summary: REGRESSION(r191360): Repro Crash: com.apple.WebKit.WebContent at ….apple.JavaScriptCore: JSC::ExecState::bytecodeOffset + 174
Product: WebKit Reporter: Michael Saboff <msaboff>
Component: JavaScriptCoreAssignee: Michael Saboff <msaboff>
Status: RESOLVED FIXED    
Severity: Normal Keywords: InRadar
Priority: P2    
Version: WebKit Nightly Build   
Hardware: All   
OS: All   
Attachments:
Description Flags
Patch mark.lam: review+

Michael Saboff
Reported 2015-10-21 21:19:00 PDT
Although this was found after r191360, this is really a tail call issue uncovered by enabling tail calls (again) in r191360. The issue here is that we are in a bound function that is tail calling a bound function where a exception is thrown or unhandled. The bound functions are called via a native wrapper which is called via the native call thunk. The exception processing in the native call thunk assumes that there is a direct JS caller. With tail calls enabled that is no longer true.
Attachments
Patch (5.91 KB, patch)
2015-10-21 21:35 PDT, Michael Saboff
mark.lam: review+
Michael Saboff
Comment 1 2015-10-21 21:24:10 PDT
Michael Saboff
Comment 2 2015-10-21 21:35:56 PDT
Mark Lam
Comment 3 2015-10-21 22:47:22 PDT
Comment on attachment 263790 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=263790&action=review You are now setting up these thunks to call operationVMHandleException() with a CallFrame that has a null codeBlock. operationVMHandleException() calls genericUnwind(), and genericUnwind() starts with: if (Options::breakOnThrow()) { dataLog("In call frame ", RawPointer(callFrame), " for code block ", *callFrame->codeBlock(), "\n"); CRASH(); } Can you also please fix the above code in genericUnwind() to not deref that codeBlock pointer if it's null? I looked thru the rest of genericUnwind() and I think it is resilient against a null codeBlock pointer except the above logging line, but I think you should double check if you haven't already. r=me with the issues fixed. > Source/JavaScriptCore/ChangeLog:3 > + REGRESSION(r191360): Repro Crash: com.apple.WebKit.WebContent at â¦.apple.JavaScriptCore: JSC::ExecState::bytecodeOffset + 174 Please fix the special character before ".apple.JavaScriptCore:". > LayoutTests/ChangeLog:3 > + REGRESSION(r191360): Repro Crash: com.apple.WebKit.WebContent at â¦.apple.JavaScriptCore: JSC::ExecState::bytecodeOffset + 174 Please fix the non-ascii character before ".apple.JavaScriptCore:". > LayoutTests/js/script-tests/regress-150434.js:47 > +testPassed("Properly handled an exception from a tail called native function that called by a native function"); did you mean "that *was* called by *another* native function"?
Michael Saboff
Comment 4 2015-10-22 09:13:22 PDT
Note You need to log in before you can comment on or make changes to this bug.