blob: 657877898ff27aa90d796e516cb8440a32068684 [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"
Yuchen He42b2d0a2022-01-12 04:39:37 +000023#include "DeviceFileReader.h"
Yu-Han Yang3a75dc02021-09-27 01:01:06 -070024#include "GnssBatching.h"
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070025#include "GnssConfiguration.h"
Joe Huang202b02d2021-11-16 23:09:11 +080026#include "GnssDebug.h"
Yu-Han Yang3089df32021-09-29 21:31:23 -070027#include "GnssGeofence.h"
Yu-Han Yang04832302020-11-20 09:51:18 -080028#include "GnssMeasurementInterface.h"
Yu-Han Yang10cf7362021-10-03 22:32:04 -070029#include "GnssNavigationMessageInterface.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070030#include "GnssPsds.h"
Edwin Tungd7a5de22021-12-08 13:27:51 +080031#include "GnssVisibilityControl.h"
Yuchen He42b2d0a2022-01-12 04:39:37 +000032#include "NmeaFixInfo.h"
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080033#include "Utils.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070034
35namespace aidl::android::hardware::gnss {
Yuchen He42b2d0a2022-01-12 04:39:37 +000036using ::android::hardware::gnss::common::NmeaFixInfo;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080037using ::android::hardware::gnss::common::Utils;
Yuchen He42b2d0a2022-01-12 04:39:37 +000038
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080039using ndk::ScopedAStatus;
40using GnssSvInfo = IGnssCallback::GnssSvInfo;
41
42constexpr int TTFF_MILLIS = 2200;
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070043
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070044std::shared_ptr<IGnssCallback> Gnss::sGnssCallback = nullptr;
45
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080046Gnss::Gnss() : mMinIntervalMs(1000), mFirstFixReceived(false) {}
47
48ScopedAStatus Gnss::setCallback(const std::shared_ptr<IGnssCallback>& callback) {
49 ALOGD("setCallback");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070050 if (callback == nullptr) {
51 ALOGE("%s: Null callback ignored", __func__);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080052 return ScopedAStatus::fromExceptionCode(STATUS_INVALID_OPERATION);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070053 }
54
55 sGnssCallback = callback;
56
Joe Huang0d203ba2020-12-07 23:57:48 +080057 int capabilities = (int)(IGnssCallback::CAPABILITY_SATELLITE_BLOCKLIST |
Shinru Han4abab502020-12-09 15:07:18 +080058 IGnssCallback::CAPABILITY_SATELLITE_PVT |
59 IGnssCallback::CAPABILITY_CORRELATION_VECTOR);
60
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070061 auto status = sGnssCallback->gnssSetCapabilitiesCb(capabilities);
62 if (!status.isOk()) {
63 ALOGE("%s: Unable to invoke callback.gnssSetCapabilities", __func__);
64 }
65
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080066 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070067}
68
Yuchen He42b2d0a2022-01-12 04:39:37 +000069std::unique_ptr<GnssLocation> Gnss::getLocationFromHW() {
70 std::string inputStr =
71 ::android::hardware::gnss::common::DeviceFileReader::Instance().getLocationData();
72 return ::android::hardware::gnss::common::NmeaFixInfo::getAidlLocationFromInputStr(inputStr);
73}
74
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080075ScopedAStatus Gnss::start() {
76 ALOGD("start()");
77 if (mIsActive) {
78 ALOGW("Gnss has started. Restarting...");
79 stop();
80 }
81
82 mIsActive = true;
83 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_BEGIN);
84 mThread = std::thread([this]() {
85 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
86 this->reportSvStatus(svStatus);
87 if (!mFirstFixReceived) {
88 std::this_thread::sleep_for(std::chrono::milliseconds(TTFF_MILLIS));
89 mFirstFixReceived = true;
90 }
91 while (mIsActive == true) {
92 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
93 this->reportSvStatus(svStatus);
94
Yuchen He42b2d0a2022-01-12 04:39:37 +000095 auto currentLocation = getLocationFromHW();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080096 mGnssPowerIndication->notePowerConsumption();
Yuchen He42b2d0a2022-01-12 04:39:37 +000097 if (currentLocation != nullptr) {
98 this->reportLocation(*currentLocation);
99 } else {
100 const auto location = Utils::getMockLocation();
101 this->reportLocation(location);
102 }
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800103 std::this_thread::sleep_for(std::chrono::milliseconds(mMinIntervalMs));
104 }
105 });
106 return ScopedAStatus::ok();
107}
108
109void Gnss::reportLocation(const GnssLocation& location) const {
110 std::unique_lock<std::mutex> lock(mMutex);
111 if (sGnssCallback == nullptr) {
112 ALOGE("%s: GnssCallback is null.", __func__);
113 return;
114 }
115 auto status = sGnssCallback->gnssLocationCb(location);
116 if (!status.isOk()) {
117 ALOGE("%s: Unable to invoke gnssLocationCb", __func__);
118 }
119 return;
120}
121
122void Gnss::reportSvStatus(const std::vector<GnssSvInfo>& svInfoList) const {
123 std::unique_lock<std::mutex> lock(mMutex);
124 if (sGnssCallback == nullptr) {
125 ALOGE("%s: sGnssCallback is null.", __func__);
126 return;
127 }
128 auto status = sGnssCallback->gnssSvStatusCb(svInfoList);
129 if (!status.isOk()) {
130 ALOGE("%s: Unable to invoke callback", __func__);
131 }
132}
133
134std::vector<GnssSvInfo> Gnss::filterBlocklistedSatellites(std::vector<GnssSvInfo> gnssSvInfoList) {
135 ALOGD("filterBlocklistedSatellites");
136 for (uint32_t i = 0; i < gnssSvInfoList.size(); i++) {
137 if (mGnssConfiguration->isBlocklisted(gnssSvInfoList[i])) {
138 gnssSvInfoList[i].svFlag &= ~(uint32_t)IGnssCallback::GnssSvFlags::USED_IN_FIX;
139 }
140 }
141 return gnssSvInfoList;
142}
143
144void Gnss::reportGnssStatusValue(const IGnssCallback::GnssStatusValue gnssStatusValue) const {
145 std::unique_lock<std::mutex> lock(mMutex);
146 if (sGnssCallback == nullptr) {
147 ALOGE("%s: sGnssCallback is null.", __func__);
148 return;
149 }
150 auto status = sGnssCallback->gnssStatusCb(gnssStatusValue);
151 if (!status.isOk()) {
152 ALOGE("%s: Unable to invoke gnssStatusCb", __func__);
153 }
154}
155
156ScopedAStatus Gnss::stop() {
157 ALOGD("stop");
158 mIsActive = false;
159 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_END);
160 if (mThread.joinable()) {
161 mThread.join();
162 }
163 return ScopedAStatus::ok();
164}
165
166ScopedAStatus Gnss::close() {
167 ALOGD("close");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700168 sGnssCallback = nullptr;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800169 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700170}
171
Shubham Dubeydd7f7b92022-01-11 05:26:13 +0000172ndk::ScopedAStatus Gnss::getExtensionAGnss(std::shared_ptr<IAGnss>* iAGnss) {
Shinru Han7f31c142021-11-05 11:56:40 +0800173 ALOGD("Gnss::getExtensionAGnss");
174 *iAGnss = SharedRefBase::make<AGnss>();
175 return ndk::ScopedAStatus::ok();
176}
177
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800178ScopedAStatus Gnss::injectTime(int64_t timeMs, int64_t timeReferenceMs, int uncertaintyMs) {
179 ALOGD("injectTime. timeMs:%" PRId64 ", timeReferenceMs:%" PRId64 ", uncertaintyMs:%d", timeMs,
180 timeReferenceMs, uncertaintyMs);
181 return ScopedAStatus::ok();
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700182}
183
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800184ScopedAStatus Gnss::injectLocation(const GnssLocation& location) {
185 ALOGD("injectLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
186 location.longitudeDegrees, location.horizontalAccuracyMeters);
187 return ScopedAStatus::ok();
188}
189
190ScopedAStatus Gnss::injectBestLocation(const GnssLocation& location) {
191 ALOGD("injectBestLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
192 location.longitudeDegrees, location.horizontalAccuracyMeters);
193 return ScopedAStatus::ok();
194}
195
196ScopedAStatus Gnss::deleteAidingData(GnssAidingData aidingDataFlags) {
197 ALOGD("deleteAidingData. flags:%d", (int)aidingDataFlags);
198 mFirstFixReceived = false;
199 return ScopedAStatus::ok();
200}
201
202ScopedAStatus Gnss::setPositionMode(GnssPositionMode, GnssPositionRecurrence, int minIntervalMs,
203 int /* preferredAccuracyMeters */, int /* preferredTimeMs */,
204 bool lowPowerMode) {
205 ALOGD("setPositionMode. minIntervalMs:%d, lowPowerMode:%d", minIntervalMs, (int)lowPowerMode);
206 mMinIntervalMs = minIntervalMs;
207 return ScopedAStatus::ok();
208}
209
210ScopedAStatus Gnss::getExtensionPsds(std::shared_ptr<IGnssPsds>* iGnssPsds) {
211 ALOGD("getExtensionPsds");
212 *iGnssPsds = SharedRefBase::make<GnssPsds>();
213 return ScopedAStatus::ok();
214}
215
216ScopedAStatus Gnss::getExtensionGnssConfiguration(
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700217 std::shared_ptr<IGnssConfiguration>* iGnssConfiguration) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800218 ALOGD("getExtensionGnssConfiguration");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700219 if (mGnssConfiguration == nullptr) {
220 mGnssConfiguration = SharedRefBase::make<GnssConfiguration>();
221 }
222 *iGnssConfiguration = mGnssConfiguration;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800223 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700224}
225
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800226ScopedAStatus Gnss::getExtensionGnssPowerIndication(
Yu-Han Yang24753612020-10-27 14:42:14 -0700227 std::shared_ptr<IGnssPowerIndication>* iGnssPowerIndication) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800228 ALOGD("getExtensionGnssPowerIndication");
Yu-Han Yang669be842021-04-26 20:17:53 -0700229 if (mGnssPowerIndication == nullptr) {
230 mGnssPowerIndication = SharedRefBase::make<GnssPowerIndication>();
231 }
Yu-Han Yang24753612020-10-27 14:42:14 -0700232
Yu-Han Yang669be842021-04-26 20:17:53 -0700233 *iGnssPowerIndication = mGnssPowerIndication;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800234 return ScopedAStatus::ok();
Yu-Han Yang24753612020-10-27 14:42:14 -0700235}
236
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800237ScopedAStatus Gnss::getExtensionGnssMeasurement(
Yu-Han Yang04832302020-11-20 09:51:18 -0800238 std::shared_ptr<IGnssMeasurementInterface>* iGnssMeasurement) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800239 ALOGD("getExtensionGnssMeasurement");
Yu-Han Yang04832302020-11-20 09:51:18 -0800240
241 *iGnssMeasurement = SharedRefBase::make<GnssMeasurementInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800242 return ScopedAStatus::ok();
Yu-Han Yang04832302020-11-20 09:51:18 -0800243}
244
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800245ScopedAStatus Gnss::getExtensionGnssBatching(std::shared_ptr<IGnssBatching>* iGnssBatching) {
246 ALOGD("getExtensionGnssBatching");
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700247
248 *iGnssBatching = SharedRefBase::make<GnssBatching>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800249 return ScopedAStatus::ok();
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700250}
251
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800252ScopedAStatus Gnss::getExtensionGnssGeofence(std::shared_ptr<IGnssGeofence>* iGnssGeofence) {
253 ALOGD("getExtensionGnssGeofence");
Yu-Han Yang3089df32021-09-29 21:31:23 -0700254
255 *iGnssGeofence = SharedRefBase::make<GnssGeofence>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800256 return ScopedAStatus::ok();
Yu-Han Yang3089df32021-09-29 21:31:23 -0700257}
258
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800259ScopedAStatus Gnss::getExtensionGnssNavigationMessage(
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700260 std::shared_ptr<IGnssNavigationMessageInterface>* iGnssNavigationMessage) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800261 ALOGD("getExtensionGnssNavigationMessage");
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700262
263 *iGnssNavigationMessage = SharedRefBase::make<GnssNavigationMessageInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800264 return ScopedAStatus::ok();
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700265}
266
Joe Huang202b02d2021-11-16 23:09:11 +0800267ndk::ScopedAStatus Gnss::getExtensionGnssDebug(std::shared_ptr<IGnssDebug>* iGnssDebug) {
268 ALOGD("Gnss::getExtensionGnssDebug");
269
270 *iGnssDebug = SharedRefBase::make<GnssDebug>();
271 return ndk::ScopedAStatus::ok();
272}
273
Edwin Tungd7a5de22021-12-08 13:27:51 +0800274ndk::ScopedAStatus Gnss::getExtensionGnssVisibilityControl(
275 std::shared_ptr<visibility_control::IGnssVisibilityControl>* iGnssVisibilityControl) {
276 ALOGD("Gnss::getExtensionGnssVisibilityControl");
277
278 *iGnssVisibilityControl = SharedRefBase::make<visibility_control::GnssVisibilityControl>();
279 return ndk::ScopedAStatus::ok();
280}
281
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700282} // namespace aidl::android::hardware::gnss