mirror of https://github.com/ArduPilot/ardupilot
99 lines
2.5 KiB
C++
99 lines
2.5 KiB
C++
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: t -*-
|
|
|
|
#include <FastSerial.h>
|
|
|
|
#define GPS_DEBUGGING 0
|
|
|
|
#if GPS_DEBUGGING
|
|
#include <FastSerial.h>
|
|
# define Debug(fmt, args ...) do {Serial.printf("%s:%d: " fmt "\n", __FUNCTION__, __LINE__, ## args); delay(0); } while(0)
|
|
#else
|
|
# define Debug(fmt, args ...)
|
|
#endif
|
|
|
|
#include <AP_Common.h>
|
|
#include <AP_Math.h>
|
|
#include "GPS.h"
|
|
#if defined(ARDUINO) && ARDUINO >= 100
|
|
#include "Arduino.h"
|
|
#else
|
|
#include "WProgram.h"
|
|
#endif
|
|
|
|
void
|
|
GPS::update(void)
|
|
{
|
|
bool result;
|
|
uint32_t tnow;
|
|
|
|
// call the GPS driver to process incoming data
|
|
result = read();
|
|
|
|
tnow = millis();
|
|
|
|
// if we did not get a message, and the idle timer has expired, re-init
|
|
if (!result) {
|
|
if ((tnow - _idleTimer) > idleTimeout) {
|
|
Debug("gps read timeout %lu %lu", (unsigned long)tnow, (unsigned long)_idleTimer);
|
|
_status = NO_GPS;
|
|
|
|
init(_nav_setting);
|
|
// reset the idle timer
|
|
_idleTimer = tnow;
|
|
}
|
|
} else {
|
|
// we got a message, update our status correspondingly
|
|
_status = fix ? GPS_OK : NO_FIX;
|
|
|
|
valid_read = true;
|
|
new_data = true;
|
|
|
|
// reset the idle timer
|
|
_idleTimer = tnow;
|
|
|
|
if (_status == GPS_OK) {
|
|
last_fix_time = _idleTimer;
|
|
_last_ground_speed_cm = ground_speed;
|
|
|
|
if (_have_raw_velocity) {
|
|
// the GPS is able to give us velocity numbers directly
|
|
_velocity_north = _vel_north * 0.01;
|
|
_velocity_east = _vel_east * 0.01;
|
|
} else {
|
|
float gps_heading = ToRad(ground_course * 0.01);
|
|
float gps_speed = ground_speed * 0.01;
|
|
float sin_heading, cos_heading;
|
|
|
|
cos_heading = cos(gps_heading);
|
|
sin_heading = sin(gps_heading);
|
|
|
|
_velocity_north = gps_speed * cos_heading;
|
|
_velocity_east = gps_speed * sin_heading;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
void
|
|
GPS::setHIL(uint32_t _time, float _latitude, float _longitude, float _altitude,
|
|
float _ground_speed, float _ground_course, float _speed_3d, uint8_t _num_sats)
|
|
{
|
|
}
|
|
|
|
// XXX this is probably the wrong way to do it, too
|
|
void
|
|
GPS::_error(const char *msg)
|
|
{
|
|
Serial.println(msg);
|
|
}
|
|
|
|
///
|
|
/// write a block of configuration data to a GPS
|
|
///
|
|
void GPS::_write_progstr_block(Stream *_fs, const prog_char *pstr, uint8_t size)
|
|
{
|
|
while (size--) {
|
|
_fs->write(pgm_read_byte(pstr++));
|
|
}
|
|
}
|