blob: 2c6df995f156550b9e2b80275d348642a930c749 [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"
Joe Huang37d77dd2021-12-30 13:14:29 +080024#include "GnssAntennaInfo.h"
Yu-Han Yang3a75dc02021-09-27 01:01:06 -070025#include "GnssBatching.h"
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070026#include "GnssConfiguration.h"
Joe Huang202b02d2021-11-16 23:09:11 +080027#include "GnssDebug.h"
Yu-Han Yang3089df32021-09-29 21:31:23 -070028#include "GnssGeofence.h"
Yu-Han Yang04832302020-11-20 09:51:18 -080029#include "GnssMeasurementInterface.h"
Yu-Han Yang10cf7362021-10-03 22:32:04 -070030#include "GnssNavigationMessageInterface.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070031#include "GnssPsds.h"
Edwin Tungd7a5de22021-12-08 13:27:51 +080032#include "GnssVisibilityControl.h"
Yuchen He42b2d0a2022-01-12 04:39:37 +000033#include "NmeaFixInfo.h"
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080034#include "Utils.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070035
36namespace aidl::android::hardware::gnss {
Yuchen He42b2d0a2022-01-12 04:39:37 +000037using ::android::hardware::gnss::common::NmeaFixInfo;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080038using ::android::hardware::gnss::common::Utils;
Yuchen He42b2d0a2022-01-12 04:39:37 +000039
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080040using ndk::ScopedAStatus;
41using GnssSvInfo = IGnssCallback::GnssSvInfo;
42
43constexpr int TTFF_MILLIS = 2200;
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070044
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070045std::shared_ptr<IGnssCallback> Gnss::sGnssCallback = nullptr;
46
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080047Gnss::Gnss() : mMinIntervalMs(1000), mFirstFixReceived(false) {}
48
49ScopedAStatus Gnss::setCallback(const std::shared_ptr<IGnssCallback>& callback) {
50 ALOGD("setCallback");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070051 if (callback == nullptr) {
52 ALOGE("%s: Null callback ignored", __func__);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080053 return ScopedAStatus::fromExceptionCode(STATUS_INVALID_OPERATION);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070054 }
55
56 sGnssCallback = callback;
57
Joe Huang0d203ba2020-12-07 23:57:48 +080058 int capabilities = (int)(IGnssCallback::CAPABILITY_SATELLITE_BLOCKLIST |
Shinru Han4abab502020-12-09 15:07:18 +080059 IGnssCallback::CAPABILITY_SATELLITE_PVT |
Joe Huang37d77dd2021-12-30 13:14:29 +080060 IGnssCallback::CAPABILITY_CORRELATION_VECTOR |
61 IGnssCallback::CAPABILITY_ANTENNA_INFO);
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() {
72 std::string inputStr =
73 ::android::hardware::gnss::common::DeviceFileReader::Instance().getLocationData();
74 return ::android::hardware::gnss::common::NmeaFixInfo::getAidlLocationFromInputStr(inputStr);
75}
76
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080077ScopedAStatus Gnss::start() {
78 ALOGD("start()");
79 if (mIsActive) {
80 ALOGW("Gnss has started. Restarting...");
81 stop();
82 }
83
84 mIsActive = true;
85 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_BEGIN);
86 mThread = std::thread([this]() {
87 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
88 this->reportSvStatus(svStatus);
89 if (!mFirstFixReceived) {
90 std::this_thread::sleep_for(std::chrono::milliseconds(TTFF_MILLIS));
91 mFirstFixReceived = true;
92 }
93 while (mIsActive == true) {
94 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
95 this->reportSvStatus(svStatus);
96
Yuchen He42b2d0a2022-01-12 04:39:37 +000097 auto currentLocation = getLocationFromHW();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080098 mGnssPowerIndication->notePowerConsumption();
Yuchen He42b2d0a2022-01-12 04:39:37 +000099 if (currentLocation != nullptr) {
100 this->reportLocation(*currentLocation);
101 } else {
102 const auto location = Utils::getMockLocation();
103 this->reportLocation(location);
104 }
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800105 std::this_thread::sleep_for(std::chrono::milliseconds(mMinIntervalMs));
106 }
107 });
108 return ScopedAStatus::ok();
109}
110
111void Gnss::reportLocation(const GnssLocation& location) const {
112 std::unique_lock<std::mutex> lock(mMutex);
113 if (sGnssCallback == nullptr) {
114 ALOGE("%s: GnssCallback is null.", __func__);
115 return;
116 }
117 auto status = sGnssCallback->gnssLocationCb(location);
118 if (!status.isOk()) {
119 ALOGE("%s: Unable to invoke gnssLocationCb", __func__);
120 }
121 return;
122}
123
124void Gnss::reportSvStatus(const std::vector<GnssSvInfo>& svInfoList) const {
125 std::unique_lock<std::mutex> lock(mMutex);
126 if (sGnssCallback == nullptr) {
127 ALOGE("%s: sGnssCallback is null.", __func__);
128 return;
129 }
130 auto status = sGnssCallback->gnssSvStatusCb(svInfoList);
131 if (!status.isOk()) {
132 ALOGE("%s: Unable to invoke callback", __func__);
133 }
134}
135
136std::vector<GnssSvInfo> Gnss::filterBlocklistedSatellites(std::vector<GnssSvInfo> gnssSvInfoList) {
137 ALOGD("filterBlocklistedSatellites");
138 for (uint32_t i = 0; i < gnssSvInfoList.size(); i++) {
139 if (mGnssConfiguration->isBlocklisted(gnssSvInfoList[i])) {
140 gnssSvInfoList[i].svFlag &= ~(uint32_t)IGnssCallback::GnssSvFlags::USED_IN_FIX;
141 }
142 }
143 return gnssSvInfoList;
144}
145
146void Gnss::reportGnssStatusValue(const IGnssCallback::GnssStatusValue gnssStatusValue) const {
147 std::unique_lock<std::mutex> lock(mMutex);
148 if (sGnssCallback == nullptr) {
149 ALOGE("%s: sGnssCallback is null.", __func__);
150 return;
151 }
152 auto status = sGnssCallback->gnssStatusCb(gnssStatusValue);
153 if (!status.isOk()) {
154 ALOGE("%s: Unable to invoke gnssStatusCb", __func__);
155 }
156}
157
158ScopedAStatus Gnss::stop() {
159 ALOGD("stop");
160 mIsActive = false;
161 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_END);
162 if (mThread.joinable()) {
163 mThread.join();
164 }
165 return ScopedAStatus::ok();
166}
167
168ScopedAStatus Gnss::close() {
169 ALOGD("close");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700170 sGnssCallback = nullptr;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800171 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700172}
173
Shubham Dubeydd7f7b92022-01-11 05:26:13 +0000174ndk::ScopedAStatus Gnss::getExtensionAGnss(std::shared_ptr<IAGnss>* iAGnss) {
Shinru Han7f31c142021-11-05 11:56:40 +0800175 ALOGD("Gnss::getExtensionAGnss");
176 *iAGnss = SharedRefBase::make<AGnss>();
177 return ndk::ScopedAStatus::ok();
178}
179
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800180ScopedAStatus Gnss::injectTime(int64_t timeMs, int64_t timeReferenceMs, int uncertaintyMs) {
181 ALOGD("injectTime. timeMs:%" PRId64 ", timeReferenceMs:%" PRId64 ", uncertaintyMs:%d", timeMs,
182 timeReferenceMs, uncertaintyMs);
183 return ScopedAStatus::ok();
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700184}
185
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800186ScopedAStatus Gnss::injectLocation(const GnssLocation& location) {
187 ALOGD("injectLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
188 location.longitudeDegrees, location.horizontalAccuracyMeters);
189 return ScopedAStatus::ok();
190}
191
192ScopedAStatus Gnss::injectBestLocation(const GnssLocation& location) {
193 ALOGD("injectBestLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
194 location.longitudeDegrees, location.horizontalAccuracyMeters);
195 return ScopedAStatus::ok();
196}
197
198ScopedAStatus Gnss::deleteAidingData(GnssAidingData aidingDataFlags) {
199 ALOGD("deleteAidingData. flags:%d", (int)aidingDataFlags);
200 mFirstFixReceived = false;
201 return ScopedAStatus::ok();
202}
203
204ScopedAStatus Gnss::setPositionMode(GnssPositionMode, GnssPositionRecurrence, int minIntervalMs,
205 int /* preferredAccuracyMeters */, int /* preferredTimeMs */,
206 bool lowPowerMode) {
207 ALOGD("setPositionMode. minIntervalMs:%d, lowPowerMode:%d", minIntervalMs, (int)lowPowerMode);
208 mMinIntervalMs = minIntervalMs;
209 return ScopedAStatus::ok();
210}
211
212ScopedAStatus Gnss::getExtensionPsds(std::shared_ptr<IGnssPsds>* iGnssPsds) {
213 ALOGD("getExtensionPsds");
214 *iGnssPsds = SharedRefBase::make<GnssPsds>();
215 return ScopedAStatus::ok();
216}
217
218ScopedAStatus Gnss::getExtensionGnssConfiguration(
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700219 std::shared_ptr<IGnssConfiguration>* iGnssConfiguration) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800220 ALOGD("getExtensionGnssConfiguration");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700221 if (mGnssConfiguration == nullptr) {
222 mGnssConfiguration = SharedRefBase::make<GnssConfiguration>();
223 }
224 *iGnssConfiguration = mGnssConfiguration;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800225 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700226}
227
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800228ScopedAStatus Gnss::getExtensionGnssPowerIndication(
Yu-Han Yang24753612020-10-27 14:42:14 -0700229 std::shared_ptr<IGnssPowerIndication>* iGnssPowerIndication) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800230 ALOGD("getExtensionGnssPowerIndication");
Yu-Han Yang669be842021-04-26 20:17:53 -0700231 if (mGnssPowerIndication == nullptr) {
232 mGnssPowerIndication = SharedRefBase::make<GnssPowerIndication>();
233 }
Yu-Han Yang24753612020-10-27 14:42:14 -0700234
Yu-Han Yang669be842021-04-26 20:17:53 -0700235 *iGnssPowerIndication = mGnssPowerIndication;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800236 return ScopedAStatus::ok();
Yu-Han Yang24753612020-10-27 14:42:14 -0700237}
238
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800239ScopedAStatus Gnss::getExtensionGnssMeasurement(
Yu-Han Yang04832302020-11-20 09:51:18 -0800240 std::shared_ptr<IGnssMeasurementInterface>* iGnssMeasurement) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800241 ALOGD("getExtensionGnssMeasurement");
Yu-Han Yang04832302020-11-20 09:51:18 -0800242
243 *iGnssMeasurement = SharedRefBase::make<GnssMeasurementInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800244 return ScopedAStatus::ok();
Yu-Han Yang04832302020-11-20 09:51:18 -0800245}
246
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800247ScopedAStatus Gnss::getExtensionGnssBatching(std::shared_ptr<IGnssBatching>* iGnssBatching) {
248 ALOGD("getExtensionGnssBatching");
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700249
250 *iGnssBatching = SharedRefBase::make<GnssBatching>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800251 return ScopedAStatus::ok();
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700252}
253
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800254ScopedAStatus Gnss::getExtensionGnssGeofence(std::shared_ptr<IGnssGeofence>* iGnssGeofence) {
255 ALOGD("getExtensionGnssGeofence");
Yu-Han Yang3089df32021-09-29 21:31:23 -0700256
257 *iGnssGeofence = SharedRefBase::make<GnssGeofence>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800258 return ScopedAStatus::ok();
Yu-Han Yang3089df32021-09-29 21:31:23 -0700259}
260
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800261ScopedAStatus Gnss::getExtensionGnssNavigationMessage(
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700262 std::shared_ptr<IGnssNavigationMessageInterface>* iGnssNavigationMessage) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800263 ALOGD("getExtensionGnssNavigationMessage");
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700264
265 *iGnssNavigationMessage = SharedRefBase::make<GnssNavigationMessageInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800266 return ScopedAStatus::ok();
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700267}
268
Joe Huang202b02d2021-11-16 23:09:11 +0800269ndk::ScopedAStatus Gnss::getExtensionGnssDebug(std::shared_ptr<IGnssDebug>* iGnssDebug) {
270 ALOGD("Gnss::getExtensionGnssDebug");
271
272 *iGnssDebug = SharedRefBase::make<GnssDebug>();
273 return ndk::ScopedAStatus::ok();
274}
275
Edwin Tungd7a5de22021-12-08 13:27:51 +0800276ndk::ScopedAStatus Gnss::getExtensionGnssVisibilityControl(
277 std::shared_ptr<visibility_control::IGnssVisibilityControl>* iGnssVisibilityControl) {
278 ALOGD("Gnss::getExtensionGnssVisibilityControl");
279
280 *iGnssVisibilityControl = SharedRefBase::make<visibility_control::GnssVisibilityControl>();
281 return ndk::ScopedAStatus::ok();
282}
283
Joe Huang37d77dd2021-12-30 13:14:29 +0800284ndk::ScopedAStatus Gnss::getExtensionGnssAntennaInfo(
285 std::shared_ptr<IGnssAntennaInfo>* iGnssAntennaInfo) {
286 ALOGD("Gnss::getExtensionGnssAntennaInfo");
287
288 *iGnssAntennaInfo = SharedRefBase::make<GnssAntennaInfo>();
289 return ndk::ScopedAStatus::ok();
290}
291
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700292} // namespace aidl::android::hardware::gnss