Bug 75050

Summary: REGRESSION(r103349): 7.5% peak memory use increase on Windows
Product: WebKit Reporter: Tony Chang <tony>
Component: WebCore Misc.Assignee: Mike Reed <reed>
Status: RESOLVED FIXED    
Severity: Normal CC: caryclark, enne, epoger, gbillock, ggaren, loislo, reed, rniwa, sail, sam
Priority: P1    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   

Tony Chang
Reported 2011-12-21 15:50:09 PST
http://build.chromium.org/f/chromium/perf/vista-release-webkit-latest/moz/report.html?history=150&rev=115372&graph=vm_peak_r Looks like the regression range is http://trac.webkit.org/log/trunk/Source?rev=103365&stop_rev=103354&verbose=on . None of the changes seems to obviously be the cause. I'm OOO right now, but thought I should file a bug so someone can take a look.
Attachments
Ryosuke Niwa
Comment 1 2011-12-21 17:13:49 PST
Suspicious revisions: Merge ScrollAnimatorChromiumMac.mm back to ScrollAnimatorMac http://trac.webkit.org/changeset/103354 Tightened up Vector<T>::append http://trac.webkit.org/changeset/103356 [Coverity] Fix leak in V8HTMLDocument http://trac.webkit.org/changeset/103358 Change adoptPtr(new ...) to ...::create in Page.cpp http://trac.webkit.org/changeset/103365
Ryosuke Niwa
Comment 3 2011-12-21 17:26:06 PST
All regressions are P1.
Ryosuke Niwa
Comment 4 2011-12-21 17:50:04 PST
Apparently http://trac.webkit.org/changeset/103354 is specific to Mac so we can cross that out. It seems very unlikely that either http://trac.webkit.org/changeset/103358 or http://trac.webkit.org/changeset/103365 can cause Windows-specific memory regression. Given that I think http://trac.webkit.org/changeset/103356/trunk/Source/JavaScriptCore/wtf/Vector.h is the culprit. I don't see why it can cause memory use increase unless the compiler is generating bad code but then I wouldn't be surprised if that were the case since the comment being removed says it used to cause a compilation error.
Ilya Tikhonovsky
Comment 5 2011-12-22 05:08:22 PST
I confirm that the problem is in webkit. I'm bisecting it. Looks like it is somewhere between 103344 and 103355 The suspicious revision is 103353 sizeof(RenderStyle) is 64 instead of 56 on Windows (x86) https://bugs.webkit.org/show_bug.cgi?id=74876 Reviewed by Ryosuke Niwa. Move bit fields into a new class and use unsigned for all types so we align at 4 byte bounds. Also move the initializers into the header file (has the side benefit of not needing to duplicate the initializers in 3 places). Enable the compile assert on Windows.
Ilya Tikhonovsky
Comment 6 2011-12-22 06:51:32 PST
(In reply to comment #5) > I confirm that the problem is in webkit. > I'm bisecting it. Looks like it is somewhere between 103344 and 103355 > > The suspicious revision is 103353 > > sizeof(RenderStyle) is 64 instead of 56 on Windows (x86) > https://bugs.webkit.org/show_bug.cgi?id=74876 > Reviewed by Ryosuke Niwa. > Move bit fields into a new class and use unsigned for all types so we > align at 4 byte bounds. Also move the initializers into the header > file (has the side benefit of not needing to duplicate the initializers > in 3 places). > Enable the compile assert on Windows. Actually it is 103349. enable USE_SKIA_TEXT by default, replacing GDI for all text drawing Revert it?
Mike Reed
Comment 7 2011-12-22 07:19:52 PST
I expect this is related to the large font-cache setting we have (in skia/skia.gyp). This gives us a big perf win on page-cyclers (faster than GDI) but will take more ram (which can be purged).
Mike Reed
Comment 8 2011-12-22 07:21:22 PST
The max cache size can be reduce (either in the gyp, or via a runtime API), or we can live with a larger peak, since that is the tradeoff for faster performance. I can go either way.
epoger
Comment 9 2011-12-22 08:22:11 PST
epoger
Comment 10 2011-12-22 08:35:00 PST
Are there any bots that went red as a result of this peak-memory-consumption regression? I don't see any on the Chromium side...
Mike Reed
Comment 11 2011-12-22 08:40:45 PST
We will locally reproduce these page cyclers, and play with the font-cache size to mitigate the ram usage -vs- performance, but for the moment I recommend the code stays as is. - faster text drawing needs ram unfortunately - we will continue to improve our balance-point for ram-vs-speed as we gather in-the-field numbers of real font usage (not just for these cyclers) - we will also implement font-cache-shrinking for tabs that go into the background
Tony Chang
Comment 12 2011-12-27 10:25:05 PST
Since this is an intentional trade off, seems like we can close this bug if we file bugs for the two follow up action items mentioned in comment #11.
Mike Reed
Comment 13 2012-01-03 05:21:01 PST
Note You need to log in before you can comment on or make changes to this bug.