| OLD | NEW |
| (Empty) |
| 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 | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "device/generic_sensor/platform_sensor.h" | |
| 6 | |
| 7 #include <utility> | |
| 8 | |
| 9 #include "base/threading/thread_task_runner_handle.h" | |
| 10 #include "device/generic_sensor/platform_sensor_provider.h" | |
| 11 #include "device/generic_sensor/public/cpp/platform_sensor_configuration.h" | |
| 12 | |
| 13 namespace device { | |
| 14 | |
| 15 PlatformSensor::PlatformSensor(mojom::SensorType type, | |
| 16 mojo::ScopedSharedBufferMapping mapping, | |
| 17 PlatformSensorProvider* provider) | |
| 18 : task_runner_(base::ThreadTaskRunnerHandle::Get()), | |
| 19 shared_buffer_mapping_(std::move(mapping)), | |
| 20 type_(type), | |
| 21 provider_(provider), | |
| 22 weak_factory_(this) {} | |
| 23 | |
| 24 PlatformSensor::~PlatformSensor() { | |
| 25 provider_->RemoveSensor(GetType()); | |
| 26 } | |
| 27 | |
| 28 mojom::SensorType PlatformSensor::GetType() const { | |
| 29 return type_; | |
| 30 } | |
| 31 | |
| 32 double PlatformSensor::GetMaximumSupportedFrequency() { | |
| 33 return GetDefaultConfiguration().frequency(); | |
| 34 } | |
| 35 | |
| 36 double PlatformSensor::GetMinimumSupportedFrequency() { | |
| 37 return 1.0 / (60 * 60); | |
| 38 } | |
| 39 | |
| 40 bool PlatformSensor::StartListening(Client* client, | |
| 41 const PlatformSensorConfiguration& config) { | |
| 42 DCHECK(clients_.HasObserver(client)); | |
| 43 if (!CheckSensorConfiguration(config)) | |
| 44 return false; | |
| 45 | |
| 46 auto& config_list = config_map_[client]; | |
| 47 config_list.push_back(config); | |
| 48 | |
| 49 if (!UpdateSensorInternal(config_map_)) { | |
| 50 config_list.pop_back(); | |
| 51 return false; | |
| 52 } | |
| 53 | |
| 54 return true; | |
| 55 } | |
| 56 | |
| 57 bool PlatformSensor::StopListening(Client* client, | |
| 58 const PlatformSensorConfiguration& config) { | |
| 59 DCHECK(clients_.HasObserver(client)); | |
| 60 auto client_entry = config_map_.find(client); | |
| 61 if (client_entry == config_map_.end()) | |
| 62 return false; | |
| 63 | |
| 64 auto& config_list = client_entry->second; | |
| 65 auto config_entry = std::find(config_list.begin(), config_list.end(), config); | |
| 66 if (config_entry == config_list.end()) | |
| 67 return false; | |
| 68 | |
| 69 config_list.erase(config_entry); | |
| 70 | |
| 71 return UpdateSensorInternal(config_map_); | |
| 72 } | |
| 73 | |
| 74 void PlatformSensor::UpdateSensor() { | |
| 75 UpdateSensorInternal(config_map_); | |
| 76 } | |
| 77 | |
| 78 void PlatformSensor::AddClient(Client* client) { | |
| 79 DCHECK(client); | |
| 80 clients_.AddObserver(client); | |
| 81 } | |
| 82 | |
| 83 void PlatformSensor::RemoveClient(Client* client) { | |
| 84 DCHECK(client); | |
| 85 clients_.RemoveObserver(client); | |
| 86 auto client_entry = config_map_.find(client); | |
| 87 if (client_entry != config_map_.end()) { | |
| 88 config_map_.erase(client_entry); | |
| 89 UpdateSensorInternal(config_map_); | |
| 90 } | |
| 91 } | |
| 92 | |
| 93 void PlatformSensor::UpdateSensorReading(const SensorReading& reading, | |
| 94 bool notify_clients) { | |
| 95 ReadingBuffer* buffer = | |
| 96 static_cast<ReadingBuffer*>(shared_buffer_mapping_.get()); | |
| 97 auto& seqlock = buffer->seqlock.value(); | |
| 98 seqlock.WriteBegin(); | |
| 99 buffer->reading = reading; | |
| 100 seqlock.WriteEnd(); | |
| 101 | |
| 102 if (notify_clients) | |
| 103 task_runner_->PostTask( | |
| 104 FROM_HERE, base::Bind(&PlatformSensor::NotifySensorReadingChanged, | |
| 105 weak_factory_.GetWeakPtr())); | |
| 106 } | |
| 107 | |
| 108 void PlatformSensor::NotifySensorReadingChanged() { | |
| 109 for (auto& client : clients_) { | |
| 110 if (!client.IsNotificationSuspended()) | |
| 111 client.OnSensorReadingChanged(); | |
| 112 } | |
| 113 } | |
| 114 | |
| 115 void PlatformSensor::NotifySensorError() { | |
| 116 for (auto& observer : clients_) | |
| 117 observer.OnSensorError(); | |
| 118 } | |
| 119 | |
| 120 bool PlatformSensor::UpdateSensorInternal(const ConfigMap& configurations) { | |
| 121 const PlatformSensorConfiguration* optimal_configuration = nullptr; | |
| 122 for (const auto& pair : configurations) { | |
| 123 if (pair.first->IsNotificationSuspended()) | |
| 124 continue; | |
| 125 | |
| 126 const auto& conf_list = pair.second; | |
| 127 for (const auto& configuration : conf_list) { | |
| 128 if (!optimal_configuration || configuration > *optimal_configuration) { | |
| 129 optimal_configuration = &configuration; | |
| 130 } | |
| 131 } | |
| 132 } | |
| 133 | |
| 134 if (!optimal_configuration) { | |
| 135 StopSensor(); | |
| 136 return true; | |
| 137 } | |
| 138 | |
| 139 return StartSensor(*optimal_configuration); | |
| 140 } | |
| 141 | |
| 142 } // namespace device | |
| OLD | NEW |