mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AP_Logger: use existing LoggerMessageWriter to log uploaded missions
Instead of creating a MessageWriter explicitly to log uploaded missions we fiddle the state of the one stored in the startup message writer. This has the advantage of being much more likely to log the entire mission (as the buffer constraint is removed), and with the addition of a time-remaining check much less likely to cause a timing glitch.
This commit is contained in:
parent
856b635e89
commit
678d6f43c5
@ -440,9 +440,8 @@ bool AP_Logger_Backend::Write_RallyPoint(uint8_t total,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Write rally points
|
// Write rally points
|
||||||
void AP_Logger_Backend::Write_Rally()
|
bool AP_Logger_Backend::Write_Rally()
|
||||||
{
|
{
|
||||||
LoggerMessageWriter_WriteAllRallyPoints writer;
|
// kick off asynchronous write:
|
||||||
writer.set_logger_backend(this);
|
return _startup_messagewriter->writeallrallypoints();
|
||||||
writer.process();
|
|
||||||
}
|
}
|
||||||
|
@ -83,11 +83,11 @@ public:
|
|||||||
uint8_t num_multipliers() const;
|
uint8_t num_multipliers() const;
|
||||||
const struct MultiplierStructure *multiplier(uint8_t multiplier) const;
|
const struct MultiplierStructure *multiplier(uint8_t multiplier) const;
|
||||||
|
|
||||||
void Write_EntireMission();
|
bool Write_EntireMission();
|
||||||
bool Write_RallyPoint(uint8_t total,
|
bool Write_RallyPoint(uint8_t total,
|
||||||
uint8_t sequence,
|
uint8_t sequence,
|
||||||
const RallyLocation &rally_point);
|
const RallyLocation &rally_point);
|
||||||
void Write_Rally();
|
bool Write_Rally();
|
||||||
bool Write_Format(const struct LogStructure *structure);
|
bool Write_Format(const struct LogStructure *structure);
|
||||||
bool Write_Message(const char *message);
|
bool Write_Message(const char *message);
|
||||||
bool Write_MessageF(const char *fmt, ...);
|
bool Write_MessageF(const char *fmt, ...);
|
||||||
|
@ -448,11 +448,10 @@ bool AP_Logger_Backend::Write_Mission_Cmd(const AP_Mission &mission,
|
|||||||
return WriteBlock(&pkt, sizeof(pkt));
|
return WriteBlock(&pkt, sizeof(pkt));
|
||||||
}
|
}
|
||||||
|
|
||||||
void AP_Logger_Backend::Write_EntireMission()
|
bool AP_Logger_Backend::Write_EntireMission()
|
||||||
{
|
{
|
||||||
LoggerMessageWriter_WriteEntireMission writer{};
|
// kick off asynchronous write:
|
||||||
writer.set_logger_backend(this);
|
return _startup_messagewriter->writeentiremission();
|
||||||
writer.process();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write a text message to the log
|
// Write a text message to the log
|
||||||
|
@ -104,39 +104,28 @@ void LoggerMessageWriter_DFLogStart::process()
|
|||||||
ap = AP_Param::next_scalar(&token, &type);
|
ap = AP_Param::next_scalar(&token, &type);
|
||||||
}
|
}
|
||||||
|
|
||||||
stage = Stage::SYSINFO;
|
stage = Stage::RUNNING_SUBWRITERS;
|
||||||
FALLTHROUGH;
|
FALLTHROUGH;
|
||||||
|
|
||||||
case Stage::SYSINFO:
|
case Stage::RUNNING_SUBWRITERS:
|
||||||
|
if (!_writesysinfo.finished()) {
|
||||||
_writesysinfo.process();
|
_writesysinfo.process();
|
||||||
if (AP::scheduler().time_available_usec() < MIN_LOOP_TIME_REMAINING_FOR_MESSAGE_WRITE_US) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (!_writesysinfo.finished()) {
|
if (!_writesysinfo.finished()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
stage = Stage::WRITE_ENTIRE_MISSION;
|
|
||||||
FALLTHROUGH;
|
|
||||||
|
|
||||||
case Stage::WRITE_ENTIRE_MISSION:
|
|
||||||
_writeentiremission.process();
|
|
||||||
if (AP::scheduler().time_available_usec() < MIN_LOOP_TIME_REMAINING_FOR_MESSAGE_WRITE_US) {
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
if (!_writeentiremission.finished()) {
|
||||||
|
_writeentiremission.process();
|
||||||
if (!_writeentiremission.finished()) {
|
if (!_writeentiremission.finished()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
stage = Stage::WRITE_ALL_RALLY_POINTS;
|
|
||||||
FALLTHROUGH;
|
|
||||||
|
|
||||||
case Stage::WRITE_ALL_RALLY_POINTS:
|
|
||||||
_writeallrallypoints.process();
|
|
||||||
if (AP::scheduler().time_available_usec() < MIN_LOOP_TIME_REMAINING_FOR_MESSAGE_WRITE_US) {
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
if (!_writeallrallypoints.finished()) {
|
||||||
|
_writeallrallypoints.process();
|
||||||
if (!_writeallrallypoints.finished()) {
|
if (!_writeallrallypoints.finished()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
stage = Stage::VEHICLE_MESSAGES;
|
stage = Stage::VEHICLE_MESSAGES;
|
||||||
FALLTHROUGH;
|
FALLTHROUGH;
|
||||||
|
|
||||||
@ -160,6 +149,28 @@ void LoggerMessageWriter_DFLogStart::process()
|
|||||||
_finished = true;
|
_finished = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool LoggerMessageWriter_DFLogStart::writeentiremission()
|
||||||
|
{
|
||||||
|
if (stage != Stage::DONE) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
stage = Stage::RUNNING_SUBWRITERS;
|
||||||
|
_finished = false;
|
||||||
|
_writeentiremission.reset();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LoggerMessageWriter_DFLogStart::writeallrallypoints()
|
||||||
|
{
|
||||||
|
if (stage != Stage::DONE) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
stage = Stage::RUNNING_SUBWRITERS;
|
||||||
|
_finished = false;
|
||||||
|
_writeallrallypoints.reset();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void LoggerMessageWriter_WriteSysInfo::reset()
|
void LoggerMessageWriter_WriteSysInfo::reset()
|
||||||
{
|
{
|
||||||
LoggerMessageWriter::reset();
|
LoggerMessageWriter::reset();
|
||||||
@ -250,6 +261,9 @@ void LoggerMessageWriter_WriteAllRallyPoints::process()
|
|||||||
|
|
||||||
case Stage::WRITE_ALL_RALLY_POINTS:
|
case Stage::WRITE_ALL_RALLY_POINTS:
|
||||||
while (_rally_number_to_send < _rally->get_rally_total()) {
|
while (_rally_number_to_send < _rally->get_rally_total()) {
|
||||||
|
if (AP::scheduler().time_available_usec() < MIN_LOOP_TIME_REMAINING_FOR_MESSAGE_WRITE_US) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
RallyLocation rallypoint;
|
RallyLocation rallypoint;
|
||||||
if (_rally->get_rally_point_with_index(_rally_number_to_send, rallypoint)) {
|
if (_rally->get_rally_point_with_index(_rally_number_to_send, rallypoint)) {
|
||||||
if (!_logger_backend->Write_RallyPoint(
|
if (!_logger_backend->Write_RallyPoint(
|
||||||
@ -297,6 +311,9 @@ void LoggerMessageWriter_WriteEntireMission::process() {
|
|||||||
case Stage::WRITE_MISSION_ITEMS: {
|
case Stage::WRITE_MISSION_ITEMS: {
|
||||||
AP_Mission::Mission_Command cmd;
|
AP_Mission::Mission_Command cmd;
|
||||||
while (_mission_number_to_send < _mission->num_commands()) {
|
while (_mission_number_to_send < _mission->num_commands()) {
|
||||||
|
if (AP::scheduler().time_available_usec() < MIN_LOOP_TIME_REMAINING_FOR_MESSAGE_WRITE_US) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
// upon failure to write the mission we will re-read from
|
// upon failure to write the mission we will re-read from
|
||||||
// storage; this could be improved.
|
// storage; this could be improved.
|
||||||
if (_mission->read_cmd_from_storage(_mission_number_to_send,cmd)) {
|
if (_mission->read_cmd_from_storage(_mission_number_to_send,cmd)) {
|
||||||
|
@ -91,6 +91,11 @@ public:
|
|||||||
void process() override;
|
void process() override;
|
||||||
bool fmt_done() { return _fmt_done; }
|
bool fmt_done() { return _fmt_done; }
|
||||||
|
|
||||||
|
// reset some writers so we push stuff out to logs again. Will
|
||||||
|
// only work if we are in state DONE!
|
||||||
|
bool writeentiremission();
|
||||||
|
bool writeallrallypoints();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
enum Stage {
|
enum Stage {
|
||||||
@ -99,10 +104,8 @@ private:
|
|||||||
MULTIPLIERS,
|
MULTIPLIERS,
|
||||||
FORMAT_UNITS,
|
FORMAT_UNITS,
|
||||||
PARMS,
|
PARMS,
|
||||||
SYSINFO,
|
|
||||||
WRITE_ENTIRE_MISSION,
|
|
||||||
WRITE_ALL_RALLY_POINTS,
|
|
||||||
VEHICLE_MESSAGES,
|
VEHICLE_MESSAGES,
|
||||||
|
RUNNING_SUBWRITERS, // must be last thing to run as we can redo bits of these
|
||||||
DONE,
|
DONE,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user