diff options
author | Arne Coucheron <arco68@gmail.com> | 2020-05-18 06:18:45 +0200 |
---|---|---|
committer | Arne Coucheron <arco68@gmail.com> | 2020-05-26 00:16:37 +0200 |
commit | 08f0000e15a28f1622e4ef0c6d17595714c1be58 (patch) | |
tree | f0f07ea59f51b486e74658d30dbe3b4091dcc61a /gnss/1.0/GnssDebug.cpp | |
parent | 21e6c8c09692bb9ae21fdc6e4bc1442f6c4cd5d0 (diff) | |
download | hardware_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.cpp | 59 |
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 |