Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1287)

Unified Diff: third_party/WebKit/Source/web/WebLeakDetector.cpp

Issue 2030883003: Revert of Delay leak reporting until worker in-process proxies have been finalized. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/WebKit/Source/core/workers/InProcessWorkerMessagingProxy.cpp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/WebKit/Source/web/WebLeakDetector.cpp
diff --git a/third_party/WebKit/Source/web/WebLeakDetector.cpp b/third_party/WebKit/Source/web/WebLeakDetector.cpp
index ba18d5bd2fda6369644449b0ae76fc0f9506aad4..c5a818ae5da8932d3c6153666239ae29fb22d030 100644
--- a/third_party/WebKit/Source/web/WebLeakDetector.cpp
+++ b/third_party/WebKit/Source/web/WebLeakDetector.cpp
@@ -34,7 +34,6 @@
#include "core/editing/spellcheck/SpellChecker.h"
#include "core/fetch/MemoryCache.h"
#include "core/inspector/InstanceCounters.h"
-#include "core/workers/InProcessWorkerMessagingProxy.h"
#include "core/workers/WorkerThread.h"
#include "platform/Timer.h"
#include "public/web/WebFrame.h"
@@ -51,7 +50,7 @@
: m_client(client)
, m_delayedGCAndReportTimer(this, &WebLeakDetectorImpl::delayedGCAndReport)
, m_delayedReportTimer(this, &WebLeakDetectorImpl::delayedReport)
- , m_numberOfWorkerGCs(0)
+ , m_numberOfGCNeeded(0)
{
DCHECK(m_client);
}
@@ -68,7 +67,7 @@
WebLeakDetectorClient* m_client;
Timer<WebLeakDetectorImpl> m_delayedGCAndReportTimer;
Timer<WebLeakDetectorImpl> m_delayedReportTimer;
- int m_numberOfWorkerGCs;
+ int m_numberOfGCNeeded;
};
void WebLeakDetectorImpl::prepareForLeakDetection(WebFrame* frame)
@@ -111,30 +110,24 @@
// This method is called from navigation hook inside FrameLoader,
// so previous document is still held by the loader until the next event loop.
// Complete all pending tasks before proceeding to gc.
- m_numberOfWorkerGCs = 0;
+ m_numberOfGCNeeded = 2;
m_delayedGCAndReportTimer.startOneShot(0, BLINK_FROM_HERE);
}
void WebLeakDetectorImpl::delayedGCAndReport(Timer<WebLeakDetectorImpl>*)
{
- // The initial GC will have swept out Resource objects, but their finalizers
- // will let go of yet more objects, needing another GC after having been back
- // to the event loop to run any clean-up tasks.
+ // We do a second and third GC here to address flakiness
+ // The second GC is necessary as Resource GC may have postponed clean-up tasks to next event loop.
+ // The third GC is necessary for cleaning up Document after worker object died.
+
V8GCController::collectAllGarbageForTesting(V8PerIsolateData::mainThreadIsolate());
// Note: Oilpan precise GC is scheduled at the end of the event loop.
- // If there are any in-process worker proxy objects still around waiting for
- // the worker to notify of destruction, we need to ensure that these have all
- // been destructed and their garbage collected (as they hold a Document
- // reference, and would generate a leak if not.)
- //
- // Do that by monitoring the remaining proxy count, iterating at most two times.
- if (InProcessWorkerMessagingProxy::proxyCount() && m_numberOfWorkerGCs < 2) {
- m_numberOfWorkerGCs++;
+ // Inspect counters on the next event loop.
+ if (--m_numberOfGCNeeded)
m_delayedGCAndReportTimer.startOneShot(0, BLINK_FROM_HERE);
- } else {
+ else
m_delayedReportTimer.startOneShot(0, BLINK_FROM_HERE);
- }
}
void WebLeakDetectorImpl::delayedReport(Timer<WebLeakDetectorImpl>*)
« no previous file with comments | « third_party/WebKit/Source/core/workers/InProcessWorkerMessagingProxy.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698