diff options
author | Simon Hausmann <simon.hausmann@nokia.com> | 2012-09-10 19:10:20 +0200 |
---|---|---|
committer | Simon Hausmann <simon.hausmann@nokia.com> | 2012-09-10 19:10:20 +0200 |
commit | 284837daa07b29d6a63a748544a90b1f5842ac5c (patch) | |
tree | ecd258180bde91fe741e0cfd2638beb3c6da7e8e /Source/JavaScriptCore/heap/IncrementalSweeper.cpp | |
parent | 2e2ba8ff45915f40ed3e014101269c175f2a89a0 (diff) | |
download | qtwebkit-284837daa07b29d6a63a748544a90b1f5842ac5c.tar.gz |
Imported WebKit commit 68645295d2e3e09af2c942f092556f06aa5f8b0d (http://svn.webkit.org/repository/webkit/trunk@128073)
New snapshot
Diffstat (limited to 'Source/JavaScriptCore/heap/IncrementalSweeper.cpp')
-rw-r--r-- | Source/JavaScriptCore/heap/IncrementalSweeper.cpp | 48 |
1 files changed, 38 insertions, 10 deletions
diff --git a/Source/JavaScriptCore/heap/IncrementalSweeper.cpp b/Source/JavaScriptCore/heap/IncrementalSweeper.cpp index f284d8b57..bd1342f2a 100644 --- a/Source/JavaScriptCore/heap/IncrementalSweeper.cpp +++ b/Source/JavaScriptCore/heap/IncrementalSweeper.cpp @@ -31,22 +31,19 @@ #include "JSObject.h" #include "JSString.h" #include "MarkedBlock.h" -#include "ScopeChain.h" + #include <wtf/HashSet.h> #include <wtf/WTFThreadData.h> namespace JSC { -#if USE(CF) +#if USE(CF) || PLATFORM(BLACKBERRY) -static const CFTimeInterval sweepTimeSlice = .01; // seconds -static const CFTimeInterval sweepTimeTotal = .10; -static const CFTimeInterval sweepTimeMultiplier = 1.0 / sweepTimeTotal; +static const double sweepTimeSlice = .01; // seconds +static const double sweepTimeTotal = .10; +static const double sweepTimeMultiplier = 1.0 / sweepTimeTotal; -void IncrementalSweeper::doWork() -{ - doSweep(WTF::monotonicallyIncreasingTime()); -} +#if USE(CF) IncrementalSweeper::IncrementalSweeper(Heap* heap, CFRunLoopRef runLoop) : HeapTimer(heap->globalData(), runLoop) @@ -70,12 +67,43 @@ void IncrementalSweeper::cancelTimer() CFRunLoopTimerSetNextFireDate(m_timer.get(), CFAbsoluteTimeGetCurrent() + s_decade); } +#elif PLATFORM(BLACKBERRY) + +IncrementalSweeper::IncrementalSweeper(Heap* heap) + : HeapTimer(heap->globalData()) + , m_currentBlockToSweepIndex(0) + , m_structuresCanBeSwept(false) +{ +} + +IncrementalSweeper* IncrementalSweeper::create(Heap* heap) +{ + return new IncrementalSweeper(heap); +} + +void IncrementalSweeper::scheduleTimer() +{ + m_timer.start(sweepTimeSlice * sweepTimeMultiplier); +} + +void IncrementalSweeper::cancelTimer() +{ + m_timer.stop(); +} + +#endif + +void IncrementalSweeper::doWork() +{ + doSweep(WTF::monotonicallyIncreasingTime()); +} + void IncrementalSweeper::doSweep(double sweepBeginTime) { while (m_currentBlockToSweepIndex < m_blocksToSweep.size()) { sweepNextBlock(); - CFTimeInterval elapsedTime = WTF::monotonicallyIncreasingTime() - sweepBeginTime; + double elapsedTime = WTF::monotonicallyIncreasingTime() - sweepBeginTime; if (elapsedTime < sweepTimeSlice) continue; |