Files
android_device_xiaomi_sm845…/gps/android/aidl-impl/GnssMeasurementInterface.cpp
Vamana Murthi cd7a05c656 sm8450-common: gps: HAL: Location compilation bringup for wearables
Enable few more important compilation flags which will consider
warnings as errors. Most of these flags were configured to be
only warning for mobile SPs, but for wearable SPs some of them
are configured to be errors. So configure these as in common
GNSS flags so that same set of flags could be applied to mobile
SPs too.
Fix compilation errors which were showing up, when these flags
were enabled.

Change-Id: I62ef74419d4416252dfc8b25251ba3a51d522bfd
CRs-Fixed: 3292623
2024-03-19 23:22:37 +01:00

674 lines
27 KiB
C++

/*
* Copyright (c) 2021, The Linux Foundation. All rights reserved.
* Not a Contribution
*/
/*
* Copyright (C) 2020 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 "GnssMeasurementInterfaceAidl"
#include <log_util.h>
#include "GnssMeasurementInterface.h"
#include <android/binder_auto_utils.h>
#include <aidl/android/hardware/gnss/BnGnss.h>
#include <inttypes.h>
#include <loc_misc_utils.h>
using aidl::android::hardware::gnss::ElapsedRealtime;
using aidl::android::hardware::gnss::GnssClock;
using aidl::android::hardware::gnss::GnssData;
using aidl::android::hardware::gnss::GnssMeasurement;
using aidl::android::hardware::gnss::GnssSignalType;
using aidl::android::hardware::gnss::GnssConstellationType;
using aidl::android::hardware::gnss::GnssMultipathIndicator;
namespace android {
namespace hardware {
namespace gnss {
namespace aidl {
namespace implementation {
GnssMeasurementInterface::GnssMeasurementInterface() :
mDeathRecipient(AIBinder_DeathRecipient_new(GnssMeasurementInterface::gnssMeasurementDied)),
mTracking(false) {
}
::ndk::ScopedAStatus GnssMeasurementInterface::setCallback(
const std::shared_ptr<IGnssMeasurementCallback>& in_callback,
bool in_enableFullTracking, bool in_enableCorrVecOutputs) {
LOC_LOGd("setCallback: enableFullTracking: %d enableCorrVecOutputs: %d",
(int)in_enableFullTracking,
(int)in_enableCorrVecOutputs);
std::unique_lock<std::mutex> lock(mMutex);
if (nullptr == in_callback) {
LOC_LOGe("callback is nullptr");
return ndk::ScopedAStatus::fromExceptionCode(STATUS_INVALID_OPERATION);
}
AIBinder_linkToDeath(in_callback->asBinder().get(), mDeathRecipient, this);
mGnssMeasurementCbIface = in_callback;
lock.unlock();
startTracking(in_enableFullTracking ? GNSS_POWER_MODE_M1 : GNSS_POWER_MODE_M2);
return ndk::ScopedAStatus::ok();
}
::ndk::ScopedAStatus GnssMeasurementInterface::close() {
LOC_LOGd("()");
if (nullptr != mGnssMeasurementCbIface) {
AIBinder_unlinkToDeath(mGnssMeasurementCbIface->asBinder().get(), mDeathRecipient, this);
mGnssMeasurementCbIface = nullptr;
}
std::unique_lock<std::mutex> lock(mMutex);
mTracking = false;
lock.unlock();
locAPIStopTracking();
return ndk::ScopedAStatus::ok();
}
void GnssMeasurementInterface::onGnssMeasurementsCb(
GnssMeasurementsNotification gnssMeasurementsNotification) {
std::unique_lock<std::mutex> lock(mMutex);
LOC_LOGd("(count: %u active: %d)", gnssMeasurementsNotification.count, mTracking);
if (mTracking) {
auto gnssMeasurementCbIface = mGnssMeasurementCbIface;
if (gnssMeasurementCbIface != nullptr) {
GnssData gnssData = {};
convertGnssData(gnssMeasurementsNotification, gnssData);
printGnssData(gnssData);
lock.unlock();
gnssMeasurementCbIface->gnssMeasurementCb(gnssData);
}
}
}
void GnssMeasurementInterface::gnssMeasurementDied(void* cookie) {
LOC_LOGe("IGnssMeasurementCallback service died");
GnssMeasurementInterface* iface = static_cast<GnssMeasurementInterface*>(cookie);
//clean up, i.e. iface->close();
if (iface != nullptr) {
iface->close();
}
}
void GnssMeasurementInterface::startTracking(
GnssPowerMode powerMode, uint32_t timeBetweenMeasurement) {
LocationCallbacks locationCallbacks;
memset(&locationCallbacks, 0, sizeof(LocationCallbacks));
locationCallbacks.size = sizeof(LocationCallbacks);
locationCallbacks.trackingCb = nullptr;
locationCallbacks.batchingCb = nullptr;
locationCallbacks.geofenceBreachCb = nullptr;
locationCallbacks.geofenceStatusCb = nullptr;
locationCallbacks.gnssLocationInfoCb = nullptr;
locationCallbacks.gnssNiCb = nullptr;
locationCallbacks.gnssSvCb = nullptr;
locationCallbacks.gnssNmeaCb = nullptr;
locationCallbacks.gnssMeasurementsCb = nullptr;
if (nullptr != mGnssMeasurementCbIface) {
locationCallbacks.gnssMeasurementsCb =
[this](GnssMeasurementsNotification gnssMeasurementsNotification) {
onGnssMeasurementsCb(gnssMeasurementsNotification);
};
}
locAPISetCallbacks(locationCallbacks);
TrackingOptions options = {};
memset(&options, 0, sizeof(TrackingOptions));
options.size = sizeof(TrackingOptions);
options.minInterval = 1000;
options.mode = GNSS_SUPL_MODE_STANDALONE;
if (GNSS_POWER_MODE_INVALID != powerMode) {
options.powerMode = powerMode;
options.tbm = timeBetweenMeasurement;
}
std::unique_lock<std::mutex> lock(mMutex);
mTracking = true;
lock.unlock();
LOC_LOGd("start tracking session");
locAPIStartTracking(options);
}
void GnssMeasurementInterface::convertGnssData(GnssMeasurementsNotification& in, GnssData& out) {
out.measurements.resize(in.count);
for (size_t i = 0; i < in.count; i++) {
out.measurements[i].flags = 0;
convertGnssMeasurement(in.measurements[i], out.measurements[i]);
}
convertGnssClock(in.clock, out.clock);
convertElapsedRealtimeNanos(in, out.elapsedRealtime);
}
void GnssMeasurementInterface::convertGnssMeasurement(
GnssMeasurementsData& in, GnssMeasurement& out) {
// flags
convertGnssFlags(in, out);
// svid
convertGnssSvId(in, out.svid);
// signalType
convertGnssSignalType(in, out.signalType);
// timeOffsetNs
out.timeOffsetNs = in.timeOffsetNs;
// state
convertGnssState(in, out);
// receivedSvTimeInNs
out.receivedSvTimeInNs = in.receivedSvTimeNs;
// receivedSvTimeUncertaintyInNs
out.receivedSvTimeUncertaintyInNs = in.receivedSvTimeUncertaintyNs;
// antennaCN0DbHz
out.antennaCN0DbHz = in.carrierToNoiseDbHz;
// basebandCN0DbHz
out.basebandCN0DbHz = in.basebandCarrierToNoiseDbHz;
// pseudorangeRateMps
out.pseudorangeRateMps = in.pseudorangeRateMps;
// pseudorangeRateUncertaintyMps
out.pseudorangeRateUncertaintyMps = in.pseudorangeRateUncertaintyMps;
// accumulatedDeltaRangeState
convertGnssAccumulatedDeltaRangeState(in, out);
// accumulatedDeltaRangeM
out.accumulatedDeltaRangeM = in.adrMeters;
// accumulatedDeltaRangeUncertaintyM
out.accumulatedDeltaRangeUncertaintyM = in.adrUncertaintyMeters;
// carrierCycles
out.carrierCycles = in.carrierCycles;
// carrierPhase
out.carrierPhase = in.carrierPhase;
// carrierPhaseUncertainty
out.carrierPhaseUncertainty = in.carrierPhaseUncertainty;
// multipathIndicator
convertGnssMultipathIndicator(in, out);
// snrDb
out.snrDb = in.signalToNoiseRatioDb;
// agcLevelDb
out.agcLevelDb = in.agcLevelDb;
// fullInterSignalBiasNs
out.fullInterSignalBiasNs = in.fullInterSignalBiasNs;
// fullInterSignalBiasUncertaintyNs
out.fullInterSignalBiasUncertaintyNs = in.fullInterSignalBiasUncertaintyNs;
// satelliteInterSignalBiasNs
out.satelliteInterSignalBiasNs = in.satelliteInterSignalBiasNs;
// satelliteInterSignalBiasUncertaintyNs
out.satelliteInterSignalBiasUncertaintyNs = in.satelliteInterSignalBiasUncertaintyNs;
// satellitePvt
convertGnssSatellitePvt(in, out);
// correlationVectors
/* This is not supported, the corresponding flag is not set */
}
void GnssMeasurementInterface::convertGnssFlags(GnssMeasurementsData& in, GnssMeasurement& out) {
if (in.flags & GNSS_MEASUREMENTS_DATA_SIGNAL_TO_NOISE_RATIO_BIT)
out.flags |= out.HAS_SNR;
if (in.flags & GNSS_MEASUREMENTS_DATA_CARRIER_FREQUENCY_BIT)
out.flags |= out.HAS_CARRIER_FREQUENCY;
if (in.flags & GNSS_MEASUREMENTS_DATA_CARRIER_CYCLES_BIT)
out.flags |= out.HAS_CARRIER_CYCLES;
if (in.flags & GNSS_MEASUREMENTS_DATA_CARRIER_PHASE_BIT)
out.flags |= out.HAS_CARRIER_PHASE;
if (in.flags & GNSS_MEASUREMENTS_DATA_CARRIER_PHASE_UNCERTAINTY_BIT)
out.flags |= out.HAS_CARRIER_PHASE_UNCERTAINTY;
if (in.flags & GNSS_MEASUREMENTS_DATA_AUTOMATIC_GAIN_CONTROL_BIT)
out.flags |= out.HAS_AUTOMATIC_GAIN_CONTROL;
if (in.flags & GNSS_MEASUREMENTS_DATA_FULL_ISB_BIT)
out.flags |= out.HAS_FULL_ISB;
if (in.flags & GNSS_MEASUREMENTS_DATA_FULL_ISB_UNCERTAINTY_BIT)
out.flags |= out.HAS_FULL_ISB_UNCERTAINTY;
if (in.flags & GNSS_MEASUREMENTS_DATA_SATELLITE_ISB_BIT)
out.flags |= out.HAS_SATELLITE_ISB;
if (in.flags & GNSS_MEASUREMENTS_DATA_SATELLITE_ISB_UNCERTAINTY_BIT)
out.flags |= out.HAS_SATELLITE_ISB_UNCERTAINTY;
if (in.flags & GNSS_MEASUREMENTS_DATA_SATELLITE_PVT_BIT)
out.flags |= out.HAS_SATELLITE_PVT;
if (in.flags & GNSS_MEASUREMENTS_DATA_CORRELATION_VECTOR_BIT)
out.flags |= out.HAS_CORRELATION_VECTOR;
}
void GnssMeasurementInterface::convertGnssSvId(GnssMeasurementsData& in, int& out) {
switch (in.svType) {
case GNSS_SV_TYPE_GPS:
out = in.svId;
break;
case GNSS_SV_TYPE_SBAS:
out = in.svId;
break;
case GNSS_SV_TYPE_GLONASS:
if (in.svId != 255) { // OSN is known
out = in.svId - GLO_SV_PRN_MIN + 1;
} else { // OSN is not known, report FCN
out = in.gloFrequency + 92;
}
break;
case GNSS_SV_TYPE_QZSS:
out = in.svId;
break;
case GNSS_SV_TYPE_BEIDOU:
out = in.svId - BDS_SV_PRN_MIN + 1;
break;
case GNSS_SV_TYPE_GALILEO:
out = in.svId - GAL_SV_PRN_MIN + 1;
break;
case GNSS_SV_TYPE_NAVIC:
out = in.svId - NAVIC_SV_PRN_MIN + 1;
break;
default:
out = in.svId;
break;
}
}
void GnssMeasurementInterface::convertGnssSignalType(
GnssMeasurementsData& in, GnssSignalType& out) {
convertGnssConstellationType(in.svType, out.constellation);
out.carrierFrequencyHz = in.carrierFrequencyHz;
convertGnssMeasurementsCodeType(in.codeType, in.otherCodeTypeName, out);
}
void GnssMeasurementInterface::convertGnssConstellationType(
GnssSvType& in, GnssConstellationType& out) {
switch (in) {
case GNSS_SV_TYPE_GPS:
out = GnssConstellationType::GPS;
break;
case GNSS_SV_TYPE_SBAS:
out = GnssConstellationType::SBAS;
break;
case GNSS_SV_TYPE_GLONASS:
out = GnssConstellationType::GLONASS;
break;
case GNSS_SV_TYPE_QZSS:
out = GnssConstellationType::QZSS;
break;
case GNSS_SV_TYPE_BEIDOU:
out = GnssConstellationType::BEIDOU;
break;
case GNSS_SV_TYPE_GALILEO:
out = GnssConstellationType::GALILEO;
break;
case GNSS_SV_TYPE_NAVIC:
out = GnssConstellationType::IRNSS;
break;
case GNSS_SV_TYPE_UNKNOWN:
default:
out = GnssConstellationType::UNKNOWN;
break;
}
}
void GnssMeasurementInterface::convertGnssMeasurementsCodeType(
GnssMeasurementsCodeType& inCodeType,
char* inOtherCodeTypeName, GnssSignalType& out) {
switch (inCodeType) {
case GNSS_MEASUREMENTS_CODE_TYPE_A:
out.codeType = out.CODE_TYPE_A;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_B:
out.codeType = out.CODE_TYPE_B;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_C:
out.codeType = out.CODE_TYPE_C;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_I:
out.codeType = out.CODE_TYPE_I;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_L:
out.codeType = out.CODE_TYPE_L;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_M:
out.codeType = out.CODE_TYPE_M;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_N:
out.codeType = out.CODE_TYPE_N;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_P:
out.codeType = out.CODE_TYPE_P;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_Q:
out.codeType = out.CODE_TYPE_Q;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_S:
out.codeType = out.CODE_TYPE_S;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_W:
out.codeType = out.CODE_TYPE_W;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_X:
out.codeType = out.CODE_TYPE_X;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_Y:
out.codeType = out.CODE_TYPE_Y;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_Z:
out.codeType = out.CODE_TYPE_Z;
break;
case GNSS_MEASUREMENTS_CODE_TYPE_OTHER:
default:
out.codeType = inOtherCodeTypeName;
break;
}
}
void GnssMeasurementInterface::convertGnssState(GnssMeasurementsData& in, GnssMeasurement& out) {
if (in.stateMask & GNSS_MEASUREMENTS_STATE_CODE_LOCK_BIT)
out.state |= out.STATE_CODE_LOCK;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_BIT_SYNC_BIT)
out.state |= out.STATE_BIT_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_SUBFRAME_SYNC_BIT)
out.state |= out.STATE_SUBFRAME_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_TOW_DECODED_BIT)
out.state |= out.STATE_TOW_DECODED;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_MSEC_AMBIGUOUS_BIT)
out.state |= out.STATE_MSEC_AMBIGUOUS;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_SYMBOL_SYNC_BIT)
out.state |= out.STATE_SYMBOL_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_GLO_STRING_SYNC_BIT)
out.state |= out.STATE_GLO_STRING_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_GLO_TOD_DECODED_BIT)
out.state |= out.STATE_GLO_TOD_DECODED;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_BDS_D2_BIT_SYNC_BIT)
out.state |= out.STATE_BDS_D2_BIT_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_BDS_D2_SUBFRAME_SYNC_BIT)
out.state |= out.STATE_BDS_D2_SUBFRAME_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_GAL_E1BC_CODE_LOCK_BIT)
out.state |= out.STATE_GAL_E1BC_CODE_LOCK;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_GAL_E1C_2ND_CODE_LOCK_BIT)
out.state |= out.STATE_GAL_E1C_2ND_CODE_LOCK;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_GAL_E1B_PAGE_SYNC_BIT)
out.state |= out.STATE_GAL_E1B_PAGE_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_SBAS_SYNC_BIT)
out.state |= out.STATE_SBAS_SYNC;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_TOW_KNOWN_BIT)
out.state |= out.STATE_TOW_KNOWN;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_GLO_TOD_KNOWN_BIT)
out.state |= out.STATE_GLO_TOD_KNOWN;
if (in.stateMask & GNSS_MEASUREMENTS_STATE_2ND_CODE_LOCK_BIT)
out.state |= out.STATE_2ND_CODE_LOCK;
}
void GnssMeasurementInterface::convertGnssAccumulatedDeltaRangeState(
GnssMeasurementsData& in, GnssMeasurement& out) {
if (in.adrStateMask & GNSS_MEASUREMENTS_ACCUMULATED_DELTA_RANGE_STATE_VALID_BIT)
out.accumulatedDeltaRangeState |= out.ADR_STATE_VALID;
if (in.adrStateMask & GNSS_MEASUREMENTS_ACCUMULATED_DELTA_RANGE_STATE_RESET_BIT)
out.accumulatedDeltaRangeState |= out.ADR_STATE_RESET;
if (in.adrStateMask & GNSS_MEASUREMENTS_ACCUMULATED_DELTA_RANGE_STATE_CYCLE_SLIP_BIT)
out.accumulatedDeltaRangeState |= out.ADR_STATE_CYCLE_SLIP;
if (in.adrStateMask & GNSS_MEASUREMENTS_ACCUMULATED_DELTA_RANGE_STATE_HALF_CYCLE_RESOLVED_BIT)
out.accumulatedDeltaRangeState |= out.ADR_STATE_HALF_CYCLE_RESOLVED;
}
void GnssMeasurementInterface::convertGnssMultipathIndicator(
GnssMeasurementsData& in, GnssMeasurement& out) {
switch (in.multipathIndicator) {
case GNSS_MEASUREMENTS_MULTIPATH_INDICATOR_PRESENT:
out.multipathIndicator = GnssMultipathIndicator::PRESENT;
break;
case GNSS_MEASUREMENTS_MULTIPATH_INDICATOR_NOT_PRESENT:
out.multipathIndicator = GnssMultipathIndicator::NOT_PRESENT;
break;
case GNSS_MEASUREMENTS_MULTIPATH_INDICATOR_UNKNOWN:
default:
out.multipathIndicator = GnssMultipathIndicator::UNKNOWN;
break;
}
}
void GnssMeasurementInterface::convertGnssSatellitePvtFlags(GnssMeasurementsData& in,
GnssMeasurement& out) {
if (in.satellitePvt.flags & GNSS_SATELLITE_PVT_POSITION_VELOCITY_CLOCK_INFO_BIT)
out.satellitePvt.flags |= out.satellitePvt.HAS_POSITION_VELOCITY_CLOCK_INFO;
if (in.satellitePvt.flags & GNSS_SATELLITE_PVT_IONO_BIT)
out.satellitePvt.flags |= out.satellitePvt.HAS_IONO;
if (in.satellitePvt.flags & GNSS_SATELLITE_PVT_TROPO_BIT)
out.satellitePvt.flags |= out.satellitePvt.HAS_TROPO;
}
void GnssMeasurementInterface::convertGnssSatellitePvt(
GnssMeasurementsData& in, GnssMeasurement& out) {
// flags
convertGnssSatellitePvtFlags(in, out);
// satPosEcef
out.satellitePvt.satPosEcef.posXMeters = in.satellitePvt.satPosEcef.posXMeters;
out.satellitePvt.satPosEcef.posYMeters = in.satellitePvt.satPosEcef.posYMeters;
out.satellitePvt.satPosEcef.posZMeters = in.satellitePvt.satPosEcef.posZMeters;
out.satellitePvt.satPosEcef.ureMeters = in.satellitePvt.satPosEcef.ureMeters;
// satVelEcef
out.satellitePvt.satVelEcef.velXMps = in.satellitePvt.satVelEcef.velXMps;
out.satellitePvt.satVelEcef.velYMps = in.satellitePvt.satVelEcef.velYMps;
out.satellitePvt.satVelEcef.velZMps = in.satellitePvt.satVelEcef.velZMps;
out.satellitePvt.satVelEcef.ureRateMps = in.satellitePvt.satVelEcef.ureRateMps;
// satClockInfo
out.satellitePvt.satClockInfo.satHardwareCodeBiasMeters =
in.satellitePvt.satClockInfo.satHardwareCodeBiasMeters;
out.satellitePvt.satClockInfo.satTimeCorrectionMeters =
in.satellitePvt.satClockInfo.satTimeCorrectionMeters;
out.satellitePvt.satClockInfo.satClkDriftMps = in.satellitePvt.satClockInfo.satClkDriftMps;
// ionoDelayMeters
out.satellitePvt.ionoDelayMeters = in.satellitePvt.ionoDelayMeters;
// tropoDelayMeters
out.satellitePvt.tropoDelayMeters = in.satellitePvt.tropoDelayMeters;
}
void GnssMeasurementInterface::convertGnssClock(
GnssMeasurementsClock& in, GnssClock& out) {
// gnssClockFlags
if (in.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_LEAP_SECOND_BIT)
out.gnssClockFlags |= out.HAS_LEAP_SECOND;
if (in.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_TIME_UNCERTAINTY_BIT)
out.gnssClockFlags |= out.HAS_TIME_UNCERTAINTY;
if (in.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_FULL_BIAS_BIT)
out.gnssClockFlags |= out.HAS_FULL_BIAS;
if (in.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_BIAS_BIT)
out.gnssClockFlags |= out.HAS_BIAS;
if (in.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_BIAS_UNCERTAINTY_BIT)
out.gnssClockFlags |= out.HAS_BIAS_UNCERTAINTY;
if (in.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_DRIFT_BIT)
out.gnssClockFlags |= out.HAS_DRIFT;
if (in.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_DRIFT_UNCERTAINTY_BIT)
out.gnssClockFlags |= out.HAS_DRIFT_UNCERTAINTY;
// leapSecond
out.leapSecond = in.leapSecond;
// timeNs
out.timeNs = in.timeNs;
// timeUncertaintyNs
out.timeUncertaintyNs = in.timeUncertaintyNs;
// fullBiasNs
out.fullBiasNs = in.fullBiasNs;
// biasNs
out.biasNs = in.biasNs;
// biasUncertaintyNs
out.biasUncertaintyNs = in.biasUncertaintyNs;
// driftNsps
out.driftNsps = in.driftNsps;
// driftUncertaintyNsps
out.driftUncertaintyNsps = in.driftUncertaintyNsps;
// hwClockDiscontinuityCount
out.hwClockDiscontinuityCount = in.hwClockDiscontinuityCount;
// referenceSignalTypeForIsb
convertGnssConstellationType(in.referenceSignalTypeForIsb.svType,
out.referenceSignalTypeForIsb.constellation);
out.referenceSignalTypeForIsb.carrierFrequencyHz =
in.referenceSignalTypeForIsb.carrierFrequencyHz;
convertGnssMeasurementsCodeType(in.referenceSignalTypeForIsb.codeType,
in.referenceSignalTypeForIsb.otherCodeTypeName,
out.referenceSignalTypeForIsb);
}
void GnssMeasurementInterface::convertElapsedRealtimeNanos(
GnssMeasurementsNotification& in, ElapsedRealtime& elapsedRealtime) {
if (in.clock.flags & GNSS_MEASUREMENTS_CLOCK_FLAGS_ELAPSED_REAL_TIME_BIT) {
elapsedRealtime.flags |= elapsedRealtime.HAS_TIMESTAMP_NS;
elapsedRealtime.timestampNs = in.clock.elapsedRealTime;
elapsedRealtime.flags |= elapsedRealtime.HAS_TIME_UNCERTAINTY_NS;
elapsedRealtime.timeUncertaintyNs = in.clock.elapsedRealTimeUnc;
LOC_LOGd("elapsedRealtime.timestampNs=%" PRIi64 ""
" elapsedRealtime.timeUncertaintyNs=%lf elapsedRealtime.flags=0x%X",
elapsedRealtime.timestampNs,
elapsedRealtime.timeUncertaintyNs, elapsedRealtime.flags);
}
}
void GnssMeasurementInterface::printGnssData(GnssData& data) {
LOC_LOGd(" Measurements Info for %d satellites", data.measurements.size());
for (size_t i = 0; i < data.measurements.size(); i++) {
LOC_LOGd("%02d : flags: 0x%08x,"
" svid: %d,"
" signalType.constellation: %u,"
" signalType.carrierFrequencyHz: %.2f,"
" signalType.codeType: %s,"
" timeOffsetNs: %.2f,"
" state: 0x%08x,"
" receivedSvTimeInNs: %" PRIu64
" receivedSvTimeUncertaintyInNs: %" PRIu64
" antennaCN0DbHz: %.2f,"
" basebandCN0DbHz: %.2f,"
" pseudorangeRateMps : %.2f,"
" pseudorangeRateUncertaintyMps : %.2f,\n"
" accumulatedDeltaRangeState: 0x%08x,"
" accumulatedDeltaRangeM: %.2f, "
" accumulatedDeltaRangeUncertaintyM : %.2f, "
" carrierCycles: %" PRIu64
" carrierPhase: %.2f,"
" carrierPhaseUncertainty: %.2f,"
" multipathIndicator: %u,"
" snrDb: %.2f,"
" agcLevelDb: %.2f,"
" fullInterSignalBiasNs: %.2f,"
" fullInterSignalBiasUncertaintyNs: %.2f,"
" satelliteInterSignalBiasNs: %.2f,"
" satelliteInterSignalBiasUncertaintyNs: %.2f",
i + 1,
data.measurements[i].flags,
data.measurements[i].svid,
data.measurements[i].signalType.constellation,
data.measurements[i].signalType.carrierFrequencyHz,
data.measurements[i].signalType.codeType.c_str(),
data.measurements[i].timeOffsetNs,
data.measurements[i].state,
data.measurements[i].receivedSvTimeInNs,
data.measurements[i].receivedSvTimeUncertaintyInNs,
data.measurements[i].antennaCN0DbHz,
data.measurements[i].basebandCN0DbHz,
data.measurements[i].pseudorangeRateMps,
data.measurements[i].pseudorangeRateUncertaintyMps,
data.measurements[i].accumulatedDeltaRangeState,
data.measurements[i].accumulatedDeltaRangeM,
data.measurements[i].accumulatedDeltaRangeUncertaintyM,
data.measurements[i].carrierCycles,
data.measurements[i].carrierPhase,
data.measurements[i].carrierPhaseUncertainty,
data.measurements[i].multipathIndicator,
data.measurements[i].snrDb,
data.measurements[i].agcLevelDb,
data.measurements[i].fullInterSignalBiasNs,
data.measurements[i].fullInterSignalBiasUncertaintyNs,
data.measurements[i].satelliteInterSignalBiasNs,
data.measurements[i].satelliteInterSignalBiasUncertaintyNs
);
LOC_LOGd(" satellitePvt.flags: 0x%04x,"
" satellitePvt.satPosEcef.posXMeters: %.2f,"
" satellitePvt.satPosEcef.posYMeters: %.2f,"
" satellitePvt.satPosEcef.posZMeters: %.2f,"
" satellitePvt.satPosEcef.ureMeters: %.2f,"
" satellitePvt.satVelEcef.velXMps: %.2f,"
" satellitePvt.satVelEcef.velYMps: %.2f,"
" satellitePvt.satVelEcef.velZMps: %.2f,"
" satellitePvt.satVelEcef.ureRateMps: %.2f,"
" satellitePvt.satClockInfo.satHardwareCodeBiasMeters: %.2f,"
" satellitePvt.satClockInfo.satTimeCorrectionMeters: %.2f,"
" satellitePvt.satClockInfo.satClkDriftMps: %.2f,"
" satellitePvt.ionoDelayMeters: %.2f,"
" satellitePvt.tropoDelayMeters: %.2f",
data.measurements[i].satellitePvt.flags,
data.measurements[i].satellitePvt.satPosEcef.posXMeters,
data.measurements[i].satellitePvt.satPosEcef.posYMeters,
data.measurements[i].satellitePvt.satPosEcef.posZMeters,
data.measurements[i].satellitePvt.satPosEcef.ureMeters,
data.measurements[i].satellitePvt.satVelEcef.velXMps,
data.measurements[i].satellitePvt.satVelEcef.velYMps,
data.measurements[i].satellitePvt.satVelEcef.velZMps,
data.measurements[i].satellitePvt.satVelEcef.ureRateMps,
data.measurements[i].satellitePvt.satClockInfo.satHardwareCodeBiasMeters,
data.measurements[i].satellitePvt.satClockInfo.satTimeCorrectionMeters,
data.measurements[i].satellitePvt.satClockInfo.satClkDriftMps,
data.measurements[i].satellitePvt.ionoDelayMeters,
data.measurements[i].satellitePvt.tropoDelayMeters
);
}
LOC_LOGd(" Clocks Info "
" gnssClockFlags: 0x%04x,"
" leapSecond: %d,"
" timeNs: %" PRId64
" timeUncertaintyNs: %.2f,"
" fullBiasNs: %" PRId64
" biasNs: %.2f,"
" biasUncertaintyNs: %.2f,"
" driftNsps: %.2f,"
" driftUncertaintyNsps: %.2f,"
" hwClockDiscontinuityCount: %u,"
" referenceSignalTypeForIsb.constellation: %u,"
" referenceSignalTypeForIsb.carrierFrequencyHz: %.2f,"
" referenceSignalTypeForIsb.codeType: %s",
data.clock.gnssClockFlags,
data.clock.leapSecond,
data.clock.timeNs,
data.clock.timeUncertaintyNs,
data.clock.fullBiasNs,
data.clock.biasNs,
data.clock.biasUncertaintyNs,
data.clock.driftNsps,
data.clock.driftUncertaintyNsps,
data.clock.hwClockDiscontinuityCount,
data.clock.referenceSignalTypeForIsb.constellation,
data.clock.referenceSignalTypeForIsb.carrierFrequencyHz,
data.clock.referenceSignalTypeForIsb.codeType.c_str());
LOC_LOGd(" ElapsedRealtime "
" flags: 0x%08x,"
" timestampNs: %" PRId64", "
" timeUncertaintyNs: %.2f",
data.elapsedRealtime.flags,
data.elapsedRealtime.timestampNs,
data.elapsedRealtime.timeUncertaintyNs);
}
} // namespace implementation
} // namespace aidl
} // namespace gnss
} // namespace hardware
} // namespace android