| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2009 Google Inc. All rights reserved. | 2 * Copyright (C) 2009 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 43 #include "core/dom/NodeTraversal.h" | 43 #include "core/dom/NodeTraversal.h" |
| 44 #include "core/dom/TemplateContentDocumentFragment.h" | 44 #include "core/dom/TemplateContentDocumentFragment.h" |
| 45 #include "core/dom/shadow/ElementShadow.h" | 45 #include "core/dom/shadow/ElementShadow.h" |
| 46 #include "core/dom/shadow/ShadowRoot.h" | 46 #include "core/dom/shadow/ShadowRoot.h" |
| 47 #include "core/html/HTMLTemplateElement.h" | 47 #include "core/html/HTMLTemplateElement.h" |
| 48 #include "core/html/imports/HTMLImportsController.h" | 48 #include "core/html/imports/HTMLImportsController.h" |
| 49 #include "core/inspector/InspectorTraceEvents.h" | 49 #include "core/inspector/InspectorTraceEvents.h" |
| 50 #include "core/svg/SVGElement.h" | 50 #include "core/svg/SVGElement.h" |
| 51 #include "platform/Histogram.h" | 51 #include "platform/Histogram.h" |
| 52 #include "platform/TraceEvent.h" | 52 #include "platform/TraceEvent.h" |
| 53 #include "public/platform/BlameContext.h" |
| 54 #include "public/platform/Platform.h" |
| 53 #include "wtf/Partitions.h" | 55 #include "wtf/Partitions.h" |
| 54 #include "wtf/Vector.h" | 56 #include "wtf/Vector.h" |
| 55 #include <algorithm> | 57 #include <algorithm> |
| 56 | 58 |
| 57 namespace blink { | 59 namespace blink { |
| 58 | 60 |
| 59 // FIXME: This should use opaque GC roots. | 61 // FIXME: This should use opaque GC roots. |
| 60 static void addReferencesForNodeWithEventListeners(v8::Isolate* isolate, Node* n
ode, const v8::Persistent<v8::Object>& wrapper) | 62 static void addReferencesForNodeWithEventListeners(v8::Isolate* isolate, Node* n
ode, const v8::Persistent<v8::Object>& wrapper) |
| 61 { | 63 { |
| 62 ASSERT(node->hasEventListeners()); | 64 ASSERT(node->hasEventListeners()); |
| (...skipping 198 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 261 objectGroupingForMajorGC(isolate, constructRetainedObjectInfos); | 263 objectGroupingForMajorGC(isolate, constructRetainedObjectInfos); |
| 262 } | 264 } |
| 263 | 265 |
| 264 } // namespace | 266 } // namespace |
| 265 | 267 |
| 266 void V8GCController::gcPrologue(v8::Isolate* isolate, v8::GCType type, v8::GCCal
lbackFlags flags) | 268 void V8GCController::gcPrologue(v8::Isolate* isolate, v8::GCType type, v8::GCCal
lbackFlags flags) |
| 267 { | 269 { |
| 268 if (isMainThread()) | 270 if (isMainThread()) |
| 269 ScriptForbiddenScope::enter(); | 271 ScriptForbiddenScope::enter(); |
| 270 | 272 |
| 273 // Attribute garbage collection to the entire thread instead of a specific |
| 274 // frame. |
| 275 if (BlameContext* blameContext = Platform::current()->threadBlameContext()) |
| 276 blameContext->Enter(); |
| 277 |
| 271 // TODO(haraken): A GC callback is not allowed to re-enter V8. This means | 278 // TODO(haraken): A GC callback is not allowed to re-enter V8. This means |
| 272 // that it's unsafe to run Oilpan's GC in the GC callback because it may | 279 // that it's unsafe to run Oilpan's GC in the GC callback because it may |
| 273 // run finalizers that call into V8. To avoid the risk, we should post | 280 // run finalizers that call into V8. To avoid the risk, we should post |
| 274 // a task to schedule the Oilpan's GC. | 281 // a task to schedule the Oilpan's GC. |
| 275 // (In practice, there is no finalizer that calls into V8 and thus is safe.) | 282 // (In practice, there is no finalizer that calls into V8 and thus is safe.) |
| 276 | 283 |
| 277 v8::HandleScope scope(isolate); | 284 v8::HandleScope scope(isolate); |
| 278 switch (type) { | 285 switch (type) { |
| 279 case v8::kGCTypeScavenge: | 286 case v8::kGCTypeScavenge: |
| 280 if (ThreadState::current()) | 287 if (ThreadState::current()) |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 325 case v8::kGCTypeProcessWeakCallbacks: | 332 case v8::kGCTypeProcessWeakCallbacks: |
| 326 TRACE_EVENT_END1("devtools.timeline,v8", "MajorGC", "usedHeapSizeAfter",
usedHeapSize(isolate)); | 333 TRACE_EVENT_END1("devtools.timeline,v8", "MajorGC", "usedHeapSizeAfter",
usedHeapSize(isolate)); |
| 327 break; | 334 break; |
| 328 default: | 335 default: |
| 329 ASSERT_NOT_REACHED(); | 336 ASSERT_NOT_REACHED(); |
| 330 } | 337 } |
| 331 | 338 |
| 332 if (isMainThread()) | 339 if (isMainThread()) |
| 333 ScriptForbiddenScope::exit(); | 340 ScriptForbiddenScope::exit(); |
| 334 | 341 |
| 342 if (BlameContext* blameContext = Platform::current()->threadBlameContext()) |
| 343 blameContext->Leave(); |
| 344 |
| 335 // v8::kGCCallbackFlagForced forces a Blink heap garbage collection | 345 // v8::kGCCallbackFlagForced forces a Blink heap garbage collection |
| 336 // when a garbage collection was forced from V8. This is either used | 346 // when a garbage collection was forced from V8. This is either used |
| 337 // for tests that force GCs from JavaScript to verify that objects die | 347 // for tests that force GCs from JavaScript to verify that objects die |
| 338 // when expected. | 348 // when expected. |
| 339 if (flags & v8::kGCCallbackFlagForced) { | 349 if (flags & v8::kGCCallbackFlagForced) { |
| 340 // This single GC is not enough for two reasons: | 350 // This single GC is not enough for two reasons: |
| 341 // (1) The GC is not precise because the GC scans on-stack pointers co
nservatively. | 351 // (1) The GC is not precise because the GC scans on-stack pointers co
nservatively. |
| 342 // (2) One GC is not enough to break a chain of persistent handles. It
's possible that | 352 // (2) One GC is not enough to break a chain of persistent handles. It
's possible that |
| 343 // some heap allocated objects own objects that contain persistent
handles | 353 // some heap allocated objects own objects that contain persistent
handles |
| 344 // pointing to other heap allocated objects. To break the chain, w
e need multiple GCs. | 354 // pointing to other heap allocated objects. To break the chain, w
e need multiple GCs. |
| (...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 488 | 498 |
| 489 DEFINE_THREAD_SAFE_STATIC_LOCAL(CustomCountHistogram, scanPendingActivityHis
togram, new CustomCountHistogram("Blink.ScanPendingActivityDuration", 1, 1000, 5
0)); | 499 DEFINE_THREAD_SAFE_STATIC_LOCAL(CustomCountHistogram, scanPendingActivityHis
togram, new CustomCountHistogram("Blink.ScanPendingActivityDuration", 1, 1000, 5
0)); |
| 490 double startTime = WTF::currentTimeMS(); | 500 double startTime = WTF::currentTimeMS(); |
| 491 PendingActivityVisitor visitor(executionContext); | 501 PendingActivityVisitor visitor(executionContext); |
| 492 toIsolate(executionContext)->VisitHandlesWithClassIds(&visitor); | 502 toIsolate(executionContext)->VisitHandlesWithClassIds(&visitor); |
| 493 scanPendingActivityHistogram.count(static_cast<int>(WTF::currentTimeMS() - s
tartTime)); | 503 scanPendingActivityHistogram.count(static_cast<int>(WTF::currentTimeMS() - s
tartTime)); |
| 494 return visitor.pendingActivityFound(); | 504 return visitor.pendingActivityFound(); |
| 495 } | 505 } |
| 496 | 506 |
| 497 } // namespace blink | 507 } // namespace blink |
| OLD | NEW |