summaryrefslogtreecommitdiffstats
path: root/gnss/1.0/GnssDebug.cpp
diff options
context:
space:
mode:
authorArne Coucheron <arco68@gmail.com>2020-05-18 06:18:45 +0200
committerArne Coucheron <arco68@gmail.com>2020-05-26 00:16:37 +0200
commit08f0000e15a28f1622e4ef0c6d17595714c1be58 (patch)
treef0f07ea59f51b486e74658d30dbe3b4091dcc61a /gnss/1.0/GnssDebug.cpp
parent21e6c8c09692bb9ae21fdc6e4bc1442f6c4cd5d0 (diff)
downloadhardware_lineage_interfaces-08f0000e15a28f1622e4ef0c6d17595714c1be58.tar.gz
hardware_lineage_interfaces-08f0000e15a28f1622e4ef0c6d17595714c1be58.tar.bz2
hardware_lineage_interfaces-08f0000e15a28f1622e4ef0c6d17595714c1be58.zip
interfaces: Import GNSS 1.0 HAL from hardware/interfaces
Change-Id: I63b0a4f66276cd078b49b7c1cfdc1d44874354ca
Diffstat (limited to 'gnss/1.0/GnssDebug.cpp')
-rw-r--r--gnss/1.0/GnssDebug.cpp59
1 files changed, 59 insertions, 0 deletions
diff --git a/gnss/1.0/GnssDebug.cpp b/gnss/1.0/GnssDebug.cpp
new file mode 100644
index 0000000..cfc38ca
--- /dev/null
+++ b/gnss/1.0/GnssDebug.cpp
@@ -0,0 +1,59 @@
+/*
+ * Copyright (C) 2016 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#define LOG_TAG "GnssHAL_GnssDebugInterface"
+
+#include <log/log.h>
+
+#include "GnssDebug.h"
+
+namespace android {
+namespace hardware {
+namespace gnss {
+namespace V1_0 {
+namespace implementation {
+
+GnssDebug::GnssDebug(const GpsDebugInterface* gpsDebugIface) : mGnssDebugIface(gpsDebugIface) {}
+
+// Methods from ::android::hardware::gnss::V1_0::IGnssDebug follow.
+Return<void> GnssDebug::getDebugData(getDebugData_cb _hidl_cb) {
+ /*
+ * This is a new interface and hence there is no way to retrieve the
+ * debug data from the HAL.
+ */
+ DebugData data = {};
+
+ _hidl_cb(data);
+
+ /*
+ * Log the debug data sent from the conventional Gnss HAL. This code is
+ * moved here from GnssLocationProvider.
+ */
+ if (mGnssDebugIface) {
+ char buffer[kMaxDebugStrLen + 1];
+ size_t length = mGnssDebugIface->get_internal_state(buffer, kMaxDebugStrLen);
+ length = std::max(length, kMaxDebugStrLen);
+ buffer[length] = '\0';
+ ALOGD("Gnss Debug Data: %s", buffer);
+ }
+ return Void();
+}
+
+} // namespace implementation
+} // namespace V1_0
+} // namespace gnss
+} // namespace hardware
+} // namespace android