blob: cf2c90d3591a1c2d3d003663a6c367138b6ac188 [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>
Yu-Han Yang19a32b62022-04-27 09:57:01 -070022#include <utils/Timers.h>
Shinru Han7f31c142021-11-05 11:56:40 +080023#include "AGnss.h"
Shinru Han0d91cbe2021-12-14 12:06:02 +080024#include "AGnssRil.h"
Yuchen He42b2d0a2022-01-12 04:39:37 +000025#include "DeviceFileReader.h"
Yuchen He090f16c2022-01-20 22:57:09 +000026#include "FixLocationParser.h"
Joe Huang37d77dd2021-12-30 13:14:29 +080027#include "GnssAntennaInfo.h"
Yu-Han Yang3a75dc02021-09-27 01:01:06 -070028#include "GnssBatching.h"
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070029#include "GnssConfiguration.h"
Joe Huang202b02d2021-11-16 23:09:11 +080030#include "GnssDebug.h"
Yu-Han Yang3089df32021-09-29 21:31:23 -070031#include "GnssGeofence.h"
Yu-Han Yang10cf7362021-10-03 22:32:04 -070032#include "GnssNavigationMessageInterface.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070033#include "GnssPsds.h"
Edwin Tungd7a5de22021-12-08 13:27:51 +080034#include "GnssVisibilityControl.h"
Edwin Tungbbf7fb92021-12-27 12:13:02 +080035#include "MeasurementCorrectionsInterface.h"
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080036#include "Utils.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070037
38namespace aidl::android::hardware::gnss {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080039using ::android::hardware::gnss::common::Utils;
Yuchen He42b2d0a2022-01-12 04:39:37 +000040
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080041using ndk::ScopedAStatus;
42using GnssSvInfo = IGnssCallback::GnssSvInfo;
43
44constexpr int TTFF_MILLIS = 2200;
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070045
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070046std::shared_ptr<IGnssCallback> Gnss::sGnssCallback = nullptr;
47
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080048Gnss::Gnss() : mMinIntervalMs(1000), mFirstFixReceived(false) {}
49
50ScopedAStatus Gnss::setCallback(const std::shared_ptr<IGnssCallback>& callback) {
51 ALOGD("setCallback");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070052 if (callback == nullptr) {
53 ALOGE("%s: Null callback ignored", __func__);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080054 return ScopedAStatus::fromExceptionCode(STATUS_INVALID_OPERATION);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070055 }
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070056 sGnssCallback = callback;
57
Yu-Han Yang4165ed12022-02-09 14:47:50 -080058 int capabilities =
59 (int)(IGnssCallback::CAPABILITY_MEASUREMENTS | IGnssCallback::CAPABILITY_SCHEDULING |
60 IGnssCallback::CAPABILITY_SATELLITE_BLOCKLIST |
61 IGnssCallback::CAPABILITY_SATELLITE_PVT |
62 IGnssCallback::CAPABILITY_CORRELATION_VECTOR |
63 IGnssCallback::CAPABILITY_ANTENNA_INFO);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070064 auto status = sGnssCallback->gnssSetCapabilitiesCb(capabilities);
65 if (!status.isOk()) {
Yu-Han Yang4165ed12022-02-09 14:47:50 -080066 ALOGE("%s: Unable to invoke callback.gnssSetCapabilitiesCb", __func__);
67 }
68
69 IGnssCallback::GnssSystemInfo systemInfo = {
70 .yearOfHw = 2022,
71 .name = "Google Mock GNSS Implementation AIDL v2",
72 };
73 status = sGnssCallback->gnssSetSystemInfoCb(systemInfo);
74 if (!status.isOk()) {
75 ALOGE("%s: Unable to invoke callback.gnssSetSystemInfoCb", __func__);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070076 }
77
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080078 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070079}
80
Yuchen He42b2d0a2022-01-12 04:39:37 +000081std::unique_ptr<GnssLocation> Gnss::getLocationFromHW() {
Yuchen He090f16c2022-01-20 22:57:09 +000082 if (!::android::hardware::gnss::common::ReplayUtils::hasFixedLocationDeviceFile()) {
83 return nullptr;
84 }
Yuchen He42b2d0a2022-01-12 04:39:37 +000085 std::string inputStr =
86 ::android::hardware::gnss::common::DeviceFileReader::Instance().getLocationData();
Yuchen He090f16c2022-01-20 22:57:09 +000087 return ::android::hardware::gnss::common::FixLocationParser::getLocationFromInputStr(inputStr);
Yuchen He42b2d0a2022-01-12 04:39:37 +000088}
89
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080090ScopedAStatus Gnss::start() {
91 ALOGD("start()");
92 if (mIsActive) {
93 ALOGW("Gnss has started. Restarting...");
94 stop();
95 }
96
97 mIsActive = true;
Yu-Han Yang19a32b62022-04-27 09:57:01 -070098 mThreadBlocker.reset();
99 // notify measurement engine to update measurement interval
100 mGnssMeasurementInterface->setLocationEnabled(true);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800101 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_BEGIN);
102 mThread = std::thread([this]() {
Yu-Han Yang69f0f8b2022-01-21 13:03:32 -0800103 this->reportSvStatus();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800104 if (!mFirstFixReceived) {
105 std::this_thread::sleep_for(std::chrono::milliseconds(TTFF_MILLIS));
106 mFirstFixReceived = true;
107 }
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700108 do {
109 if (!mIsActive) {
110 break;
111 }
Yu-Han Yang69f0f8b2022-01-21 13:03:32 -0800112 this->reportSvStatus();
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700113 this->reportNmea();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800114
Yuchen He42b2d0a2022-01-12 04:39:37 +0000115 auto currentLocation = getLocationFromHW();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800116 mGnssPowerIndication->notePowerConsumption();
Yuchen He42b2d0a2022-01-12 04:39:37 +0000117 if (currentLocation != nullptr) {
118 this->reportLocation(*currentLocation);
119 } else {
120 const auto location = Utils::getMockLocation();
121 this->reportLocation(location);
122 }
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700123 } while (mIsActive && mThreadBlocker.wait_for(std::chrono::milliseconds(mMinIntervalMs)));
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800124 });
125 return ScopedAStatus::ok();
126}
127
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700128ScopedAStatus Gnss::stop() {
129 ALOGD("stop");
130 mIsActive = false;
131 mGnssMeasurementInterface->setLocationEnabled(false);
132 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_END);
133 mThreadBlocker.notify();
134 if (mThread.joinable()) {
135 mThread.join();
136 }
137 return ScopedAStatus::ok();
138}
139
140ScopedAStatus Gnss::close() {
141 ALOGD("close");
142 sGnssCallback = nullptr;
143 return ScopedAStatus::ok();
144}
145
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800146void Gnss::reportLocation(const GnssLocation& location) const {
147 std::unique_lock<std::mutex> lock(mMutex);
148 if (sGnssCallback == nullptr) {
149 ALOGE("%s: GnssCallback is null.", __func__);
150 return;
151 }
152 auto status = sGnssCallback->gnssLocationCb(location);
153 if (!status.isOk()) {
154 ALOGE("%s: Unable to invoke gnssLocationCb", __func__);
155 }
156 return;
157}
158
Yu-Han Yang69f0f8b2022-01-21 13:03:32 -0800159void Gnss::reportSvStatus() const {
160 if (mIsSvStatusActive) {
161 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
162 reportSvStatus(svStatus);
163 }
164}
165
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800166void Gnss::reportSvStatus(const std::vector<GnssSvInfo>& svInfoList) const {
167 std::unique_lock<std::mutex> lock(mMutex);
168 if (sGnssCallback == nullptr) {
169 ALOGE("%s: sGnssCallback is null.", __func__);
170 return;
171 }
172 auto status = sGnssCallback->gnssSvStatusCb(svInfoList);
173 if (!status.isOk()) {
174 ALOGE("%s: Unable to invoke callback", __func__);
175 }
176}
177
Yu-Han Yang69f0f8b2022-01-21 13:03:32 -0800178std::vector<GnssSvInfo> Gnss::filterBlocklistedSatellites(
179 std::vector<GnssSvInfo> gnssSvInfoList) const {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800180 for (uint32_t i = 0; i < gnssSvInfoList.size(); i++) {
181 if (mGnssConfiguration->isBlocklisted(gnssSvInfoList[i])) {
182 gnssSvInfoList[i].svFlag &= ~(uint32_t)IGnssCallback::GnssSvFlags::USED_IN_FIX;
183 }
184 }
185 return gnssSvInfoList;
186}
187
188void Gnss::reportGnssStatusValue(const IGnssCallback::GnssStatusValue gnssStatusValue) const {
189 std::unique_lock<std::mutex> lock(mMutex);
190 if (sGnssCallback == nullptr) {
191 ALOGE("%s: sGnssCallback is null.", __func__);
192 return;
193 }
194 auto status = sGnssCallback->gnssStatusCb(gnssStatusValue);
195 if (!status.isOk()) {
196 ALOGE("%s: Unable to invoke gnssStatusCb", __func__);
197 }
198}
199
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700200void Gnss::reportNmea() const {
201 if (mIsNmeaActive) {
202 std::unique_lock<std::mutex> lock(mMutex);
203 if (sGnssCallback == nullptr) {
204 ALOGE("%s: sGnssCallback is null.", __func__);
205 return;
206 }
207 nsecs_t now = systemTime(SYSTEM_TIME_MONOTONIC);
208 auto status = sGnssCallback->gnssNmeaCb(now, "$TEST,0,1,2,3,4,5");
209 if (!status.isOk()) {
210 ALOGE("%s: Unable to invoke callback", __func__);
211 }
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800212 }
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800213}
214
Yu-Han Yang69f0f8b2022-01-21 13:03:32 -0800215ScopedAStatus Gnss::startSvStatus() {
216 ALOGD("startSvStatus");
217 mIsSvStatusActive = true;
218 return ScopedAStatus::ok();
219}
220
221ScopedAStatus Gnss::stopSvStatus() {
222 ALOGD("stopSvStatus");
223 mIsSvStatusActive = false;
224 return ScopedAStatus::ok();
225}
226ScopedAStatus Gnss::startNmea() {
227 ALOGD("startNmea");
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700228 mIsNmeaActive = true;
Yu-Han Yang69f0f8b2022-01-21 13:03:32 -0800229 return ScopedAStatus::ok();
230}
231ScopedAStatus Gnss::stopNmea() {
232 ALOGD("stopNmea");
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700233 mIsNmeaActive = false;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800234 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700235}
236
Shinru Han0d91cbe2021-12-14 12:06:02 +0800237ScopedAStatus Gnss::getExtensionAGnss(std::shared_ptr<IAGnss>* iAGnss) {
Shinru Han7f31c142021-11-05 11:56:40 +0800238 ALOGD("Gnss::getExtensionAGnss");
239 *iAGnss = SharedRefBase::make<AGnss>();
240 return ndk::ScopedAStatus::ok();
241}
242
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800243ScopedAStatus Gnss::injectTime(int64_t timeMs, int64_t timeReferenceMs, int uncertaintyMs) {
244 ALOGD("injectTime. timeMs:%" PRId64 ", timeReferenceMs:%" PRId64 ", uncertaintyMs:%d", timeMs,
245 timeReferenceMs, uncertaintyMs);
246 return ScopedAStatus::ok();
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700247}
248
Shinru Han0d91cbe2021-12-14 12:06:02 +0800249ScopedAStatus Gnss::getExtensionAGnssRil(std::shared_ptr<IAGnssRil>* iAGnssRil) {
250 ALOGD("Gnss::getExtensionAGnssRil");
251 *iAGnssRil = SharedRefBase::make<AGnssRil>();
252 return ndk::ScopedAStatus::ok();
253}
254
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800255ScopedAStatus Gnss::injectLocation(const GnssLocation& location) {
256 ALOGD("injectLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
257 location.longitudeDegrees, location.horizontalAccuracyMeters);
258 return ScopedAStatus::ok();
259}
260
261ScopedAStatus Gnss::injectBestLocation(const GnssLocation& location) {
262 ALOGD("injectBestLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
263 location.longitudeDegrees, location.horizontalAccuracyMeters);
264 return ScopedAStatus::ok();
265}
266
267ScopedAStatus Gnss::deleteAidingData(GnssAidingData aidingDataFlags) {
268 ALOGD("deleteAidingData. flags:%d", (int)aidingDataFlags);
269 mFirstFixReceived = false;
270 return ScopedAStatus::ok();
271}
272
Yu-Han Yang75934f72022-01-24 15:35:25 -0800273ScopedAStatus Gnss::setPositionMode(const PositionModeOptions& options) {
274 ALOGD("setPositionMode. minIntervalMs:%d, lowPowerMode:%d", options.minIntervalMs,
275 (int)options.lowPowerMode);
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700276 mMinIntervalMs = std::max(1000, options.minIntervalMs);
277 mGnssMeasurementInterface->setLocationInterval(mMinIntervalMs);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800278 return ScopedAStatus::ok();
279}
280
281ScopedAStatus Gnss::getExtensionPsds(std::shared_ptr<IGnssPsds>* iGnssPsds) {
282 ALOGD("getExtensionPsds");
283 *iGnssPsds = SharedRefBase::make<GnssPsds>();
284 return ScopedAStatus::ok();
285}
286
287ScopedAStatus Gnss::getExtensionGnssConfiguration(
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700288 std::shared_ptr<IGnssConfiguration>* iGnssConfiguration) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800289 ALOGD("getExtensionGnssConfiguration");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700290 if (mGnssConfiguration == nullptr) {
291 mGnssConfiguration = SharedRefBase::make<GnssConfiguration>();
292 }
293 *iGnssConfiguration = mGnssConfiguration;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800294 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700295}
296
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800297ScopedAStatus Gnss::getExtensionGnssPowerIndication(
Yu-Han Yang24753612020-10-27 14:42:14 -0700298 std::shared_ptr<IGnssPowerIndication>* iGnssPowerIndication) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800299 ALOGD("getExtensionGnssPowerIndication");
Yu-Han Yang669be842021-04-26 20:17:53 -0700300 if (mGnssPowerIndication == nullptr) {
301 mGnssPowerIndication = SharedRefBase::make<GnssPowerIndication>();
302 }
Yu-Han Yang24753612020-10-27 14:42:14 -0700303
Yu-Han Yang669be842021-04-26 20:17:53 -0700304 *iGnssPowerIndication = mGnssPowerIndication;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800305 return ScopedAStatus::ok();
Yu-Han Yang24753612020-10-27 14:42:14 -0700306}
307
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800308ScopedAStatus Gnss::getExtensionGnssMeasurement(
Yu-Han Yang04832302020-11-20 09:51:18 -0800309 std::shared_ptr<IGnssMeasurementInterface>* iGnssMeasurement) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800310 ALOGD("getExtensionGnssMeasurement");
Yu-Han Yang19a32b62022-04-27 09:57:01 -0700311 if (mGnssMeasurementInterface == nullptr) {
312 mGnssMeasurementInterface = SharedRefBase::make<GnssMeasurementInterface>();
313 }
314 *iGnssMeasurement = mGnssMeasurementInterface;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800315 return ScopedAStatus::ok();
Yu-Han Yang04832302020-11-20 09:51:18 -0800316}
317
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800318ScopedAStatus Gnss::getExtensionGnssBatching(std::shared_ptr<IGnssBatching>* iGnssBatching) {
319 ALOGD("getExtensionGnssBatching");
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700320
321 *iGnssBatching = SharedRefBase::make<GnssBatching>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800322 return ScopedAStatus::ok();
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700323}
324
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800325ScopedAStatus Gnss::getExtensionGnssGeofence(std::shared_ptr<IGnssGeofence>* iGnssGeofence) {
326 ALOGD("getExtensionGnssGeofence");
Yu-Han Yang3089df32021-09-29 21:31:23 -0700327
328 *iGnssGeofence = SharedRefBase::make<GnssGeofence>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800329 return ScopedAStatus::ok();
Yu-Han Yang3089df32021-09-29 21:31:23 -0700330}
331
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800332ScopedAStatus Gnss::getExtensionGnssNavigationMessage(
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700333 std::shared_ptr<IGnssNavigationMessageInterface>* iGnssNavigationMessage) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800334 ALOGD("getExtensionGnssNavigationMessage");
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700335
336 *iGnssNavigationMessage = SharedRefBase::make<GnssNavigationMessageInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800337 return ScopedAStatus::ok();
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700338}
339
Joe Huang202b02d2021-11-16 23:09:11 +0800340ndk::ScopedAStatus Gnss::getExtensionGnssDebug(std::shared_ptr<IGnssDebug>* iGnssDebug) {
341 ALOGD("Gnss::getExtensionGnssDebug");
342
343 *iGnssDebug = SharedRefBase::make<GnssDebug>();
344 return ndk::ScopedAStatus::ok();
345}
346
Edwin Tungd7a5de22021-12-08 13:27:51 +0800347ndk::ScopedAStatus Gnss::getExtensionGnssVisibilityControl(
348 std::shared_ptr<visibility_control::IGnssVisibilityControl>* iGnssVisibilityControl) {
349 ALOGD("Gnss::getExtensionGnssVisibilityControl");
350
351 *iGnssVisibilityControl = SharedRefBase::make<visibility_control::GnssVisibilityControl>();
352 return ndk::ScopedAStatus::ok();
353}
354
Joe Huang37d77dd2021-12-30 13:14:29 +0800355ndk::ScopedAStatus Gnss::getExtensionGnssAntennaInfo(
356 std::shared_ptr<IGnssAntennaInfo>* iGnssAntennaInfo) {
357 ALOGD("Gnss::getExtensionGnssAntennaInfo");
358
359 *iGnssAntennaInfo = SharedRefBase::make<GnssAntennaInfo>();
360 return ndk::ScopedAStatus::ok();
361}
362
Edwin Tungbbf7fb92021-12-27 12:13:02 +0800363ndk::ScopedAStatus Gnss::getExtensionMeasurementCorrections(
364 std::shared_ptr<measurement_corrections::IMeasurementCorrectionsInterface>*
365 iMeasurementCorrections) {
366 ALOGD("Gnss::getExtensionMeasurementCorrections");
367
368 *iMeasurementCorrections =
369 SharedRefBase::make<measurement_corrections::MeasurementCorrectionsInterface>();
370 return ndk::ScopedAStatus::ok();
371}
372
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700373} // namespace aidl::android::hardware::gnss