blob: eb17bbfed3d0dfcb3df828c362b0101aa7b1b7ca [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"
Shinru Han0d91cbe2021-12-14 12:06:02 +080023#include "AGnssRil.h"
Yuchen He42b2d0a2022-01-12 04:39:37 +000024#include "DeviceFileReader.h"
Yuchen He090f16c2022-01-20 22:57:09 +000025#include "FixLocationParser.h"
Joe Huang37d77dd2021-12-30 13:14:29 +080026#include "GnssAntennaInfo.h"
Yu-Han Yang3a75dc02021-09-27 01:01:06 -070027#include "GnssBatching.h"
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070028#include "GnssConfiguration.h"
Joe Huang202b02d2021-11-16 23:09:11 +080029#include "GnssDebug.h"
Yu-Han Yang3089df32021-09-29 21:31:23 -070030#include "GnssGeofence.h"
Yu-Han Yang04832302020-11-20 09:51:18 -080031#include "GnssMeasurementInterface.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 }
56
57 sGnssCallback = callback;
58
Joe Huang0d203ba2020-12-07 23:57:48 +080059 int capabilities = (int)(IGnssCallback::CAPABILITY_SATELLITE_BLOCKLIST |
Shinru Han4abab502020-12-09 15:07:18 +080060 IGnssCallback::CAPABILITY_SATELLITE_PVT |
Joe Huangad5d0702022-01-19 19:01:44 +080061 IGnssCallback::CAPABILITY_CORRELATION_VECTOR);
Shinru Han4abab502020-12-09 15:07:18 +080062
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070063 auto status = sGnssCallback->gnssSetCapabilitiesCb(capabilities);
64 if (!status.isOk()) {
65 ALOGE("%s: Unable to invoke callback.gnssSetCapabilities", __func__);
66 }
67
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080068 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070069}
70
Yuchen He42b2d0a2022-01-12 04:39:37 +000071std::unique_ptr<GnssLocation> Gnss::getLocationFromHW() {
Yuchen He090f16c2022-01-20 22:57:09 +000072 if (!::android::hardware::gnss::common::ReplayUtils::hasFixedLocationDeviceFile()) {
73 return nullptr;
74 }
Yuchen He42b2d0a2022-01-12 04:39:37 +000075 std::string inputStr =
76 ::android::hardware::gnss::common::DeviceFileReader::Instance().getLocationData();
Yuchen He090f16c2022-01-20 22:57:09 +000077 return ::android::hardware::gnss::common::FixLocationParser::getLocationFromInputStr(inputStr);
Yuchen He42b2d0a2022-01-12 04:39:37 +000078}
79
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080080ScopedAStatus Gnss::start() {
81 ALOGD("start()");
82 if (mIsActive) {
83 ALOGW("Gnss has started. Restarting...");
84 stop();
85 }
86
87 mIsActive = true;
88 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_BEGIN);
89 mThread = std::thread([this]() {
90 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
91 this->reportSvStatus(svStatus);
92 if (!mFirstFixReceived) {
93 std::this_thread::sleep_for(std::chrono::milliseconds(TTFF_MILLIS));
94 mFirstFixReceived = true;
95 }
96 while (mIsActive == true) {
97 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
98 this->reportSvStatus(svStatus);
99
Yuchen He42b2d0a2022-01-12 04:39:37 +0000100 auto currentLocation = getLocationFromHW();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800101 mGnssPowerIndication->notePowerConsumption();
Yuchen He42b2d0a2022-01-12 04:39:37 +0000102 if (currentLocation != nullptr) {
103 this->reportLocation(*currentLocation);
104 } else {
105 const auto location = Utils::getMockLocation();
106 this->reportLocation(location);
107 }
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800108 std::this_thread::sleep_for(std::chrono::milliseconds(mMinIntervalMs));
109 }
110 });
111 return ScopedAStatus::ok();
112}
113
114void Gnss::reportLocation(const GnssLocation& location) const {
115 std::unique_lock<std::mutex> lock(mMutex);
116 if (sGnssCallback == nullptr) {
117 ALOGE("%s: GnssCallback is null.", __func__);
118 return;
119 }
120 auto status = sGnssCallback->gnssLocationCb(location);
121 if (!status.isOk()) {
122 ALOGE("%s: Unable to invoke gnssLocationCb", __func__);
123 }
124 return;
125}
126
127void Gnss::reportSvStatus(const std::vector<GnssSvInfo>& svInfoList) const {
128 std::unique_lock<std::mutex> lock(mMutex);
129 if (sGnssCallback == nullptr) {
130 ALOGE("%s: sGnssCallback is null.", __func__);
131 return;
132 }
133 auto status = sGnssCallback->gnssSvStatusCb(svInfoList);
134 if (!status.isOk()) {
135 ALOGE("%s: Unable to invoke callback", __func__);
136 }
137}
138
139std::vector<GnssSvInfo> Gnss::filterBlocklistedSatellites(std::vector<GnssSvInfo> gnssSvInfoList) {
140 ALOGD("filterBlocklistedSatellites");
141 for (uint32_t i = 0; i < gnssSvInfoList.size(); i++) {
142 if (mGnssConfiguration->isBlocklisted(gnssSvInfoList[i])) {
143 gnssSvInfoList[i].svFlag &= ~(uint32_t)IGnssCallback::GnssSvFlags::USED_IN_FIX;
144 }
145 }
146 return gnssSvInfoList;
147}
148
149void Gnss::reportGnssStatusValue(const IGnssCallback::GnssStatusValue gnssStatusValue) const {
150 std::unique_lock<std::mutex> lock(mMutex);
151 if (sGnssCallback == nullptr) {
152 ALOGE("%s: sGnssCallback is null.", __func__);
153 return;
154 }
155 auto status = sGnssCallback->gnssStatusCb(gnssStatusValue);
156 if (!status.isOk()) {
157 ALOGE("%s: Unable to invoke gnssStatusCb", __func__);
158 }
159}
160
161ScopedAStatus Gnss::stop() {
162 ALOGD("stop");
163 mIsActive = false;
164 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_END);
165 if (mThread.joinable()) {
166 mThread.join();
167 }
168 return ScopedAStatus::ok();
169}
170
171ScopedAStatus Gnss::close() {
172 ALOGD("close");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700173 sGnssCallback = nullptr;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800174 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700175}
176
Shinru Han0d91cbe2021-12-14 12:06:02 +0800177ScopedAStatus Gnss::getExtensionAGnss(std::shared_ptr<IAGnss>* iAGnss) {
Shinru Han7f31c142021-11-05 11:56:40 +0800178 ALOGD("Gnss::getExtensionAGnss");
179 *iAGnss = SharedRefBase::make<AGnss>();
180 return ndk::ScopedAStatus::ok();
181}
182
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800183ScopedAStatus Gnss::injectTime(int64_t timeMs, int64_t timeReferenceMs, int uncertaintyMs) {
184 ALOGD("injectTime. timeMs:%" PRId64 ", timeReferenceMs:%" PRId64 ", uncertaintyMs:%d", timeMs,
185 timeReferenceMs, uncertaintyMs);
186 return ScopedAStatus::ok();
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700187}
188
Shinru Han0d91cbe2021-12-14 12:06:02 +0800189ScopedAStatus Gnss::getExtensionAGnssRil(std::shared_ptr<IAGnssRil>* iAGnssRil) {
190 ALOGD("Gnss::getExtensionAGnssRil");
191 *iAGnssRil = SharedRefBase::make<AGnssRil>();
192 return ndk::ScopedAStatus::ok();
193}
194
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800195ScopedAStatus Gnss::injectLocation(const GnssLocation& location) {
196 ALOGD("injectLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
197 location.longitudeDegrees, location.horizontalAccuracyMeters);
198 return ScopedAStatus::ok();
199}
200
201ScopedAStatus Gnss::injectBestLocation(const GnssLocation& location) {
202 ALOGD("injectBestLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
203 location.longitudeDegrees, location.horizontalAccuracyMeters);
204 return ScopedAStatus::ok();
205}
206
207ScopedAStatus Gnss::deleteAidingData(GnssAidingData aidingDataFlags) {
208 ALOGD("deleteAidingData. flags:%d", (int)aidingDataFlags);
209 mFirstFixReceived = false;
210 return ScopedAStatus::ok();
211}
212
Yu-Han Yang75934f72022-01-24 15:35:25 -0800213ScopedAStatus Gnss::setPositionMode(const PositionModeOptions& options) {
214 ALOGD("setPositionMode. minIntervalMs:%d, lowPowerMode:%d", options.minIntervalMs,
215 (int)options.lowPowerMode);
216 mMinIntervalMs = options.minIntervalMs;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800217 return ScopedAStatus::ok();
218}
219
220ScopedAStatus Gnss::getExtensionPsds(std::shared_ptr<IGnssPsds>* iGnssPsds) {
221 ALOGD("getExtensionPsds");
222 *iGnssPsds = SharedRefBase::make<GnssPsds>();
223 return ScopedAStatus::ok();
224}
225
226ScopedAStatus Gnss::getExtensionGnssConfiguration(
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700227 std::shared_ptr<IGnssConfiguration>* iGnssConfiguration) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800228 ALOGD("getExtensionGnssConfiguration");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700229 if (mGnssConfiguration == nullptr) {
230 mGnssConfiguration = SharedRefBase::make<GnssConfiguration>();
231 }
232 *iGnssConfiguration = mGnssConfiguration;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800233 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700234}
235
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800236ScopedAStatus Gnss::getExtensionGnssPowerIndication(
Yu-Han Yang24753612020-10-27 14:42:14 -0700237 std::shared_ptr<IGnssPowerIndication>* iGnssPowerIndication) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800238 ALOGD("getExtensionGnssPowerIndication");
Yu-Han Yang669be842021-04-26 20:17:53 -0700239 if (mGnssPowerIndication == nullptr) {
240 mGnssPowerIndication = SharedRefBase::make<GnssPowerIndication>();
241 }
Yu-Han Yang24753612020-10-27 14:42:14 -0700242
Yu-Han Yang669be842021-04-26 20:17:53 -0700243 *iGnssPowerIndication = mGnssPowerIndication;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800244 return ScopedAStatus::ok();
Yu-Han Yang24753612020-10-27 14:42:14 -0700245}
246
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800247ScopedAStatus Gnss::getExtensionGnssMeasurement(
Yu-Han Yang04832302020-11-20 09:51:18 -0800248 std::shared_ptr<IGnssMeasurementInterface>* iGnssMeasurement) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800249 ALOGD("getExtensionGnssMeasurement");
Yu-Han Yang04832302020-11-20 09:51:18 -0800250
251 *iGnssMeasurement = SharedRefBase::make<GnssMeasurementInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800252 return ScopedAStatus::ok();
Yu-Han Yang04832302020-11-20 09:51:18 -0800253}
254
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800255ScopedAStatus Gnss::getExtensionGnssBatching(std::shared_ptr<IGnssBatching>* iGnssBatching) {
256 ALOGD("getExtensionGnssBatching");
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700257
258 *iGnssBatching = SharedRefBase::make<GnssBatching>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800259 return ScopedAStatus::ok();
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700260}
261
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800262ScopedAStatus Gnss::getExtensionGnssGeofence(std::shared_ptr<IGnssGeofence>* iGnssGeofence) {
263 ALOGD("getExtensionGnssGeofence");
Yu-Han Yang3089df32021-09-29 21:31:23 -0700264
265 *iGnssGeofence = SharedRefBase::make<GnssGeofence>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800266 return ScopedAStatus::ok();
Yu-Han Yang3089df32021-09-29 21:31:23 -0700267}
268
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800269ScopedAStatus Gnss::getExtensionGnssNavigationMessage(
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700270 std::shared_ptr<IGnssNavigationMessageInterface>* iGnssNavigationMessage) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800271 ALOGD("getExtensionGnssNavigationMessage");
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700272
273 *iGnssNavigationMessage = SharedRefBase::make<GnssNavigationMessageInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800274 return ScopedAStatus::ok();
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700275}
276
Joe Huang202b02d2021-11-16 23:09:11 +0800277ndk::ScopedAStatus Gnss::getExtensionGnssDebug(std::shared_ptr<IGnssDebug>* iGnssDebug) {
278 ALOGD("Gnss::getExtensionGnssDebug");
279
280 *iGnssDebug = SharedRefBase::make<GnssDebug>();
281 return ndk::ScopedAStatus::ok();
282}
283
Edwin Tungd7a5de22021-12-08 13:27:51 +0800284ndk::ScopedAStatus Gnss::getExtensionGnssVisibilityControl(
285 std::shared_ptr<visibility_control::IGnssVisibilityControl>* iGnssVisibilityControl) {
286 ALOGD("Gnss::getExtensionGnssVisibilityControl");
287
288 *iGnssVisibilityControl = SharedRefBase::make<visibility_control::GnssVisibilityControl>();
289 return ndk::ScopedAStatus::ok();
290}
291
Joe Huang37d77dd2021-12-30 13:14:29 +0800292ndk::ScopedAStatus Gnss::getExtensionGnssAntennaInfo(
293 std::shared_ptr<IGnssAntennaInfo>* iGnssAntennaInfo) {
294 ALOGD("Gnss::getExtensionGnssAntennaInfo");
295
296 *iGnssAntennaInfo = SharedRefBase::make<GnssAntennaInfo>();
297 return ndk::ScopedAStatus::ok();
298}
299
Edwin Tungbbf7fb92021-12-27 12:13:02 +0800300ndk::ScopedAStatus Gnss::getExtensionMeasurementCorrections(
301 std::shared_ptr<measurement_corrections::IMeasurementCorrectionsInterface>*
302 iMeasurementCorrections) {
303 ALOGD("Gnss::getExtensionMeasurementCorrections");
304
305 *iMeasurementCorrections =
306 SharedRefBase::make<measurement_corrections::MeasurementCorrectionsInterface>();
307 return ndk::ScopedAStatus::ok();
308}
309
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700310} // namespace aidl::android::hardware::gnss