This class provides an API to communicate with a u-blox GNSS chip. The files here were originally part of the C027_Support library (https://developer.mbed.org/teams/ublox/code/C027_Support/ at revision 138:dafbbf31bf76) but have been separated out, primarily for use on the u-blox C030 board where the cellular interace portion of the C027_Support library will instead be provided through the new mbed Cellular API.

Dependents:   example-ublox-at-cellular-interface-ext example-low-power-sleep example-C030-out-of-box-demo example-C030-out-of-box-demo ... more

Committer:
fahim.alavi@u-blox.com
Date:
Wed Apr 03 16:32:30 2019 +0500
Revision:
31:9a1ce433f062
Parent:
30:de9fcdbc4d06
Child:
33:75163fa7e453
NAVX5 support added

Who changed what in which revision?

UserRevisionLine numberNew contents of line
rob.meades@u-blox.com 1:ef70a58a6c98 1 /* mbed Microcontroller Library
rob.meades@u-blox.com 1:ef70a58a6c98 2 * Copyright (c) 2017 u-blox
rob.meades@u-blox.com 1:ef70a58a6c98 3 *
rob.meades@u-blox.com 1:ef70a58a6c98 4 * Licensed under the Apache License, Version 2.0 (the "License");
rob.meades@u-blox.com 1:ef70a58a6c98 5 * you may not use this file except in compliance with the License.
rob.meades@u-blox.com 1:ef70a58a6c98 6 * You may obtain a copy of the License at
rob.meades@u-blox.com 1:ef70a58a6c98 7 *
rob.meades@u-blox.com 1:ef70a58a6c98 8 * http://www.apache.org/licenses/LICENSE-2.0
rob.meades@u-blox.com 1:ef70a58a6c98 9 *
rob.meades@u-blox.com 1:ef70a58a6c98 10 * Unless required by applicable law or agreed to in writing, software
rob.meades@u-blox.com 1:ef70a58a6c98 11 * distributed under the License is distributed on an "AS IS" BASIS,
rob.meades@u-blox.com 1:ef70a58a6c98 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
rob.meades@u-blox.com 1:ef70a58a6c98 13 * See the License for the specific language governing permissions and
rob.meades@u-blox.com 1:ef70a58a6c98 14 * limitations under the License.
rob.meades@u-blox.com 1:ef70a58a6c98 15 */
rob.meades@u-blox.com 1:ef70a58a6c98 16
rob.meades@u-blox.com 1:ef70a58a6c98 17 #ifndef GNSS_H
rob.meades@u-blox.com 1:ef70a58a6c98 18 #define GNSS_H
rob.meades@u-blox.com 1:ef70a58a6c98 19
rob.meades@u-blox.com 1:ef70a58a6c98 20 /**
rob.meades@u-blox.com 1:ef70a58a6c98 21 * @file gnss.h
rob.meades@u-blox.com 1:ef70a58a6c98 22 * This file defines a class that communicates with a u-blox GNSS chip.
rob.meades@u-blox.com 1:ef70a58a6c98 23 */
rob.meades@u-blox.com 1:ef70a58a6c98 24
rob.meades@u-blox.com 1:ef70a58a6c98 25 #include "mbed.h"
rob.meades@u-blox.com 1:ef70a58a6c98 26 #include "pipe.h"
rob.meades@u-blox.com 1:ef70a58a6c98 27 #include "serial_pipe.h"
rob.meades@u-blox.com 1:ef70a58a6c98 28
rob.meades@u-blox.com 4:82308d600690 29 #if defined (TARGET_UBLOX_C030) || defined (TARGET_UBLOX_C027)
RobMeades 2:b10ca4aa2e5e 30 # define GNSS_IF(onboard, shield) onboard
rob.meades@u-blox.com 1:ef70a58a6c98 31 #else
RobMeades 2:b10ca4aa2e5e 32 # define GNSS_IF(onboard, shield) shield
rob.meades@u-blox.com 1:ef70a58a6c98 33 #endif
rob.meades@u-blox.com 1:ef70a58a6c98 34
RobMeades 5:af4baf3c67f3 35 #ifdef TARGET_UBLOX_C027
rob.meades@u-blox.com 6:56eda66d585b 36 # define GNSSEN GPSEN
rob.meades@u-blox.com 6:56eda66d585b 37 # define GNSSTXD GPSTXD
rob.meades@u-blox.com 6:56eda66d585b 38 # define GNSSRXD GPSRXD
rob.meades@u-blox.com 6:56eda66d585b 39 # define GNSSBAUD GPSBAUD
RobMeades 5:af4baf3c67f3 40 #endif
RobMeades 5:af4baf3c67f3 41
fahim.alavi@u-blox.com 8:720841961804 42 #define UBX_FRAME_SIZE 8
fahim.alavi@u-blox.com 8:720841961804 43 #define RETRY 5
fahim.alavi@u-blox.com 8:720841961804 44 #define SYNC_CHAR_INDEX_1 0
fahim.alavi@u-blox.com 8:720841961804 45 #define SYNC_CHAR_INDEX_2 1
fahim.alavi@u-blox.com 8:720841961804 46 #define MSG_CLASS_INDEX 2
fahim.alavi@u-blox.com 8:720841961804 47 #define MSG_ID_INDEX 3
fahim.alavi@u-blox.com 8:720841961804 48 #define UBX_LENGTH_INDEX 4
fahim.alavi@u-blox.com 8:720841961804 49 #define UBX_PAYLOAD_INDEX 6
fahim.alavi@u-blox.com 8:720841961804 50
fahim.alavi@u-blox.com 8:720841961804 51 enum eUBX_MSG_CLASS {NAV = 0x01, ACK = 0x05, LOG = 0x21};
fahim.alavi@u-blox.com 8:720841961804 52
fahim.alavi@u-blox.com 29:54fd002f2376 53 enum eUBX_MESSAGE {UBX_LOG_BATCH, UBX_ACK_ACK, UBX_ACK_NAK, UBX_NAV_ODO, UBX_NAV_PVT, UBX_NAV_STATUS, UBX_NAV_SAT, UNKNOWN_UBX};
fahim.alavi@u-blox.com 8:720841961804 54
fahim.alavi@u-blox.com 9:cff83b9f5093 55 typedef struct UBX_ACK_ACK {
fahim.alavi@u-blox.com 8:720841961804 56 uint8_t msg_class;
fahim.alavi@u-blox.com 8:720841961804 57 uint8_t msg_id;
fahim.alavi@u-blox.com 8:720841961804 58
fahim.alavi@u-blox.com 9:cff83b9f5093 59 }tUBX_ACK_ACK;
fahim.alavi@u-blox.com 8:720841961804 60
fahim.alavi@u-blox.com 8:720841961804 61 typedef struct UBX_NAV_ODO {
fahim.alavi@u-blox.com 8:720841961804 62 uint8_t version;
fahim.alavi@u-blox.com 8:720841961804 63 uint8_t reserved[3];
fahim.alavi@u-blox.com 8:720841961804 64 uint32_t itow;
fahim.alavi@u-blox.com 8:720841961804 65 uint32_t distance;
fahim.alavi@u-blox.com 8:720841961804 66 uint32_t totalDistance;
fahim.alavi@u-blox.com 8:720841961804 67 uint32_t distanceSTD;
fahim.alavi@u-blox.com 8:720841961804 68 }tUBX_NAV_ODO;
fahim.alavi@u-blox.com 8:720841961804 69
fahim.alavi@u-blox.com 8:720841961804 70 typedef struct UBX_NAV_PVT {
fahim.alavi@u-blox.com 8:720841961804 71 uint32_t itow;
fahim.alavi@u-blox.com 8:720841961804 72 uint16_t year;
fahim.alavi@u-blox.com 8:720841961804 73 uint8_t month;
fahim.alavi@u-blox.com 8:720841961804 74 uint8_t day;
fahim.alavi@u-blox.com 17:6c226e3e9d61 75 uint8_t fixType;
fahim.alavi@u-blox.com 30:de9fcdbc4d06 76 uint8_t flag1; // gnssFixOK, diffSoln, psmState, headVehValid and carrSoln.
fahim.alavi@u-blox.com 8:720841961804 77 int32_t lon; // scaling 1e-7
fahim.alavi@u-blox.com 8:720841961804 78 int32_t lat; // scaling 1e-7
fahim.alavi@u-blox.com 8:720841961804 79 int32_t height;
fahim.alavi@u-blox.com 17:6c226e3e9d61 80 int32_t speed;
fahim.alavi@u-blox.com 8:720841961804 81
fahim.alavi@u-blox.com 8:720841961804 82 }tUBX_NAV_PVT;
fahim.alavi@u-blox.com 8:720841961804 83
fahim.alavi@u-blox.com 8:720841961804 84 typedef struct UBX_LOG_BATCH {
fahim.alavi@u-blox.com 8:720841961804 85 uint32_t itow;
fahim.alavi@u-blox.com 8:720841961804 86 int32_t lon; // scaling 1e-7
fahim.alavi@u-blox.com 8:720841961804 87 int32_t lat; // scaling 1e-7
fahim.alavi@u-blox.com 8:720841961804 88 int32_t height;
fahim.alavi@u-blox.com 8:720841961804 89 uint32_t distance;
fahim.alavi@u-blox.com 8:720841961804 90 uint32_t totalDistance;
fahim.alavi@u-blox.com 8:720841961804 91 uint32_t distanceSTD;
fahim.alavi@u-blox.com 8:720841961804 92
fahim.alavi@u-blox.com 8:720841961804 93 }tUBX_LOG_BATCH;
fahim.alavi@u-blox.com 8:720841961804 94
Bilal Qamar 11:514ea8bf1dc8 95 typedef struct UBX_CFG_BATCH {
Bilal Qamar 11:514ea8bf1dc8 96 uint32_t version;
Bilal Qamar 11:514ea8bf1dc8 97 uint8_t flags;
Bilal Qamar 11:514ea8bf1dc8 98 uint32_t bufSize;
Bilal Qamar 11:514ea8bf1dc8 99 uint32_t notifThrs;
Bilal Qamar 12:a04f7eeece23 100 uint8_t pioId;
Bilal Qamar 12:a04f7eeece23 101 uint8_t reserved1;
Bilal Qamar 11:514ea8bf1dc8 102
Bilal Qamar 11:514ea8bf1dc8 103 }tUBX_CFG_BATCH;
Bilal Qamar 11:514ea8bf1dc8 104
fahim.alavi@u-blox.com 21:f91c0334d017 105 typedef struct UBX_NAV_STATUS{
fahim.alavi@u-blox.com 21:f91c0334d017 106 uint32_t itow;
fahim.alavi@u-blox.com 21:f91c0334d017 107 uint8_t fix;
fahim.alavi@u-blox.com 21:f91c0334d017 108 uint8_t flags;
fahim.alavi@u-blox.com 21:f91c0334d017 109 uint32_t ttff;
fahim.alavi@u-blox.com 21:f91c0334d017 110 uint32_t msss;
fahim.alavi@u-blox.com 21:f91c0334d017 111
fahim.alavi@u-blox.com 21:f91c0334d017 112 }tUBX_NAV_STATUS;
fahim.alavi@u-blox.com 21:f91c0334d017 113
fahim.alavi@u-blox.com 29:54fd002f2376 114 typedef struct UBX_NAV_SAT{
fahim.alavi@u-blox.com 29:54fd002f2376 115 bool status;
fahim.alavi@u-blox.com 29:54fd002f2376 116
fahim.alavi@u-blox.com 29:54fd002f2376 117 }tUBX_NAV_SAT;
fahim.alavi@u-blox.com 29:54fd002f2376 118
rob.meades@u-blox.com 4:82308d600690 119 /** Basic GNSS parser class.
rob.meades@u-blox.com 1:ef70a58a6c98 120 */
rob.meades@u-blox.com 1:ef70a58a6c98 121 class GnssParser
rob.meades@u-blox.com 1:ef70a58a6c98 122 {
rob.meades@u-blox.com 1:ef70a58a6c98 123 public:
rob.meades@u-blox.com 4:82308d600690 124 /** Constructor.
rob.meades@u-blox.com 4:82308d600690 125 */
rob.meades@u-blox.com 1:ef70a58a6c98 126 GnssParser();
rob.meades@u-blox.com 4:82308d600690 127 /** Destructor.
rob.meades@u-blox.com 4:82308d600690 128 */
rob.meades@u-blox.com 1:ef70a58a6c98 129 virtual ~GnssParser(void);
rob.meades@u-blox.com 1:ef70a58a6c98 130
rob.meades@u-blox.com 4:82308d600690 131 /** Power-on/wake-up the GNSS.
rob.meades@u-blox.com 1:ef70a58a6c98 132 */
rob.meades@u-blox.com 1:ef70a58a6c98 133 virtual bool init(PinName pn) = 0;
rob.meades@u-blox.com 1:ef70a58a6c98 134
rob.meades@u-blox.com 1:ef70a58a6c98 135 enum {
rob.meades@u-blox.com 1:ef70a58a6c98 136 // getLine Responses
rob.meades@u-blox.com 1:ef70a58a6c98 137 WAIT = -1, //!< wait for more incoming data (the start of a message was found, or no data available)
rob.meades@u-blox.com 1:ef70a58a6c98 138 NOT_FOUND = 0, //!< a parser concluded the the current offset of the pipe doe not contain a valid message
rob.meades@u-blox.com 1:ef70a58a6c98 139
rob.meades@u-blox.com 1:ef70a58a6c98 140 #define LENGTH(x) (x & 0x00FFFF) //!< extract/mask the length
rob.meades@u-blox.com 1:ef70a58a6c98 141 #define PROTOCOL(x) (x & 0xFF0000) //!< extract/mask the type
rob.meades@u-blox.com 1:ef70a58a6c98 142
rob.meades@u-blox.com 1:ef70a58a6c98 143 UNKNOWN = 0x000000, //!< message type is unknown
rob.meades@u-blox.com 1:ef70a58a6c98 144 UBX = 0x100000, //!< message if of protocol NMEA
rob.meades@u-blox.com 1:ef70a58a6c98 145 NMEA = 0x200000 //!< message if of protocol UBX
rob.meades@u-blox.com 1:ef70a58a6c98 146 };
rob.meades@u-blox.com 1:ef70a58a6c98 147
rob.meades@u-blox.com 1:ef70a58a6c98 148 /** Get a line from the physical interface. This function
rob.meades@u-blox.com 4:82308d600690 149 * needs to be implemented in the inherited class.
rob.meades@u-blox.com 4:82308d600690 150 * @param buf the buffer to store it.
rob.meades@u-blox.com 4:82308d600690 151 * @param len size of the buffer.
rob.meades@u-blox.com 4:82308d600690 152 * @return type and length if something was found,
rob.meades@u-blox.com 4:82308d600690 153 * WAIT if not enough data is available,
rob.meades@u-blox.com 4:82308d600690 154 * NOT_FOUND if nothing was found
rob.meades@u-blox.com 4:82308d600690 155 */
rob.meades@u-blox.com 1:ef70a58a6c98 156 virtual int getMessage(char* buf, int len) = 0;
rob.meades@u-blox.com 1:ef70a58a6c98 157
rob.meades@u-blox.com 4:82308d600690 158 /** Send a buffer.
rob.meades@u-blox.com 4:82308d600690 159 * @param buf the buffer to write.
rob.meades@u-blox.com 4:82308d600690 160 * @param len size of the buffer to write.
rob.meades@u-blox.com 4:82308d600690 161 * @return bytes written.
rob.meades@u-blox.com 4:82308d600690 162 */
rob.meades@u-blox.com 1:ef70a58a6c98 163 virtual int send(const char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 164
rob.meades@u-blox.com 1:ef70a58a6c98 165 /** send a NMEA message, this function just takes the
rob.meades@u-blox.com 4:82308d600690 166 * payload and calculates and adds checksum. ($ and *XX\r\n will be added).
rob.meades@u-blox.com 4:82308d600690 167 * @param buf the message payload to write.
rob.meades@u-blox.com 4:82308d600690 168 * @param len size of the message payload to write.
rob.meades@u-blox.com 4:82308d600690 169 * @return total bytes written.
rob.meades@u-blox.com 4:82308d600690 170 */
rob.meades@u-blox.com 1:ef70a58a6c98 171 virtual int sendNmea(const char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 172
rob.meades@u-blox.com 4:82308d600690 173 /** Send a UBX message, this function just takes the
rob.meades@u-blox.com 4:82308d600690 174 * payload and calculates and adds checksum.
rob.meades@u-blox.com 4:82308d600690 175 * @param cls the UBX class id.
rob.meades@u-blox.com 4:82308d600690 176 * @param id the UBX message id.
rob.meades@u-blox.com 4:82308d600690 177 * @param buf the message payload to write.
rob.meades@u-blox.com 4:82308d600690 178 * @param len size of the message payload to write.
rob.meades@u-blox.com 4:82308d600690 179 * @return total bytes written.
rob.meades@u-blox.com 4:82308d600690 180 */
rob.meades@u-blox.com 1:ef70a58a6c98 181 virtual int sendUbx(unsigned char cls, unsigned char id,
rob.meades@u-blox.com 1:ef70a58a6c98 182 const void* buf = NULL, int len = 0);
rob.meades@u-blox.com 1:ef70a58a6c98 183
rob.meades@u-blox.com 1:ef70a58a6c98 184 /** Power off the GNSS, it can be again woken up by an
rob.meades@u-blox.com 4:82308d600690 185 * edge on the serial port on the external interrupt pin.
rob.meades@u-blox.com 1:ef70a58a6c98 186 */
rob.meades@u-blox.com 1:ef70a58a6c98 187 void powerOff(void);
bqam 13:10108cd3ad23 188
bqam 13:10108cd3ad23 189 /** Cuts off the power supply of GNSS by disabling gnssEnable pin
bqam 13:10108cd3ad23 190 * Backup supply is provided, can turn it on again by enabling PA15
bqam 13:10108cd3ad23 191 */
bqam 13:10108cd3ad23 192 void cutOffPower(void);
rob.meades@u-blox.com 1:ef70a58a6c98 193
rob.meades@u-blox.com 4:82308d600690 194 /** get the first character of a NMEA field.
rob.meades@u-blox.com 4:82308d600690 195 * @param ix the index of the field to find.
rob.meades@u-blox.com 4:82308d600690 196 * @param start the start of the buffer.
rob.meades@u-blox.com 4:82308d600690 197 * @param end the end of the buffer.
rob.meades@u-blox.com 4:82308d600690 198 * @return the pointer to the first character of the field.
rob.meades@u-blox.com 4:82308d600690 199 */
rob.meades@u-blox.com 1:ef70a58a6c98 200 static const char* findNmeaItemPos(int ix, const char* start, const char* end);
rob.meades@u-blox.com 1:ef70a58a6c98 201
rob.meades@u-blox.com 4:82308d600690 202 /** Extract a double value from a buffer containing a NMEA message.
rob.meades@u-blox.com 4:82308d600690 203 * @param ix the index of the field to extract.
rob.meades@u-blox.com 4:82308d600690 204 * @param buf the NMEA message.
rob.meades@u-blox.com 4:82308d600690 205 * @param len the size of the NMEA message.
rob.meades@u-blox.com 4:82308d600690 206 * @param val the extracted value.
rob.meades@u-blox.com 4:82308d600690 207 * @return true if successful, false otherwise.
rob.meades@u-blox.com 4:82308d600690 208 */
rob.meades@u-blox.com 1:ef70a58a6c98 209 static bool getNmeaItem(int ix, char* buf, int len, double& val);
rob.meades@u-blox.com 1:ef70a58a6c98 210
rob.meades@u-blox.com 4:82308d600690 211 /** Extract a interger value from a buffer containing a NMEA message.
rob.meades@u-blox.com 4:82308d600690 212 * @param ix the index of the field to extract.
rob.meades@u-blox.com 4:82308d600690 213 * @param buf the NMEA message.
rob.meades@u-blox.com 4:82308d600690 214 * @param len the size of the NMEA message.
rob.meades@u-blox.com 4:82308d600690 215 * @param val the extracted value.
rob.meades@u-blox.com 4:82308d600690 216 * @param base the numeric base to be used (e.g. 8, 10 or 16).
rob.meades@u-blox.com 4:82308d600690 217 * @return true if successful, false otherwise.
rob.meades@u-blox.com 4:82308d600690 218 */
rob.meades@u-blox.com 1:ef70a58a6c98 219 static bool getNmeaItem(int ix, char* buf, int len, int& val, int base/*=10*/);
rob.meades@u-blox.com 1:ef70a58a6c98 220
rob.meades@u-blox.com 4:82308d600690 221 /** Extract a char value from a buffer containing a NMEA message.
rob.meades@u-blox.com 4:82308d600690 222 * @param ix the index of the field to extract.
rob.meades@u-blox.com 4:82308d600690 223 * @param buf the NMEA message.
rob.meades@u-blox.com 4:82308d600690 224 * @param len the size of the NMEA message.
rob.meades@u-blox.com 4:82308d600690 225 * @param val the extracted value.
rob.meades@u-blox.com 4:82308d600690 226 * @return true if successful, false otherwise.
rob.meades@u-blox.com 4:82308d600690 227 */
rob.meades@u-blox.com 1:ef70a58a6c98 228 static bool getNmeaItem(int ix, char* buf, int len, char& val);
rob.meades@u-blox.com 1:ef70a58a6c98 229
rob.meades@u-blox.com 4:82308d600690 230 /** Extract a latitude/longitude value from a buffer containing a NMEA message.
rob.meades@u-blox.com 4:82308d600690 231 * @param ix the index of the field to extract (will extract ix and ix + 1),
rob.meades@u-blox.com 4:82308d600690 232 * @param buf the NMEA message,
rob.meades@u-blox.com 4:82308d600690 233 * @param len the size of the NMEA message,
rob.meades@u-blox.com 4:82308d600690 234 * @param val the extracted latitude or longitude,
rob.meades@u-blox.com 4:82308d600690 235 * @return true if successful, false otherwise.
rob.meades@u-blox.com 4:82308d600690 236 */
rob.meades@u-blox.com 1:ef70a58a6c98 237 static bool getNmeaAngle(int ix, char* buf, int len, double& val);
fahim.alavi@u-blox.com 8:720841961804 238
fahim.alavi@u-blox.com 8:720841961804 239 /** Enable UBX messages.
fahim.alavi@u-blox.com 8:720841961804 240 * @param none
Bilal Qamar 12:a04f7eeece23 241 * @return 1 if successful, false otherwise.
fahim.alavi@u-blox.com 8:720841961804 242 */
fahim.alavi@u-blox.com 8:720841961804 243 int enable_ubx();
rob.meades@u-blox.com 1:ef70a58a6c98 244
fahim.alavi@u-blox.com 8:720841961804 245 /** GET Message type of receiver UBX message
fahim.alavi@u-blox.com 8:720841961804 246 * @param buff the UXB message
fahim.alavi@u-blox.com 8:720841961804 247 * @return eUBX_MESSAGE
fahim.alavi@u-blox.com 8:720841961804 248 */
fahim.alavi@u-blox.com 8:720841961804 249 eUBX_MESSAGE get_ubx_message(char *);
fahim.alavi@u-blox.com 8:720841961804 250
fahim.alavi@u-blox.com 9:cff83b9f5093 251 /** Method to parse contents of UBX ACK-ACK/NAK and return messageid amd class for which ACK is received
fahim.alavi@u-blox.com 8:720841961804 252 * @param buff the UXB message
fahim.alavi@u-blox.com 9:cff83b9f5093 253 * @return tUBX_ACK_ACK
fahim.alavi@u-blox.com 8:720841961804 254 */
fahim.alavi@u-blox.com 9:cff83b9f5093 255 tUBX_ACK_ACK decode_ubx_cfg_ack_nak_msg(char *);
fahim.alavi@u-blox.com 8:720841961804 256
fahim.alavi@u-blox.com 8:720841961804 257 /** Method to parse contents of UBX_NAV_ODO and return decoded msg
fahim.alavi@u-blox.com 8:720841961804 258 * @param buff the UXB message
fahim.alavi@u-blox.com 8:720841961804 259 * @return tUBX_NAV_ODO
fahim.alavi@u-blox.com 8:720841961804 260 */
fahim.alavi@u-blox.com 8:720841961804 261 tUBX_NAV_ODO decode_ubx_nav_odo_msg(char *);
fahim.alavi@u-blox.com 8:720841961804 262
fahim.alavi@u-blox.com 8:720841961804 263 /** Method to parse contents of UBX_NAV_PVT and return decoded msg
fahim.alavi@u-blox.com 8:720841961804 264 * @param buff the UXB message
fahim.alavi@u-blox.com 8:720841961804 265 * @return tUBX_NAV_PVT
fahim.alavi@u-blox.com 8:720841961804 266 */
fahim.alavi@u-blox.com 8:720841961804 267 tUBX_NAV_PVT decode_ubx_nav_pvt_msg(char *);
fahim.alavi@u-blox.com 8:720841961804 268
fahim.alavi@u-blox.com 8:720841961804 269 /** Method to parse contents of UBX_LOG_BATCH and return decoded msg
fahim.alavi@u-blox.com 8:720841961804 270 * @param buff the UXB message
fahim.alavi@u-blox.com 8:720841961804 271 * @return tUBX_LOG_BATCH
fahim.alavi@u-blox.com 8:720841961804 272 */
fahim.alavi@u-blox.com 8:720841961804 273 tUBX_LOG_BATCH decode_ubx_log_batch_msg(char *);
fahim.alavi@u-blox.com 8:720841961804 274
fahim.alavi@u-blox.com 21:f91c0334d017 275 /** Method to parse contents of UBX_NAV_STATUS and return decoded msg
fahim.alavi@u-blox.com 21:f91c0334d017 276 * @param buff the UXB message
fahim.alavi@u-blox.com 21:f91c0334d017 277 * @return tUBX_NAV_STATUS
fahim.alavi@u-blox.com 21:f91c0334d017 278 */
fahim.alavi@u-blox.com 21:f91c0334d017 279 tUBX_NAV_STATUS decode_ubx_nav_status_msg(char *);
fahim.alavi@u-blox.com 21:f91c0334d017 280
fahim.alavi@u-blox.com 29:54fd002f2376 281 /** Method to parse contents of UBX_NAV_SAT and return decoded msg
fahim.alavi@u-blox.com 29:54fd002f2376 282 * @param buff the UXB message, int length
fahim.alavi@u-blox.com 29:54fd002f2376 283 * @return tUBX_NAV_SAT
fahim.alavi@u-blox.com 29:54fd002f2376 284 */
fahim.alavi@u-blox.com 29:54fd002f2376 285 tUBX_NAV_SAT decode_ubx_nav_sat_msg(char *, int);
fahim.alavi@u-blox.com 29:54fd002f2376 286
fahim.alavi@u-blox.com 10:bfa9081e1d14 287 /** Method to send UBX LOG-RETRIEVEBATCH msg. This message is used to request batched data.
fahim.alavi@u-blox.com 10:bfa9081e1d14 288 * @param bool
fahim.alavi@u-blox.com 10:bfa9081e1d14 289 * @return int
fahim.alavi@u-blox.com 10:bfa9081e1d14 290 */
fahim.alavi@u-blox.com 10:bfa9081e1d14 291 int ubx_request_batched_data(bool sendMonFirst = false);
fahim.alavi@u-blox.com 10:bfa9081e1d14 292
rob.meades@u-blox.com 1:ef70a58a6c98 293 protected:
rob.meades@u-blox.com 1:ef70a58a6c98 294 /** Power on the GNSS module.
rob.meades@u-blox.com 1:ef70a58a6c98 295 */
rob.meades@u-blox.com 1:ef70a58a6c98 296 void _powerOn(void);
rob.meades@u-blox.com 1:ef70a58a6c98 297
rob.meades@u-blox.com 4:82308d600690 298 /** Get a line from the physical interface.
rob.meades@u-blox.com 4:82308d600690 299 * @param pipe the receiveing pipe to parse messages .
rob.meades@u-blox.com 4:82308d600690 300 * @param buf the buffer to store it.
rob.meades@u-blox.com 4:82308d600690 301 * @param len size of the buffer.
rob.meades@u-blox.com 4:82308d600690 302 * @return type and length if something was found,
rob.meades@u-blox.com 4:82308d600690 303 * WAIT if not enough data is available,
rob.meades@u-blox.com 4:82308d600690 304 * NOT_FOUND if nothing was found.
rob.meades@u-blox.com 4:82308d600690 305 */
rob.meades@u-blox.com 1:ef70a58a6c98 306 static int _getMessage(Pipe<char>* pipe, char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 307
rob.meades@u-blox.com 1:ef70a58a6c98 308 /** Check if the current offset of the pipe contains a NMEA message.
rob.meades@u-blox.com 4:82308d600690 309 * @param pipe the receiveing pipe to parse messages.
rob.meades@u-blox.com 4:82308d600690 310 * @param len numer of bytes to parse at maximum.
rob.meades@u-blox.com 4:82308d600690 311 * @return length if something was found (including the NMEA frame),
rob.meades@u-blox.com 4:82308d600690 312 * WAIT if not enough data is available,
rob.meades@u-blox.com 4:82308d600690 313 * NOT_FOUND if nothing was found.
rob.meades@u-blox.com 4:82308d600690 314 */
rob.meades@u-blox.com 1:ef70a58a6c98 315 static int _parseNmea(Pipe<char>* pipe, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 316
rob.meades@u-blox.com 1:ef70a58a6c98 317 /** Check if the current offset of the pipe contains a UBX message.
rob.meades@u-blox.com 4:82308d600690 318 * @param pipe the receiveing pipe to parse messages.
rob.meades@u-blox.com 4:82308d600690 319 * @param len numer of bytes to parse at maximum.
rob.meades@u-blox.com 4:82308d600690 320 * @return length if something was found (including the UBX frame),
rob.meades@u-blox.com 4:82308d600690 321 * WAIT if not enough data is available,
rob.meades@u-blox.com 4:82308d600690 322 * NOT_FOUND if nothing was found.
rob.meades@u-blox.com 4:82308d600690 323 */
rob.meades@u-blox.com 1:ef70a58a6c98 324 static int _parseUbx(Pipe<char>* pipe, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 325
rob.meades@u-blox.com 1:ef70a58a6c98 326 /** Write bytes to the physical interface. This function
rob.meades@u-blox.com 4:82308d600690 327 * needs to be implemented by the inherited class.
rob.meades@u-blox.com 4:82308d600690 328 * @param buf the buffer to write.
rob.meades@u-blox.com 4:82308d600690 329 * @param len size of the buffer to write.
rob.meades@u-blox.com 4:82308d600690 330 * @return bytes written.
rob.meades@u-blox.com 4:82308d600690 331 */
rob.meades@u-blox.com 1:ef70a58a6c98 332 virtual int _send(const void* buf, int len) = 0;
rob.meades@u-blox.com 1:ef70a58a6c98 333
rob.meades@u-blox.com 1:ef70a58a6c98 334 static const char _toHex[16]; //!< num to hex conversion
rob.meades@u-blox.com 4:82308d600690 335 DigitalInOut *_gnssEnable; //!< IO pin that enables GNSS
rob.meades@u-blox.com 1:ef70a58a6c98 336 };
rob.meades@u-blox.com 1:ef70a58a6c98 337
rob.meades@u-blox.com 4:82308d600690 338 /** GNSS class which uses a serial port as physical interface.
rob.meades@u-blox.com 4:82308d600690 339 */
rob.meades@u-blox.com 1:ef70a58a6c98 340 class GnssSerial : public SerialPipe, public GnssParser
rob.meades@u-blox.com 1:ef70a58a6c98 341 {
rob.meades@u-blox.com 1:ef70a58a6c98 342 public:
rob.meades@u-blox.com 4:82308d600690 343 /** Constructor.
rob.meades@u-blox.com 4:82308d600690 344 * @param tx is the serial ports transmit pin (GNSS to CPU).
rob.meades@u-blox.com 4:82308d600690 345 * @param rx is the serial ports receive pin (CPU to GNSS).
rob.meades@u-blox.com 4:82308d600690 346 * @param baudrate the baudrate of the GNSS use 9600.
rob.meades@u-blox.com 4:82308d600690 347 * @param rxSize the size of the serial rx buffer.
rob.meades@u-blox.com 4:82308d600690 348 * @param txSize the size of the serial tx buffer.
rob.meades@u-blox.com 4:82308d600690 349 */
RobMeades 2:b10ca4aa2e5e 350 GnssSerial(PinName tx GNSS_IF( = GNSSTXD, = D8 /* = D8 */), // resistor on shield not populated
RobMeades 2:b10ca4aa2e5e 351 PinName rx GNSS_IF( = GNSSRXD, = D9 /* = D9 */), // resistor on shield not populated
rob.meades@u-blox.com 1:ef70a58a6c98 352 int baudrate GNSS_IF( = GNSSBAUD, = 9600 ),
fahim.alavi@u-blox.com 28:8852ebda4e8f 353 int rxSize = 512 ,
fahim.alavi@u-blox.com 27:405a5e611635 354 int txSize = 512 );
rob.meades@u-blox.com 1:ef70a58a6c98 355
rob.meades@u-blox.com 4:82308d600690 356 /** Destructor.
rob.meades@u-blox.com 4:82308d600690 357 */
rob.meades@u-blox.com 1:ef70a58a6c98 358 virtual ~GnssSerial(void);
rob.meades@u-blox.com 1:ef70a58a6c98 359
rob.meades@u-blox.com 4:82308d600690 360 /** Initialise the GNSS device.
rob.meades@u-blox.com 4:82308d600690 361 * @param pn NOT USED.
fahim.alavi@u-blox.com 15:105cf3ca48c9 362 * @param baudrate
rob.meades@u-blox.com 4:82308d600690 363 * @return true if successful, otherwise false.
rob.meades@u-blox.com 4:82308d600690 364 */
rob.meades@u-blox.com 1:ef70a58a6c98 365 virtual bool init(PinName pn = NC);
rob.meades@u-blox.com 1:ef70a58a6c98 366
rob.meades@u-blox.com 1:ef70a58a6c98 367 /** Get a line from the physical interface.
rob.meades@u-blox.com 4:82308d600690 368 * @param buf the buffer to store it.
rob.meades@u-blox.com 4:82308d600690 369 * @param len size of the buffer.
rob.meades@u-blox.com 4:82308d600690 370 * @return type and length if something was found,
rob.meades@u-blox.com 4:82308d600690 371 * WAIT if not enough data is available,
rob.meades@u-blox.com 4:82308d600690 372 * NOT_FOUND if nothing was found.
rob.meades@u-blox.com 4:82308d600690 373 */
rob.meades@u-blox.com 1:ef70a58a6c98 374 virtual int getMessage(char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 375
rob.meades@u-blox.com 1:ef70a58a6c98 376 protected:
rob.meades@u-blox.com 1:ef70a58a6c98 377 /** Write bytes to the physical interface.
rob.meades@u-blox.com 4:82308d600690 378 * @param buf the buffer to write.
rob.meades@u-blox.com 4:82308d600690 379 * @param len size of the buffer to write.
rob.meades@u-blox.com 4:82308d600690 380 * @return bytes written.
rob.meades@u-blox.com 4:82308d600690 381 */
rob.meades@u-blox.com 1:ef70a58a6c98 382 virtual int _send(const void* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 383 };
rob.meades@u-blox.com 1:ef70a58a6c98 384
rob.meades@u-blox.com 1:ef70a58a6c98 385 /** GNSS class which uses a i2c as physical interface.
rob.meades@u-blox.com 1:ef70a58a6c98 386 */
rob.meades@u-blox.com 1:ef70a58a6c98 387 class GnssI2C : public I2C, public GnssParser
rob.meades@u-blox.com 1:ef70a58a6c98 388 {
rob.meades@u-blox.com 1:ef70a58a6c98 389 public:
rob.meades@u-blox.com 4:82308d600690 390 /** Constructor.
rob.meades@u-blox.com 4:82308d600690 391 * @param sda is the I2C SDA pin (between CPU and GNSS).
rob.meades@u-blox.com 4:82308d600690 392 * @param scl is the I2C SCL pin (CPU to GNSS).
rob.meades@u-blox.com 4:82308d600690 393 * @param adr the I2C address of the GNSS set to (66<<1).
rob.meades@u-blox.com 4:82308d600690 394 * @param rxSize the size of the serial rx buffer.
rob.meades@u-blox.com 4:82308d600690 395 */
RobMeades 2:b10ca4aa2e5e 396 GnssI2C(PinName sda GNSS_IF( = NC, = /* D16 TODO */ NC ),
RobMeades 2:b10ca4aa2e5e 397 PinName scl GNSS_IF( = NC, = /* D17 TODO */ NC ),
RobMeades 2:b10ca4aa2e5e 398 unsigned char i2cAdr GNSS_IF( = (66<<1), = (66<<1) ),
RobMeades 2:b10ca4aa2e5e 399 int rxSize = 256 );
rob.meades@u-blox.com 4:82308d600690 400 /** Destructor
rob.meades@u-blox.com 4:82308d600690 401 */
rob.meades@u-blox.com 1:ef70a58a6c98 402 virtual ~GnssI2C(void);
rob.meades@u-blox.com 1:ef70a58a6c98 403
rob.meades@u-blox.com 4:82308d600690 404 /** Helper function to probe the i2c device.
rob.meades@u-blox.com 4:82308d600690 405 * @param pn the power-on pin for the chip.
rob.meades@u-blox.com 4:82308d600690 406 * @return true if successfully detected the GNSS chip.
rob.meades@u-blox.com 4:82308d600690 407 */
rob.meades@u-blox.com 1:ef70a58a6c98 408 virtual bool init(PinName pn = GNSS_IF( NC, NC /* D7 resistor R67 on shield not mounted */));
rob.meades@u-blox.com 1:ef70a58a6c98 409
rob.meades@u-blox.com 1:ef70a58a6c98 410 /** Get a line from the physical interface.
rob.meades@u-blox.com 4:82308d600690 411 * @param buf the buffer to store it.
rob.meades@u-blox.com 4:82308d600690 412 * @param len size of the buffer.
rob.meades@u-blox.com 4:82308d600690 413 * @return type and length if something was found,
rob.meades@u-blox.com 4:82308d600690 414 * WAIT if not enough data is available,
rob.meades@u-blox.com 4:82308d600690 415 * NOT_FOUND if nothing was found.
rob.meades@u-blox.com 4:82308d600690 416 */
rob.meades@u-blox.com 1:ef70a58a6c98 417 virtual int getMessage(char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 418
rob.meades@u-blox.com 4:82308d600690 419 /** Send a buffer.
rob.meades@u-blox.com 4:82308d600690 420 * @param buf the buffer to write.
rob.meades@u-blox.com 4:82308d600690 421 * @param len size of the buffer to write.
rob.meades@u-blox.com 4:82308d600690 422 * @return bytes written.
rob.meades@u-blox.com 4:82308d600690 423 */
rob.meades@u-blox.com 1:ef70a58a6c98 424 virtual int send(const char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 425
rob.meades@u-blox.com 4:82308d600690 426 /** Send an NMEA message, this function just takes the
rob.meades@u-blox.com 4:82308d600690 427 * payload and calculates and adds checksum ($ and *XX\r\n will be added).
rob.meades@u-blox.com 4:82308d600690 428 * @param buf the message payload to write.
rob.meades@u-blox.com 4:82308d600690 429 * @param len size of the message payload to write.
rob.meades@u-blox.com 4:82308d600690 430 * @return total bytes written.
rob.meades@u-blox.com 4:82308d600690 431 */
rob.meades@u-blox.com 1:ef70a58a6c98 432 virtual int sendNmea(const char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 433
rob.meades@u-blox.com 4:82308d600690 434 /** Send a UBX message, this function just takes the
rob.meades@u-blox.com 4:82308d600690 435 * payload and calculates and adds checksum.
rob.meades@u-blox.com 4:82308d600690 436 * @param cls the UBX class id.
rob.meades@u-blox.com 4:82308d600690 437 * @param id the UBX message id.
rob.meades@u-blox.com 4:82308d600690 438 * @param buf the message payload to write.
rob.meades@u-blox.com 4:82308d600690 439 * @param len size of the message payload to write.
rob.meades@u-blox.com 4:82308d600690 440 * @return total bytes written.
rob.meades@u-blox.com 4:82308d600690 441 */
rob.meades@u-blox.com 1:ef70a58a6c98 442 virtual int sendUbx(unsigned char cls, unsigned char id,
rob.meades@u-blox.com 1:ef70a58a6c98 443 const void* buf = NULL, int len = 0);
rob.meades@u-blox.com 1:ef70a58a6c98 444
rob.meades@u-blox.com 1:ef70a58a6c98 445 protected:
rob.meades@u-blox.com 4:82308d600690 446 /** Check if the port is writeable (like SerialPipe)
rob.meades@u-blox.com 4:82308d600690 447 * @return true if writeable
rob.meades@u-blox.com 4:82308d600690 448 */
rob.meades@u-blox.com 4:82308d600690 449 bool writeable(void) {return true;}
rob.meades@u-blox.com 1:ef70a58a6c98 450
rob.meades@u-blox.com 4:82308d600690 451 /** Write a character (like SerialPipe).
rob.meades@u-blox.com 4:82308d600690 452 * @param c the character to write.
rob.meades@u-blox.com 4:82308d600690 453 * @return true if succesffully written .
rob.meades@u-blox.com 4:82308d600690 454 */
rob.meades@u-blox.com 4:82308d600690 455 bool putc(int c) {char ch = c; return send(&ch, 1);}
rob.meades@u-blox.com 1:ef70a58a6c98 456
rob.meades@u-blox.com 1:ef70a58a6c98 457 /** Write bytes to the physical interface.
rob.meades@u-blox.com 4:82308d600690 458 * @param buf the buffer to write.
rob.meades@u-blox.com 4:82308d600690 459 * @param len size of the buffer to write.
rob.meades@u-blox.com 4:82308d600690 460 * @return bytes written.
rob.meades@u-blox.com 4:82308d600690 461 */
rob.meades@u-blox.com 1:ef70a58a6c98 462 virtual int _send(const void* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 463
rob.meades@u-blox.com 4:82308d600690 464 /** Read bytes from the physical interface.
rob.meades@u-blox.com 4:82308d600690 465 * @param buf the buffer to read into.
rob.meades@u-blox.com 4:82308d600690 466 * @param len size of the read buffer .
rob.meades@u-blox.com 4:82308d600690 467 * @return bytes read.
rob.meades@u-blox.com 4:82308d600690 468 */
rob.meades@u-blox.com 1:ef70a58a6c98 469 int _get(char* buf, int len);
rob.meades@u-blox.com 1:ef70a58a6c98 470
rob.meades@u-blox.com 4:82308d600690 471 Pipe<char> _pipe; //!< the rx pipe.
rob.meades@u-blox.com 4:82308d600690 472 unsigned char _i2cAdr; //!< the i2c address.
rob.meades@u-blox.com 4:82308d600690 473 static const char REGLEN; //!< the length i2c register address.
rob.meades@u-blox.com 4:82308d600690 474 static const char REGSTREAM;//!< the stream i2c register address.
rob.meades@u-blox.com 1:ef70a58a6c98 475 };
rob.meades@u-blox.com 1:ef70a58a6c98 476
rob.meades@u-blox.com 1:ef70a58a6c98 477 #endif
rob.meades@u-blox.com 1:ef70a58a6c98 478
rob.meades@u-blox.com 1:ef70a58a6c98 479 // End Of File