blob: dba54a017dc387314fabb137455a9ee54768045b [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 Han5f33dbe2021-12-14 12:06:02 +080023#include "AGnssRil.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"
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080032#include "Utils.h"
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070033
34namespace aidl::android::hardware::gnss {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080035using ::android::hardware::gnss::common::Utils;
36using ndk::ScopedAStatus;
37using GnssSvInfo = IGnssCallback::GnssSvInfo;
38
39constexpr int TTFF_MILLIS = 2200;
Yu-Han Yang274ea0a2020-09-09 17:25:02 -070040
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070041std::shared_ptr<IGnssCallback> Gnss::sGnssCallback = nullptr;
42
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080043Gnss::Gnss() : mMinIntervalMs(1000), mFirstFixReceived(false) {}
44
45ScopedAStatus Gnss::setCallback(const std::shared_ptr<IGnssCallback>& callback) {
46 ALOGD("setCallback");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070047 if (callback == nullptr) {
48 ALOGE("%s: Null callback ignored", __func__);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080049 return ScopedAStatus::fromExceptionCode(STATUS_INVALID_OPERATION);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070050 }
51
52 sGnssCallback = callback;
53
Joe Huang0d203ba2020-12-07 23:57:48 +080054 int capabilities = (int)(IGnssCallback::CAPABILITY_SATELLITE_BLOCKLIST |
Shinru Han4abab502020-12-09 15:07:18 +080055 IGnssCallback::CAPABILITY_SATELLITE_PVT |
56 IGnssCallback::CAPABILITY_CORRELATION_VECTOR);
57
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070058 auto status = sGnssCallback->gnssSetCapabilitiesCb(capabilities);
59 if (!status.isOk()) {
60 ALOGE("%s: Unable to invoke callback.gnssSetCapabilities", __func__);
61 }
62
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080063 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070064}
65
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080066ScopedAStatus Gnss::start() {
67 ALOGD("start()");
68 if (mIsActive) {
69 ALOGW("Gnss has started. Restarting...");
70 stop();
71 }
72
73 mIsActive = true;
74 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_BEGIN);
75 mThread = std::thread([this]() {
76 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
77 this->reportSvStatus(svStatus);
78 if (!mFirstFixReceived) {
79 std::this_thread::sleep_for(std::chrono::milliseconds(TTFF_MILLIS));
80 mFirstFixReceived = true;
81 }
82 while (mIsActive == true) {
83 auto svStatus = filterBlocklistedSatellites(Utils::getMockSvInfoList());
84 this->reportSvStatus(svStatus);
85
86 mGnssPowerIndication->notePowerConsumption();
87 const auto location = Utils::getMockLocation();
88 this->reportLocation(location);
89 std::this_thread::sleep_for(std::chrono::milliseconds(mMinIntervalMs));
90 }
91 });
92 return ScopedAStatus::ok();
93}
94
95void Gnss::reportLocation(const GnssLocation& location) const {
96 std::unique_lock<std::mutex> lock(mMutex);
97 if (sGnssCallback == nullptr) {
98 ALOGE("%s: GnssCallback is null.", __func__);
99 return;
100 }
101 auto status = sGnssCallback->gnssLocationCb(location);
102 if (!status.isOk()) {
103 ALOGE("%s: Unable to invoke gnssLocationCb", __func__);
104 }
105 return;
106}
107
108void Gnss::reportSvStatus(const std::vector<GnssSvInfo>& svInfoList) const {
109 std::unique_lock<std::mutex> lock(mMutex);
110 if (sGnssCallback == nullptr) {
111 ALOGE("%s: sGnssCallback is null.", __func__);
112 return;
113 }
114 auto status = sGnssCallback->gnssSvStatusCb(svInfoList);
115 if (!status.isOk()) {
116 ALOGE("%s: Unable to invoke callback", __func__);
117 }
118}
119
120std::vector<GnssSvInfo> Gnss::filterBlocklistedSatellites(std::vector<GnssSvInfo> gnssSvInfoList) {
121 ALOGD("filterBlocklistedSatellites");
122 for (uint32_t i = 0; i < gnssSvInfoList.size(); i++) {
123 if (mGnssConfiguration->isBlocklisted(gnssSvInfoList[i])) {
124 gnssSvInfoList[i].svFlag &= ~(uint32_t)IGnssCallback::GnssSvFlags::USED_IN_FIX;
125 }
126 }
127 return gnssSvInfoList;
128}
129
130void Gnss::reportGnssStatusValue(const IGnssCallback::GnssStatusValue gnssStatusValue) const {
131 std::unique_lock<std::mutex> lock(mMutex);
132 if (sGnssCallback == nullptr) {
133 ALOGE("%s: sGnssCallback is null.", __func__);
134 return;
135 }
136 auto status = sGnssCallback->gnssStatusCb(gnssStatusValue);
137 if (!status.isOk()) {
138 ALOGE("%s: Unable to invoke gnssStatusCb", __func__);
139 }
140}
141
142ScopedAStatus Gnss::stop() {
143 ALOGD("stop");
144 mIsActive = false;
145 this->reportGnssStatusValue(IGnssCallback::GnssStatusValue::SESSION_END);
146 if (mThread.joinable()) {
147 mThread.join();
148 }
149 return ScopedAStatus::ok();
150}
151
152ScopedAStatus Gnss::close() {
153 ALOGD("close");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700154 sGnssCallback = nullptr;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800155 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700156}
157
Shinru Han5f33dbe2021-12-14 12:06:02 +0800158ScopedAStatus Gnss::getExtensionAGnss(std::shared_ptr<IAGnss>* iAGnss) {
Shinru Han7f31c142021-11-05 11:56:40 +0800159 ALOGD("Gnss::getExtensionAGnss");
160 *iAGnss = SharedRefBase::make<AGnss>();
161 return ndk::ScopedAStatus::ok();
162}
163
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800164ScopedAStatus Gnss::injectTime(int64_t timeMs, int64_t timeReferenceMs, int uncertaintyMs) {
165 ALOGD("injectTime. timeMs:%" PRId64 ", timeReferenceMs:%" PRId64 ", uncertaintyMs:%d", timeMs,
166 timeReferenceMs, uncertaintyMs);
167 return ScopedAStatus::ok();
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700168}
169
Shinru Han5f33dbe2021-12-14 12:06:02 +0800170ScopedAStatus Gnss::getExtensionAGnssRil(std::shared_ptr<IAGnssRil>* iAGnssRil) {
171 ALOGD("Gnss::getExtensionAGnssRil");
172 *iAGnssRil = SharedRefBase::make<AGnssRil>();
173 return ndk::ScopedAStatus::ok();
174}
175
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800176ScopedAStatus Gnss::injectLocation(const GnssLocation& location) {
177 ALOGD("injectLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
178 location.longitudeDegrees, location.horizontalAccuracyMeters);
179 return ScopedAStatus::ok();
180}
181
182ScopedAStatus Gnss::injectBestLocation(const GnssLocation& location) {
183 ALOGD("injectBestLocation. lat:%lf, lng:%lf, acc:%f", location.latitudeDegrees,
184 location.longitudeDegrees, location.horizontalAccuracyMeters);
185 return ScopedAStatus::ok();
186}
187
188ScopedAStatus Gnss::deleteAidingData(GnssAidingData aidingDataFlags) {
189 ALOGD("deleteAidingData. flags:%d", (int)aidingDataFlags);
190 mFirstFixReceived = false;
191 return ScopedAStatus::ok();
192}
193
194ScopedAStatus Gnss::setPositionMode(GnssPositionMode, GnssPositionRecurrence, int minIntervalMs,
195 int /* preferredAccuracyMeters */, int /* preferredTimeMs */,
196 bool lowPowerMode) {
197 ALOGD("setPositionMode. minIntervalMs:%d, lowPowerMode:%d", minIntervalMs, (int)lowPowerMode);
198 mMinIntervalMs = minIntervalMs;
199 return ScopedAStatus::ok();
200}
201
202ScopedAStatus Gnss::getExtensionPsds(std::shared_ptr<IGnssPsds>* iGnssPsds) {
203 ALOGD("getExtensionPsds");
204 *iGnssPsds = SharedRefBase::make<GnssPsds>();
205 return ScopedAStatus::ok();
206}
207
208ScopedAStatus Gnss::getExtensionGnssConfiguration(
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700209 std::shared_ptr<IGnssConfiguration>* iGnssConfiguration) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800210 ALOGD("getExtensionGnssConfiguration");
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700211 if (mGnssConfiguration == nullptr) {
212 mGnssConfiguration = SharedRefBase::make<GnssConfiguration>();
213 }
214 *iGnssConfiguration = mGnssConfiguration;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800215 return ScopedAStatus::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -0700216}
217
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800218ScopedAStatus Gnss::getExtensionGnssPowerIndication(
Yu-Han Yang24753612020-10-27 14:42:14 -0700219 std::shared_ptr<IGnssPowerIndication>* iGnssPowerIndication) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800220 ALOGD("getExtensionGnssPowerIndication");
Yu-Han Yang669be842021-04-26 20:17:53 -0700221 if (mGnssPowerIndication == nullptr) {
222 mGnssPowerIndication = SharedRefBase::make<GnssPowerIndication>();
223 }
Yu-Han Yang24753612020-10-27 14:42:14 -0700224
Yu-Han Yang669be842021-04-26 20:17:53 -0700225 *iGnssPowerIndication = mGnssPowerIndication;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800226 return ScopedAStatus::ok();
Yu-Han Yang24753612020-10-27 14:42:14 -0700227}
228
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800229ScopedAStatus Gnss::getExtensionGnssMeasurement(
Yu-Han Yang04832302020-11-20 09:51:18 -0800230 std::shared_ptr<IGnssMeasurementInterface>* iGnssMeasurement) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800231 ALOGD("getExtensionGnssMeasurement");
Yu-Han Yang04832302020-11-20 09:51:18 -0800232
233 *iGnssMeasurement = SharedRefBase::make<GnssMeasurementInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800234 return ScopedAStatus::ok();
Yu-Han Yang04832302020-11-20 09:51:18 -0800235}
236
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800237ScopedAStatus Gnss::getExtensionGnssBatching(std::shared_ptr<IGnssBatching>* iGnssBatching) {
238 ALOGD("getExtensionGnssBatching");
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700239
240 *iGnssBatching = SharedRefBase::make<GnssBatching>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800241 return ScopedAStatus::ok();
Yu-Han Yang3a75dc02021-09-27 01:01:06 -0700242}
243
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800244ScopedAStatus Gnss::getExtensionGnssGeofence(std::shared_ptr<IGnssGeofence>* iGnssGeofence) {
245 ALOGD("getExtensionGnssGeofence");
Yu-Han Yang3089df32021-09-29 21:31:23 -0700246
247 *iGnssGeofence = SharedRefBase::make<GnssGeofence>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800248 return ScopedAStatus::ok();
Yu-Han Yang3089df32021-09-29 21:31:23 -0700249}
250
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800251ScopedAStatus Gnss::getExtensionGnssNavigationMessage(
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700252 std::shared_ptr<IGnssNavigationMessageInterface>* iGnssNavigationMessage) {
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800253 ALOGD("getExtensionGnssNavigationMessage");
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700254
255 *iGnssNavigationMessage = SharedRefBase::make<GnssNavigationMessageInterface>();
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -0800256 return ScopedAStatus::ok();
Yu-Han Yang10cf7362021-10-03 22:32:04 -0700257}
258
Joe Huang202b02d2021-11-16 23:09:11 +0800259ndk::ScopedAStatus Gnss::getExtensionGnssDebug(std::shared_ptr<IGnssDebug>* iGnssDebug) {
260 ALOGD("Gnss::getExtensionGnssDebug");
261
262 *iGnssDebug = SharedRefBase::make<GnssDebug>();
263 return ndk::ScopedAStatus::ok();
264}
265
Edwin Tungd7a5de22021-12-08 13:27:51 +0800266ndk::ScopedAStatus Gnss::getExtensionGnssVisibilityControl(
267 std::shared_ptr<visibility_control::IGnssVisibilityControl>* iGnssVisibilityControl) {
268 ALOGD("Gnss::getExtensionGnssVisibilityControl");
269
270 *iGnssVisibilityControl = SharedRefBase::make<visibility_control::GnssVisibilityControl>();
271 return ndk::ScopedAStatus::ok();
272}
273
Yu-Han Yang274ea0a2020-09-09 17:25:02 -0700274} // namespace aidl::android::hardware::gnss