2010-09-06 06:20:44 -03:00
|
|
|
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: t -*-
|
|
|
|
|
|
|
|
/// @file GPS.h
|
|
|
|
/// @brief Interface definition for the various GPS drivers.
|
|
|
|
|
2010-08-29 19:58:22 -03:00
|
|
|
#ifndef GPS_h
|
|
|
|
#define GPS_h
|
|
|
|
|
|
|
|
#include <inttypes.h>
|
2010-09-06 06:20:44 -03:00
|
|
|
#include <Stream.h>
|
2010-08-29 19:58:22 -03:00
|
|
|
|
2010-09-06 06:20:44 -03:00
|
|
|
/// @class GPS
|
|
|
|
/// @brief Abstract base class for GPS receiver drivers.
|
2010-08-29 19:58:22 -03:00
|
|
|
class GPS
|
|
|
|
{
|
2010-09-06 06:20:44 -03:00
|
|
|
public:
|
|
|
|
|
|
|
|
/// Constructor
|
|
|
|
///
|
|
|
|
/// @note The stream is expected to be set up and configured for the
|
|
|
|
/// correct bitrate before ::init is called.
|
|
|
|
///
|
2010-10-17 03:06:04 -03:00
|
|
|
/// @param s Stream connected to the GPS module. If NULL, assumed
|
|
|
|
/// to be set up at ::init time. Support for setting
|
|
|
|
/// the port in the ctor for backwards compatibility.
|
2010-09-06 06:20:44 -03:00
|
|
|
///
|
2010-10-17 03:06:04 -03:00
|
|
|
GPS(Stream *s = NULL) : _port(s) {};
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
/// Startup initialisation.
|
|
|
|
///
|
|
|
|
/// This routine performs any one-off initialisation required to set the
|
|
|
|
/// GPS up for use.
|
|
|
|
///
|
2010-10-17 17:13:53 -03:00
|
|
|
/// Must be implemented by the GPS driver.
|
|
|
|
///
|
2010-10-17 03:06:04 -03:00
|
|
|
/// @param s Stream connected to the GPS module. If NULL, assumed to
|
|
|
|
/// have been set up at constructor time.
|
|
|
|
///
|
|
|
|
virtual void init(void) = 0;
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
/// Update GPS state based on possible bytes received from the module.
|
|
|
|
///
|
|
|
|
/// This routine must be called periodically to process incoming data.
|
|
|
|
///
|
2010-10-17 17:13:53 -03:00
|
|
|
/// Must be implemented by the GPS driver.
|
|
|
|
///
|
2010-12-19 09:24:29 -04:00
|
|
|
void update(void);
|
|
|
|
|
|
|
|
/// Implement specific routines for gps to receive a message.
|
|
|
|
virtual void read(void) = 0;
|
2010-08-29 19:58:22 -03:00
|
|
|
|
2010-10-17 17:13:53 -03:00
|
|
|
/// Query GPS status
|
|
|
|
///
|
|
|
|
/// The 'valid message' status indicates that a recognised message was
|
|
|
|
/// received from the GPS within the last 500ms.
|
|
|
|
///
|
|
|
|
/// @todo should probably return an enumeration here.
|
|
|
|
///
|
|
|
|
/// @return 0 No GPS connected/detected
|
|
|
|
/// @return 1 Receiving valid GPS messages but no lock
|
|
|
|
/// @return 2 Receiving valid messages and locked
|
|
|
|
///
|
|
|
|
int status(void);
|
|
|
|
|
2010-08-29 19:58:22 -03:00
|
|
|
// Properties
|
2010-09-06 06:20:44 -03:00
|
|
|
long time; ///< GPS time in milliseconds from the start of the week
|
|
|
|
long latitude; ///< latitude in degrees * 10,000,000
|
|
|
|
long longitude; ///< longitude in degrees * 10,000,000
|
|
|
|
long altitude; ///< altitude in cm
|
|
|
|
long ground_speed; ///< ground speed in cm/sec
|
|
|
|
long ground_course; ///< ground course in 100ths of a degree
|
|
|
|
long speed_3d; ///< 3D speed in cm/sec (not always available)
|
|
|
|
uint8_t num_sats; ///< Number of visible satelites
|
2010-10-17 17:13:53 -03:00
|
|
|
|
2010-09-06 06:20:44 -03:00
|
|
|
/// Set to true when new data arrives. A client may set this
|
|
|
|
/// to false in order to avoid processing data they have
|
|
|
|
/// already seen.
|
|
|
|
bool new_data;
|
2010-10-17 01:07:46 -03:00
|
|
|
|
2010-10-17 17:13:53 -03:00
|
|
|
// Deprecated properties
|
|
|
|
bool fix; ///< true if we have a position fix (use ::status instead)
|
|
|
|
bool valid_read; ///< true if we have seen data from the GPS (use ::status instead)
|
2010-09-06 06:20:44 -03:00
|
|
|
|
2010-10-17 17:13:53 -03:00
|
|
|
// Debug support
|
2010-11-27 04:46:41 -04:00
|
|
|
bool print_errors; ///< deprecated
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
protected:
|
2010-10-17 17:13:53 -03:00
|
|
|
Stream *_port; ///< stream port the GPS is attached to
|
|
|
|
unsigned long _lastTime; ///< Timer for lost connection
|
|
|
|
|
|
|
|
/// reset the last-message-received timer used by ::status
|
|
|
|
///
|
|
|
|
void _setTime(void);
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
/// perform an endian swap on a long
|
|
|
|
///
|
|
|
|
/// @param bytes pointer to a buffer containing bytes representing a
|
|
|
|
/// long in the wrong byte order
|
|
|
|
/// @returns endian-swapped value
|
|
|
|
///
|
2010-09-06 17:00:57 -03:00
|
|
|
long _swapl(const void *bytes);
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
/// perform an endian swap on an int
|
|
|
|
///
|
|
|
|
/// @param bytes pointer to a buffer containing bytes representing an
|
|
|
|
/// int in the wrong byte order
|
|
|
|
/// @returns endian-swapped value
|
2010-09-06 17:00:57 -03:00
|
|
|
int _swapi(const void *bytes);
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
/// emit an error message
|
|
|
|
///
|
|
|
|
/// based on the value of print_errors, emits the printf-formatted message
|
|
|
|
/// in msg,... to stderr
|
|
|
|
///
|
|
|
|
/// @param fmt printf-like format string
|
|
|
|
///
|
2010-11-27 04:46:41 -04:00
|
|
|
/// @note deprecated as-is due to the difficulty of hooking up to a working
|
|
|
|
/// printf vs. the potential benefits
|
|
|
|
///
|
|
|
|
void _error(const char *msg, ...) {};
|
2010-10-17 01:07:46 -03:00
|
|
|
|
2010-08-29 19:58:22 -03:00
|
|
|
};
|
|
|
|
|
2010-09-06 06:20:44 -03:00
|
|
|
inline long
|
2010-09-06 17:00:57 -03:00
|
|
|
GPS::_swapl(const void *bytes)
|
2010-09-06 06:20:44 -03:00
|
|
|
{
|
2010-09-06 17:00:57 -03:00
|
|
|
const uint8_t *b = (const uint8_t *)bytes;
|
2010-09-06 06:20:44 -03:00
|
|
|
union {
|
|
|
|
long v;
|
|
|
|
uint8_t b[4];
|
|
|
|
} u;
|
|
|
|
|
2010-09-06 17:00:57 -03:00
|
|
|
u.b[0] = b[3];
|
|
|
|
u.b[1] = b[2];
|
|
|
|
u.b[2] = b[1];
|
|
|
|
u.b[3] = b[0];
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
return(u.v);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int16_t
|
2010-09-06 17:00:57 -03:00
|
|
|
GPS::_swapi(const void *bytes)
|
2010-09-06 06:20:44 -03:00
|
|
|
{
|
2010-09-06 17:00:57 -03:00
|
|
|
const uint8_t *b = (const uint8_t *)bytes;
|
2010-09-06 06:20:44 -03:00
|
|
|
union {
|
|
|
|
int16_t v;
|
|
|
|
uint8_t b[2];
|
|
|
|
} u;
|
|
|
|
|
2010-09-06 17:00:57 -03:00
|
|
|
u.b[0] = b[1];
|
|
|
|
u.b[1] = b[0];
|
2010-09-06 06:20:44 -03:00
|
|
|
|
|
|
|
return(u.v);
|
|
|
|
}
|
|
|
|
|
2010-08-29 19:58:22 -03:00
|
|
|
#endif
|