Bug 22482

Summary: REGRESSION (r37991): Occasionally see "Scene rendered incorrectly" message when running the V8 Raytrace benchmark
Product: WebKit Reporter: Cameron Zwarich (cpst) <zwarich>
Component: JavaScriptCoreAssignee: Oliver Hunt <oliver>
Status: RESOLVED FIXED    
Severity: Normal CC: ap, barraclough, ggaren
Priority: P1 Keywords: HasReduction
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Attachments:
Description Flags
in-browser test case
none
Patch to fix problem ggaren: review+

Cameron Zwarich (cpst)
Reported 2008-11-25 01:31:25 PST
When running the V8 Raytrace benchmark, many of us have seen the "Scene rendered incorrectly" message. It doesn't always occur, so I have always suspected that it is a GC issue. If I hack up the V8 test harness, it always occurs with the JIT and COLLECT_ON_EVERY_ALLOCATION. It does not occur with the bytecode interpreter, even with COLLECT_ON_EVERY_ALLOCATION. I will try to reduce and fix this. I suspect that it is caused by some bad interaction between inline caching and GC.
Attachments
in-browser test case (222 bytes, text/html)
2008-11-25 04:49 PST, Alexey Proskuryakov
no flags
Patch to fix problem (15.92 KB, patch)
2008-11-30 08:45 PST, Cameron Zwarich (cpst)
ggaren: review+
Cameron Zwarich (cpst)
Comment 1 2008-11-25 03:20:49 PST
Here is a reduction for the jsc shell, only with COLLECT_ON_EVERY_ALLOCATION: var o = { x: 0.2, normalize: function() { return this.x / 5.0039984012787215; } }; print(-o.normalize()); This prints 0, but it should print something nonzero. I believe that it happens because a number cell is being collected. I can't trigger it by putting explicit gc() calls anywhere.
Cameron Zwarich (cpst)
Comment 2 2008-11-25 04:05:08 PST
The problem seems to be caused by the negation, as it goes away if I remove it. The GC caused by the call to allocateNumber() emitted by if (!resultType.isReusableNumber()) emitAllocateNumber(m_globalData, i); must not be marking the operand to op_negate.
Cameron Zwarich (cpst)
Comment 3 2008-11-25 04:10:18 PST
Here is a simpler reduction: function f() { return 0.1; } print(-f());
Alexey Proskuryakov
Comment 4 2008-11-25 04:49:24 PST
Created attachment 25478 [details] in-browser test case Same as the above, but doesn't need COLLECT_ON_EVERY_ALLOCATION.
Cameron Zwarich (cpst)
Comment 5 2008-11-25 14:09:00 PST
This is likely caused by r37991: http://trac.webkit.org/changeset/37991 Oliver says that he probably has a fix.
Cameron Zwarich (cpst)
Comment 6 2008-11-25 14:43:05 PST
I have verified that this is caused by r37991.
Cameron Zwarich (cpst)
Comment 7 2008-11-25 14:48:59 PST
Oliver indeed has a fix for this, but it is part of other work. The problem is that xmm0 is not callee-save, so eventually some function (like memcpy()) will get called and smash its value. I am assigning this to Oliver.
Cameron Zwarich (cpst)
Comment 8 2008-11-30 08:45:06 PST
Created attachment 25614 [details] Patch to fix problem This patch simply reverts r37991. I can't accurately test its performance. It seems to be a regression, but my loaner machine has insane variance.
Geoffrey Garen
Comment 9 2008-12-02 13:52:32 PST
Comment on attachment 25614 [details] Patch to fix problem r=me Performance seems OK.
Geoffrey Garen
Comment 10 2008-12-02 13:52:40 PST
Committed revision 38917.
Note You need to log in before you can comment on or make changes to this bug.