1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "content/browser/power_profiler/power_profiler_service.h"
8 #include "base/message_loop/message_loop.h"
9 #include "base/threading/sequenced_worker_pool.h"
10 #include "content/public/browser/browser_thread.h"
14 PowerProfilerService::PowerProfilerService()
15 : status_(UNINITIALIZED
),
16 data_provider_(PowerDataProvider::Create()) {
17 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI
));
19 // No provider supported for current platform.
20 if (!data_provider_
.get())
22 sample_period_
= data_provider_
->GetSamplingRate();
23 status_
= INITIALIZED
;
24 task_runner_
= BrowserThread::GetBlockingPool()->GetSequencedTaskRunner(
25 BrowserThread::GetBlockingPool()->GetSequenceToken());
28 PowerProfilerService::PowerProfilerService(
29 scoped_ptr
<PowerDataProvider
> provider
,
30 scoped_refptr
<base::TaskRunner
> task_runner
,
31 const base::TimeDelta
& sample_period
)
32 : task_runner_(task_runner
),
33 status_(UNINITIALIZED
),
34 sample_period_(sample_period
),
35 data_provider_(provider
.Pass()) {
36 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI
));
38 if (data_provider_
.get())
39 status_
= INITIALIZED
;
42 PowerProfilerService::~PowerProfilerService() {
45 bool PowerProfilerService::IsAvailable() const {
46 return status_
!= UNINITIALIZED
;
49 std::string
PowerProfilerService::GetAccuracyLevel() const {
50 DCHECK(IsAvailable());
51 switch (data_provider_
->GetAccuracyLevel()) {
52 case PowerDataProvider::High
:
54 case PowerDataProvider::Moderate
:
56 case PowerDataProvider::Low
:
62 PowerProfilerService
* PowerProfilerService::GetInstance() {
63 return Singleton
<PowerProfilerService
>::get();
66 void PowerProfilerService::AddObserver(PowerProfilerObserver
* observer
) {
67 if (status_
== UNINITIALIZED
)
70 observers_
.AddObserver(observer
);
71 if (status_
!= PROFILING
)
75 void PowerProfilerService::RemoveObserver(PowerProfilerObserver
* observer
) {
76 observers_
.RemoveObserver(observer
);
78 if (status_
== PROFILING
&& !observers_
.might_have_observers())
82 void PowerProfilerService::Start() {
83 DCHECK(status_
== INITIALIZED
);
86 // Send out power events immediately.
89 query_power_timer_
.Start(FROM_HERE
,
90 sample_period_
, this, &PowerProfilerService::QueryData
);
93 void PowerProfilerService::Stop() {
94 DCHECK(status_
== PROFILING
);
96 query_power_timer_
.Stop();
97 status_
= INITIALIZED
;
100 void PowerProfilerService::QueryData() {
101 task_runner_
->PostTask(
102 FROM_HERE
, base::Bind(&PowerProfilerService::QueryDataOnTaskRunner
,
103 base::Unretained(this)));
106 void PowerProfilerService::Notify(const PowerEventVector
& events
) {
107 FOR_EACH_OBSERVER(PowerProfilerObserver
, observers_
, OnPowerEvent(events
));
110 void PowerProfilerService::QueryDataOnTaskRunner() {
111 DCHECK(task_runner_
->RunsTasksOnCurrentThread());
112 DCHECK(status_
== PROFILING
);
114 // Get data and notify.
115 PowerEventVector events
= data_provider_
->GetData();
116 if (events
.size() != 0) {
117 BrowserThread::PostTask(BrowserThread::UI
, FROM_HERE
, base::Bind(
118 &PowerProfilerService::Notify
, base::Unretained(this), events
));
122 } // namespace content