Bug 19024 - SQUIRRELFISH: ASSERTION FAILED: activation->isActivationObject() in Machine::unwindCallFrame
Summary: SQUIRRELFISH: ASSERTION FAILED: activation->isActivationObject() in Machine::...
Alias: None
Product: WebKit
Classification: Unclassified
Component: JavaScriptCore (show other bugs)
Version: 528+ (Nightly build)
Hardware: All All
: P2 Normal
Assignee: Nobody
URL: http://blog.wired.com/games/2008/05/f...
Depends on:
Reported: 2008-05-12 17:44 PDT by Cameron Zwarich (cpst)
Modified: 2008-05-14 05:15 PDT (History)
3 users (show)

See Also:

Reduction (1.05 KB, text/html)
2008-05-12 19:20 PDT, Cameron Zwarich (cpst)
no flags Details
Further reduction (20.32 KB, text/html)
2008-05-12 20:24 PDT, Cameron Zwarich (cpst)
no flags Details
Further reduction (3.15 KB, text/html)
2008-05-12 21:09 PDT, Cameron Zwarich (cpst)
no flags Details
Further reduction (362 bytes, text/html)
2008-05-12 22:41 PDT, Cameron Zwarich (cpst)
no flags Details

Note You need to log in before you can comment on or make changes to this bug.
Description Cameron Zwarich (cpst) 2008-05-12 17:44:49 PDT
SquirrelFish crashes on the site


with the following assertion failure:

ASSERTION FAILED: activation->isActivationObject()
(/Users/Cameron/sf/JavaScriptCore/VM/Machine.cpp:523 bool KJS::Machine::unwindCallFrame(KJS::ExecState*, KJS::Register**, const KJS::Instruction*&, KJS::CodeBlock*&, KJS::JSValue**&, KJS::ScopeChainNode*&, KJS::Register*&))

I occasionally need to reload to get it to crash.
Comment 1 Cameron Zwarich (cpst) 2008-05-12 19:20:35 PDT
Created attachment 21096 [details]

Here is a partial reduction of this bug. Even though the crash occurs in the SHARETHIS code, I needed to create and add the flash object earlier to get the crash to occur. It should be possible to further reduce the library code to get some idea of what is going on.
Comment 2 Cameron Zwarich (cpst) 2008-05-12 20:24:51 PDT
Created attachment 21098 [details]
Further reduction

Here is a further reduction, including the library source. When I tried to reduce it more, I sometimes got a plain crash instead of an assertion failure.
Comment 3 Cameron Zwarich (cpst) 2008-05-12 21:09:31 PDT
Created attachment 21100 [details]
Further reduction

Here's a further reduction of the bug. Most of the library code is irrelevant to the assertion failure. The assertion failure doesn't occur when I replace the eval at the beginning with an eval of the actual JS source produced.
Comment 4 Cameron Zwarich (cpst) 2008-05-12 22:41:49 PDT
Created attachment 21101 [details]
Further reduction

Here's a further reduction. This one doesn't trigger the same assertion. Instead, it hits this assertion:

(/Users/Cameron/sf/JavaScriptCore/kjs/JSImmediate.cpp:44 static KJS::JSObject* KJS::JSImmediate::toObject(const KJS::JSValue*, KJS::ExecState*))
Comment 5 Oliver Hunt 2008-05-14 00:37:25 PDT
Comment on attachment 21101 [details]
Further reduction

This test is actually a test of bug #19025
Comment 6 Oliver Hunt 2008-05-14 00:39:30 PDT
Comment on attachment 21100 [details]
Further reduction

I was wrong
Comment 7 Oliver Hunt 2008-05-14 05:15:56 PDT
	M	JavaScriptCore/ChangeLog
	M	JavaScriptCore/VM/Machine.cpp
	M	JavaScriptCore/VM/RegisterFile.cpp
	M	JavaScriptCore/VM/RegisterFileStack.cpp
	M	JavaScriptCore/VM/RegisterFileStack.h
	M	LayoutTests/ChangeLog
	A	LayoutTests/fast/js/implicit-global-to-global-reentry-expected.txt
	A	LayoutTests/fast/js/implicit-global-to-global-reentry.html
Committed r33438