Plane: log the number of lost log messages

This commit is contained in:
Andrew Tridgell 2016-04-21 16:11:48 +10:00
parent c765979f9a
commit cf7b6123a9
4 changed files with 15 additions and 8 deletions

View File

@ -340,11 +340,12 @@ void Plane::one_second_loop()
void Plane::log_perf_info() void Plane::log_perf_info()
{ {
if (scheduler.debug() != 0) { if (scheduler.debug() != 0) {
gcs_send_text_fmt(MAV_SEVERITY_INFO, "PERF: %u/%u %lu %lu\n", gcs_send_text_fmt(MAV_SEVERITY_INFO, "PERF: %u/%u Dt=%u/%u Log=%u\n",
(unsigned)perf.num_long, (unsigned)perf.num_long,
(unsigned)perf.mainLoop_count, (unsigned)perf.mainLoop_count,
(unsigned long)perf.G_Dt_max, (unsigned)perf.G_Dt_max,
(unsigned long)perf.G_Dt_min); (unsigned)perf.G_Dt_min,
(unsigned)(DataFlash.num_dropped() - perf.last_log_dropped));
} }
if (should_log(MASK_LOG_PM)) { if (should_log(MASK_LOG_PM)) {

View File

@ -198,6 +198,7 @@ struct PACKED log_Performance {
uint16_t main_loop_count; uint16_t main_loop_count;
uint32_t g_dt_max; uint32_t g_dt_max;
uint32_t g_dt_min; uint32_t g_dt_min;
uint32_t log_dropped;
}; };
// Write a performance monitoring packet. Total length : 19 bytes // Write a performance monitoring packet. Total length : 19 bytes
@ -209,9 +210,10 @@ void Plane::Log_Write_Performance()
num_long : perf.num_long, num_long : perf.num_long,
main_loop_count : perf.mainLoop_count, main_loop_count : perf.mainLoop_count,
g_dt_max : perf.G_Dt_max, g_dt_max : perf.G_Dt_max,
g_dt_min : perf.G_Dt_min g_dt_min : perf.G_Dt_min,
log_dropped : DataFlash.num_dropped() - perf.last_log_dropped
}; };
DataFlash.WriteBlock(&pkt, sizeof(pkt)); DataFlash.WriteCriticalBlock(&pkt, sizeof(pkt));
} }
struct PACKED log_Startup { struct PACKED log_Startup {
@ -229,7 +231,7 @@ void Plane::Log_Write_Startup(uint8_t type)
startup_type : type, startup_type : type,
command_total : mission.num_commands() command_total : mission.num_commands()
}; };
DataFlash.WriteBlock(&pkt, sizeof(pkt)); DataFlash.WriteCriticalBlock(&pkt, sizeof(pkt));
} }
struct PACKED log_Control_Tuning { struct PACKED log_Control_Tuning {
@ -424,7 +426,7 @@ void Plane::Log_Arm_Disarm() {
arm_state : arming.is_armed(), arm_state : arming.is_armed(),
arm_checks : arming.get_enabled_checks() arm_checks : arming.get_enabled_checks()
}; };
DataFlash.WriteBlock(&pkt, sizeof(pkt)); DataFlash.WriteCriticalBlock(&pkt, sizeof(pkt));
} }
void Plane::Log_Write_GPS(uint8_t instance) void Plane::Log_Write_GPS(uint8_t instance)
@ -477,7 +479,7 @@ void Plane::Log_Write_Home_And_Origin()
const struct LogStructure Plane::log_structure[] = { const struct LogStructure Plane::log_structure[] = {
LOG_COMMON_STRUCTURES, LOG_COMMON_STRUCTURES,
{ LOG_PERFORMANCE_MSG, sizeof(log_Performance), { LOG_PERFORMANCE_MSG, sizeof(log_Performance),
"PM", "QHHII", "TimeUS,NLon,NLoop,MaxT,MinT" }, "PM", "QHHIII", "TimeUS,NLon,NLoop,MaxT,MinT,LogDrop" },
{ LOG_STARTUP_MSG, sizeof(log_Startup), { LOG_STARTUP_MSG, sizeof(log_Startup),
"STRT", "QBH", "TimeUS,SType,CTot" }, "STRT", "QBH", "TimeUS,SType,CTot" },
{ LOG_CTUN_MSG, sizeof(log_Control_Tuning), { LOG_CTUN_MSG, sizeof(log_Control_Tuning),

View File

@ -706,6 +706,9 @@ private:
// number of long loops // number of long loops
uint16_t num_long; uint16_t num_long;
// accumulated lost log messages
uint32_t last_log_dropped;
} perf; } perf;
// Camera/Antenna mount tracking and stabilisation stuff // Camera/Antenna mount tracking and stabilisation stuff

View File

@ -637,6 +637,7 @@ void Plane::resetPerfData(void)
perf.G_Dt_min = 0; perf.G_Dt_min = 0;
perf.num_long = 0; perf.num_long = 0;
perf.start_ms = millis(); perf.start_ms = millis();
perf.last_log_dropped = DataFlash.num_dropped();
} }