| /* Copyright (c) 2017-2021, The Linux Foundation. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are |
| * met: |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above |
| * copyright notice, this list of conditions and the following |
| * disclaimer in the documentation and/or other materials provided |
| * with the distribution. |
| * * Neither the name of The Linux Foundation, nor the names of its |
| * contributors may be used to endorse or promote products derived |
| * from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED |
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
| * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT |
| * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS |
| * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR |
| * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |
| * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE |
| * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN |
| * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| * |
| */ |
| #define LOG_TAG "LocSvc_SystemStatus" |
| |
| #include <inttypes.h> |
| #include <string> |
| #include <stdlib.h> |
| #include <string.h> |
| #include <sys/time.h> |
| #include <pthread.h> |
| #include <loc_pla.h> |
| #include <log_util.h> |
| #include <loc_nmea.h> |
| #include <DataItemsFactoryProxy.h> |
| #include <SystemStatus.h> |
| #include <SystemStatusOsObserver.h> |
| #include <DataItemConcreteTypesBase.h> |
| |
| namespace loc_core |
| { |
| |
| /****************************************************************************** |
| SystemStatusNmeaBase - base class for all NMEA parsers |
| ******************************************************************************/ |
| class SystemStatusNmeaBase |
| { |
| protected: |
| std::vector<std::string> mField; |
| |
| SystemStatusNmeaBase(const char *str_in, uint32_t len_in) |
| { |
| // check size and talker |
| if (!loc_nmea_is_debug(str_in, len_in)) { |
| return; |
| } |
| |
| std::string parser(str_in); |
| std::string::size_type index = 0; |
| |
| // verify checksum field |
| index = parser.find("*"); |
| if (index == std::string::npos) { |
| return; |
| } |
| parser[index] = ','; |
| |
| // tokenize parser |
| while (1) { |
| std::string str; |
| index = parser.find(","); |
| if (index == std::string::npos) { |
| break; |
| } |
| str = parser.substr(0, index); |
| parser = parser.substr(index + 1); |
| mField.push_back(str); |
| } |
| } |
| |
| virtual ~SystemStatusNmeaBase() { } |
| |
| public: |
| static const uint32_t NMEA_MINSIZE = DEBUG_NMEA_MINSIZE; |
| static const uint32_t NMEA_MAXSIZE = DEBUG_NMEA_MAXSIZE; |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWM1 |
| ******************************************************************************/ |
| class SystemStatusPQWM1 |
| { |
| public: |
| uint16_t mGpsWeek; // x1 |
| uint32_t mGpsTowMs; // x2 |
| uint8_t mTimeValid; // x3 |
| uint8_t mTimeSource; // x4 |
| int32_t mTimeUnc; // x5 |
| int32_t mClockFreqBias; // x6 |
| int32_t mClockFreqBiasUnc; // x7 |
| uint8_t mXoState; // x8 |
| int32_t mPgaGain; // x9 |
| uint32_t mGpsBpAmpI; // xA |
| uint32_t mGpsBpAmpQ; // xB |
| uint32_t mAdcI; // xC |
| uint32_t mAdcQ; // xD |
| uint32_t mJammerGps; // xE |
| uint32_t mJammerGlo; // xF |
| uint32_t mJammerBds; // x10 |
| uint32_t mJammerGal; // x11 |
| uint32_t mRecErrorRecovery; // x12 |
| double mAgcGps; // x13 |
| double mAgcGlo; // x14 |
| double mAgcBds; // x15 |
| double mAgcGal; // x16 |
| int32_t mLeapSeconds;// x17 |
| int32_t mLeapSecUnc; // x18 |
| uint32_t mGloBpAmpI; // x19 |
| uint32_t mGloBpAmpQ; // x1A |
| uint32_t mBdsBpAmpI; // x1B |
| uint32_t mBdsBpAmpQ; // x1C |
| uint32_t mGalBpAmpI; // x1D |
| uint32_t mGalBpAmpQ; // x1E |
| uint64_t mTimeUncNs; // x1F |
| }; |
| |
| // parser |
| class SystemStatusPQWM1parser : public SystemStatusNmeaBase |
| { |
| private: |
| enum |
| { |
| eTalker = 0, |
| eGpsWeek = 1, |
| eGpsTowMs = 2, |
| eTimeValid = 3, |
| eTimeSource = 4, |
| eTimeUnc = 5, |
| eClockFreqBias = 6, |
| eClockFreqBiasUnc = 7, |
| eXoState = 8, |
| ePgaGain = 9, |
| eGpsBpAmpI = 10, |
| eGpsBpAmpQ = 11, |
| eAdcI = 12, |
| eAdcQ = 13, |
| eJammerGps = 14, |
| eJammerGlo = 15, |
| eJammerBds = 16, |
| eJammerGal = 17, |
| eRecErrorRecovery = 18, |
| eAgcGps = 19, |
| eAgcGlo = 20, |
| eAgcBds = 21, |
| eAgcGal = 22, |
| eMax0 = eAgcGal, |
| eLeapSeconds = 23, |
| eLeapSecUnc = 24, |
| eGloBpAmpI = 25, |
| eGloBpAmpQ = 26, |
| eBdsBpAmpI = 27, |
| eBdsBpAmpQ = 28, |
| eGalBpAmpI = 29, |
| eGalBpAmpQ = 30, |
| eTimeUncNs = 31, |
| eMax |
| }; |
| SystemStatusPQWM1 mM1; |
| |
| public: |
| inline uint16_t getGpsWeek() { return mM1.mGpsWeek; } |
| inline uint32_t getGpsTowMs() { return mM1.mGpsTowMs; } |
| inline uint8_t getTimeValid() { return mM1.mTimeValid; } |
| inline uint8_t getTimeSource() { return mM1.mTimeSource; } |
| inline int32_t getTimeUnc() { return mM1.mTimeUnc; } |
| inline int32_t getClockFreqBias() { return mM1.mClockFreqBias; } |
| inline int32_t getClockFreqBiasUnc() { return mM1.mClockFreqBiasUnc; } |
| inline uint8_t getXoState() { return mM1.mXoState;} |
| inline int32_t getPgaGain() { return mM1.mPgaGain; } |
| inline uint32_t getGpsBpAmpI() { return mM1.mGpsBpAmpI; } |
| inline uint32_t getGpsBpAmpQ() { return mM1.mGpsBpAmpQ; } |
| inline uint32_t getAdcI() { return mM1.mAdcI; } |
| inline uint32_t getAdcQ() { return mM1.mAdcQ; } |
| inline uint32_t getJammerGps() { return mM1.mJammerGps; } |
| inline uint32_t getJammerGlo() { return mM1.mJammerGlo; } |
| inline uint32_t getJammerBds() { return mM1.mJammerBds; } |
| inline uint32_t getJammerGal() { return mM1.mJammerGal; } |
| inline uint32_t getAgcGps() { return mM1.mAgcGps; } |
| inline uint32_t getAgcGlo() { return mM1.mAgcGlo; } |
| inline uint32_t getAgcBds() { return mM1.mAgcBds; } |
| inline uint32_t getAgcGal() { return mM1.mAgcGal; } |
| inline uint32_t getRecErrorRecovery() { return mM1.mRecErrorRecovery; } |
| inline int32_t getLeapSeconds(){ return mM1.mLeapSeconds; } |
| inline int32_t getLeapSecUnc() { return mM1.mLeapSecUnc; } |
| inline uint32_t getGloBpAmpI() { return mM1.mGloBpAmpI; } |
| inline uint32_t getGloBpAmpQ() { return mM1.mGloBpAmpQ; } |
| inline uint32_t getBdsBpAmpI() { return mM1.mBdsBpAmpI; } |
| inline uint32_t getBdsBpAmpQ() { return mM1.mBdsBpAmpQ; } |
| inline uint32_t getGalBpAmpI() { return mM1.mGalBpAmpI; } |
| inline uint32_t getGalBpAmpQ() { return mM1.mGalBpAmpQ; } |
| inline uint64_t getTimeUncNs() { return mM1.mTimeUncNs; } |
| |
| SystemStatusPQWM1parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| memset(&mM1, 0, sizeof(mM1)); |
| if (mField.size() <= eMax0) { |
| LOC_LOGE("PQWM1parser - invalid size=%zu", mField.size()); |
| mM1.mTimeValid = 0; |
| return; |
| } |
| mM1.mGpsWeek = atoi(mField[eGpsWeek].c_str()); |
| mM1.mGpsTowMs = atoi(mField[eGpsTowMs].c_str()); |
| mM1.mTimeValid = atoi(mField[eTimeValid].c_str()); |
| mM1.mTimeSource = atoi(mField[eTimeSource].c_str()); |
| mM1.mTimeUnc = atoi(mField[eTimeUnc].c_str()); |
| mM1.mClockFreqBias = atoi(mField[eClockFreqBias].c_str()); |
| mM1.mClockFreqBiasUnc = atoi(mField[eClockFreqBiasUnc].c_str()); |
| mM1.mXoState = atoi(mField[eXoState].c_str()); |
| mM1.mPgaGain = atoi(mField[ePgaGain].c_str()); |
| mM1.mGpsBpAmpI = atoi(mField[eGpsBpAmpI].c_str()); |
| mM1.mGpsBpAmpQ = atoi(mField[eGpsBpAmpQ].c_str()); |
| mM1.mAdcI = atoi(mField[eAdcI].c_str()); |
| mM1.mAdcQ = atoi(mField[eAdcQ].c_str()); |
| mM1.mJammerGps = atoi(mField[eJammerGps].c_str()); |
| mM1.mJammerGlo = atoi(mField[eJammerGlo].c_str()); |
| mM1.mJammerBds = atoi(mField[eJammerBds].c_str()); |
| mM1.mJammerGal = atoi(mField[eJammerGal].c_str()); |
| mM1.mRecErrorRecovery = atoi(mField[eRecErrorRecovery].c_str()); |
| mM1.mAgcGps = atof(mField[eAgcGps].c_str()); |
| mM1.mAgcGlo = atof(mField[eAgcGlo].c_str()); |
| mM1.mAgcBds = atof(mField[eAgcBds].c_str()); |
| mM1.mAgcGal = atof(mField[eAgcGal].c_str()); |
| if (mField.size() > eLeapSecUnc) { |
| mM1.mLeapSeconds = atoi(mField[eLeapSeconds].c_str()); |
| mM1.mLeapSecUnc = atoi(mField[eLeapSecUnc].c_str()); |
| } |
| if (mField.size() > eGalBpAmpQ) { |
| mM1.mGloBpAmpI = atoi(mField[eGloBpAmpI].c_str()); |
| mM1.mGloBpAmpQ = atoi(mField[eGloBpAmpQ].c_str()); |
| mM1.mBdsBpAmpI = atoi(mField[eBdsBpAmpI].c_str()); |
| mM1.mBdsBpAmpQ = atoi(mField[eBdsBpAmpQ].c_str()); |
| mM1.mGalBpAmpI = atoi(mField[eGalBpAmpI].c_str()); |
| mM1.mGalBpAmpQ = atoi(mField[eGalBpAmpQ].c_str()); |
| } |
| if (mField.size() > eTimeUncNs) { |
| mM1.mTimeUncNs = strtoull(mField[eTimeUncNs].c_str(), nullptr, 10); |
| } |
| } |
| |
| inline SystemStatusPQWM1& get() { return mM1;} //getparser |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWP1 |
| ******************************************************************************/ |
| class SystemStatusPQWP1 |
| { |
| public: |
| uint8_t mEpiValidity; // x4 |
| float mEpiLat; // x5 |
| float mEpiLon; // x6 |
| float mEpiAlt; // x7 |
| float mEpiHepe; // x8 |
| float mEpiAltUnc; // x9 |
| uint8_t mEpiSrc; // x10 |
| }; |
| |
| class SystemStatusPQWP1parser : public SystemStatusNmeaBase |
| { |
| private: |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eEpiValidity = 2, |
| eEpiLat = 3, |
| eEpiLon = 4, |
| eEpiAlt = 5, |
| eEpiHepe = 6, |
| eEpiAltUnc = 7, |
| eEpiSrc = 8, |
| eMax |
| }; |
| SystemStatusPQWP1 mP1; |
| |
| public: |
| inline uint8_t getEpiValidity() { return mP1.mEpiValidity; } |
| inline float getEpiLat() { return mP1.mEpiLat; } |
| inline float getEpiLon() { return mP1.mEpiLon; } |
| inline float getEpiAlt() { return mP1.mEpiAlt; } |
| inline float getEpiHepe() { return mP1.mEpiHepe; } |
| inline float getEpiAltUnc() { return mP1.mEpiAltUnc; } |
| inline uint8_t getEpiSrc() { return mP1.mEpiSrc; } |
| |
| SystemStatusPQWP1parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| if (mField.size() < eMax) { |
| return; |
| } |
| memset(&mP1, 0, sizeof(mP1)); |
| mP1.mEpiValidity = strtol(mField[eEpiValidity].c_str(), NULL, 16); |
| mP1.mEpiLat = atof(mField[eEpiLat].c_str()); |
| mP1.mEpiLon = atof(mField[eEpiLon].c_str()); |
| mP1.mEpiAlt = atof(mField[eEpiAlt].c_str()); |
| mP1.mEpiHepe = atoi(mField[eEpiHepe].c_str()); |
| mP1.mEpiAltUnc = atof(mField[eEpiAltUnc].c_str()); |
| mP1.mEpiSrc = atoi(mField[eEpiSrc].c_str()); |
| } |
| |
| inline SystemStatusPQWP1& get() { return mP1;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWP2 |
| ******************************************************************************/ |
| class SystemStatusPQWP2 |
| { |
| public: |
| float mBestLat; // x4 |
| float mBestLon; // x5 |
| float mBestAlt; // x6 |
| float mBestHepe; // x7 |
| float mBestAltUnc; // x8 |
| }; |
| |
| class SystemStatusPQWP2parser : public SystemStatusNmeaBase |
| { |
| private: |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eBestLat = 2, |
| eBestLon = 3, |
| eBestAlt = 4, |
| eBestHepe = 5, |
| eBestAltUnc = 6, |
| eMax |
| }; |
| SystemStatusPQWP2 mP2; |
| |
| public: |
| inline float getBestLat() { return mP2.mBestLat; } |
| inline float getBestLon() { return mP2.mBestLon; } |
| inline float getBestAlt() { return mP2.mBestAlt; } |
| inline float getBestHepe() { return mP2.mBestHepe; } |
| inline float getBestAltUnc() { return mP2.mBestAltUnc; } |
| |
| SystemStatusPQWP2parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| if (mField.size() < eMax) { |
| return; |
| } |
| memset(&mP2, 0, sizeof(mP2)); |
| mP2.mBestLat = atof(mField[eBestLat].c_str()); |
| mP2.mBestLon = atof(mField[eBestLon].c_str()); |
| mP2.mBestAlt = atof(mField[eBestAlt].c_str()); |
| mP2.mBestHepe = atof(mField[eBestHepe].c_str()); |
| mP2.mBestAltUnc = atof(mField[eBestAltUnc].c_str()); |
| } |
| |
| inline SystemStatusPQWP2& get() { return mP2;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWP3 |
| ******************************************************************************/ |
| class SystemStatusPQWP3 |
| { |
| public: |
| uint8_t mXtraValidMask; |
| uint32_t mGpsXtraAge; |
| uint32_t mGloXtraAge; |
| uint32_t mBdsXtraAge; |
| uint32_t mGalXtraAge; |
| uint32_t mQzssXtraAge; |
| uint32_t mNavicXtraAge; |
| uint32_t mGpsXtraValid; |
| uint32_t mGloXtraValid; |
| uint64_t mBdsXtraValid; |
| uint64_t mGalXtraValid; |
| uint8_t mQzssXtraValid; |
| uint32_t mNavicXtraValid; |
| }; |
| |
| class SystemStatusPQWP3parser : public SystemStatusNmeaBase |
| { |
| private: |
| // todo: update for navic once available |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eXtraValidMask = 2, |
| eGpsXtraAge = 3, |
| eGloXtraAge = 4, |
| eBdsXtraAge = 5, |
| eGalXtraAge = 6, |
| eQzssXtraAge = 7, |
| eGpsXtraValid = 8, |
| eGloXtraValid = 9, |
| eBdsXtraValid = 10, |
| eGalXtraValid = 11, |
| eQzssXtraValid = 12, |
| eMax |
| }; |
| SystemStatusPQWP3 mP3; |
| |
| public: |
| inline uint8_t getXtraValid() { return mP3.mXtraValidMask; } |
| inline uint32_t getGpsXtraAge() { return mP3.mGpsXtraAge; } |
| inline uint32_t getGloXtraAge() { return mP3.mGloXtraAge; } |
| inline uint32_t getBdsXtraAge() { return mP3.mBdsXtraAge; } |
| inline uint32_t getGalXtraAge() { return mP3.mGalXtraAge; } |
| inline uint32_t getQzssXtraAge() { return mP3.mQzssXtraAge; } |
| inline uint32_t getNavicXtraAge() { return mP3.mNavicXtraAge; } |
| inline uint32_t getGpsXtraValid() { return mP3.mGpsXtraValid; } |
| inline uint32_t getGloXtraValid() { return mP3.mGloXtraValid; } |
| inline uint64_t getBdsXtraValid() { return mP3.mBdsXtraValid; } |
| inline uint64_t getGalXtraValid() { return mP3.mGalXtraValid; } |
| inline uint8_t getQzssXtraValid() { return mP3.mQzssXtraValid; } |
| inline uint32_t getNavicXtraValid() { return mP3.mNavicXtraValid; } |
| |
| SystemStatusPQWP3parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| if (mField.size() < eMax) { |
| return; |
| } |
| memset(&mP3, 0, sizeof(mP3)); |
| // todo: update for navic once available |
| mP3.mXtraValidMask = strtol(mField[eXtraValidMask].c_str(), NULL, 16); |
| mP3.mGpsXtraAge = atoi(mField[eGpsXtraAge].c_str()); |
| mP3.mGloXtraAge = atoi(mField[eGloXtraAge].c_str()); |
| mP3.mBdsXtraAge = atoi(mField[eBdsXtraAge].c_str()); |
| mP3.mGalXtraAge = atoi(mField[eGalXtraAge].c_str()); |
| mP3.mQzssXtraAge = atoi(mField[eQzssXtraAge].c_str()); |
| mP3.mGpsXtraValid = strtol(mField[eGpsXtraValid].c_str(), NULL, 16); |
| mP3.mGloXtraValid = strtol(mField[eGloXtraValid].c_str(), NULL, 16); |
| mP3.mBdsXtraValid = strtol(mField[eBdsXtraValid].c_str(), NULL, 16); |
| mP3.mGalXtraValid = strtol(mField[eGalXtraValid].c_str(), NULL, 16); |
| mP3.mQzssXtraValid = strtol(mField[eQzssXtraValid].c_str(), NULL, 16); |
| } |
| |
| inline SystemStatusPQWP3& get() { return mP3;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWP4 |
| ******************************************************************************/ |
| class SystemStatusPQWP4 |
| { |
| public: |
| uint32_t mGpsEpheValid; |
| uint32_t mGloEpheValid; |
| uint64_t mBdsEpheValid; |
| uint64_t mGalEpheValid; |
| uint8_t mQzssEpheValid; |
| }; |
| |
| class SystemStatusPQWP4parser : public SystemStatusNmeaBase |
| { |
| private: |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eGpsEpheValid = 2, |
| eGloEpheValid = 3, |
| eBdsEpheValid = 4, |
| eGalEpheValid = 5, |
| eQzssEpheValid = 6, |
| eMax |
| }; |
| SystemStatusPQWP4 mP4; |
| |
| public: |
| inline uint32_t getGpsEpheValid() { return mP4.mGpsEpheValid; } |
| inline uint32_t getGloEpheValid() { return mP4.mGloEpheValid; } |
| inline uint64_t getBdsEpheValid() { return mP4.mBdsEpheValid; } |
| inline uint64_t getGalEpheValid() { return mP4.mGalEpheValid; } |
| inline uint8_t getQzssEpheValid() { return mP4.mQzssEpheValid; } |
| |
| SystemStatusPQWP4parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| if (mField.size() < eMax) { |
| return; |
| } |
| memset(&mP4, 0, sizeof(mP4)); |
| mP4.mGpsEpheValid = strtol(mField[eGpsEpheValid].c_str(), NULL, 16); |
| mP4.mGloEpheValid = strtol(mField[eGloEpheValid].c_str(), NULL, 16); |
| mP4.mBdsEpheValid = strtol(mField[eBdsEpheValid].c_str(), NULL, 16); |
| mP4.mGalEpheValid = strtol(mField[eGalEpheValid].c_str(), NULL, 16); |
| mP4.mQzssEpheValid = strtol(mField[eQzssEpheValid].c_str(), NULL, 16); |
| } |
| |
| inline SystemStatusPQWP4& get() { return mP4;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWP5 |
| ******************************************************************************/ |
| class SystemStatusPQWP5 |
| { |
| public: |
| uint32_t mGpsUnknownMask; |
| uint32_t mGloUnknownMask; |
| uint64_t mBdsUnknownMask; |
| uint64_t mGalUnknownMask; |
| uint8_t mQzssUnknownMask; |
| uint32_t mNavicUnknownMask; |
| uint32_t mGpsGoodMask; |
| uint32_t mGloGoodMask; |
| uint64_t mBdsGoodMask; |
| uint64_t mGalGoodMask; |
| uint8_t mQzssGoodMask; |
| uint32_t mNavicGoodMask; |
| uint32_t mGpsBadMask; |
| uint32_t mGloBadMask; |
| uint64_t mBdsBadMask; |
| uint64_t mGalBadMask; |
| uint8_t mQzssBadMask; |
| uint32_t mNavicBadMask; |
| }; |
| |
| class SystemStatusPQWP5parser : public SystemStatusNmeaBase |
| { |
| private: |
| // todo: update for navic once available |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eGpsUnknownMask = 2, |
| eGloUnknownMask = 3, |
| eBdsUnknownMask = 4, |
| eGalUnknownMask = 5, |
| eQzssUnknownMask = 6, |
| eGpsGoodMask = 7, |
| eGloGoodMask = 8, |
| eBdsGoodMask = 9, |
| eGalGoodMask = 10, |
| eQzssGoodMask = 11, |
| eGpsBadMask = 12, |
| eGloBadMask = 13, |
| eBdsBadMask = 14, |
| eGalBadMask = 15, |
| eQzssBadMask = 16, |
| eMax |
| }; |
| SystemStatusPQWP5 mP5; |
| |
| public: |
| inline uint32_t getGpsUnknownMask() { return mP5.mGpsUnknownMask; } |
| inline uint32_t getGloUnknownMask() { return mP5.mGloUnknownMask; } |
| inline uint64_t getBdsUnknownMask() { return mP5.mBdsUnknownMask; } |
| inline uint64_t getGalUnknownMask() { return mP5.mGalUnknownMask; } |
| inline uint8_t getQzssUnknownMask() { return mP5.mQzssUnknownMask; } |
| inline uint32_t getNavicUnknownMask() { return mP5.mNavicUnknownMask; } |
| inline uint32_t getGpsGoodMask() { return mP5.mGpsGoodMask; } |
| inline uint32_t getGloGoodMask() { return mP5.mGloGoodMask; } |
| inline uint64_t getBdsGoodMask() { return mP5.mBdsGoodMask; } |
| inline uint64_t getGalGoodMask() { return mP5.mGalGoodMask; } |
| inline uint8_t getQzssGoodMask() { return mP5.mQzssGoodMask; } |
| inline uint32_t getNavicGoodMask() { return mP5.mNavicGoodMask; } |
| inline uint32_t getGpsBadMask() { return mP5.mGpsBadMask; } |
| inline uint32_t getGloBadMask() { return mP5.mGloBadMask; } |
| inline uint64_t getBdsBadMask() { return mP5.mBdsBadMask; } |
| inline uint64_t getGalBadMask() { return mP5.mGalBadMask; } |
| inline uint8_t getQzssBadMask() { return mP5.mQzssBadMask; } |
| inline uint32_t getNavicBadMask() { return mP5.mNavicBadMask; } |
| |
| SystemStatusPQWP5parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| if (mField.size() < eMax) { |
| return; |
| } |
| memset(&mP5, 0, sizeof(mP5)); |
| // todo: update for navic once available |
| mP5.mGpsUnknownMask = strtol(mField[eGpsUnknownMask].c_str(), NULL, 16); |
| mP5.mGloUnknownMask = strtol(mField[eGloUnknownMask].c_str(), NULL, 16); |
| mP5.mBdsUnknownMask = strtol(mField[eBdsUnknownMask].c_str(), NULL, 16); |
| mP5.mGalUnknownMask = strtol(mField[eGalUnknownMask].c_str(), NULL, 16); |
| mP5.mQzssUnknownMask = strtol(mField[eQzssUnknownMask].c_str(), NULL, 16); |
| mP5.mGpsGoodMask = strtol(mField[eGpsGoodMask].c_str(), NULL, 16); |
| mP5.mGloGoodMask = strtol(mField[eGloGoodMask].c_str(), NULL, 16); |
| mP5.mBdsGoodMask = strtol(mField[eBdsGoodMask].c_str(), NULL, 16); |
| mP5.mGalGoodMask = strtol(mField[eGalGoodMask].c_str(), NULL, 16); |
| mP5.mQzssGoodMask = strtol(mField[eQzssGoodMask].c_str(), NULL, 16); |
| mP5.mGpsBadMask = strtol(mField[eGpsBadMask].c_str(), NULL, 16); |
| mP5.mGloBadMask = strtol(mField[eGloBadMask].c_str(), NULL, 16); |
| mP5.mBdsBadMask = strtol(mField[eBdsBadMask].c_str(), NULL, 16); |
| mP5.mGalBadMask = strtol(mField[eGalBadMask].c_str(), NULL, 16); |
| mP5.mQzssBadMask = strtol(mField[eQzssBadMask].c_str(), NULL, 16); |
| } |
| |
| inline SystemStatusPQWP5& get() { return mP5;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWP6parser |
| ******************************************************************************/ |
| class SystemStatusPQWP6 |
| { |
| public: |
| uint32_t mFixInfoMask; |
| }; |
| |
| class SystemStatusPQWP6parser : public SystemStatusNmeaBase |
| { |
| private: |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eFixInfoMask = 2, |
| eMax |
| }; |
| SystemStatusPQWP6 mP6; |
| |
| public: |
| inline uint32_t getFixInfoMask() { return mP6.mFixInfoMask; } |
| |
| SystemStatusPQWP6parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| if (mField.size() < eMax) { |
| return; |
| } |
| memset(&mP6, 0, sizeof(mP6)); |
| mP6.mFixInfoMask = strtol(mField[eFixInfoMask].c_str(), NULL, 16); |
| } |
| |
| inline SystemStatusPQWP6& get() { return mP6;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWP7parser |
| ******************************************************************************/ |
| class SystemStatusPQWP7 |
| { |
| public: |
| SystemStatusNav mNav[SV_ALL_NUM]; |
| }; |
| |
| class SystemStatusPQWP7parser : public SystemStatusNmeaBase |
| { |
| private: |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eMin = 2 + SV_ALL_NUM_MIN*3, |
| eMax = 2 + SV_ALL_NUM*3 |
| }; |
| SystemStatusPQWP7 mP7; |
| |
| public: |
| SystemStatusPQWP7parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| uint32_t svLimit = SV_ALL_NUM; |
| if (mField.size() < eMin) { |
| LOC_LOGE("PQWP7parser - invalid size=%zu", mField.size()); |
| return; |
| } |
| if (mField.size() < eMax) { |
| // Try reducing limit, accounting for possibly missing NAVIC support |
| svLimit = SV_ALL_NUM_MIN; |
| } |
| |
| memset(mP7.mNav, 0, sizeof(mP7.mNav)); |
| for (uint32_t i=0; i<svLimit; i++) { |
| mP7.mNav[i].mType = GnssEphemerisType(atoi(mField[i*3+2].c_str())); |
| mP7.mNav[i].mSource = GnssEphemerisSource(atoi(mField[i*3+3].c_str())); |
| mP7.mNav[i].mAgeSec = atoi(mField[i*3+4].c_str()); |
| } |
| } |
| |
| inline SystemStatusPQWP7& get() { return mP7;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusPQWS1parser |
| ******************************************************************************/ |
| class SystemStatusPQWS1 |
| { |
| public: |
| uint32_t mFixInfoMask; |
| uint32_t mHepeLimit; |
| }; |
| |
| class SystemStatusPQWS1parser : public SystemStatusNmeaBase |
| { |
| private: |
| enum |
| { |
| eTalker = 0, |
| eUtcTime = 1, |
| eFixInfoMask = 2, |
| eHepeLimit = 3, |
| eMax |
| }; |
| SystemStatusPQWS1 mS1; |
| |
| public: |
| inline uint16_t getFixInfoMask() { return mS1.mFixInfoMask; } |
| inline uint32_t getHepeLimit() { return mS1.mHepeLimit; } |
| |
| SystemStatusPQWS1parser(const char *str_in, uint32_t len_in) |
| : SystemStatusNmeaBase(str_in, len_in) |
| { |
| if (mField.size() < eMax) { |
| return; |
| } |
| memset(&mS1, 0, sizeof(mS1)); |
| mS1.mFixInfoMask = atoi(mField[eFixInfoMask].c_str()); |
| mS1.mHepeLimit = atoi(mField[eHepeLimit].c_str()); |
| } |
| |
| inline SystemStatusPQWS1& get() { return mS1;} |
| }; |
| |
| /****************************************************************************** |
| SystemStatusTimeAndClock |
| ******************************************************************************/ |
| SystemStatusTimeAndClock::SystemStatusTimeAndClock(const SystemStatusPQWM1& nmea) : |
| mGpsWeek(nmea.mGpsWeek), |
| mGpsTowMs(nmea.mGpsTowMs), |
| mTimeValid(nmea.mTimeValid), |
| mTimeSource(nmea.mTimeSource), |
| mTimeUnc(nmea.mTimeUnc), |
| mClockFreqBias(nmea.mClockFreqBias), |
| mClockFreqBiasUnc(nmea.mClockFreqBiasUnc), |
| mLeapSeconds(nmea.mLeapSeconds), |
| mLeapSecUnc(nmea.mLeapSecUnc), |
| mTimeUncNs(nmea.mTimeUncNs) |
| { |
| } |
| |
| bool SystemStatusTimeAndClock::equals(const SystemStatusTimeAndClock& peer) |
| { |
| if ((mGpsWeek != peer.mGpsWeek) || |
| (mGpsTowMs != peer.mGpsTowMs) || |
| (mTimeValid != peer.mTimeValid) || |
| (mTimeSource != peer.mTimeSource) || |
| (mTimeUnc != peer.mTimeUnc) || |
| (mClockFreqBias != peer.mClockFreqBias) || |
| (mClockFreqBiasUnc != peer.mClockFreqBiasUnc) || |
| (mLeapSeconds != peer.mLeapSeconds) || |
| (mLeapSecUnc != peer.mLeapSecUnc) || |
| (mTimeUncNs != peer.mTimeUncNs)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusTimeAndClock::dump() |
| { |
| LOC_LOGV("TimeAndClock: u=%ld:%ld g=%d:%d v=%d ts=%d tu=%d b=%d bu=%d ls=%d lu=%d un=%" PRIu64, |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mGpsWeek, |
| mGpsTowMs, |
| mTimeValid, |
| mTimeSource, |
| mTimeUnc, |
| mClockFreqBias, |
| mClockFreqBiasUnc, |
| mLeapSeconds, |
| mLeapSecUnc, |
| mTimeUncNs); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusXoState |
| ******************************************************************************/ |
| SystemStatusXoState::SystemStatusXoState(const SystemStatusPQWM1& nmea) : |
| mXoState(nmea.mXoState) |
| { |
| } |
| |
| bool SystemStatusXoState::equals(const SystemStatusXoState& peer) |
| { |
| if (mXoState != peer.mXoState) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusXoState::dump() |
| { |
| LOC_LOGV("XoState: u=%ld:%ld x=%d", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mXoState); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusRfAndParams |
| ******************************************************************************/ |
| SystemStatusRfAndParams::SystemStatusRfAndParams(const SystemStatusPQWM1& nmea) : |
| mPgaGain(nmea.mPgaGain), |
| mGpsBpAmpI(nmea.mGpsBpAmpI), |
| mGpsBpAmpQ(nmea.mGpsBpAmpQ), |
| mAdcI(nmea.mAdcI), |
| mAdcQ(nmea.mAdcQ), |
| mJammerGps(nmea.mJammerGps), |
| mJammerGlo(nmea.mJammerGlo), |
| mJammerBds(nmea.mJammerBds), |
| mJammerGal(nmea.mJammerGal), |
| mAgcGps(nmea.mAgcGps), |
| mAgcGlo(nmea.mAgcGlo), |
| mAgcBds(nmea.mAgcBds), |
| mAgcGal(nmea.mAgcGal), |
| mGloBpAmpI(nmea.mGloBpAmpI), |
| mGloBpAmpQ(nmea.mGloBpAmpQ), |
| mBdsBpAmpI(nmea.mBdsBpAmpI), |
| mBdsBpAmpQ(nmea.mBdsBpAmpQ), |
| mGalBpAmpI(nmea.mGalBpAmpI), |
| mGalBpAmpQ(nmea.mGalBpAmpQ) |
| { |
| } |
| |
| bool SystemStatusRfAndParams::equals(const SystemStatusRfAndParams& peer) |
| { |
| if ((mPgaGain != peer.mPgaGain) || |
| (mGpsBpAmpI != peer.mGpsBpAmpI) || |
| (mGpsBpAmpQ != peer.mGpsBpAmpQ) || |
| (mAdcI != peer.mAdcI) || |
| (mAdcQ != peer.mAdcQ) || |
| (mJammerGps != peer.mJammerGps) || |
| (mJammerGlo != peer.mJammerGlo) || |
| (mJammerBds != peer.mJammerBds) || |
| (mJammerGal != peer.mJammerGal) || |
| (mAgcGps != peer.mAgcGps) || |
| (mAgcGlo != peer.mAgcGlo) || |
| (mAgcBds != peer.mAgcBds) || |
| (mAgcGal != peer.mAgcGal) || |
| (mGloBpAmpI != peer.mGloBpAmpI) || |
| (mGloBpAmpQ != peer.mGloBpAmpQ) || |
| (mBdsBpAmpI != peer.mBdsBpAmpI) || |
| (mBdsBpAmpQ != peer.mBdsBpAmpQ) || |
| (mGalBpAmpI != peer.mGalBpAmpI) || |
| (mGalBpAmpQ != peer.mGalBpAmpQ)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusRfAndParams::dump() |
| { |
| LOC_LOGV("RfAndParams: u=%ld:%ld p=%d bi=%d bq=%d ai=%d aq=%d " |
| "jgp=%d jgl=%d jbd=%d jga=%d " |
| "agp=%lf agl=%lf abd=%lf aga=%lf", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mPgaGain, |
| mGpsBpAmpI, |
| mGpsBpAmpQ, |
| mAdcI, |
| mAdcQ, |
| mJammerGps, |
| mJammerGlo, |
| mJammerBds, |
| mJammerGal, |
| mAgcGps, |
| mAgcGlo, |
| mAgcBds, |
| mAgcGal); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusErrRecovery |
| ******************************************************************************/ |
| SystemStatusErrRecovery::SystemStatusErrRecovery(const SystemStatusPQWM1& nmea) : |
| mRecErrorRecovery(nmea.mRecErrorRecovery) |
| { |
| } |
| |
| bool SystemStatusErrRecovery::equals(const SystemStatusErrRecovery& peer) |
| { |
| if (mRecErrorRecovery != peer.mRecErrorRecovery) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusErrRecovery::dump() |
| { |
| LOC_LOGV("ErrRecovery: u=%ld:%ld e=%d", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mRecErrorRecovery); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusInjectedPosition |
| ******************************************************************************/ |
| SystemStatusInjectedPosition::SystemStatusInjectedPosition(const SystemStatusPQWP1& nmea) : |
| mEpiValidity(nmea.mEpiValidity), |
| mEpiLat(nmea.mEpiLat), |
| mEpiLon(nmea.mEpiLon), |
| mEpiAlt(nmea.mEpiAlt), |
| mEpiHepe(nmea.mEpiHepe), |
| mEpiAltUnc(nmea.mEpiAltUnc), |
| mEpiSrc(nmea.mEpiSrc) |
| { |
| } |
| |
| bool SystemStatusInjectedPosition::equals(const SystemStatusInjectedPosition& peer) |
| { |
| if ((mEpiValidity != peer.mEpiValidity) || |
| (mEpiLat != peer.mEpiLat) || |
| (mEpiLon != peer.mEpiLon) || |
| (mEpiAlt != peer.mEpiAlt) || |
| (mEpiHepe != peer.mEpiHepe) || |
| (mEpiAltUnc != peer.mEpiAltUnc) || |
| (mEpiSrc != peer.mEpiSrc)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusInjectedPosition::dump() |
| { |
| LOC_LOGV("InjectedPosition: u=%ld:%ld v=%x la=%f lo=%f al=%f he=%f au=%f es=%d", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mEpiValidity, |
| mEpiLat, |
| mEpiLon, |
| mEpiAlt, |
| mEpiHepe, |
| mEpiAltUnc, |
| mEpiSrc); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusBestPosition |
| ******************************************************************************/ |
| SystemStatusBestPosition::SystemStatusBestPosition(const SystemStatusPQWP2& nmea) : |
| mValid(true), |
| mBestLat(nmea.mBestLat), |
| mBestLon(nmea.mBestLon), |
| mBestAlt(nmea.mBestAlt), |
| mBestHepe(nmea.mBestHepe), |
| mBestAltUnc(nmea.mBestAltUnc) |
| { |
| } |
| |
| bool SystemStatusBestPosition::equals(const SystemStatusBestPosition& peer) |
| { |
| if ((mBestLat != peer.mBestLat) || |
| (mBestLon != peer.mBestLon) || |
| (mBestAlt != peer.mBestAlt) || |
| (mBestHepe != peer.mBestHepe) || |
| (mBestAltUnc != peer.mBestAltUnc)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusBestPosition::dump() |
| { |
| LOC_LOGV("BestPosition: u=%ld:%ld la=%f lo=%f al=%f he=%f au=%f", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mBestLat, |
| mBestLon, |
| mBestAlt, |
| mBestHepe, |
| mBestAltUnc); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusXtra |
| ******************************************************************************/ |
| SystemStatusXtra::SystemStatusXtra(const SystemStatusPQWP3& nmea) : |
| mXtraValidMask(nmea.mXtraValidMask), |
| mGpsXtraAge(nmea.mGpsXtraAge), |
| mGloXtraAge(nmea.mGloXtraAge), |
| mBdsXtraAge(nmea.mBdsXtraAge), |
| mGalXtraAge(nmea.mGalXtraAge), |
| mQzssXtraAge(nmea.mQzssXtraAge), |
| mNavicXtraAge(nmea.mNavicXtraAge), |
| mGpsXtraValid(nmea.mGpsXtraValid), |
| mGloXtraValid(nmea.mGloXtraValid), |
| mBdsXtraValid(nmea.mBdsXtraValid), |
| mGalXtraValid(nmea.mGalXtraValid), |
| mQzssXtraValid(nmea.mQzssXtraValid), |
| mNavicXtraValid(nmea.mNavicXtraValid) |
| { |
| } |
| |
| bool SystemStatusXtra::equals(const SystemStatusXtra& peer) |
| { |
| if ((mXtraValidMask != peer.mXtraValidMask) || |
| (mGpsXtraAge != peer.mGpsXtraAge) || |
| (mGloXtraAge != peer.mGloXtraAge) || |
| (mBdsXtraAge != peer.mBdsXtraAge) || |
| (mGalXtraAge != peer.mGalXtraAge) || |
| (mQzssXtraAge != peer.mQzssXtraAge) || |
| (mNavicXtraAge != peer.mNavicXtraAge) || |
| (mGpsXtraValid != peer.mGpsXtraValid) || |
| (mGloXtraValid != peer.mGloXtraValid) || |
| (mBdsXtraValid != peer.mBdsXtraValid) || |
| (mGalXtraValid != peer.mGalXtraValid) || |
| (mQzssXtraValid != peer.mQzssXtraValid) || |
| (mNavicXtraValid != peer.mNavicXtraValid)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusXtra::dump() |
| { |
| LOC_LOGV("SystemStatusXtra: u=%ld:%ld m=%x a=%d:%d:%d:%d:%d v=%x:%x:%" PRIx64 ":%" PRIx64":%x", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mXtraValidMask, |
| mGpsXtraAge, |
| mGloXtraAge, |
| mBdsXtraAge, |
| mGalXtraAge, |
| mQzssXtraAge, |
| mGpsXtraValid, |
| mGloXtraValid, |
| mBdsXtraValid, |
| mGalXtraValid, |
| mQzssXtraValid); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusEphemeris |
| ******************************************************************************/ |
| SystemStatusEphemeris::SystemStatusEphemeris(const SystemStatusPQWP4& nmea) : |
| mGpsEpheValid(nmea.mGpsEpheValid), |
| mGloEpheValid(nmea.mGloEpheValid), |
| mBdsEpheValid(nmea.mBdsEpheValid), |
| mGalEpheValid(nmea.mGalEpheValid), |
| mQzssEpheValid(nmea.mQzssEpheValid) |
| { |
| } |
| |
| bool SystemStatusEphemeris::equals(const SystemStatusEphemeris& peer) |
| { |
| if ((mGpsEpheValid != peer.mGpsEpheValid) || |
| (mGloEpheValid != peer.mGloEpheValid) || |
| (mBdsEpheValid != peer.mBdsEpheValid) || |
| (mGalEpheValid != peer.mGalEpheValid) || |
| (mQzssEpheValid != peer.mQzssEpheValid)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusEphemeris::dump() |
| { |
| LOC_LOGV("Ephemeris: u=%ld:%ld ev=%x:%x:%" PRIx64 ":%" PRIx64 ":%x", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mGpsEpheValid, |
| mGloEpheValid, |
| mBdsEpheValid, |
| mGalEpheValid, |
| mQzssEpheValid); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusSvHealth |
| ******************************************************************************/ |
| SystemStatusSvHealth::SystemStatusSvHealth(const SystemStatusPQWP5& nmea) : |
| mGpsUnknownMask(nmea.mGpsUnknownMask), |
| mGloUnknownMask(nmea.mGloUnknownMask), |
| mBdsUnknownMask(nmea.mBdsUnknownMask), |
| mGalUnknownMask(nmea.mGalUnknownMask), |
| mQzssUnknownMask(nmea.mQzssUnknownMask), |
| mNavicUnknownMask(nmea.mNavicUnknownMask), |
| mGpsGoodMask(nmea.mGpsGoodMask), |
| mGloGoodMask(nmea.mGloGoodMask), |
| mBdsGoodMask(nmea.mBdsGoodMask), |
| mGalGoodMask(nmea.mGalGoodMask), |
| mQzssGoodMask(nmea.mQzssGoodMask), |
| mNavicGoodMask(nmea.mNavicGoodMask), |
| mGpsBadMask(nmea.mGpsBadMask), |
| mGloBadMask(nmea.mGloBadMask), |
| mBdsBadMask(nmea.mBdsBadMask), |
| mGalBadMask(nmea.mGalBadMask), |
| mQzssBadMask(nmea.mQzssBadMask), |
| mNavicBadMask(nmea.mNavicBadMask) |
| { |
| } |
| |
| bool SystemStatusSvHealth::equals(const SystemStatusSvHealth& peer) |
| { |
| if ((mGpsUnknownMask != peer.mGpsUnknownMask) || |
| (mGloUnknownMask != peer.mGloUnknownMask) || |
| (mBdsUnknownMask != peer.mBdsUnknownMask) || |
| (mGalUnknownMask != peer.mGalUnknownMask) || |
| (mQzssUnknownMask != peer.mQzssUnknownMask) || |
| (mGpsGoodMask != peer.mGpsGoodMask) || |
| (mGloGoodMask != peer.mGloGoodMask) || |
| (mBdsGoodMask != peer.mBdsGoodMask) || |
| (mGalGoodMask != peer.mGalGoodMask) || |
| (mQzssGoodMask != peer.mQzssGoodMask) || |
| (mGpsBadMask != peer.mGpsBadMask) || |
| (mGloBadMask != peer.mGloBadMask) || |
| (mBdsBadMask != peer.mBdsBadMask) || |
| (mGalBadMask != peer.mGalBadMask) || |
| (mQzssBadMask != peer.mQzssBadMask)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusSvHealth::dump() |
| { |
| LOC_LOGV("SvHealth: u=%ld:%ld \ |
| u=%x:%x:%" PRIx64 ":%" PRIx64 ":%x \ |
| g=%x:%x:%" PRIx64 ":%" PRIx64 ":%x \ |
| b=%x:%x:%" PRIx64 ":%" PRIx64 ":%x", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mGpsUnknownMask, |
| mGloUnknownMask, |
| mBdsUnknownMask, |
| mGalUnknownMask, |
| mQzssUnknownMask, |
| mGpsGoodMask, |
| mGloGoodMask, |
| mBdsGoodMask, |
| mGalGoodMask, |
| mQzssGoodMask, |
| mGpsBadMask, |
| mGloBadMask, |
| mBdsBadMask, |
| mGalBadMask, |
| mQzssBadMask); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusPdr |
| ******************************************************************************/ |
| SystemStatusPdr::SystemStatusPdr(const SystemStatusPQWP6& nmea) : |
| mFixInfoMask(nmea.mFixInfoMask) |
| { |
| } |
| |
| bool SystemStatusPdr::equals(const SystemStatusPdr& peer) |
| { |
| if (mFixInfoMask != peer.mFixInfoMask) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusPdr::dump() |
| { |
| LOC_LOGV("Pdr: u=%ld:%ld m=%x", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mFixInfoMask); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusNavData |
| ******************************************************************************/ |
| SystemStatusNavData::SystemStatusNavData(const SystemStatusPQWP7& nmea) |
| { |
| for (uint32_t i=0; i<SV_ALL_NUM; i++) { |
| mNav[i] = nmea.mNav[i]; |
| } |
| } |
| |
| bool SystemStatusNavData::equals(const SystemStatusNavData& peer) |
| { |
| for (uint32_t i=0; i<SV_ALL_NUM; i++) { |
| if ((mNav[i].mType != peer.mNav[i].mType) || |
| (mNav[i].mSource != peer.mNav[i].mSource) || |
| (mNav[i].mAgeSec != peer.mNav[i].mAgeSec)) { |
| return false; |
| } |
| } |
| return true; |
| } |
| |
| void SystemStatusNavData::dump() |
| { |
| LOC_LOGV("NavData: u=%ld:%ld", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec); |
| for (uint32_t i=0; i<SV_ALL_NUM; i++) { |
| LOC_LOGV("i=%d type=%d src=%d age=%d", |
| i, mNav[i].mType, mNav[i].mSource, mNav[i].mAgeSec); |
| } |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusPositionFailure |
| ******************************************************************************/ |
| SystemStatusPositionFailure::SystemStatusPositionFailure(const SystemStatusPQWS1& nmea) : |
| mFixInfoMask(nmea.mFixInfoMask), |
| mHepeLimit(nmea.mHepeLimit) |
| { |
| } |
| |
| bool SystemStatusPositionFailure::equals(const SystemStatusPositionFailure& peer) |
| { |
| if ((mFixInfoMask != peer.mFixInfoMask) || |
| (mHepeLimit != peer.mHepeLimit)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusPositionFailure::dump() |
| { |
| LOC_LOGV("PositionFailure: u=%ld:%ld m=%d h=%d", |
| mUtcTime.tv_sec, mUtcTime.tv_nsec, |
| mFixInfoMask, |
| mHepeLimit); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatusLocation |
| ******************************************************************************/ |
| bool SystemStatusLocation::equals(const SystemStatusLocation& peer) |
| { |
| if ((mLocation.gpsLocation.latitude != peer.mLocation.gpsLocation.latitude) || |
| (mLocation.gpsLocation.longitude != peer.mLocation.gpsLocation.longitude) || |
| (mLocation.gpsLocation.altitude != peer.mLocation.gpsLocation.altitude)) { |
| return false; |
| } |
| return true; |
| } |
| |
| void SystemStatusLocation::dump() |
| { |
| LOC_LOGV("Location: lat=%f lon=%f alt=%f spd=%f", |
| mLocation.gpsLocation.latitude, |
| mLocation.gpsLocation.longitude, |
| mLocation.gpsLocation.altitude, |
| mLocation.gpsLocation.speed); |
| return; |
| } |
| |
| /****************************************************************************** |
| SystemStatus |
| ******************************************************************************/ |
| pthread_mutex_t SystemStatus::mMutexSystemStatus = PTHREAD_MUTEX_INITIALIZER; |
| SystemStatus* SystemStatus::mInstance = NULL; |
| |
| SystemStatus* SystemStatus::getInstance(const MsgTask* msgTask) |
| { |
| pthread_mutex_lock(&mMutexSystemStatus); |
| |
| if (!mInstance) { |
| // Instantiating for the first time. msgTask should not be NULL |
| if (msgTask == NULL) { |
| LOC_LOGE("SystemStatus: msgTask is NULL!!"); |
| pthread_mutex_unlock(&mMutexSystemStatus); |
| return NULL; |
| } |
| mInstance = new (nothrow) SystemStatus(msgTask); |
| LOC_LOGD("SystemStatus::getInstance:%p. Msgtask:%p", mInstance, msgTask); |
| } |
| |
| pthread_mutex_unlock(&mMutexSystemStatus); |
| return mInstance; |
| } |
| |
| void SystemStatus::destroyInstance() |
| { |
| delete mInstance; |
| mInstance = NULL; |
| } |
| |
| void SystemStatus::resetNetworkInfo() { |
| for (int i=0; i<mCache.mNetworkInfo.size(); ++i) { |
| // Reset all the cached NetworkInfo Items as disconnected |
| eventConnectionStatus(false, mCache.mNetworkInfo[i].mType, mCache.mNetworkInfo[i].mRoaming, |
| mCache.mNetworkInfo[i].mNetworkHandle, mCache.mNetworkInfo[i].mApn); |
| } |
| } |
| |
| IOsObserver* SystemStatus::getOsObserver() |
| { |
| return &mSysStatusObsvr; |
| } |
| |
| SystemStatus::SystemStatus(const MsgTask* msgTask) : |
| mSysStatusObsvr(this, msgTask) |
| { |
| int result = 0; |
| ENTRY_LOG (); |
| mCache.mLocation.clear(); |
| |
| mCache.mTimeAndClock.clear(); |
| mCache.mXoState.clear(); |
| mCache.mRfAndParams.clear(); |
| mCache.mErrRecovery.clear(); |
| |
| mCache.mInjectedPosition.clear(); |
| mCache.mBestPosition.clear(); |
| mCache.mXtra.clear(); |
| mCache.mEphemeris.clear(); |
| mCache.mSvHealth.clear(); |
| mCache.mPdr.clear(); |
| mCache.mNavData.clear(); |
| |
| mCache.mPositionFailure.clear(); |
| |
| mCache.mAirplaneMode.clear(); |
| mCache.mENH.clear(); |
| mCache.mGPSState.clear(); |
| mCache.mNLPStatus.clear(); |
| mCache.mWifiHardwareState.clear(); |
| mCache.mNetworkInfo.clear(); |
| mCache.mRilServiceInfo.clear(); |
| mCache.mRilCellInfo.clear(); |
| mCache.mServiceStatus.clear(); |
| mCache.mModel.clear(); |
| mCache.mManufacturer.clear(); |
| mCache.mAssistedGps.clear(); |
| mCache.mScreenState.clear(); |
| mCache.mPowerConnectState.clear(); |
| mCache.mTimeZoneChange.clear(); |
| mCache.mTimeChange.clear(); |
| mCache.mWifiSupplicantStatus.clear(); |
| mCache.mShutdownState.clear(); |
| mCache.mTac.clear(); |
| mCache.mMccMnc.clear(); |
| mCache.mBtDeviceScanDetail.clear(); |
| mCache.mBtLeDeviceScanDetail.clear(); |
| |
| EXIT_LOG_WITH_ERROR ("%d",result); |
| } |
| |
| /****************************************************************************** |
| SystemStatus - storing dataitems |
| ******************************************************************************/ |
| template <typename TYPE_REPORT, typename TYPE_ITEM> |
| bool SystemStatus::setIteminReport(TYPE_REPORT& report, TYPE_ITEM&& s) |
| { |
| if (s.ignore()) { |
| return false; |
| } |
| if (!report.empty() && report.back().equals(static_cast<TYPE_ITEM&>(s.collate(report.back())))) { |
| // there is no change - just update reported timestamp |
| report.back().mUtcReported = s.mUtcReported; |
| return false; |
| } |
| |
| // first event or updated |
| report.push_back(s); |
| if (report.size() > s.maxItem) { |
| report.erase(report.begin()); |
| } |
| return true; |
| } |
| |
| template <typename TYPE_REPORT, typename TYPE_ITEM> |
| void SystemStatus::setDefaultIteminReport(TYPE_REPORT& report, const TYPE_ITEM& s) |
| { |
| report.push_back(s); |
| if (report.size() > s.maxItem) { |
| report.erase(report.begin()); |
| } |
| } |
| |
| template <typename TYPE_REPORT, typename TYPE_ITEM> |
| void SystemStatus::getIteminReport(TYPE_REPORT& reportout, const TYPE_ITEM& c) const |
| { |
| reportout.clear(); |
| if (c.size() >= 1) { |
| reportout.push_back(c.back()); |
| reportout.back().dump(); |
| } |
| } |
| |
| /****************************************************************************** |
| @brief API to set report data into internal buffer |
| |
| @param[In] data pointer to the NMEA string |
| @param[In] len length of the NMEA string |
| |
| @return true when the NMEA is consumed by the method. |
| ******************************************************************************/ |
| bool SystemStatus::setNmeaString(const char *data, uint32_t len) |
| { |
| if (!loc_nmea_is_debug(data, len)) { |
| return false; |
| } |
| |
| char buf[SystemStatusNmeaBase::NMEA_MAXSIZE + 1] = { 0 }; |
| strlcpy(buf, data, sizeof(buf)); |
| |
| pthread_mutex_lock(&mMutexSystemStatus); |
| |
| // parse the received nmea strings here |
| if (0 == strncmp(data, "$PQWM1", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| SystemStatusPQWM1 s = SystemStatusPQWM1parser(buf, len).get(); |
| setIteminReport(mCache.mTimeAndClock, SystemStatusTimeAndClock(s)); |
| setIteminReport(mCache.mXoState, SystemStatusXoState(s)); |
| setIteminReport(mCache.mRfAndParams, SystemStatusRfAndParams(s)); |
| setIteminReport(mCache.mErrRecovery, SystemStatusErrRecovery(s)); |
| } |
| else if (0 == strncmp(data, "$PQWP1", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mInjectedPosition, |
| SystemStatusInjectedPosition(SystemStatusPQWP1parser(buf, len).get())); |
| } |
| else if (0 == strncmp(data, "$PQWP2", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mBestPosition, |
| SystemStatusBestPosition(SystemStatusPQWP2parser(buf, len).get())); |
| } |
| else if (0 == strncmp(data, "$PQWP3", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mXtra, |
| SystemStatusXtra(SystemStatusPQWP3parser(buf, len).get())); |
| } |
| else if (0 == strncmp(data, "$PQWP4", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mEphemeris, |
| SystemStatusEphemeris(SystemStatusPQWP4parser(buf, len).get())); |
| } |
| else if (0 == strncmp(data, "$PQWP5", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mSvHealth, |
| SystemStatusSvHealth(SystemStatusPQWP5parser(buf, len).get())); |
| } |
| else if (0 == strncmp(data, "$PQWP6", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mPdr, |
| SystemStatusPdr(SystemStatusPQWP6parser(buf, len).get())); |
| } |
| else if (0 == strncmp(data, "$PQWP7", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mNavData, |
| SystemStatusNavData(SystemStatusPQWP7parser(buf, len).get())); |
| } |
| else if (0 == strncmp(data, "$PQWS1", SystemStatusNmeaBase::NMEA_MINSIZE)) { |
| setIteminReport(mCache.mPositionFailure, |
| SystemStatusPositionFailure(SystemStatusPQWS1parser(buf, len).get())); |
| } |
| else { |
| // do nothing |
| } |
| |
| pthread_mutex_unlock(&mMutexSystemStatus); |
| return true; |
| } |
| |
| /****************************************************************************** |
| @brief API to set report position data into internal buffer |
| |
| @param[In] UlpLocation |
| |
| @return true when successfully done |
| ******************************************************************************/ |
| bool SystemStatus::eventPosition(const UlpLocation& location, |
| const GpsLocationExtended& locationEx) |
| { |
| bool ret = false; |
| pthread_mutex_lock(&mMutexSystemStatus); |
| |
| ret = setIteminReport(mCache.mLocation, SystemStatusLocation(location, locationEx)); |
| LOC_LOGV("eventPosition - lat=%f lon=%f alt=%f speed=%f", |
| location.gpsLocation.latitude, |
| location.gpsLocation.longitude, |
| location.gpsLocation.altitude, |
| location.gpsLocation.speed); |
| |
| pthread_mutex_unlock(&mMutexSystemStatus); |
| return ret; |
| } |
| |
| /****************************************************************************** |
| @brief API to set report DataItem event into internal buffer |
| |
| @param[In] DataItem |
| |
| @return true when info is updatated |
| ******************************************************************************/ |
| bool SystemStatus::eventDataItemNotify(IDataItemCore* dataitem) |
| { |
| bool ret = false; |
| pthread_mutex_lock(&mMutexSystemStatus); |
| switch(dataitem->getId()) |
| { |
| case AIRPLANEMODE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mAirplaneMode, |
| SystemStatusAirplaneMode(*(static_cast<AirplaneModeDataItemBase*>(dataitem)))); |
| break; |
| case ENH_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mENH, |
| SystemStatusENH(*(static_cast<ENHDataItemBase*>(dataitem)))); |
| break; |
| case GPSSTATE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mGPSState, |
| SystemStatusGpsState(*(static_cast<GPSStateDataItemBase*>(dataitem)))); |
| break; |
| case NLPSTATUS_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mNLPStatus, |
| SystemStatusNLPStatus(*(static_cast<NLPStatusDataItemBase*>(dataitem)))); |
| break; |
| case WIFIHARDWARESTATE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mWifiHardwareState, |
| SystemStatusWifiHardwareState(*(static_cast<WifiHardwareStateDataItemBase*>(dataitem)))); |
| break; |
| case NETWORKINFO_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mNetworkInfo, |
| SystemStatusNetworkInfo(*(static_cast<NetworkInfoDataItemBase*>(dataitem)))); |
| break; |
| case RILSERVICEINFO_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mRilServiceInfo, |
| SystemStatusServiceInfo(*(static_cast<RilServiceInfoDataItemBase*>(dataitem)))); |
| break; |
| case RILCELLINFO_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mRilCellInfo, |
| SystemStatusRilCellInfo(*(static_cast<RilCellInfoDataItemBase*>(dataitem)))); |
| break; |
| case SERVICESTATUS_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mServiceStatus, |
| SystemStatusServiceStatus(*(static_cast<ServiceStatusDataItemBase*>(dataitem)))); |
| break; |
| case MODEL_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mModel, |
| SystemStatusModel(*(static_cast<ModelDataItemBase*>(dataitem)))); |
| break; |
| case MANUFACTURER_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mManufacturer, |
| SystemStatusManufacturer(*(static_cast<ManufacturerDataItemBase*>(dataitem)))); |
| break; |
| case ASSISTED_GPS_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mAssistedGps, |
| SystemStatusAssistedGps(*(static_cast<AssistedGpsDataItemBase*>(dataitem)))); |
| break; |
| case SCREEN_STATE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mScreenState, |
| SystemStatusScreenState(*(static_cast<ScreenStateDataItemBase*>(dataitem)))); |
| break; |
| case POWER_CONNECTED_STATE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mPowerConnectState, |
| SystemStatusPowerConnectState(*(static_cast<PowerConnectStateDataItemBase*>(dataitem)))); |
| break; |
| case TIMEZONE_CHANGE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mTimeZoneChange, |
| SystemStatusTimeZoneChange(*(static_cast<TimeZoneChangeDataItemBase*>(dataitem)))); |
| break; |
| case TIME_CHANGE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mTimeChange, |
| SystemStatusTimeChange(*(static_cast<TimeChangeDataItemBase*>(dataitem)))); |
| break; |
| case WIFI_SUPPLICANT_STATUS_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mWifiSupplicantStatus, |
| SystemStatusWifiSupplicantStatus(*(static_cast<WifiSupplicantStatusDataItemBase*>(dataitem)))); |
| break; |
| case SHUTDOWN_STATE_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mShutdownState, |
| SystemStatusShutdownState(*(static_cast<ShutdownStateDataItemBase*>(dataitem)))); |
| break; |
| case TAC_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mTac, |
| SystemStatusTac(*(static_cast<TacDataItemBase*>(dataitem)))); |
| break; |
| case MCCMNC_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mMccMnc, |
| SystemStatusMccMnc(*(static_cast<MccmncDataItemBase*>(dataitem)))); |
| break; |
| case BTLE_SCAN_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mBtDeviceScanDetail, |
| SystemStatusBtDeviceScanDetail(*(static_cast<BtDeviceScanDetailsDataItemBase*>(dataitem)))); |
| break; |
| case BT_SCAN_DATA_ITEM_ID: |
| ret = setIteminReport(mCache.mBtLeDeviceScanDetail, |
| SystemStatusBtleDeviceScanDetail(*(static_cast<BtLeDeviceScanDetailsDataItemBase*>(dataitem)))); |
| break; |
| default: |
| break; |
| } |
| pthread_mutex_unlock(&mMutexSystemStatus); |
| LOC_LOGv("DataItemId: %d, whether to record dateitem in cache: %d", dataitem->getId(), ret); |
| return ret; |
| } |
| |
| /****************************************************************************** |
| @brief API to get report data into a given buffer |
| |
| @param[In] reference to report buffer |
| @param[In] bool flag to identify latest only or entire buffer |
| |
| @return true when successfully done |
| ******************************************************************************/ |
| bool SystemStatus::getReport(SystemStatusReports& report, bool isLatestOnly) const |
| { |
| pthread_mutex_lock(&mMutexSystemStatus); |
| |
| if (isLatestOnly) { |
| // push back only the latest report and return it |
| getIteminReport(report.mLocation, mCache.mLocation); |
| |
| getIteminReport(report.mTimeAndClock, mCache.mTimeAndClock); |
| getIteminReport(report.mXoState, mCache.mXoState); |
| getIteminReport(report.mRfAndParams, mCache.mRfAndParams); |
| getIteminReport(report.mErrRecovery, mCache.mErrRecovery); |
| |
| getIteminReport(report.mInjectedPosition, mCache.mInjectedPosition); |
| getIteminReport(report.mBestPosition, mCache.mBestPosition); |
| getIteminReport(report.mXtra, mCache.mXtra); |
| getIteminReport(report.mEphemeris, mCache.mEphemeris); |
| getIteminReport(report.mSvHealth, mCache.mSvHealth); |
| getIteminReport(report.mPdr, mCache.mPdr); |
| getIteminReport(report.mNavData, mCache.mNavData); |
| |
| getIteminReport(report.mPositionFailure, mCache.mPositionFailure); |
| |
| getIteminReport(report.mAirplaneMode, mCache.mAirplaneMode); |
| getIteminReport(report.mENH, mCache.mENH); |
| getIteminReport(report.mGPSState, mCache.mGPSState); |
| getIteminReport(report.mNLPStatus, mCache.mNLPStatus); |
| getIteminReport(report.mWifiHardwareState, mCache.mWifiHardwareState); |
| getIteminReport(report.mNetworkInfo, mCache.mNetworkInfo); |
| getIteminReport(report.mRilServiceInfo, mCache.mRilServiceInfo); |
| getIteminReport(report.mRilCellInfo, mCache.mRilCellInfo); |
| getIteminReport(report.mServiceStatus, mCache.mServiceStatus); |
| getIteminReport(report.mModel, mCache.mModel); |
| getIteminReport(report.mManufacturer, mCache.mManufacturer); |
| getIteminReport(report.mAssistedGps, mCache.mAssistedGps); |
| getIteminReport(report.mScreenState, mCache.mScreenState); |
| getIteminReport(report.mPowerConnectState, mCache.mPowerConnectState); |
| getIteminReport(report.mTimeZoneChange, mCache.mTimeZoneChange); |
| getIteminReport(report.mTimeChange, mCache.mTimeChange); |
| getIteminReport(report.mWifiSupplicantStatus, mCache.mWifiSupplicantStatus); |
| getIteminReport(report.mShutdownState, mCache.mShutdownState); |
| getIteminReport(report.mTac, mCache.mTac); |
| getIteminReport(report.mMccMnc, mCache.mMccMnc); |
| getIteminReport(report.mBtDeviceScanDetail, mCache.mBtDeviceScanDetail); |
| getIteminReport(report.mBtLeDeviceScanDetail, mCache.mBtLeDeviceScanDetail); |
| } |
| else { |
| // copy entire reports and return them |
| report.mLocation.clear(); |
| |
| report.mTimeAndClock.clear(); |
| report.mXoState.clear(); |
| report.mRfAndParams.clear(); |
| report.mErrRecovery.clear(); |
| |
| report.mInjectedPosition.clear(); |
| report.mBestPosition.clear(); |
| report.mXtra.clear(); |
| report.mEphemeris.clear(); |
| report.mSvHealth.clear(); |
| report.mPdr.clear(); |
| report.mNavData.clear(); |
| |
| report.mPositionFailure.clear(); |
| |
| report.mAirplaneMode.clear(); |
| report.mENH.clear(); |
| report.mGPSState.clear(); |
| report.mNLPStatus.clear(); |
| report.mWifiHardwareState.clear(); |
| report.mNetworkInfo.clear(); |
| report.mRilServiceInfo.clear(); |
| report.mRilCellInfo.clear(); |
| report.mServiceStatus.clear(); |
| report.mModel.clear(); |
| report.mManufacturer.clear(); |
| report.mAssistedGps.clear(); |
| report.mScreenState.clear(); |
| report.mPowerConnectState.clear(); |
| report.mTimeZoneChange.clear(); |
| report.mTimeChange.clear(); |
| report.mWifiSupplicantStatus.clear(); |
| report.mShutdownState.clear(); |
| report.mTac.clear(); |
| report.mMccMnc.clear(); |
| report.mBtDeviceScanDetail.clear(); |
| report.mBtLeDeviceScanDetail.clear(); |
| |
| report = mCache; |
| } |
| |
| pthread_mutex_unlock(&mMutexSystemStatus); |
| return true; |
| } |
| |
| /****************************************************************************** |
| @brief API to set default report data |
| |
| @param[In] none |
| |
| @return true when successfully done |
| ******************************************************************************/ |
| bool SystemStatus::setDefaultGnssEngineStates(void) |
| { |
| pthread_mutex_lock(&mMutexSystemStatus); |
| |
| setDefaultIteminReport(mCache.mLocation, SystemStatusLocation()); |
| |
| setDefaultIteminReport(mCache.mTimeAndClock, SystemStatusTimeAndClock()); |
| setDefaultIteminReport(mCache.mXoState, SystemStatusXoState()); |
| setDefaultIteminReport(mCache.mRfAndParams, SystemStatusRfAndParams()); |
| setDefaultIteminReport(mCache.mErrRecovery, SystemStatusErrRecovery()); |
| |
| setDefaultIteminReport(mCache.mInjectedPosition, SystemStatusInjectedPosition()); |
| setDefaultIteminReport(mCache.mBestPosition, SystemStatusBestPosition()); |
| setDefaultIteminReport(mCache.mXtra, SystemStatusXtra()); |
| setDefaultIteminReport(mCache.mEphemeris, SystemStatusEphemeris()); |
| setDefaultIteminReport(mCache.mSvHealth, SystemStatusSvHealth()); |
| setDefaultIteminReport(mCache.mPdr, SystemStatusPdr()); |
| setDefaultIteminReport(mCache.mNavData, SystemStatusNavData()); |
| |
| setDefaultIteminReport(mCache.mPositionFailure, SystemStatusPositionFailure()); |
| |
| pthread_mutex_unlock(&mMutexSystemStatus); |
| return true; |
| } |
| |
| /****************************************************************************** |
| @brief API to handle connection status update event from GnssRil |
| |
| @param[In] Connection status |
| |
| @return true when successfully done |
| ******************************************************************************/ |
| bool SystemStatus::eventConnectionStatus(bool connected, int8_t type, |
| bool roaming, NetworkHandle networkHandle, |
| string& apn) |
| { |
| // send networkinof dataitem to systemstatus observer clients |
| SystemStatusNetworkInfo s(type, "", "", connected, roaming, |
| (uint64_t) networkHandle, apn); |
| mSysStatusObsvr.notify({&s}); |
| |
| return true; |
| } |
| |
| /****************************************************************************** |
| @brief API to update power connect state |
| |
| @param[In] power connect status |
| |
| @return true when successfully done |
| ******************************************************************************/ |
| bool SystemStatus::updatePowerConnectState(bool charging) |
| { |
| SystemStatusPowerConnectState s(charging); |
| mSysStatusObsvr.notify({&s}); |
| return true; |
| } |
| } // namespace loc_core |
| |