blob: e296351d953fc2a81001003a15e54457416cd78a [file] [log] [blame]
Yu-Han Yang274ea0a2020-09-09 17:25:02 -07001/*
2 * Copyright (C) 2020 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#define LOG_TAG "GnssAidl"
18
19#include "Gnss.h"
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080020#include <inttypes.h>
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070021#include <log/log.h>
Shinru Han7f31c142021-11-05 11:56:40 +080022#include "AGnss.h"
Yu-Han Yang3a75dc02021-09-27 01:01:06 -070023#include "GnssBatching.h"
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070024#include "GnssConfiguration.h"
Joe Huang202b02d2021-11-16 23:09:11 +080025#include "GnssDebug.h"
Yu-Han Yang3089df32021-09-29 21:31:23 -070026#include "GnssGeofence.h"
Yu-Han Yang04832302020-11-20 09:51:18 -080027#include "GnssMeasurementInterface.h"
Yu-Han Yang10cf7362021-10-03 22:32:04 -070028#include "GnssNavigationMessageInterface.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070029#include "GnssPsds.h"
Edwin Tungd7a5de22021-12-08 13:27:51 +080030#include "GnssVisibilityControl.h"
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080031#include "Utils.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070032
33namespace aidl::android::hardware::gnss {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080034using ::android::hardware::gnss::common::Utils;
35using ndk::ScopedAStatus;
36using GnssSvInfo = IGnssCallback::GnssSvInfo;
37
38constexpr int TTFF_MILLIS = 2200;
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070039
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070040std::shared_ptr<IGnssCallback> Gnss::sGnssCallback = nullptr;
41
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080042Gnss::Gnss() : mMinIntervalMs(1000), mFirstFixReceived(false) {}
43
44ScopedAStatus Gnss::setCallback(const std::shared_ptr<IGnssCallback>& callback) {
45 ALOGD("setCallback");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070046 if (callback == nullptr) {
47 ALOGE("%s: Null callback ignored", __func__);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080048 return ScopedAStatus::fromExceptionCode(STATUS_INVALID_OPERATION);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070049 }
50
51 sGnssCallback = callback;
52
Joe Huang0d203ba2020-12-07 23:57:48 +080053 int capabilities = (int)(IGnssCallback::CAPABILITY_SATELLITE_BLOCKLIST |
Shinru Han4abab502020-12-09 15:07:18 +080054 IGnssCallback::CAPABILITY_SATELLITE_PVT |
55 IGnssCallback::CAPABILITY_CORRELATION_VECTOR);
56
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070057 auto status = sGnssCallback->gnssSetCapabilitiesCb(capabilities);
58 if (!status.isOk()) {
59 ALOGE("%s: Unable to invoke callback.gnssSetCapabilities", __func__);
60 }
61
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080062 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070063}
64
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080065ScopedAStatus Gnss::start() {
66 ALOGD("start()");
67 if (mIsActive) {
68 ALOGW("Gnss has started. Restarting...");
69 stop();
70 }
71
72 mIsActive = true;
73 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_BEGIN);
74 mThread = std::thread([this]() {
75 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
76 this->reportSvStatus(svStatus);
77 if (!mFirstFixReceived) {
78 std::this_thread::sleep_for(std::chrono::milliseconds(TTFF_MILLIS));
79 mFirstFixReceived = true;
80 }
81 while (mIsActive == true) {
82 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
83 this->reportSvStatus(svStatus);
84
85 mGnssPowerIndication->notePowerConsumption();
86 const auto location = Utils::getMockLocation();
87 this->reportLocation(location);
88 std::this_thread::sleep_for(std::chrono::milliseconds(mMinIntervalMs));
89 }
90 });
91 return ScopedAStatus::ok();
92}
93
94void Gnss::reportLocation(const GnssLocation& location) const {
95 std::unique_lock<std::mutex> lock(mMutex);
96 if (sGnssCallback == nullptr) {
97 ALOGE("%s: GnssCallback is null.", __func__);
98 return;
99 }
100 auto status = sGnssCallback->gnssLocationCb(location);
101 if (!status.isOk()) {
102 ALOGE("%s: Unable to invoke gnssLocationCb", __func__);
103 }
104 return;
105}
106
107void Gnss::reportSvStatus(const std::vector<GnssSvInfo>& svInfoList) const {
108 std::unique_lock<std::mutex> lock(mMutex);
109 if (sGnssCallback == nullptr) {
110 ALOGE("%s: sGnssCallback is null.", __func__);
111 return;
112 }
113 auto status = sGnssCallback->gnssSvStatusCb(svInfoList);
114 if (!status.isOk()) {
115 ALOGE("%s: Unable to invoke callback", __func__);
116 }
117}
118
119std::vector<GnssSvInfo> Gnss::filterBlocklistedSatellites(std::vector<GnssSvInfo> gnssSvInfoList) {
120 ALOGD("filterBlocklistedSatellites");
121 for (uint32_t i = 0; i < gnssSvInfoList.size(); i++) {
122 if (mGnssConfiguration->isBlocklisted(gnssSvInfoList[i])) {
123 gnssSvInfoList[i].svFlag &= ~(uint32_t)IGnssCallback::GnssSvFlags::USED_IN_FIX;
124 }
125 }
126 return gnssSvInfoList;
127}
128
129void Gnss::reportGnssStatusValue(const IGnssCallback::GnssStatusValue gnssStatusValue) const {
130 std::unique_lock<std::mutex> lock(mMutex);
131 if (sGnssCallback == nullptr) {
132 ALOGE("%s: sGnssCallback is null.", __func__);
133 return;
134 }
135 auto status = sGnssCallback->gnssStatusCb(gnssStatusValue);
136 if (!status.isOk()) {
137 ALOGE("%s: Unable to invoke gnssStatusCb", __func__);
138 }
139}
140
141ScopedAStatus Gnss::stop() {
142 ALOGD("stop");
143 mIsActive = false;
144 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_END);
145 if (mThread.joinable()) {
146 mThread.join();
147 }
148 return ScopedAStatus::ok();
149}
150
151ScopedAStatus Gnss::close() {
152 ALOGD("close");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700153 sGnssCallback = nullptr;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800154 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700155}
156
Shubham Dubeydd7f7b92022-01-11 05:26:13 +0000157ndk::ScopedAStatus Gnss::getExtensionAGnss(std::shared_ptr<IAGnss>* iAGnss) {
Shinru Han7f31c142021-11-05 11:56:40 +0800158 ALOGD("Gnss::getExtensionAGnss");
159 *iAGnss = SharedRefBase::make<AGnss>();
160 return ndk::ScopedAStatus::ok();
161}
162
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800163ScopedAStatus Gnss::injectTime(int64_t timeMs, int64_t timeReferenceMs, int uncertaintyMs) {
164 ALOGD("injectTime. timeMs:%" PRId64 ", timeReferenceMs:%" PRId64 ", uncertaintyMs:%d", timeMs,
165 timeReferenceMs, uncertaintyMs);
166 return ScopedAStatus::ok();
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700167}
168
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800169ScopedAStatus Gnss::injectLocation(const GnssLocation& location) {
170 ALOGD("injectLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
171 location.longitudeDegrees, location.horizontalAccuracyMeters);
172 return ScopedAStatus::ok();
173}
174
175ScopedAStatus Gnss::injectBestLocation(const GnssLocation& location) {
176 ALOGD("injectBestLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
177 location.longitudeDegrees, location.horizontalAccuracyMeters);
178 return ScopedAStatus::ok();
179}
180
181ScopedAStatus Gnss::deleteAidingData(GnssAidingData aidingDataFlags) {
182 ALOGD("deleteAidingData. flags:%d", (int)aidingDataFlags);
183 mFirstFixReceived = false;
184 return ScopedAStatus::ok();
185}
186
187ScopedAStatus Gnss::setPositionMode(GnssPositionMode, GnssPositionRecurrence, int minIntervalMs,
188 int /* preferredAccuracyMeters */, int /* preferredTimeMs */,
189 bool lowPowerMode) {
190 ALOGD("setPositionMode. minIntervalMs:%d, lowPowerMode:%d", minIntervalMs, (int)lowPowerMode);
191 mMinIntervalMs = minIntervalMs;
192 return ScopedAStatus::ok();
193}
194
195ScopedAStatus Gnss::getExtensionPsds(std::shared_ptr<IGnssPsds>* iGnssPsds) {
196 ALOGD("getExtensionPsds");
197 *iGnssPsds = SharedRefBase::make<GnssPsds>();
198 return ScopedAStatus::ok();
199}
200
201ScopedAStatus Gnss::getExtensionGnssConfiguration(
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700202 std::shared_ptr<IGnssConfiguration>* iGnssConfiguration) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800203 ALOGD("getExtensionGnssConfiguration");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700204 if (mGnssConfiguration == nullptr) {
205 mGnssConfiguration = SharedRefBase::make<GnssConfiguration>();
206 }
207 *iGnssConfiguration = mGnssConfiguration;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800208 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700209}
210
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800211ScopedAStatus Gnss::getExtensionGnssPowerIndication(
Yu-Han Yang24753612020-10-27 14:42:14 -0700212 std::shared_ptr<IGnssPowerIndication>* iGnssPowerIndication) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800213 ALOGD("getExtensionGnssPowerIndication");
Yu-Han Yang669be842021-04-26 20:17:53 -0700214 if (mGnssPowerIndication == nullptr) {
215 mGnssPowerIndication = SharedRefBase::make<GnssPowerIndication>();
216 }
Yu-Han Yang24753612020-10-27 14:42:14 -0700217
Yu-Han Yang669be842021-04-26 20:17:53 -0700218 *iGnssPowerIndication = mGnssPowerIndication;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800219 return ScopedAStatus::ok();
Yu-Han Yang24753612020-10-27 14:42:14 -0700220}
221
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800222ScopedAStatus Gnss::getExtensionGnssMeasurement(
Yu-Han Yang04832302020-11-20 09:51:18 -0800223 std::shared_ptr<IGnssMeasurementInterface>* iGnssMeasurement) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800224 ALOGD("getExtensionGnssMeasurement");
Yu-Han Yang04832302020-11-20 09:51:18 -0800225
226 *iGnssMeasurement = SharedRefBase::make<GnssMeasurementInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800227 return ScopedAStatus::ok();
Yu-Han Yang04832302020-11-20 09:51:18 -0800228}
229
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800230ScopedAStatus Gnss::getExtensionGnssBatching(std::shared_ptr<IGnssBatching>* iGnssBatching) {
231 ALOGD("getExtensionGnssBatching");
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700232
233 *iGnssBatching = SharedRefBase::make<GnssBatching>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800234 return ScopedAStatus::ok();
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700235}
236
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800237ScopedAStatus Gnss::getExtensionGnssGeofence(std::shared_ptr<IGnssGeofence>* iGnssGeofence) {
238 ALOGD("getExtensionGnssGeofence");
Yu-Han Yang3089df32021-09-29 21:31:23 -0700239
240 *iGnssGeofence = SharedRefBase::make<GnssGeofence>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800241 return ScopedAStatus::ok();
Yu-Han Yang3089df32021-09-29 21:31:23 -0700242}
243
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800244ScopedAStatus Gnss::getExtensionGnssNavigationMessage(
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700245 std::shared_ptr<IGnssNavigationMessageInterface>* iGnssNavigationMessage) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800246 ALOGD("getExtensionGnssNavigationMessage");
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700247
248 *iGnssNavigationMessage = SharedRefBase::make<GnssNavigationMessageInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800249 return ScopedAStatus::ok();
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700250}
251
Joe Huang202b02d2021-11-16 23:09:11 +0800252ndk::ScopedAStatus Gnss::getExtensionGnssDebug(std::shared_ptr<IGnssDebug>* iGnssDebug) {
253 ALOGD("Gnss::getExtensionGnssDebug");
254
255 *iGnssDebug = SharedRefBase::make<GnssDebug>();
256 return ndk::ScopedAStatus::ok();
257}
258
Edwin Tungd7a5de22021-12-08 13:27:51 +0800259ndk::ScopedAStatus Gnss::getExtensionGnssVisibilityControl(
260 std::shared_ptr<visibility_control::IGnssVisibilityControl>* iGnssVisibilityControl) {
261 ALOGD("Gnss::getExtensionGnssVisibilityControl");
262
263 *iGnssVisibilityControl = SharedRefBase::make<visibility_control::GnssVisibilityControl>();
264 return ndk::ScopedAStatus::ok();
265}
266
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700267} // namespace aidl::android::hardware::gnss