Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "services/device/device_service.h" | 5 #include "services/device/device_service.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/memory/ptr_util.h" | 8 #include "base/memory/ptr_util.h" |
| 9 #include "base/memory/weak_ptr.h" | 9 #include "base/memory/weak_ptr.h" |
| 10 #include "base/threading/thread_task_runner_handle.h" | 10 #include "base/threading/thread_task_runner_handle.h" |
| 11 #include "services/device/fingerprint/fingerprint.h" | 11 #include "services/device/fingerprint/fingerprint.h" |
| 12 #include "services/device/power_monitor/power_monitor_message_broadcaster.h" | 12 #include "services/device/power_monitor/power_monitor_message_broadcaster.h" |
| 13 #include "services/device/time_zone_monitor/time_zone_monitor.h" | 13 #include "services/device/time_zone_monitor/time_zone_monitor.h" |
| 14 #include "services/service_manager/public/cpp/connection.h" | 14 #include "services/service_manager/public/cpp/connection.h" |
| 15 #include "services/service_manager/public/cpp/interface_registry.h" | 15 #include "services/service_manager/public/cpp/interface_registry.h" |
| 16 | 16 |
| 17 #if defined(OS_ANDROID) | 17 #if defined(OS_ANDROID) |
| 18 #include "base/trace_event/trace_event.h" | |
| 19 #include "device/sensors/device_sensor_service.h" | |
| 18 #include "services/device/android/register_jni.h" | 20 #include "services/device/android/register_jni.h" |
| 19 #endif | 21 #endif |
| 20 | 22 |
| 21 namespace device { | 23 namespace device { |
| 22 | 24 |
| 23 std::unique_ptr<service_manager::Service> CreateDeviceService( | 25 std::unique_ptr<service_manager::Service> CreateDeviceService( |
| 24 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner) { | 26 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner) { |
| 25 #if defined(OS_ANDROID) | 27 #if defined(OS_ANDROID) |
| 26 if (!EnsureJniRegistered()) { | 28 if (!EnsureJniRegistered()) { |
| 27 DLOG(ERROR) << "Failed to register JNI for Device Service"; | 29 DLOG(ERROR) << "Failed to register JNI for Device Service"; |
| 28 return nullptr; | 30 return nullptr; |
| 29 } | 31 } |
| 30 #endif | 32 #endif |
| 31 | 33 |
| 32 return base::MakeUnique<DeviceService>(std::move(file_task_runner)); | 34 return base::MakeUnique<DeviceService>(std::move(file_task_runner)); |
| 33 } | 35 } |
| 34 | 36 |
| 35 DeviceService::DeviceService( | 37 DeviceService::DeviceService( |
| 36 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner) | 38 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner) |
| 37 : file_task_runner_(std::move(file_task_runner)) {} | 39 : file_task_runner_(std::move(file_task_runner)) {} |
| 38 | 40 |
| 39 DeviceService::~DeviceService() {} | 41 DeviceService::~DeviceService() { |
| 42 #if defined(OS_ANDROID) | |
| 43 TRACE_EVENT0("shutdown", "DeviceService::Subsystem:SensorService"); | |
|
ke.he
2017/03/08 09:19:55
For Android platform, it is safe to shutdown in UI
blundell
2017/03/08 17:38:17
Do you think that we could just use the same mecha
ke.he
2017/03/09 02:37:33
For Android platform, DeviceSensorService runs in
| |
| 44 device::DeviceSensorService::GetInstance()->Shutdown(); | |
| 45 #endif | |
| 46 } | |
| 40 | 47 |
| 41 void DeviceService::OnStart() {} | 48 void DeviceService::OnStart() {} |
| 42 | 49 |
| 43 bool DeviceService::OnConnect(const service_manager::ServiceInfo& remote_info, | 50 bool DeviceService::OnConnect(const service_manager::ServiceInfo& remote_info, |
| 44 service_manager::InterfaceRegistry* registry) { | 51 service_manager::InterfaceRegistry* registry) { |
| 45 registry->AddInterface<mojom::Fingerprint>(this); | 52 registry->AddInterface<mojom::Fingerprint>(this); |
| 46 registry->AddInterface<mojom::PowerMonitor>(this); | 53 registry->AddInterface<mojom::PowerMonitor>(this); |
| 47 registry->AddInterface<mojom::TimeZoneMonitor>(this); | 54 registry->AddInterface<mojom::TimeZoneMonitor>(this); |
| 48 return true; | 55 return true; |
| 49 } | 56 } |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 63 } | 70 } |
| 64 | 71 |
| 65 void DeviceService::Create(const service_manager::Identity& remote_identity, | 72 void DeviceService::Create(const service_manager::Identity& remote_identity, |
| 66 mojom::TimeZoneMonitorRequest request) { | 73 mojom::TimeZoneMonitorRequest request) { |
| 67 if (!time_zone_monitor_) | 74 if (!time_zone_monitor_) |
| 68 time_zone_monitor_ = device::TimeZoneMonitor::Create(file_task_runner_); | 75 time_zone_monitor_ = device::TimeZoneMonitor::Create(file_task_runner_); |
| 69 time_zone_monitor_->Bind(std::move(request)); | 76 time_zone_monitor_->Bind(std::move(request)); |
| 70 } | 77 } |
| 71 | 78 |
| 72 } // namespace device | 79 } // namespace device |
| OLD | NEW |