APMrover v2.1.4: compatibility with the latest version of mavlink library...

Signed-off-by: Jean-Louis Naudin <jlnaudin@gmail.com>
This commit is contained in:
Jean-Louis Naudin 2012-05-14 20:33:03 +02:00
parent 4a4402556b
commit 5cece403a5
5 changed files with 289 additions and 140 deletions

View File

@ -1,6 +1,6 @@
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- /// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
#define THISFIRMWARE "APMrover v2.13 JL NAUDIN" //New version of the APMrover for the APM v1 or APM v2 and magnetometer + SONAR #define THISFIRMWARE "APMrover v2.14 JL NAUDIN" //New version of the APMrover for the APM v1 or APM v2 and magnetometer + SONAR
// This is a full version of Arduplane v2.32 specially adapted for a Rover by Jean-Louis Naudin (JLN) // This is a full version of Arduplane v2.32 specially adapted for a Rover by Jean-Louis Naudin (JLN)
@ -26,7 +26,8 @@ version 2.1 of the License, or (at your option) any later version.
//------------------------------------------------------------------------------------------------------------------------- //-------------------------------------------------------------------------------------------------------------------------
// Dev Startup : 2012-04-21 // Dev Startup : 2012-04-21
// //
// 2012-05-14: Added option (hold roll to full right + SW7 ON/OFF) to init_home during the wp_list reset // 2012-05-14: Update about mavlink library (now compatible with the latest version of mavlink)
// 2012-05-14: Added option (with yaw full right)to init_home during the wp_list reset
// 2012-05-13: Add ROV_SONAR_TRIG (default = 200 cm) // 2012-05-13: Add ROV_SONAR_TRIG (default = 200 cm)
// 2012-05-13: Restart_nav() added and heading bug correction, tested OK in the field // 2012-05-13: Restart_nav() added and heading bug correction, tested OK in the field
// 2012-05-12: RTL then stop update - Tested in the field // 2012-05-12: RTL then stop update - Tested in the field
@ -124,7 +125,12 @@ version 2.1 of the License, or (at your option) any later version.
// //
FastSerialPort0(Serial); // FTDI/console FastSerialPort0(Serial); // FTDI/console
FastSerialPort1(Serial1); // GPS port FastSerialPort1(Serial1); // GPS port
FastSerialPort3(Serial3); // Telemetry port #if TELEMETRY_UART2 == ENABLED
// solder bridge set to enable UART2 instead of USB MUX
FastSerialPort2(Serial3);
#else
FastSerialPort3(Serial3); // Telemetry port for APM1
#endif
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// ISR Registry // ISR Registry
@ -851,7 +857,7 @@ static void fast_loop()
// XXX is it appropriate to be doing the comms below on the fast loop? // XXX is it appropriate to be doing the comms below on the fast loop?
gcs_update(); gcs_update();
gcs_data_stream_send(45,1000); gcs_data_stream_send();
} }
static void medium_loop() static void medium_loop()
@ -945,9 +951,6 @@ Serial.println(tempaccel.z, DEC);
if (g.log_bitmask & MASK_LOG_GPS) if (g.log_bitmask & MASK_LOG_GPS)
Log_Write_GPS(g_gps->time, current_loc.lat, current_loc.lng, g_gps->altitude, current_loc.alt, (long) g_gps->ground_speed, g_gps->ground_course, g_gps->fix, g_gps->num_sats); Log_Write_GPS(g_gps->time, current_loc.lat, current_loc.lng, g_gps->altitude, current_loc.alt, (long) g_gps->ground_speed, g_gps->ground_course, g_gps->fix, g_gps->num_sats);
#endif #endif
// send all requested output streams with rates requested
// between 5 and 45 Hz
gcs_data_stream_send(5,45);
break; break;
// This case controls the slow loop // This case controls the slow loop
@ -1013,7 +1016,6 @@ static void slow_loop()
update_events(); update_events();
mavlink_system.sysid = g.sysid_this_mav; // This is just an ugly hack to keep mavlink_system.sysid sync'd with our parameter mavlink_system.sysid = g.sysid_this_mav; // This is just an ugly hack to keep mavlink_system.sysid sync'd with our parameter
gcs_data_stream_send(3,5);
#if USB_MUX_PIN > 0 #if USB_MUX_PIN > 0
check_usb_mux(); check_usb_mux();
@ -1037,7 +1039,6 @@ static void one_second_loop()
#endif #endif
// send a heartbeat // send a heartbeat
gcs_send_message(MSG_HEARTBEAT); gcs_send_message(MSG_HEARTBEAT);
gcs_data_stream_send(1,3);
} }
static void update_GPS(void) static void update_GPS(void)

View File

@ -8,7 +8,6 @@
#include <FastSerial.h> #include <FastSerial.h>
#include <AP_Common.h> #include <AP_Common.h>
#include <GCS_MAVLink.h>
#include <GPS.h> #include <GPS.h>
#include <Stream.h> #include <Stream.h>
#include <stdint.h> #include <stdint.h>
@ -43,6 +42,7 @@ public:
void init(FastSerial *port) { void init(FastSerial *port) {
_port = port; _port = port;
initialised = true; initialised = true;
last_gps_satellites = 255;
} }
/// Update GCS state. /// Update GCS state.
@ -75,20 +75,15 @@ public:
/// ///
void send_text(gcs_severity severity, const prog_char_t *str) {} void send_text(gcs_severity severity, const prog_char_t *str) {}
// test if frequency within range requested for loop
// used by data_stream_send
static bool freqLoopMatch(uint16_t freq, uint16_t freqMin, uint16_t freqMax)
{
if (freq != 0 && freq >= freqMin && freq < freqMax) return true;
else return false;
}
// send streams which match frequency range // send streams which match frequency range
void data_stream_send(uint16_t freqMin, uint16_t freqMax); void data_stream_send(void);
// set to true if this GCS link is active // set to true if this GCS link is active
bool initialised; bool initialised;
// used to prevent wasting bandwidth with GPS_STATUS messages
uint8_t last_gps_satellites;
protected: protected:
/// The stream we are communicating over /// The stream we are communicating over
FastSerial *_port; FastSerial *_port;
@ -114,12 +109,29 @@ public:
void send_message(enum ap_message id); void send_message(enum ap_message id);
void send_text(gcs_severity severity, const char *str); void send_text(gcs_severity severity, const char *str);
void send_text(gcs_severity severity, const prog_char_t *str); void send_text(gcs_severity severity, const prog_char_t *str);
void data_stream_send(uint16_t freqMin, uint16_t freqMax); void data_stream_send(void);
void queued_param_send(); void queued_param_send();
void queued_waypoint_send(); void queued_waypoint_send();
static const struct AP_Param::GroupInfo var_info[]; static const struct AP_Param::GroupInfo var_info[];
// NOTE! The streams enum below and the
// set of AP_Int16 stream rates _must_ be
// kept in the same order
enum streams {STREAM_RAW_SENSORS,
STREAM_EXTENDED_STATUS,
STREAM_RC_CHANNELS,
STREAM_RAW_CONTROLLER,
STREAM_POSITION,
STREAM_EXTRA1,
STREAM_EXTRA2,
STREAM_EXTRA3,
STREAM_PARAMS,
NUM_STREAMS};
// see if we should send a stream now. Called at 50Hz
bool stream_trigger(enum streams stream_num);
private: private:
void handleMessage(mavlink_message_t * msg); void handleMessage(mavlink_message_t * msg);
@ -164,7 +176,8 @@ private:
uint16_t waypoint_send_timeout; // milliseconds uint16_t waypoint_send_timeout; // milliseconds
uint16_t waypoint_receive_timeout; // milliseconds uint16_t waypoint_receive_timeout; // milliseconds
// data stream rates // data stream rates. The code assumes that
// streamRateRawSensors is the first
AP_Int16 streamRateRawSensors; AP_Int16 streamRateRawSensors;
AP_Int16 streamRateExtendedStatus; AP_Int16 streamRateExtendedStatus;
AP_Int16 streamRateRCChannels; AP_Int16 streamRateRCChannels;
@ -173,6 +186,13 @@ private:
AP_Int16 streamRateExtra1; AP_Int16 streamRateExtra1;
AP_Int16 streamRateExtra2; AP_Int16 streamRateExtra2;
AP_Int16 streamRateExtra3; AP_Int16 streamRateExtra3;
AP_Int16 streamRateParams;
// number of 50Hz ticks until we next send this stream
uint8_t stream_ticks[NUM_STREAMS];
// number of extra ticks to add to slow things down for the radio
uint8_t stream_slowdown;
}; };
#endif // __GCS_H #endif // __GCS_H

View File

@ -27,7 +27,7 @@ static bool mavlink_active;
static NOINLINE void send_heartbeat(mavlink_channel_t chan) static NOINLINE void send_heartbeat(mavlink_channel_t chan)
{ {
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
uint8_t base_mode = MAV_MODE_FLAG_CUSTOM_MODE_ENABLED; uint8_t base_mode = MAV_MODE_FLAG_CUSTOM_MODE_ENABLED;
uint8_t system_status = MAV_STATE_ACTIVE; uint8_t system_status = MAV_STATE_ACTIVE;
uint32_t custom_mode = control_mode; uint32_t custom_mode = control_mode;
@ -131,7 +131,7 @@ static NOINLINE void send_fence_status(mavlink_channel_t chan)
static NOINLINE void send_extended_status1(mavlink_channel_t chan, uint16_t packet_drops) static NOINLINE void send_extended_status1(mavlink_channel_t chan, uint16_t packet_drops)
{ {
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
uint32_t control_sensors_present = 0; uint32_t control_sensors_present = 0;
uint32_t control_sensors_enabled; uint32_t control_sensors_enabled;
uint32_t control_sensors_health; uint32_t control_sensors_health;
@ -143,7 +143,7 @@ static NOINLINE void send_extended_status1(mavlink_channel_t chan, uint16_t pack
control_sensors_present |= (1<<2); // compass present control_sensors_present |= (1<<2); // compass present
} }
control_sensors_present |= (1<<3); // absolute pressure sensor present control_sensors_present |= (1<<3); // absolute pressure sensor present
if (g_gps->fix) { if (g_gps != NULL && g_gps->status() == GPS::GPS_OK) {
control_sensors_present |= (1<<5); // GPS present control_sensors_present |= (1<<5); // GPS present
} }
control_sensors_present |= (1<<10); // 3D angular rate control control_sensors_present |= (1<<10); // 3D angular rate control
@ -338,12 +338,10 @@ static void NOINLINE send_nav_controller_output(mavlink_channel_t chan)
static void NOINLINE send_gps_raw(mavlink_channel_t chan) static void NOINLINE send_gps_raw(mavlink_channel_t chan)
{ {
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
uint8_t fix; uint8_t fix = g_gps->status();
if (g_gps->status() == 2) { if (fix == GPS::GPS_OK) {
fix = 3; fix = 3;
} else {
fix = 0;
} }
mavlink_msg_gps_raw_int_send( mavlink_msg_gps_raw_int_send(
@ -380,7 +378,7 @@ static void NOINLINE send_servo_out(mavlink_channel_t chan)
// normalized values scaled to -10000 to 10000 // normalized values scaled to -10000 to 10000
// This is used for HIL. Do not change without discussing with // This is used for HIL. Do not change without discussing with
// HIL maintainers // HIL maintainers
#if X_PLANE == ENABLED #if X_PLANE == ENABLED
/* update by JLN for X-Plane or AeroSIM HIL */ /* update by JLN for X-Plane or AeroSIM HIL */
int thr_out = constrain((g.channel_throttle.servo_out *2) - 100, -100, 100); // throttle set from -100 to 100 int thr_out = constrain((g.channel_throttle.servo_out *2) - 100, -100, 100); // throttle set from -100 to 100
@ -436,14 +434,14 @@ static void NOINLINE send_radio_out(mavlink_channel_t chan)
chan, chan,
micros(), micros(),
0, // port 0, // port
g.channel_roll.radio_out, APM_RC.OutputCh_current(0),
g.channel_pitch.radio_out, APM_RC.OutputCh_current(1),
g.channel_throttle.radio_out, APM_RC.OutputCh_current(2),
g.channel_rudder.radio_out, APM_RC.OutputCh_current(3),
g.rc_5.radio_out, // XXX currently only 4 RC channels defined APM_RC.OutputCh_current(4),
g.rc_6.radio_out, APM_RC.OutputCh_current(5),
g.rc_7.radio_out, APM_RC.OutputCh_current(6),
g.rc_8.radio_out); APM_RC.OutputCh_current(7));
} }
static void NOINLINE send_vfr_hud(mavlink_channel_t chan) static void NOINLINE send_vfr_hud(mavlink_channel_t chan)
@ -503,8 +501,57 @@ static void NOINLINE send_raw_imu3(mavlink_channel_t chan)
imu.gx(), imu.gy(), imu.gz(), imu.gx(), imu.gy(), imu.gz(),
imu.ax(), imu.ay(), imu.az()); imu.ax(), imu.ay(), imu.az());
} }
static void NOINLINE send_ahrs(mavlink_channel_t chan)
{
Vector3f omega_I = ahrs.get_gyro_drift();
mavlink_msg_ahrs_send(
chan,
omega_I.x,
omega_I.y,
omega_I.z,
0,
0,
ahrs.get_error_rp(),
ahrs.get_error_yaw());
}
#endif // HIL_MODE != HIL_MODE_ATTITUDE #endif // HIL_MODE != HIL_MODE_ATTITUDE
#ifdef DESKTOP_BUILD
void mavlink_simstate_send(uint8_t chan,
float roll,
float pitch,
float yaw,
float xAcc,
float yAcc,
float zAcc,
float p,
float q,
float r)
{
mavlink_msg_simstate_send((mavlink_channel_t)chan,
roll, pitch, yaw, xAcc, yAcc, zAcc, p, q, r);
}
// report simulator state
static void NOINLINE send_simstate(mavlink_channel_t chan)
{
extern void sitl_simstate_send(uint8_t chan);
sitl_simstate_send((uint8_t)chan);
}
#endif
#ifndef DESKTOP_BUILD
static void NOINLINE send_hwstatus(mavlink_channel_t chan)
{
mavlink_msg_hwstatus_send(
chan,
board_voltage(),
I2c.lockup_count());
}
#endif
static void NOINLINE send_gps_status(mavlink_channel_t chan) static void NOINLINE send_gps_status(mavlink_channel_t chan)
{ {
mavlink_msg_gps_status_send( mavlink_msg_gps_status_send(
@ -578,7 +625,7 @@ static bool mavlink_try_send_message(mavlink_channel_t chan, enum ap_message id,
break; break;
case MSG_GPS_RAW: case MSG_GPS_RAW:
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
CHECK_PAYLOAD_SIZE(GPS_RAW_INT); CHECK_PAYLOAD_SIZE(GPS_RAW_INT);
#else #else
CHECK_PAYLOAD_SIZE(GPS_RAW); CHECK_PAYLOAD_SIZE(GPS_RAW);
@ -663,6 +710,27 @@ static bool mavlink_try_send_message(mavlink_channel_t chan, enum ap_message id,
break; break;
#endif #endif
case MSG_AHRS:
#if HIL_MODE != HIL_MODE_ATTITUDE
CHECK_PAYLOAD_SIZE(AHRS);
send_ahrs(chan);
#endif
break;
case MSG_SIMSTATE:
#ifdef DESKTOP_BUILD
CHECK_PAYLOAD_SIZE(SIMSTATE);
send_simstate(chan);
#endif
break;
case MSG_HWSTATUS:
#ifndef DESKTOP_BUILD
CHECK_PAYLOAD_SIZE(HWSTATUS);
send_hwstatus(chan);
#endif
break;
case MSG_RETRY_DEFERRED: case MSG_RETRY_DEFERRED:
break; // just here to prevent a warning break; // just here to prevent a warning
} }
@ -757,6 +825,7 @@ const AP_Param::GroupInfo GCS_MAVLINK::var_info[] PROGMEM = {
AP_GROUPINFO("EXTRA1", 5, GCS_MAVLINK, streamRateExtra1), AP_GROUPINFO("EXTRA1", 5, GCS_MAVLINK, streamRateExtra1),
AP_GROUPINFO("EXTRA2", 6, GCS_MAVLINK, streamRateExtra2), AP_GROUPINFO("EXTRA2", 6, GCS_MAVLINK, streamRateExtra2),
AP_GROUPINFO("EXTRA3", 7, GCS_MAVLINK, streamRateExtra3), AP_GROUPINFO("EXTRA3", 7, GCS_MAVLINK, streamRateExtra3),
AP_GROUPINFO("PARAMS", 8, GCS_MAVLINK, streamRateParams),
AP_GROUPEND AP_GROUPEND
}; };
@ -820,11 +889,6 @@ GCS_MAVLINK::update(void)
// Update packet drops counter // Update packet drops counter
packet_drops += status.packet_rx_drop_count; packet_drops += status.packet_rx_drop_count;
// send out queued params/ waypoints
if (NULL != _queued_parameter) {
send_message(MSG_NEXT_PARAM);
}
if (!waypoint_receiving && !waypoint_sending) { if (!waypoint_receiving && !waypoint_sending) {
return; return;
} }
@ -833,7 +897,7 @@ GCS_MAVLINK::update(void)
if (waypoint_receiving && if (waypoint_receiving &&
waypoint_request_i <= (unsigned)g.command_total && waypoint_request_i <= (unsigned)g.command_total &&
tnow > waypoint_timelast_request + 500) { tnow > waypoint_timelast_request + 500 + (stream_slowdown*20)) {
waypoint_timelast_request = tnow; waypoint_timelast_request = tnow;
send_message(MSG_NEXT_WAYPOINT); send_message(MSG_NEXT_WAYPOINT);
} }
@ -849,54 +913,100 @@ GCS_MAVLINK::update(void)
} }
} }
void // see if we should send a stream now. Called at 50Hz
GCS_MAVLINK::data_stream_send(uint16_t freqMin, uint16_t freqMax) bool GCS_MAVLINK::stream_trigger(enum streams stream_num)
{ {
if (waypoint_sending == false && waypoint_receiving == false && _queued_parameter == NULL) { AP_Int16 *stream_rates = &streamRateRawSensors;
uint8_t rate = (uint8_t)stream_rates[stream_num].get();
if (freqLoopMatch(streamRateRawSensors, freqMin, freqMax)){ if (rate == 0) {
send_message(MSG_RAW_IMU1); return false;
send_message(MSG_RAW_IMU2); }
send_message(MSG_RAW_IMU3);
}
if (freqLoopMatch(streamRateExtendedStatus, freqMin, freqMax)) { if (stream_ticks[stream_num] == 0) {
send_message(MSG_EXTENDED_STATUS1); // we're triggering now, setup the next trigger point
send_message(MSG_EXTENDED_STATUS2); if (rate > 50) {
send_message(MSG_GPS_STATUS); rate = 50;
send_message(MSG_CURRENT_WAYPOINT); }
send_message(MSG_GPS_RAW); // TODO - remove this message after location message is working stream_ticks[stream_num] = (50 / rate) + stream_slowdown;
send_message(MSG_NAV_CONTROLLER_OUTPUT); return true;
send_message(MSG_FENCE_STATUS); }
}
if (freqLoopMatch(streamRatePosition, freqMin, freqMax)) { // count down at 50Hz
// sent with GPS read stream_ticks[stream_num]--;
send_message(MSG_LOCATION); return false;
} }
if (freqLoopMatch(streamRateRawController, freqMin, freqMax)) { void
// This is used for HIL. Do not change without discussing with HIL maintainers GCS_MAVLINK::data_stream_send(void)
send_message(MSG_SERVO_OUT); {
} if (waypoint_receiving || waypoint_sending) {
// don't interfere with mission transfer
return;
}
if (freqLoopMatch(streamRateRCChannels, freqMin, freqMax)) { if (_queued_parameter != NULL) {
send_message(MSG_RADIO_OUT); if (streamRateParams.get() <= 0) {
send_message(MSG_RADIO_IN); streamRateParams.set(50);
} }
if (stream_trigger(STREAM_PARAMS)) {
send_message(MSG_NEXT_PARAM);
}
// don't send anything else at the same time as parameters
return;
}
if (freqLoopMatch(streamRateExtra1, freqMin, freqMax)){ // Use Extra 1 for AHRS info if (stream_trigger(STREAM_RAW_SENSORS)) {
send_message(MSG_ATTITUDE); send_message(MSG_RAW_IMU1);
} send_message(MSG_RAW_IMU2);
send_message(MSG_RAW_IMU3);
}
if (freqLoopMatch(streamRateExtra2, freqMin, freqMax)){ // Use Extra 2 for additional HIL info if (stream_trigger(STREAM_EXTENDED_STATUS)) {
send_message(MSG_VFR_HUD); send_message(MSG_EXTENDED_STATUS1);
} send_message(MSG_EXTENDED_STATUS2);
send_message(MSG_CURRENT_WAYPOINT);
send_message(MSG_GPS_RAW); // TODO - remove this message after location message is working
send_message(MSG_NAV_CONTROLLER_OUTPUT);
send_message(MSG_FENCE_STATUS);
if (freqLoopMatch(streamRateExtra3, freqMin, freqMax)){ if (last_gps_satellites != g_gps->num_sats) {
// Available datastream // this message is mostly a huge waste of bandwidth,
} // except it is the only message that gives the number
} // of visible satellites. So only send it when that
// changes.
send_message(MSG_GPS_STATUS);
last_gps_satellites = g_gps->num_sats;
}
}
if (stream_trigger(STREAM_POSITION)) {
// sent with GPS read
send_message(MSG_LOCATION);
}
if (stream_trigger(STREAM_RAW_CONTROLLER)) {
send_message(MSG_SERVO_OUT);
}
if (stream_trigger(STREAM_RC_CHANNELS)) {
send_message(MSG_RADIO_OUT);
send_message(MSG_RADIO_IN);
}
if (stream_trigger(STREAM_EXTRA1)) {
send_message(MSG_ATTITUDE);
send_message(MSG_SIMSTATE);
}
if (stream_trigger(STREAM_EXTRA2)) {
send_message(MSG_VFR_HUD);
}
if (stream_trigger(STREAM_EXTRA3)) {
send_message(MSG_AHRS);
send_message(MSG_HWSTATUS);
}
} }
@ -1005,7 +1115,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
break; break;
} }
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
case MAVLINK_MSG_ID_COMMAND_LONG: case MAVLINK_MSG_ID_COMMAND_LONG:
{ {
// decode // decode
@ -1030,20 +1140,16 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
result = MAV_RESULT_ACCEPTED; result = MAV_RESULT_ACCEPTED;
break; break;
#if 0 case MAV_CMD_MISSION_START:
// not implemented yet, but could implement some of them set_mode(AUTO);
case MAV_CMD_NAV_LAND: result = MAV_RESULT_ACCEPTED;
case MAV_CMD_NAV_TAKEOFF:
case MAV_CMD_NAV_ROI:
case MAV_CMD_NAV_PATHPLANNING:
break; break;
#endif
case MAV_CMD_PREFLIGHT_CALIBRATION: case MAV_CMD_PREFLIGHT_CALIBRATION:
if (packet.param1 == 1 || if (packet.param1 == 1 ||
packet.param2 == 1 || packet.param2 == 1 ||
packet.param3 == 1) { packet.param3 == 1) {
startup_IMU_ground(true);
} }
if (packet.param4 == 1) { if (packet.param4 == 1) {
trim_radio(); trim_radio();
@ -1138,7 +1244,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
result=1; result=1;
break; break;
case MAV_ACTION_CALIBRATE_RC: //break; case MAV_ACTION_CALIBRATE_RC: break;
trim_radio(); trim_radio();
result=1; result=1;
break; break;
@ -1148,6 +1254,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
case MAV_ACTION_CALIBRATE_ACC: case MAV_ACTION_CALIBRATE_ACC:
case MAV_ACTION_CALIBRATE_PRESSURE: case MAV_ACTION_CALIBRATE_PRESSURE:
case MAV_ACTION_REBOOT: // this is a rough interpretation case MAV_ACTION_REBOOT: // this is a rough interpretation
startup_IMU_ground(true);
result=1; result=1;
break; break;
@ -1198,7 +1305,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
mavlink_set_mode_t packet; mavlink_set_mode_t packet;
mavlink_msg_set_mode_decode(msg, &packet); mavlink_msg_set_mode_decode(msg, &packet);
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
if (!(packet.base_mode & MAV_MODE_FLAG_CUSTOM_MODE_ENABLED)) { if (!(packet.base_mode & MAV_MODE_FLAG_CUSTOM_MODE_ENABLED)) {
// we ignore base_mode as there is no sane way to map // we ignore base_mode as there is no sane way to map
// from that bitmap to a APM flight mode. We rely on // from that bitmap to a APM flight mode. We rely on
@ -1254,7 +1361,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
break; break;
} }
#ifndef MAVLINK10 #if MAVLINK10 == DISABLED
case MAVLINK_MSG_ID_SET_NAV_MODE: case MAVLINK_MSG_ID_SET_NAV_MODE:
{ {
// decode // decode
@ -1606,7 +1713,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
break; break;
default: default:
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
result = MAV_MISSION_UNSUPPORTED; result = MAV_MISSION_UNSUPPORTED;
#endif #endif
break; break;
@ -1750,13 +1857,19 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
((AP_Float *)vp)->set_and_save(packet.param_value); ((AP_Float *)vp)->set_and_save(packet.param_value);
} else if (var_type == AP_PARAM_INT32) { } else if (var_type == AP_PARAM_INT32) {
if (packet.param_value < 0) rounding_addition = -rounding_addition; if (packet.param_value < 0) rounding_addition = -rounding_addition;
((AP_Int32 *)vp)->set_and_save(packet.param_value+rounding_addition); float v = packet.param_value+rounding_addition;
v = constrain(v, -2147483648.0, 2147483647.0);
((AP_Int32 *)vp)->set_and_save(v);
} else if (var_type == AP_PARAM_INT16) { } else if (var_type == AP_PARAM_INT16) {
if (packet.param_value < 0) rounding_addition = -rounding_addition; if (packet.param_value < 0) rounding_addition = -rounding_addition;
((AP_Int16 *)vp)->set_and_save(packet.param_value+rounding_addition); float v = packet.param_value+rounding_addition;
v = constrain(v, -32768, 32767);
((AP_Int16 *)vp)->set_and_save(v);
} else if (var_type == AP_PARAM_INT8) { } else if (var_type == AP_PARAM_INT8) {
if (packet.param_value < 0) rounding_addition = -rounding_addition; if (packet.param_value < 0) rounding_addition = -rounding_addition;
((AP_Int8 *)vp)->set_and_save(packet.param_value+rounding_addition); float v = packet.param_value+rounding_addition;
v = constrain(v, -128, 127);
((AP_Int8 *)vp)->set_and_save(v);
} else { } else {
// we don't support mavlink set on this parameter // we don't support mavlink set on this parameter
break; break;
@ -1816,7 +1929,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
#if HIL_MODE != HIL_MODE_DISABLED #if HIL_MODE != HIL_MODE_DISABLED
// This is used both as a sensor and to pass the location // This is used both as a sensor and to pass the location
// in HIL_ATTITUDE mode. // in HIL_ATTITUDE mode.
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
case MAVLINK_MSG_ID_GPS_RAW_INT: case MAVLINK_MSG_ID_GPS_RAW_INT:
{ {
// decode // decode
@ -1839,16 +1952,6 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
// set gps hil sensor // set gps hil sensor
g_gps->setHIL(packet.usec/1000.0,packet.lat,packet.lon,packet.alt, g_gps->setHIL(packet.usec/1000.0,packet.lat,packet.lon,packet.alt,
packet.v,packet.hdg,0,0); packet.v,packet.hdg,0,0);
//if ((gps_base_alt == 0) && (airspeed ==0 )) { // we are on the ground so, get the altitude offset
// gps_base_alt = packet.alt*100;
//}
current_loc.lng = packet.lon * T7;
current_loc.lat = packet.lat * T7;
//current_loc.alt = g_gps->altitude - gps_base_alt;
//if (!home_is_set) {
// init_home();
//}
break; break;
} }
#endif // MAVLINK10 #endif // MAVLINK10
@ -1864,13 +1967,13 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
airspeed = 100*packet.airspeed; airspeed = 100*packet.airspeed;
break; break;
} }
#ifdef MAVLINK10 #if MAVLINK10 == ENABLED
case MAVLINK_MSG_ID_HIL_STATE: case MAVLINK_MSG_ID_HIL_STATE:
{ {
mavlink_hil_state_t packet; mavlink_hil_state_t packet;
mavlink_msg_hil_state_decode(msg, &packet); mavlink_msg_hil_state_decode(msg, &packet);
float vel = sqrt((packet.vx * packet.vx) + (packet.vy * packet.vy)); float vel = sqrt((packet.vx * (float)packet.vx) + (packet.vy * (float)packet.vy));
float cog = wrap_360(ToDeg(atan2(packet.vx, packet.vy)) * 100); float cog = wrap_360(ToDeg(atan2(packet.vx, packet.vy)) * 100);
// set gps hil sensor // set gps hil sensor
@ -1897,7 +2000,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
#else #else
// set dcm hil sensor // set AHRS hil sensor
ahrs.setHil(packet.roll,packet.pitch,packet.yaw,packet.rollspeed, ahrs.setHil(packet.roll,packet.pitch,packet.yaw,packet.rollspeed,
packet.pitchspeed,packet.yawspeed); packet.pitchspeed,packet.yawspeed);
@ -1914,24 +2017,9 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
mavlink_attitude_t packet; mavlink_attitude_t packet;
mavlink_msg_attitude_decode(msg, &packet); mavlink_msg_attitude_decode(msg, &packet);
// set dcm hil sensor // set AHRS hil sensor
ahrs.setHil(packet.roll,packet.pitch,packet.yaw,packet.rollspeed, ahrs.setHil(packet.roll,packet.pitch,packet.yaw,packet.rollspeed,
packet.pitchspeed,packet.yawspeed); packet.pitchspeed,packet.yawspeed);
// rad/sec // JLN update - FOR HIL SIMULATION WITH AEROSIM
Vector3f gyros;
gyros.x = (float)packet.rollspeed / 1000.0;
gyros.y = (float)packet.pitchspeed / 1000.0;
gyros.z = (float)packet.yawspeed / 1000.0;
imu.set_gyro(gyros);
// m/s/s
Vector3f accels;
accels.x = (float)packet.roll * gravity / 1000.0;
accels.y = (float)packet.pitch * gravity / 1000.0;
accels.z = (float)packet.yaw * gravity / 1000.0;
imu.set_accel(accels);
break; break;
} }
#endif #endif
@ -2002,6 +2090,30 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
break; break;
} }
#endif // MOUNT == ENABLED #endif // MOUNT == ENABLED
case MAVLINK_MSG_ID_RADIO:
{
mavlink_radio_t packet;
mavlink_msg_radio_decode(msg, &packet);
// use the state of the transmit buffer in the radio to
// control the stream rate, giving us adaptive software
// flow control
if (packet.txbuf < 20 && stream_slowdown < 100) {
// we are very low on space - slow down a lot
stream_slowdown += 3;
} else if (packet.txbuf < 50 && stream_slowdown < 100) {
// we are a bit low on space, slow down slightly
stream_slowdown += 1;
} else if (packet.txbuf > 95 && stream_slowdown > 10) {
// the buffer has plenty of space, speed up a lot
stream_slowdown -= 2;
} else if (packet.txbuf > 90 && stream_slowdown != 0) {
// the buffer has enough space, speed up a bit
stream_slowdown--;
}
break;
}
} // end switch } // end switch
} // end handle mavlink } // end handle mavlink
@ -2041,7 +2153,7 @@ GCS_MAVLINK::queued_param_send()
value = vp->cast_to_float(_queued_parameter_type); value = vp->cast_to_float(_queued_parameter_type);
char param_name[ONBOARD_PARAM_NAME_LENGTH]; char param_name[ONBOARD_PARAM_NAME_LENGTH];
vp->copy_name(param_name, sizeof(param_name)); vp->copy_name(param_name, sizeof(param_name), true);
mavlink_msg_param_value_send( mavlink_msg_param_value_send(
chan, chan,
@ -2127,11 +2239,11 @@ static void gcs_send_message(enum ap_message id)
/* /*
send data streams in the given rate range on both links send data streams in the given rate range on both links
*/ */
static void gcs_data_stream_send(uint16_t freqMin, uint16_t freqMax) static void gcs_data_stream_send(void)
{ {
gcs0.data_stream_send(freqMin, freqMax); gcs0.data_stream_send();
if (gcs3.initialised) { if (gcs3.initialised) {
gcs3.data_stream_send(freqMin, freqMax); gcs3.data_stream_send();
} }
} }
@ -2178,3 +2290,19 @@ static void gcs_send_text_fmt(const prog_char_t *fmt, ...)
mavlink_send_message(MAVLINK_COMM_1, MSG_STATUSTEXT, 0); mavlink_send_message(MAVLINK_COMM_1, MSG_STATUSTEXT, 0);
} }
} }
// this code was moved from libraries/GCS_MAVLink to allow compile
// time selection of MAVLink 1.0
BetterStream *mavlink_comm_0_port;
BetterStream *mavlink_comm_1_port;
mavlink_system_t mavlink_system = {7,1,0,0};
uint8_t mavlink_check_target(uint8_t sysid, uint8_t compid)
{
if (sysid != mavlink_system.sysid)
return 1;
// Currently we are not checking for correct compid since APM is not passing mavlink info to any subsystem
// If it is addressed to our system ID we assume it is for us
return 0; // no error
}

View File

@ -159,6 +159,9 @@ enum ap_message {
MSG_NEXT_PARAM, MSG_NEXT_PARAM,
MSG_STATUSTEXT, MSG_STATUSTEXT,
MSG_FENCE_STATUS, MSG_FENCE_STATUS,
MSG_AHRS,
MSG_SIMSTATE,
MSG_HWSTATUS,
MSG_RETRY_DEFERRED // this must be last MSG_RETRY_DEFERRED // this must be last
}; };

View File

@ -27,7 +27,7 @@ planner_gcs(uint8_t argc, const Menu::arg *argv)
{ {
gcs0.init(&Serial); gcs0.init(&Serial);
#if USB_MUX_PIN > 0 #if USB_MUX_PIN < 0
// we don't have gcs3 if we have the USB mux setup // we don't have gcs3 if we have the USB mux setup
gcs3.init(&Serial3); gcs3.init(&Serial3);
#endif #endif
@ -41,11 +41,8 @@ planner_gcs(uint8_t argc, const Menu::arg *argv)
read_radio(); read_radio();
gcs_data_stream_send(45,1000); gcs_data_stream_send();
if ((loopcount % 5) == 0) // 10 hz
gcs_data_stream_send(5,45);
if ((loopcount % 16) == 0) { // 3 hz if ((loopcount % 16) == 0) { // 3 hz
gcs_data_stream_send(1,5);
gcs_send_message(MSG_HEARTBEAT); gcs_send_message(MSG_HEARTBEAT);
} }
loopcount++; loopcount++;