OLD | NEW |
1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "config.h" | 5 #include "config.h" |
6 | 6 |
7 #include "cc/delay_based_time_source.h" | 7 #include "cc/delay_based_time_source.h" |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 #include <cmath> | 10 #include <cmath> |
11 | 11 |
12 #include "base/debug/trace_event.h" | 12 #include "base/debug/trace_event.h" |
13 #include "base/logging.h" | 13 #include "base/logging.h" |
| 14 #include "base/message_loop.h" |
| 15 #include "cc/thread.h" |
14 | 16 |
15 namespace cc { | 17 namespace cc { |
16 | 18 |
17 namespace { | 19 namespace { |
18 | 20 |
19 // doubleTickThreshold prevents ticks from running within the specified fraction
of an interval. | 21 // doubleTickThreshold prevents ticks from running within the specified fraction
of an interval. |
20 // This helps account for jitter in the timebase as well as quick timer reactiva
tion. | 22 // This helps account for jitter in the timebase as well as quick timer reactiva
tion. |
21 const double doubleTickThreshold = 0.25; | 23 const double doubleTickThreshold = 0.25; |
22 | 24 |
23 // intervalChangeThreshold is the fraction of the interval that will trigger an
immediate interval change. | 25 // intervalChangeThreshold is the fraction of the interval that will trigger an
immediate interval change. |
24 // phaseChangeThreshold is the fraction of the interval that will trigger an imm
ediate phase change. | 26 // phaseChangeThreshold is the fraction of the interval that will trigger an imm
ediate phase change. |
25 // If the changes are within the thresholds, the change will take place on the n
ext tick. | 27 // If the changes are within the thresholds, the change will take place on the n
ext tick. |
26 // If either change is outside the thresholds, the next tick will be canceled an
d reissued immediately. | 28 // If either change is outside the thresholds, the next tick will be canceled an
d reissued immediately. |
27 const double intervalChangeThreshold = 0.25; | 29 const double intervalChangeThreshold = 0.25; |
28 const double phaseChangeThreshold = 0.25; | 30 const double phaseChangeThreshold = 0.25; |
29 | 31 |
30 } // namespace | 32 } // namespace |
31 | 33 |
32 scoped_refptr<DelayBasedTimeSource> DelayBasedTimeSource::create(base::TimeDelta
interval, Thread* thread) | 34 scoped_refptr<DelayBasedTimeSource> DelayBasedTimeSource::create(base::TimeDelta
interval, Thread* thread) |
33 { | 35 { |
34 return make_scoped_refptr(new DelayBasedTimeSource(interval, thread)); | 36 return make_scoped_refptr(new DelayBasedTimeSource(interval, thread)); |
35 } | 37 } |
36 | 38 |
37 DelayBasedTimeSource::DelayBasedTimeSource(base::TimeDelta interval, Thread* thr
ead) | 39 DelayBasedTimeSource::DelayBasedTimeSource(base::TimeDelta interval, Thread* thr
ead) |
38 : m_client(0) | 40 : m_client(0) |
39 , m_hasTickTarget(false) | 41 , m_hasTickTarget(false) |
40 , m_currentParameters(interval, base::TimeTicks()) | 42 , m_currentParameters(interval, base::TimeTicks()) |
41 , m_nextParameters(interval, base::TimeTicks()) | 43 , m_nextParameters(interval, base::TimeTicks()) |
42 , m_state(STATE_INACTIVE) | 44 , m_state(STATE_INACTIVE) |
43 , m_timer(thread, this) | 45 , m_thread(thread) |
| 46 , m_weakFactory(ALLOW_THIS_IN_INITIALIZER_LIST(this)) |
44 { | 47 { |
45 } | 48 } |
46 | 49 |
47 DelayBasedTimeSource::~DelayBasedTimeSource() | 50 DelayBasedTimeSource::~DelayBasedTimeSource() |
48 { | 51 { |
49 } | 52 } |
50 | 53 |
51 void DelayBasedTimeSource::setActive(bool active) | 54 void DelayBasedTimeSource::setActive(bool active) |
52 { | 55 { |
53 TRACE_EVENT1("cc", "DelayBasedTimeSource::setActive", "active", active); | 56 TRACE_EVENT1("cc", "DelayBasedTimeSource::setActive", "active", active); |
54 if (!active) { | 57 if (!active) { |
55 m_state = STATE_INACTIVE; | 58 m_state = STATE_INACTIVE; |
56 m_timer.stop(); | 59 m_weakFactory.InvalidateWeakPtrs(); |
57 return; | 60 return; |
58 } | 61 } |
59 | 62 |
60 if (m_state == STATE_STARTING || m_state == STATE_ACTIVE) | 63 if (m_state == STATE_STARTING || m_state == STATE_ACTIVE) |
61 return; | 64 return; |
62 | 65 |
63 if (!m_hasTickTarget) { | 66 if (!m_hasTickTarget) { |
64 // Becoming active the first time is deferred: we post a 0-delay task. W
hen | 67 // Becoming active the first time is deferred: we post a 0-delay task. W
hen |
65 // it runs, we use that to establish the timebase, become truly active,
and | 68 // it runs, we use that to establish the timebase, become truly active,
and |
66 // fire the first tick. | 69 // fire the first tick. |
67 m_state = STATE_STARTING; | 70 m_state = STATE_STARTING; |
68 m_timer.startOneShot(0); | 71 m_thread->postTask(base::Bind(&DelayBasedTimeSource::onTimerFired, m_wea
kFactory.GetWeakPtr())); |
69 return; | 72 return; |
70 } | 73 } |
71 | 74 |
72 m_state = STATE_ACTIVE; | 75 m_state = STATE_ACTIVE; |
73 | 76 |
74 postNextTickTask(now()); | 77 postNextTickTask(now()); |
75 } | 78 } |
76 | 79 |
77 bool DelayBasedTimeSource::active() const | 80 bool DelayBasedTimeSource::active() const |
78 { | 81 { |
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
215 } | 218 } |
216 | 219 |
217 void DelayBasedTimeSource::postNextTickTask(base::TimeTicks now) | 220 void DelayBasedTimeSource::postNextTickTask(base::TimeTicks now) |
218 { | 221 { |
219 base::TimeTicks newTickTarget = nextTickTarget(now); | 222 base::TimeTicks newTickTarget = nextTickTarget(now); |
220 | 223 |
221 // Post another task *before* the tick and update state | 224 // Post another task *before* the tick and update state |
222 base::TimeDelta delay = newTickTarget - now; | 225 base::TimeDelta delay = newTickTarget - now; |
223 DCHECK(delay.InMillisecondsF() <= | 226 DCHECK(delay.InMillisecondsF() <= |
224 m_nextParameters.interval.InMillisecondsF() * (1.0 + doubleTickThresh
old)); | 227 m_nextParameters.interval.InMillisecondsF() * (1.0 + doubleTickThresh
old)); |
225 m_timer.startOneShot(delay.InSecondsF()); | 228 m_thread->postDelayedTask(base::Bind(&DelayBasedTimeSource::onTimerFired, |
| 229 m_weakFactory.GetWeakPtr()), |
| 230 delay.InMilliseconds()); |
226 | 231 |
227 m_nextParameters.tickTarget = newTickTarget; | 232 m_nextParameters.tickTarget = newTickTarget; |
228 m_currentParameters = m_nextParameters; | 233 m_currentParameters = m_nextParameters; |
229 } | 234 } |
230 | 235 |
231 } // namespace cc | 236 } // namespace cc |
OLD | NEW |