Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 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 "content/browser/device_sensors/device_sensor_service.h" | 5 #include "content/browser/device_sensors/device_sensor_service.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "base/memory/singleton.h" | 9 #include "base/memory/singleton.h" |
| 10 #include "build/build_config.h" | |
| 10 #include "content/browser/device_sensors/data_fetcher_shared_memory.h" | 11 #include "content/browser/device_sensors/data_fetcher_shared_memory.h" |
| 11 | 12 |
| 13 #if defined(OS_ANDROID) | |
| 14 #include "content/browser/device_sensors/sensor_manager_android.h" | |
| 15 #endif | |
| 16 | |
| 12 namespace content { | 17 namespace content { |
| 13 | 18 |
| 14 DeviceSensorService::DeviceSensorService() | 19 DeviceSensorService::DeviceSensorService() |
| 15 : num_light_readers_(0), | 20 : num_light_readers_(0), |
| 16 num_motion_readers_(0), | 21 num_motion_readers_(0), |
| 17 num_orientation_readers_(0), | 22 num_orientation_readers_(0), |
| 18 num_orientation_absolute_readers_(0), | 23 num_orientation_absolute_readers_(0), |
| 19 is_shutdown_(false) {} | 24 is_shutdown_(false) {} |
| 20 | 25 |
| 21 DeviceSensorService::~DeviceSensorService() {} | 26 DeviceSensorService::~DeviceSensorService() {} |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 39 void DeviceSensorService::RemoveConsumer(ConsumerType consumer_type) { | 44 void DeviceSensorService::RemoveConsumer(ConsumerType consumer_type) { |
| 40 if (!ChangeNumberConsumers(consumer_type, -1)) | 45 if (!ChangeNumberConsumers(consumer_type, -1)) |
| 41 return; | 46 return; |
| 42 | 47 |
| 43 if (GetNumberConsumers(consumer_type) == 0) | 48 if (GetNumberConsumers(consumer_type) == 0) |
| 44 data_fetcher_->StopFetchingDeviceData(consumer_type); | 49 data_fetcher_->StopFetchingDeviceData(consumer_type); |
| 45 } | 50 } |
| 46 | 51 |
| 47 bool DeviceSensorService::ChangeNumberConsumers(ConsumerType consumer_type, | 52 bool DeviceSensorService::ChangeNumberConsumers(ConsumerType consumer_type, |
| 48 int delta) { | 53 int delta) { |
| 49 DCHECK(thread_checker_.CalledOnValidThread()); | 54 DCHECK(io_thread_checker_.CalledOnValidThread()); |
| 50 if (is_shutdown_) | 55 if (is_shutdown_) |
| 51 return false; | 56 return false; |
| 52 | 57 |
| 53 switch (consumer_type) { | 58 switch (consumer_type) { |
| 54 case CONSUMER_TYPE_MOTION: | 59 case CONSUMER_TYPE_MOTION: |
| 55 num_motion_readers_ += delta; | 60 num_motion_readers_ += delta; |
| 56 DCHECK_GE(num_motion_readers_, 0); | 61 DCHECK_GE(num_motion_readers_, 0); |
| 57 return true; | 62 return true; |
| 58 case CONSUMER_TYPE_ORIENTATION: | 63 case CONSUMER_TYPE_ORIENTATION: |
| 59 num_orientation_readers_ += delta; | 64 num_orientation_readers_ += delta; |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 84 case CONSUMER_TYPE_LIGHT: | 89 case CONSUMER_TYPE_LIGHT: |
| 85 return num_light_readers_; | 90 return num_light_readers_; |
| 86 default: | 91 default: |
| 87 NOTREACHED(); | 92 NOTREACHED(); |
| 88 } | 93 } |
| 89 return 0; | 94 return 0; |
| 90 } | 95 } |
| 91 | 96 |
| 92 mojo::ScopedSharedBufferHandle DeviceSensorService::GetSharedMemoryHandle( | 97 mojo::ScopedSharedBufferHandle DeviceSensorService::GetSharedMemoryHandle( |
| 93 ConsumerType consumer_type) { | 98 ConsumerType consumer_type) { |
| 94 DCHECK(thread_checker_.CalledOnValidThread()); | 99 DCHECK(io_thread_checker_.CalledOnValidThread()); |
| 95 return data_fetcher_->GetSharedMemoryHandle(consumer_type); | 100 return data_fetcher_->GetSharedMemoryHandle(consumer_type); |
| 96 } | 101 } |
| 97 | 102 |
| 98 void DeviceSensorService::Shutdown() { | 103 void DeviceSensorService::InitOnUIThread() { |
| 104 #if defined(OS_ANDROID) | |
| 105 SensorManagerAndroid::GetInstance()->InitOnUIThread(); | |
| 106 #endif | |
| 107 } | |
| 108 | |
| 109 void DeviceSensorService::InitOnIOThread() { | |
|
timvolodine
2016/10/12 16:28:58
I am slightly confused by the two Init methods, wi
| |
| 110 // Ensure that the thread checker is associated with the IO thread in case | |
| 111 // instantiation of this object occurred on the UI thread. | |
| 112 io_thread_checker_.DetachFromThread(); | |
| 113 ignore_result(io_thread_checker_.CalledOnValidThread()); | |
| 114 } | |
| 115 | |
| 116 void DeviceSensorService::ShutDownOnUIThread() { | |
| 99 if (data_fetcher_) { | 117 if (data_fetcher_) { |
| 100 data_fetcher_->Shutdown(); | 118 data_fetcher_->ShutDownOnUIThread(); |
| 101 data_fetcher_.reset(); | 119 data_fetcher_.reset(); |
| 102 } | 120 } |
| 103 is_shutdown_ = true; | 121 is_shutdown_ = true; |
| 104 } | 122 } |
| 105 | 123 |
| 106 void DeviceSensorService::SetDataFetcherForTesting( | 124 void DeviceSensorService::SetDataFetcherForTesting( |
| 107 DataFetcherSharedMemory* test_data_fetcher) { | 125 DataFetcherSharedMemory* test_data_fetcher) { |
| 108 if (data_fetcher_) | 126 if (data_fetcher_) |
| 109 data_fetcher_->Shutdown(); | 127 data_fetcher_->ShutDownOnUIThread(); |
| 110 data_fetcher_.reset(test_data_fetcher); | 128 data_fetcher_.reset(test_data_fetcher); |
| 111 } | 129 } |
| 112 | 130 |
| 113 } // namespace content | 131 } // namespace content |
| OLD | NEW |