Browse Source

GCS_MAVLink: support erase and faster downloads

master
Andrew Tridgell 11 years ago
parent
commit
0a9e2d332a
  1. 3
      libraries/GCS_MAVLink/GCS.h
  2. 36
      libraries/GCS_MAVLink/GCS_Logs.cpp

3
libraries/GCS_MAVLink/GCS.h

@ -176,6 +176,9 @@ public:
// call to reset the timeout window for entering the cli // call to reset the timeout window for entering the cli
void reset_cli_timeout(); void reset_cli_timeout();
uint32_t last_heartbeat_time; // milliseconds
private: private:
void handleMessage(mavlink_message_t * msg); void handleMessage(mavlink_message_t * msg);

36
libraries/GCS_MAVLink/GCS_Logs.cpp

@ -18,9 +18,11 @@
*/ */
#include <AP_HAL.h>
#include <GCS.h> #include <GCS.h>
#include <DataFlash.h> #include <DataFlash.h>
#include <stdio.h>
extern const AP_HAL::HAL& hal;
/** /**
handle all types of log download requests from the GCS handle all types of log download requests from the GCS
@ -34,6 +36,9 @@ void GCS_MAVLINK::handle_log_message(mavlink_message_t *msg, DataFlash_Class &da
case MAVLINK_MSG_ID_LOG_REQUEST_DATA: case MAVLINK_MSG_ID_LOG_REQUEST_DATA:
handle_log_request_data(msg, dataflash); handle_log_request_data(msg, dataflash);
break; break;
case MAVLINK_MSG_ID_LOG_ERASE:
dataflash.EraseAll();
break;
} }
} }
@ -48,10 +53,13 @@ void GCS_MAVLINK::handle_log_request_list(mavlink_message_t *msg, DataFlash_Clas
mavlink_msg_log_request_list_decode(msg, &packet); mavlink_msg_log_request_list_decode(msg, &packet);
if (mavlink_check_target(packet.target_system, packet.target_component)) if (mavlink_check_target(packet.target_system, packet.target_component))
return; return;
_log_listing = true; _log_listing = false;
_log_sending = false; _log_sending = false;
_log_num_logs = dataflash.get_num_logs(); _log_num_logs = dataflash.get_num_logs();
if (_log_num_logs == 0) {
return;
}
int16_t last_log_num = dataflash.find_last_log(); int16_t last_log_num = dataflash.find_last_log();
_log_next_list_entry = packet.start; _log_next_list_entry = packet.start;
@ -63,6 +71,9 @@ void GCS_MAVLINK::handle_log_request_list(mavlink_message_t *msg, DataFlash_Clas
if (_log_next_list_entry < last_log_num + 1 - _log_num_logs) { if (_log_next_list_entry < last_log_num + 1 - _log_num_logs) {
_log_next_list_entry = last_log_num + 1 - _log_num_logs; _log_next_list_entry = last_log_num + 1 - _log_num_logs;
} }
_log_listing = true;
handle_log_send_listing(dataflash);
} }
@ -96,7 +107,12 @@ void GCS_MAVLINK::handle_log_request_data(mavlink_message_t *msg, DataFlash_Clas
} else { } else {
_log_data_remaining = size - _log_data_offset; _log_data_remaining = size - _log_data_offset;
} }
if (_log_data_remaining > packet.count) {
_log_data_remaining = packet.count;
}
_log_sending = true; _log_sending = true;
handle_log_send_data(dataflash);
} }
/** /**
@ -107,7 +123,11 @@ void GCS_MAVLINK::handle_log_send(DataFlash_Class &dataflash)
if (_log_listing) { if (_log_listing) {
handle_log_send_listing(dataflash); handle_log_send_listing(dataflash);
} }
uint8_t num_sends = 5; uint8_t num_sends = 1;
if (chan == MAVLINK_COMM_0 && hal.gpio->usb_connected()) {
// when on USB we can send a lot more data
num_sends = 20;
}
if (stream_slowdown != 0) { if (stream_slowdown != 0) {
// we're using a radio and starting to clag up, slowdown log send // we're using a radio and starting to clag up, slowdown log send
num_sends = 1; num_sends = 1;
@ -129,6 +149,10 @@ void GCS_MAVLINK::handle_log_send_listing(DataFlash_Class &dataflash)
// no space // no space
return; return;
} }
if (hal.scheduler->millis() - last_heartbeat_time > 3000) {
// give a heartbeat a chance
return;
}
uint32_t size, time_utc; uint32_t size, time_utc;
dataflash.get_log_info(_log_next_list_entry, size, time_utc); dataflash.get_log_info(_log_next_list_entry, size, time_utc);
@ -150,6 +174,10 @@ void GCS_MAVLINK::handle_log_send_data(DataFlash_Class &dataflash)
// no space // no space
return; return;
} }
if (hal.scheduler->millis() - last_heartbeat_time > 3000) {
// give a heartbeat a chance
return;
}
int16_t ret = 0; int16_t ret = 0;
uint32_t len = _log_data_remaining; uint32_t len = _log_data_remaining;
@ -166,7 +194,7 @@ void GCS_MAVLINK::handle_log_send_data(DataFlash_Class &dataflash)
mavlink_msg_log_data_send(chan, _log_num_data, _log_data_offset, ret, data); mavlink_msg_log_data_send(chan, _log_num_data, _log_data_offset, ret, data);
_log_data_offset += len; _log_data_offset += len;
_log_data_remaining -= len; _log_data_remaining -= len;
if (len < 90) { if (len < 90 || _log_data_remaining == 0) {
_log_sending = false; _log_sending = false;
} }
} }

Loading…
Cancel
Save