Bug 58687

Summary: [V8] KeepAlive is called everytime JS is executed but is not always necessary
Product: WebKit Reporter: Greg Simon <gregsimon>
Component: WebCore Misc.Assignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: abarth, arv, darin, eric
Priority: P3    
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Attachments:
Description Flags
Patch to only call keepAlive when necessary, not every time we call JS.
none
Patch to only call Frame::keepAlive when necessary, not every time we call into JS. abarth: commit-queue-

Greg Simon
Reported 2011-04-15 13:22:05 PDT
In the v8 bindings (V8Proxy) the Frame is kept alive every time JS is executed in case the JS code itself causes the Frame to be deleted. The Frame::keepAlive is not a free call; it schedules an async timer to fire at a later date to balance the ref() made initially in Frame::keepAlive. On loading gmail.google.com for example, > 100 async timers are scheduled. This bug suggests an optimization to only call Frame::keepAlive when it is necessary-- when the protector ref in the proxy is the last reference held to the Frame object, which appears to be the exception not the rule.
Attachments
Patch to only call keepAlive when necessary, not every time we call JS. (2.76 KB, text/plain)
2011-04-15 13:33 PDT, Greg Simon
no flags
Patch to only call Frame::keepAlive when necessary, not every time we call into JS. (2.76 KB, patch)
2011-04-18 13:06 PDT, Greg Simon
abarth: commit-queue-
Greg Simon
Comment 1 2011-04-15 13:33:55 PDT
Created attachment 89842 [details] Patch to only call keepAlive when necessary, not every time we call JS. Patch to only call keepAlive when necessary in v8 bindings, not every time we call JS.
Greg Simon
Comment 2 2011-04-18 13:06:29 PDT
Created attachment 90078 [details] Patch to only call Frame::keepAlive when necessary, not every time we call into JS.
Adam Barth
Comment 3 2011-04-19 15:09:11 PDT
Comment on attachment 90078 [details] Patch to only call Frame::keepAlive when necessary, not every time we call into JS. View in context: https://bugs.webkit.org/attachment.cgi?id=90078&action=review > Source/WebCore/ChangeLog:5 > + Fix comment What does "fix comment" mean? > Source/WebCore/ChangeLog:11 > + No new tests since it is an optimization of standard behavior. Is there some performance test that shows improvement after this patch? If so, which one and how much?
Greg Simon
Comment 4 2011-04-21 11:50:10 PDT
I have not been able to get sunspider or dromaeo to react beyond a noise level with this change. That being said, the change eliminates ~571 calls to Timer::startOneShot in a single sunspider run. The reason I'm not seeing results is because calls to setNextFireTime entries are coalesced when they are very close together. So... I an argue either side on this one. I like that it is eliminating scheduled timer callbacks (overhead in general), but in the existing benchmarks I'm not able to prove it makes a huge difference.
Eric Seidel (no email)
Comment 5 2011-06-18 20:01:00 PDT
Is Greg a committer now? What's the path foward here?
Eric Seidel (no email)
Comment 6 2011-12-21 15:29:29 PST
Ping?
Adam Barth
Comment 7 2011-12-21 22:58:06 PST
Comment on attachment 90078 [details] Patch to only call Frame::keepAlive when necessary, not every time we call into JS. Clearing R+. I think this probably just needs a fixed up ChangeLog at this point.
Greg Simon
Comment 8 2011-12-22 10:37:14 PST
This change is in trunk via changeset 93913
Note You need to log in before you can comment on or make changes to this bug.