2011-11-12 23:29:07 -04:00
|
|
|
/* ************************************************************ */
|
2019-01-18 00:23:42 -04:00
|
|
|
/* Test for AP_Logger Log library */
|
2011-11-12 23:29:07 -04:00
|
|
|
/* ************************************************************ */
|
2016-02-17 21:25:53 -04:00
|
|
|
#pragma once
|
2011-11-12 23:29:07 -04:00
|
|
|
|
2021-01-06 22:04:09 -04:00
|
|
|
#include <AP_Filesystem/AP_Filesystem_Available.h>
|
|
|
|
|
2021-05-17 03:51:37 -03:00
|
|
|
#ifndef HAL_LOGGING_ENABLED
|
|
|
|
#define HAL_LOGGING_ENABLED 1
|
|
|
|
#endif
|
|
|
|
|
2021-01-06 22:04:09 -04:00
|
|
|
// set default for HAL_LOGGING_DATAFLASH_ENABLED
|
|
|
|
#ifndef HAL_LOGGING_DATAFLASH_ENABLED
|
2021-12-21 01:02:05 -04:00
|
|
|
#define HAL_LOGGING_DATAFLASH_ENABLED (CONFIG_HAL_BOARD == HAL_BOARD_SITL)
|
2021-01-06 22:04:09 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef HAL_LOGGING_MAVLINK_ENABLED
|
2021-05-19 23:34:13 -03:00
|
|
|
#define HAL_LOGGING_MAVLINK_ENABLED HAL_LOGGING_ENABLED
|
2021-01-06 22:04:09 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef HAL_LOGGING_FILESYSTEM_ENABLED
|
|
|
|
#if HAVE_FILESYSTEM_SUPPORT
|
2021-05-19 23:34:13 -03:00
|
|
|
#define HAL_LOGGING_FILESYSTEM_ENABLED HAL_LOGGING_ENABLED
|
2021-01-06 22:04:09 -04:00
|
|
|
#else
|
|
|
|
#define HAL_LOGGING_FILESYSTEM_ENABLED 0
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2021-12-21 01:02:05 -04:00
|
|
|
#if HAL_LOGGING_DATAFLASH_ENABLED
|
2021-01-06 22:04:09 -04:00
|
|
|
#define HAL_LOGGING_BLOCK_ENABLED 1
|
|
|
|
#else
|
|
|
|
#define HAL_LOGGING_BLOCK_ENABLED 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if HAL_LOGGING_FILESYSTEM_ENABLED
|
|
|
|
|
|
|
|
#if !defined (HAL_BOARD_LOG_DIRECTORY)
|
|
|
|
#error Need HAL_BOARD_LOG_DIRECTORY for filesystem backend support
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined (HAVE_FILESYSTEM_SUPPORT)
|
|
|
|
#error Need HAVE_FILESYSTEM_SUPPORT for filesystem backend support
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2021-10-28 03:31:51 -03:00
|
|
|
#ifndef HAL_LOGGER_FILE_CONTENTS_ENABLED
|
|
|
|
#define HAL_LOGGER_FILE_CONTENTS_ENABLED HAL_LOGGING_FILESYSTEM_ENABLED
|
|
|
|
#endif
|
|
|
|
|
2021-03-06 02:36:57 -04:00
|
|
|
// range of IDs to allow for new messages during replay. It is very
|
|
|
|
// useful to be able to add new messages during a replay, but we need
|
|
|
|
// to avoid colliding with existing messages
|
|
|
|
#define REPLAY_LOG_NEW_MSG_MAX 230
|
|
|
|
#define REPLAY_LOG_NEW_MSG_MIN 220
|
|
|
|
|
2022-03-03 23:29:47 -04:00
|
|
|
#include <AC_PID/AC_PID.h>
|
2015-08-11 03:28:46 -03:00
|
|
|
#include <AP_HAL/AP_HAL.h>
|
2018-12-27 07:58:29 -04:00
|
|
|
#include <AP_AHRS/AP_AHRS.h>
|
|
|
|
#include <AP_AHRS/AP_AHRS_DCM.h>
|
2015-08-11 03:28:46 -03:00
|
|
|
#include <AP_Common/AP_Common.h>
|
|
|
|
#include <AP_Param/AP_Param.h>
|
|
|
|
#include <AP_Mission/AP_Mission.h>
|
2019-01-18 00:23:42 -04:00
|
|
|
#include <AP_Logger/LogStructure.h>
|
2016-03-24 22:11:11 -03:00
|
|
|
#include <AP_Motors/AP_Motors.h>
|
2016-07-03 23:14:26 -03:00
|
|
|
#include <AP_Rally/AP_Rally.h>
|
2019-10-17 00:48:00 -03:00
|
|
|
#include <AP_Vehicle/ModeReason.h>
|
2017-09-01 08:05:16 -03:00
|
|
|
|
2011-11-12 23:29:07 -04:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2019-01-18 00:23:42 -04:00
|
|
|
#include "LoggerMessageWriter.h"
|
2014-11-13 06:38:33 -04:00
|
|
|
|
2019-01-18 00:23:42 -04:00
|
|
|
class AP_Logger_Backend;
|
2019-08-27 17:08:01 -03:00
|
|
|
class AP_AHRS;
|
|
|
|
class AP_AHRS_View;
|
2015-11-09 18:14:22 -04:00
|
|
|
|
2019-02-01 07:29:43 -04:00
|
|
|
// do not do anything here apart from add stuff; maintaining older
|
|
|
|
// entries means log analysis is easier
|
2019-10-25 03:03:57 -03:00
|
|
|
enum class LogEvent : uint8_t {
|
|
|
|
ARMED = 10,
|
|
|
|
DISARMED = 11,
|
|
|
|
AUTO_ARMED = 15,
|
|
|
|
LAND_COMPLETE_MAYBE = 17,
|
|
|
|
LAND_COMPLETE = 18,
|
|
|
|
NOT_LANDED = 28,
|
|
|
|
LOST_GPS = 19,
|
|
|
|
FLIP_START = 21,
|
|
|
|
FLIP_END = 22,
|
|
|
|
SET_HOME = 25,
|
|
|
|
SET_SIMPLE_ON = 26,
|
|
|
|
SET_SIMPLE_OFF = 27,
|
|
|
|
SET_SUPERSIMPLE_ON = 29,
|
|
|
|
AUTOTUNE_INITIALISED = 30,
|
|
|
|
AUTOTUNE_OFF = 31,
|
|
|
|
AUTOTUNE_RESTART = 32,
|
|
|
|
AUTOTUNE_SUCCESS = 33,
|
|
|
|
AUTOTUNE_FAILED = 34,
|
|
|
|
AUTOTUNE_REACHED_LIMIT = 35,
|
|
|
|
AUTOTUNE_PILOT_TESTING = 36,
|
|
|
|
AUTOTUNE_SAVEDGAINS = 37,
|
|
|
|
SAVE_TRIM = 38,
|
|
|
|
SAVEWP_ADD_WP = 39,
|
|
|
|
FENCE_ENABLE = 41,
|
|
|
|
FENCE_DISABLE = 42,
|
|
|
|
ACRO_TRAINER_OFF = 43,
|
|
|
|
ACRO_TRAINER_LEVELING = 44,
|
|
|
|
ACRO_TRAINER_LIMITED = 45,
|
|
|
|
GRIPPER_GRAB = 46,
|
|
|
|
GRIPPER_RELEASE = 47,
|
|
|
|
PARACHUTE_DISABLED = 49,
|
|
|
|
PARACHUTE_ENABLED = 50,
|
|
|
|
PARACHUTE_RELEASED = 51,
|
|
|
|
LANDING_GEAR_DEPLOYED = 52,
|
|
|
|
LANDING_GEAR_RETRACTED = 53,
|
|
|
|
MOTORS_EMERGENCY_STOPPED = 54,
|
|
|
|
MOTORS_EMERGENCY_STOP_CLEARED = 55,
|
|
|
|
MOTORS_INTERLOCK_DISABLED = 56,
|
|
|
|
MOTORS_INTERLOCK_ENABLED = 57,
|
|
|
|
ROTOR_RUNUP_COMPLETE = 58, // Heli only
|
|
|
|
ROTOR_SPEED_BELOW_CRITICAL = 59, // Heli only
|
|
|
|
EKF_ALT_RESET = 60,
|
|
|
|
LAND_CANCELLED_BY_PILOT = 61,
|
|
|
|
EKF_YAW_RESET = 62,
|
|
|
|
AVOIDANCE_ADSB_ENABLE = 63,
|
|
|
|
AVOIDANCE_ADSB_DISABLE = 64,
|
|
|
|
AVOIDANCE_PROXIMITY_ENABLE = 65,
|
|
|
|
AVOIDANCE_PROXIMITY_DISABLE = 66,
|
|
|
|
GPS_PRIMARY_CHANGED = 67,
|
2020-07-24 01:28:30 -03:00
|
|
|
// 68, 69, 70 were winch events
|
2019-10-25 03:03:57 -03:00
|
|
|
ZIGZAG_STORE_A = 71,
|
|
|
|
ZIGZAG_STORE_B = 72,
|
|
|
|
LAND_REPO_ACTIVE = 73,
|
|
|
|
STANDBY_ENABLE = 74,
|
|
|
|
STANDBY_DISABLE = 75,
|
|
|
|
|
2020-09-11 00:14:11 -03:00
|
|
|
FENCE_FLOOR_ENABLE = 80,
|
|
|
|
FENCE_FLOOR_DISABLE = 81,
|
|
|
|
|
2021-07-15 22:54:35 -03:00
|
|
|
// if the EKF's source input set is changed (e.g. via a switch or
|
|
|
|
// a script), we log an event:
|
|
|
|
EK3_SOURCES_SET_TO_PRIMARY = 85,
|
|
|
|
EK3_SOURCES_SET_TO_SECONDARY = 86,
|
|
|
|
EK3_SOURCES_SET_TO_TERTIARY = 87,
|
|
|
|
|
2022-05-13 01:02:24 -03:00
|
|
|
AIRSPEED_PRIMARY_CHANGED = 90,
|
|
|
|
|
2019-10-25 03:03:57 -03:00
|
|
|
SURFACED = 163,
|
|
|
|
NOT_SURFACED = 164,
|
|
|
|
BOTTOMED = 165,
|
|
|
|
NOT_BOTTOMED = 166,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum class LogDataID : uint8_t {
|
|
|
|
AP_STATE = 7,
|
|
|
|
// SYSTEM_TIME_SET = 8,
|
|
|
|
INIT_SIMPLE_BEARING = 9,
|
2019-02-01 07:29:43 -04:00
|
|
|
};
|
|
|
|
|
2019-03-24 22:04:59 -03:00
|
|
|
enum class LogErrorSubsystem : uint8_t {
|
|
|
|
MAIN = 1,
|
|
|
|
RADIO = 2,
|
|
|
|
COMPASS = 3,
|
|
|
|
OPTFLOW = 4, // not used
|
|
|
|
FAILSAFE_RADIO = 5,
|
|
|
|
FAILSAFE_BATT = 6,
|
|
|
|
FAILSAFE_GPS = 7, // not used
|
|
|
|
FAILSAFE_GCS = 8,
|
|
|
|
FAILSAFE_FENCE = 9,
|
|
|
|
FLIGHT_MODE = 10,
|
|
|
|
GPS = 11,
|
|
|
|
CRASH_CHECK = 12,
|
|
|
|
FLIP = 13,
|
|
|
|
AUTOTUNE = 14, // not used
|
|
|
|
PARACHUTES = 15,
|
|
|
|
EKFCHECK = 16,
|
|
|
|
FAILSAFE_EKFINAV = 17,
|
|
|
|
BARO = 18,
|
|
|
|
CPU = 19,
|
|
|
|
FAILSAFE_ADSB = 20,
|
|
|
|
TERRAIN = 21,
|
|
|
|
NAVIGATION = 22,
|
|
|
|
FAILSAFE_TERRAIN = 23,
|
|
|
|
EKF_PRIMARY = 24,
|
|
|
|
THRUST_LOSS_CHECK = 25,
|
2019-03-24 22:52:59 -03:00
|
|
|
FAILSAFE_SENSORS = 26,
|
|
|
|
FAILSAFE_LEAK = 27,
|
|
|
|
PILOT_INPUT = 28,
|
2019-10-04 23:13:59 -03:00
|
|
|
FAILSAFE_VIBE = 29,
|
2021-08-28 13:18:07 -03:00
|
|
|
INTERNAL_ERROR = 30,
|
2022-05-10 23:16:44 -03:00
|
|
|
FAILSAFE_DEADRECKON = 31
|
2019-03-24 22:04:59 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
// bizarrely this enumeration has lots of duplicate values, offering
|
|
|
|
// very little in the way of typesafety
|
|
|
|
enum class LogErrorCode : uint8_t {
|
|
|
|
// general error codes
|
|
|
|
ERROR_RESOLVED = 0,
|
|
|
|
FAILED_TO_INITIALISE = 1,
|
|
|
|
UNHEALTHY = 4,
|
|
|
|
// subsystem specific error codes -- radio
|
|
|
|
RADIO_LATE_FRAME = 2,
|
|
|
|
// subsystem specific error codes -- failsafe_thr, batt, gps
|
|
|
|
FAILSAFE_RESOLVED = 0,
|
|
|
|
FAILSAFE_OCCURRED = 1,
|
|
|
|
// subsystem specific error codes -- main
|
|
|
|
MAIN_INS_DELAY = 1,
|
|
|
|
// subsystem specific error codes -- crash checker
|
|
|
|
CRASH_CHECK_CRASH = 1,
|
|
|
|
CRASH_CHECK_LOSS_OF_CONTROL = 2,
|
|
|
|
// subsystem specific error codes -- flip
|
|
|
|
FLIP_ABANDONED = 2,
|
|
|
|
// subsystem specific error codes -- terrain
|
|
|
|
MISSING_TERRAIN_DATA = 2,
|
|
|
|
// subsystem specific error codes -- navigation
|
|
|
|
FAILED_TO_SET_DESTINATION = 2,
|
|
|
|
RESTARTED_RTL = 3,
|
|
|
|
FAILED_CIRCLE_INIT = 4,
|
|
|
|
DEST_OUTSIDE_FENCE = 5,
|
2019-12-12 02:22:03 -04:00
|
|
|
RTL_MISSING_RNGFND = 6,
|
2021-08-28 13:18:07 -03:00
|
|
|
// subsystem specific error codes -- internal_error
|
|
|
|
INTERNAL_ERRORS_DETECTED = 1,
|
2019-03-24 22:04:59 -03:00
|
|
|
|
|
|
|
// parachute failed to deploy because of low altitude or landed
|
|
|
|
PARACHUTE_TOO_LOW = 2,
|
|
|
|
PARACHUTE_LANDED = 3,
|
|
|
|
// EKF check definitions
|
|
|
|
EKFCHECK_BAD_VARIANCE = 2,
|
|
|
|
EKFCHECK_VARIANCE_CLEARED = 0,
|
|
|
|
// Baro specific error codes
|
|
|
|
BARO_GLITCH = 2,
|
2019-03-26 23:52:32 -03:00
|
|
|
BAD_DEPTH = 3, // sub-only
|
2019-03-24 22:04:59 -03:00
|
|
|
// GPS specific error coces
|
|
|
|
GPS_GLITCH = 2,
|
|
|
|
};
|
|
|
|
|
2019-01-18 00:23:42 -04:00
|
|
|
class AP_Logger
|
2011-11-12 23:29:07 -04:00
|
|
|
{
|
2019-01-18 00:23:42 -04:00
|
|
|
friend class AP_Logger_Backend; // for _num_types
|
2021-07-27 05:47:45 -03:00
|
|
|
friend class AP_Logger_RateLimiter;
|
2015-08-06 09:18:28 -03:00
|
|
|
|
2013-02-22 20:17:34 -04:00
|
|
|
public:
|
2019-01-18 00:24:08 -04:00
|
|
|
FUNCTOR_TYPEDEF(vehicle_startup_message_Writer, void);
|
2017-08-23 17:40:59 -03:00
|
|
|
|
2019-01-18 00:23:42 -04:00
|
|
|
AP_Logger(const AP_Int32 &log_bitmask);
|
2017-12-12 21:06:15 -04:00
|
|
|
|
|
|
|
/* Do not allow copies */
|
2019-01-18 00:23:42 -04:00
|
|
|
AP_Logger(const AP_Logger &other) = delete;
|
|
|
|
AP_Logger &operator=(const AP_Logger&) = delete;
|
2015-08-06 09:18:28 -03:00
|
|
|
|
2016-05-03 03:33:15 -03:00
|
|
|
// get singleton instance
|
2019-02-10 14:05:22 -04:00
|
|
|
static AP_Logger *get_singleton(void) {
|
|
|
|
return _singleton;
|
2016-05-03 03:33:15 -03:00
|
|
|
}
|
2017-08-23 17:40:59 -03:00
|
|
|
|
2013-02-22 20:17:34 -04:00
|
|
|
// initialisation
|
2015-06-25 10:53:20 -03:00
|
|
|
void Init(const struct LogStructure *structure, uint8_t num_types);
|
2018-04-22 07:19:30 -03:00
|
|
|
void set_num_types(uint8_t num_types) { _num_types = num_types; }
|
2015-12-07 20:21:18 -04:00
|
|
|
|
2015-06-25 10:53:20 -03:00
|
|
|
bool CardInserted(void);
|
2013-02-22 20:17:34 -04:00
|
|
|
|
|
|
|
// erase handling
|
2015-06-25 10:53:20 -03:00
|
|
|
void EraseAll();
|
2013-02-22 20:17:34 -04:00
|
|
|
|
|
|
|
/* Write a block of data at current offset */
|
2015-11-09 18:14:22 -04:00
|
|
|
void WriteBlock(const void *pBuffer, uint16_t size);
|
2021-02-09 15:05:03 -04:00
|
|
|
|
|
|
|
/* Write block of data at current offset and return true if first backend succeeds*/
|
|
|
|
bool WriteBlock_first_succeed(const void *pBuffer, uint16_t size);
|
|
|
|
|
2015-08-06 09:18:28 -03:00
|
|
|
/* Write an *important* block of data at current offset */
|
2015-11-09 18:14:22 -04:00
|
|
|
void WriteCriticalBlock(const void *pBuffer, uint16_t size);
|
2013-02-22 20:17:34 -04:00
|
|
|
|
2020-11-05 19:28:26 -04:00
|
|
|
/* Write a block of replay data at current offset */
|
|
|
|
bool WriteReplayBlock(uint8_t msg_id, const void *pBuffer, uint16_t size);
|
|
|
|
|
2013-02-22 20:17:34 -04:00
|
|
|
// high level interface
|
2015-10-20 07:32:31 -03:00
|
|
|
uint16_t find_last_log() const;
|
2019-01-18 18:45:36 -04:00
|
|
|
void get_log_boundaries(uint16_t log_num, uint32_t & start_page, uint32_t & end_page);
|
2015-06-25 10:53:20 -03:00
|
|
|
uint16_t get_num_logs(void);
|
2013-02-22 20:17:34 -04:00
|
|
|
|
2019-01-18 00:24:08 -04:00
|
|
|
void setVehicle_Startup_Writer(vehicle_startup_message_Writer writer);
|
2015-08-06 09:18:28 -03:00
|
|
|
|
2017-07-06 22:28:42 -03:00
|
|
|
void PrepForArming();
|
|
|
|
|
2017-06-14 22:21:17 -03:00
|
|
|
void EnableWrites(bool enable) { _writes_enabled = enable; }
|
|
|
|
bool WritesEnabled() const { return _writes_enabled; }
|
2016-01-01 06:03:22 -04:00
|
|
|
|
2016-04-22 10:33:40 -03:00
|
|
|
void StopLogging();
|
|
|
|
|
2019-01-18 00:24:08 -04:00
|
|
|
void Write_Parameter(const char *name, float value);
|
2019-10-25 03:03:57 -03:00
|
|
|
void Write_Event(LogEvent id);
|
2019-03-24 22:04:59 -03:00
|
|
|
void Write_Error(LogErrorSubsystem sub_system,
|
|
|
|
LogErrorCode error_code);
|
2019-01-18 00:24:08 -04:00
|
|
|
void Write_RCIN(void);
|
|
|
|
void Write_RCOUT(void);
|
2019-04-05 19:48:11 -03:00
|
|
|
void Write_RSSI();
|
2019-03-28 03:45:53 -03:00
|
|
|
void Write_Rally();
|
2019-01-18 00:24:08 -04:00
|
|
|
void Write_Power(void);
|
|
|
|
void Write_Radio(const mavlink_radio_t &packet);
|
|
|
|
void Write_Message(const char *message);
|
|
|
|
void Write_MessageF(const char *fmt, ...);
|
2020-01-04 00:25:55 -04:00
|
|
|
void Write_ServoStatus(uint64_t time_us, uint8_t id, float position, float force, float speed, uint8_t power_pct);
|
2020-11-19 18:25:51 -04:00
|
|
|
void Write_Compass();
|
2019-10-17 00:48:00 -03:00
|
|
|
void Write_Mode(uint8_t mode, const ModeReason reason);
|
2019-01-18 00:24:08 -04:00
|
|
|
|
2019-01-29 21:43:24 -04:00
|
|
|
void Write_EntireMission();
|
2021-09-04 03:40:38 -03:00
|
|
|
void Write_Command(const mavlink_command_int_t &packet,
|
|
|
|
uint8_t source_system,
|
|
|
|
uint8_t source_component,
|
|
|
|
MAV_RESULT result,
|
|
|
|
bool was_command_long=false);
|
2019-01-18 00:24:08 -04:00
|
|
|
void Write_Mission_Cmd(const AP_Mission &mission,
|
2015-06-30 01:33:50 -03:00
|
|
|
const AP_Mission::Mission_Command &cmd);
|
2018-12-29 00:02:29 -04:00
|
|
|
void Write_RallyPoint(uint8_t total,
|
|
|
|
uint8_t sequence,
|
|
|
|
const RallyLocation &rally_point);
|
2019-01-18 00:24:08 -04:00
|
|
|
void Write_SRTL(bool active, uint16_t num_points, uint16_t max_points, uint8_t action, const Vector3f& point);
|
2020-07-24 02:59:41 -03:00
|
|
|
void Write_Winch(bool healthy, bool thread_end, bool moving, bool clutch, uint8_t mode, float desired_length, float length, float desired_rate, uint16_t tension, float voltage, int8_t temp);
|
2021-09-21 23:41:15 -03:00
|
|
|
void Write_PSCN(float pos_target, float pos, float vel_desired, float vel_target, float vel, float accel_desired, float accel_target, float accel);
|
|
|
|
void Write_PSCE(float pos_target, float pos, float vel_desired, float vel_target, float vel, float accel_desired, float accel_target, float accel);
|
|
|
|
void Write_PSCD(float pos_target, float pos, float vel_desired, float vel_target, float vel, float accel_desired, float accel_target, float accel);
|
2015-06-30 01:33:50 -03:00
|
|
|
|
2019-01-18 00:24:08 -04:00
|
|
|
void Write(const char *name, const char *labels, const char *fmt, ...);
|
|
|
|
void Write(const char *name, const char *labels, const char *units, const char *mults, const char *fmt, ...);
|
2021-07-27 05:47:45 -03:00
|
|
|
void WriteStreaming(const char *name, const char *labels, const char *fmt, ...);
|
|
|
|
void WriteStreaming(const char *name, const char *labels, const char *units, const char *mults, const char *fmt, ...);
|
2019-05-15 01:39:32 -03:00
|
|
|
void WriteCritical(const char *name, const char *labels, const char *fmt, ...);
|
|
|
|
void WriteCritical(const char *name, const char *labels, const char *units, const char *mults, const char *fmt, ...);
|
2021-07-27 05:47:45 -03:00
|
|
|
void WriteV(const char *name, const char *labels, const char *units, const char *mults, const char *fmt, va_list arg_list, bool is_critical=false, bool is_streaming=false);
|
2016-04-20 02:07:48 -03:00
|
|
|
|
2022-03-03 23:29:47 -04:00
|
|
|
void Write_PID(uint8_t msg_type, const AP_PIDInfo &info);
|
2015-05-21 22:42:08 -03:00
|
|
|
|
2017-06-27 01:14:27 -03:00
|
|
|
// returns true if logging of a message should be attempted
|
|
|
|
bool should_log(uint32_t mask) const;
|
2017-06-14 09:45:54 -03:00
|
|
|
|
2015-06-25 10:53:20 -03:00
|
|
|
bool logging_started(void);
|
2013-04-19 04:49:16 -03:00
|
|
|
|
2015-06-18 22:57:01 -03:00
|
|
|
#if CONFIG_HAL_BOARD == HAL_BOARD_SITL || CONFIG_HAL_BOARD == HAL_BOARD_LINUX
|
2019-01-18 00:23:42 -04:00
|
|
|
// currently only AP_Logger_File support this:
|
2015-06-18 22:57:01 -03:00
|
|
|
void flush(void);
|
|
|
|
#endif
|
|
|
|
|
2019-04-30 07:22:48 -03:00
|
|
|
void handle_mavlink_msg(class GCS_MAVLINK &, const mavlink_message_t &msg);
|
2015-11-10 02:34:31 -04:00
|
|
|
|
2015-08-06 09:18:28 -03:00
|
|
|
void periodic_tasks(); // may want to split this into GCS/non-GCS duties
|
|
|
|
|
2020-11-05 19:28:26 -04:00
|
|
|
// We may need to make sure data is loggable before starting the
|
|
|
|
// EKF; when allow_start_ekf we should be able to log that data
|
|
|
|
bool allow_start_ekf() const;
|
|
|
|
|
2016-04-21 03:11:21 -03:00
|
|
|
// number of blocks that have been dropped
|
|
|
|
uint32_t num_dropped(void) const;
|
2016-05-08 23:00:55 -03:00
|
|
|
|
|
|
|
// accesss to public parameters
|
2018-07-05 20:58:50 -03:00
|
|
|
void set_force_log_disarmed(bool force_logging) { _force_log_disarmed = force_logging; }
|
2021-09-06 22:42:02 -03:00
|
|
|
void set_long_log_persist(bool b) { _force_long_log_persist = b; }
|
2019-06-10 18:55:30 -03:00
|
|
|
bool log_while_disarmed(void) const;
|
2016-05-08 23:00:55 -03:00
|
|
|
uint8_t log_replay(void) const { return _params.log_replay; }
|
2020-11-05 19:28:26 -04:00
|
|
|
|
2019-01-18 00:24:08 -04:00
|
|
|
vehicle_startup_message_Writer _vehicle_messages;
|
2015-08-06 09:18:28 -03:00
|
|
|
|
2015-11-09 18:14:22 -04:00
|
|
|
// parameter support
|
|
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
struct {
|
|
|
|
AP_Int8 backend_types;
|
2020-11-07 23:55:57 -04:00
|
|
|
AP_Int16 file_bufsize; // in kilobytes
|
2016-07-28 02:58:20 -03:00
|
|
|
AP_Int8 file_disarm_rot;
|
2016-05-08 23:00:55 -03:00
|
|
|
AP_Int8 log_disarmed;
|
|
|
|
AP_Int8 log_replay;
|
2018-04-23 01:35:29 -03:00
|
|
|
AP_Int8 mav_bufsize; // in kilobytes
|
2019-08-03 04:00:17 -03:00
|
|
|
AP_Int16 file_timeout; // in seconds
|
2020-06-01 17:07:07 -03:00
|
|
|
AP_Int16 min_MB_free;
|
2021-07-27 05:47:45 -03:00
|
|
|
AP_Float file_ratemax;
|
2021-07-28 03:52:35 -03:00
|
|
|
AP_Float mav_ratemax;
|
|
|
|
AP_Float blk_ratemax;
|
2015-11-09 18:14:22 -04:00
|
|
|
} _params;
|
|
|
|
|
|
|
|
const struct LogStructure *structure(uint16_t num) const;
|
2015-12-07 20:51:46 -04:00
|
|
|
const struct UnitStructure *unit(uint16_t num) const;
|
|
|
|
const struct MultiplierStructure *multiplier(uint16_t num) const;
|
2015-11-09 18:14:22 -04:00
|
|
|
|
2018-12-04 00:33:02 -04:00
|
|
|
// methods for mavlink SYS_STATUS message (send_sys_status)
|
2016-07-07 04:12:27 -03:00
|
|
|
// these methods cover only the first logging backend used -
|
2019-01-18 00:23:42 -04:00
|
|
|
// typically AP_Logger_File.
|
2016-07-07 04:12:27 -03:00
|
|
|
bool logging_present() const;
|
|
|
|
bool logging_enabled() const;
|
|
|
|
bool logging_failed() const;
|
|
|
|
|
2019-06-10 18:55:30 -03:00
|
|
|
// notify logging subsystem of an arming failure. This triggers
|
|
|
|
// logging for HAL_LOGGER_ARM_PERSIST seconds
|
2022-01-05 22:05:15 -04:00
|
|
|
void arming_failure() {
|
|
|
|
_last_arming_failure_ms = AP_HAL::millis();
|
|
|
|
#if HAL_LOGGER_FILE_CONTENTS_ENABLED
|
|
|
|
file_content_prepare_for_arming = true;
|
|
|
|
#endif
|
|
|
|
}
|
2019-06-10 18:55:30 -03:00
|
|
|
|
2016-07-28 00:06:03 -03:00
|
|
|
void set_vehicle_armed(bool armed_state);
|
2017-06-09 01:19:11 -03:00
|
|
|
bool vehicle_is_armed() const { return _armed; }
|
2016-07-28 00:06:03 -03:00
|
|
|
|
2018-03-19 00:37:21 -03:00
|
|
|
void handle_log_send();
|
2021-04-30 22:15:11 -03:00
|
|
|
bool in_log_download() const;
|
2017-06-18 20:43:15 -03:00
|
|
|
|
2017-07-21 23:27:45 -03:00
|
|
|
float quiet_nanf() const { return nanf("0x4152"); } // "AR"
|
|
|
|
double quiet_nan() const { return nan("0x4152445550490a"); } // "ARDUPI"
|
|
|
|
|
2018-04-22 07:19:30 -03:00
|
|
|
// returns true if msg_type is associated with a message
|
|
|
|
bool msg_type_in_use(uint8_t msg_type) const;
|
|
|
|
|
2020-01-15 22:17:01 -04:00
|
|
|
// calculate the length of a message using fields specified in
|
|
|
|
// fmt; includes the message header
|
|
|
|
int16_t Write_calc_msg_len(const char *fmt) const;
|
|
|
|
|
|
|
|
// this structure looks much like struct LogStructure in
|
|
|
|
// LogStructure.h, however we need to remember a pointer value for
|
|
|
|
// efficiency of finding message types
|
|
|
|
struct log_write_fmt {
|
|
|
|
struct log_write_fmt *next;
|
|
|
|
uint8_t msg_type;
|
|
|
|
uint8_t msg_len;
|
|
|
|
uint8_t sent_mask; // bitmask of backends sent to
|
|
|
|
const char *name;
|
|
|
|
const char *fmt;
|
|
|
|
const char *labels;
|
|
|
|
const char *units;
|
|
|
|
const char *mults;
|
|
|
|
} *log_write_fmts;
|
|
|
|
|
|
|
|
// return (possibly allocating) a log_write_fmt for a name
|
|
|
|
struct log_write_fmt *msg_fmt_for_name(const char *name, const char *labels, const char *units, const char *mults, const char *fmt, const bool direct_comp = false);
|
|
|
|
|
|
|
|
// output a FMT message for each backend if not already done so
|
|
|
|
void Safe_Write_Emit_FMT(log_write_fmt *f);
|
|
|
|
|
2020-12-31 17:03:06 -04:00
|
|
|
// get count of number of times we have started logging
|
|
|
|
uint8_t get_log_start_count(void) const {
|
|
|
|
return _log_start_count;
|
|
|
|
}
|
|
|
|
|
2021-10-28 03:31:51 -03:00
|
|
|
// add a filename to list of files to log. The name must be a constant string, not allocated
|
|
|
|
void log_file_content(const char *name);
|
|
|
|
|
2013-04-19 04:49:16 -03:00
|
|
|
protected:
|
2015-08-06 09:18:28 -03:00
|
|
|
|
2013-12-16 20:12:42 -04:00
|
|
|
const struct LogStructure *_structures;
|
|
|
|
uint8_t _num_types;
|
2015-12-07 20:51:46 -04:00
|
|
|
const struct UnitStructure *_units = log_Units;
|
|
|
|
const struct MultiplierStructure *_multipliers = log_Multipliers;
|
|
|
|
const uint8_t _num_units = (sizeof(log_Units) / sizeof(log_Units[0]));
|
|
|
|
const uint8_t _num_multipliers = (sizeof(log_Multipliers) / sizeof(log_Multipliers[0]));
|
2013-04-19 21:25:10 -03:00
|
|
|
|
2015-08-06 09:18:28 -03:00
|
|
|
/* Write a block with specified importance */
|
|
|
|
/* might be useful if you have a boolean indicating a message is
|
|
|
|
* important... */
|
2015-11-09 18:14:22 -04:00
|
|
|
void WritePrioritisedBlock(const void *pBuffer, uint16_t size,
|
2015-08-06 09:18:28 -03:00
|
|
|
bool is_critical);
|
|
|
|
|
2015-06-25 10:53:20 -03:00
|
|
|
private:
|
2019-02-11 04:38:01 -04:00
|
|
|
#define LOGGER_MAX_BACKENDS 2
|
2015-11-09 18:14:22 -04:00
|
|
|
uint8_t _next_backend;
|
2019-02-11 04:38:01 -04:00
|
|
|
AP_Logger_Backend *backends[LOGGER_MAX_BACKENDS];
|
2017-06-27 01:14:27 -03:00
|
|
|
const AP_Int32 &_log_bitmask;
|
2016-04-20 02:07:48 -03:00
|
|
|
|
2019-02-28 21:23:55 -04:00
|
|
|
enum class Backend_Type : uint8_t {
|
|
|
|
NONE = 0,
|
|
|
|
FILESYSTEM = (1<<0),
|
|
|
|
MAVLINK = (1<<1),
|
|
|
|
BLOCK = (1<<2),
|
|
|
|
};
|
|
|
|
|
2016-04-20 02:07:48 -03:00
|
|
|
/*
|
2019-01-18 00:24:08 -04:00
|
|
|
* support for dynamic Write; user-supplies name, format,
|
2016-04-20 02:07:48 -03:00
|
|
|
* labels and values in a single function call.
|
|
|
|
*/
|
2020-01-18 17:57:26 -04:00
|
|
|
HAL_Semaphore log_write_fmts_sem;
|
2016-04-20 02:07:48 -03:00
|
|
|
|
2016-05-04 06:06:23 -03:00
|
|
|
// return (possibly allocating) a log_write_fmt for a name
|
2018-08-08 23:12:18 -03:00
|
|
|
const struct log_write_fmt *log_write_fmt_for_msg_type(uint8_t msg_type) const;
|
2017-11-07 23:32:45 -04:00
|
|
|
|
2021-02-01 12:26:29 -04:00
|
|
|
const struct LogStructure *structure_for_msg_type(uint8_t msg_type) const;
|
2018-08-08 23:12:18 -03:00
|
|
|
|
2016-04-20 02:07:48 -03:00
|
|
|
// return a msg_type which is not currently in use (or -1 if none available)
|
|
|
|
int16_t find_free_msg_type() const;
|
|
|
|
|
|
|
|
// fill LogStructure with information about msg_type
|
|
|
|
bool fill_log_write_logstructure(struct LogStructure &logstruct, const uint8_t msg_type) const;
|
|
|
|
|
2016-07-28 00:06:03 -03:00
|
|
|
bool _armed;
|
|
|
|
|
2020-08-19 05:56:50 -03:00
|
|
|
// state to help us not log unneccesary RCIN values:
|
2021-05-15 00:45:43 -03:00
|
|
|
bool should_log_rcin2;
|
2020-08-19 05:56:50 -03:00
|
|
|
|
2020-11-01 21:46:43 -04:00
|
|
|
void Write_Compass_instance(uint64_t time_us, uint8_t mag_instance);
|
2017-09-27 21:19:35 -03:00
|
|
|
|
2019-01-18 00:23:42 -04:00
|
|
|
void backend_starting_new_log(const AP_Logger_Backend *backend);
|
2017-04-28 04:37:13 -03:00
|
|
|
|
2019-02-10 14:05:22 -04:00
|
|
|
static AP_Logger *_singleton;
|
2015-12-07 20:21:18 -04:00
|
|
|
|
2017-11-14 20:24:54 -04:00
|
|
|
#if CONFIG_HAL_BOARD == HAL_BOARD_SITL
|
2017-11-08 00:55:06 -04:00
|
|
|
bool validate_structure(const struct LogStructure *logstructure, int16_t offset);
|
2017-06-14 07:22:18 -03:00
|
|
|
void validate_structures(const struct LogStructure *logstructures, const uint8_t num_types);
|
|
|
|
void dump_structure_field(const struct LogStructure *logstructure, const char *label, const uint8_t fieldnum);
|
|
|
|
void dump_structures(const struct LogStructure *logstructures, const uint8_t num_types);
|
2020-11-15 21:45:11 -04:00
|
|
|
bool assert_same_fmt_for_name(const log_write_fmt *f,
|
2017-11-14 20:02:56 -04:00
|
|
|
const char *name,
|
|
|
|
const char *labels,
|
|
|
|
const char *units,
|
|
|
|
const char *mults,
|
|
|
|
const char *fmt) const;
|
2015-12-07 20:21:18 -04:00
|
|
|
const char* unit_name(const uint8_t unit_id);
|
|
|
|
double multiplier_name(const uint8_t multiplier_id);
|
2017-11-08 00:55:06 -04:00
|
|
|
bool seen_ids[256] = { };
|
2020-04-07 02:16:51 -03:00
|
|
|
bool labels_string_is_good(const char *labels) const;
|
2017-11-08 00:55:06 -04:00
|
|
|
#endif
|
2017-04-27 22:34:02 -03:00
|
|
|
|
2018-02-22 05:38:58 -04:00
|
|
|
bool _writes_enabled:1;
|
2018-07-05 20:58:50 -03:00
|
|
|
bool _force_log_disarmed:1;
|
2021-09-06 22:42:02 -03:00
|
|
|
bool _force_long_log_persist:1;
|
2017-06-14 22:21:17 -03:00
|
|
|
|
2020-11-15 17:47:39 -04:00
|
|
|
// remember formats for replay
|
|
|
|
void save_format_Replay(const void *pBuffer);
|
|
|
|
|
2020-12-22 13:25:44 -04:00
|
|
|
// io thread support
|
|
|
|
bool _io_thread_started;
|
|
|
|
|
|
|
|
void start_io_thread(void);
|
|
|
|
void io_thread();
|
2022-06-05 03:37:02 -03:00
|
|
|
bool check_crash_dump_save(void);
|
2020-12-22 13:25:44 -04:00
|
|
|
|
2021-10-28 03:31:51 -03:00
|
|
|
#if HAL_LOGGER_FILE_CONTENTS_ENABLED
|
|
|
|
// support for logging file content
|
|
|
|
struct file_list {
|
|
|
|
struct file_list *next;
|
|
|
|
const char *filename;
|
2021-11-16 13:20:04 -04:00
|
|
|
char log_filename[16];
|
2021-10-28 03:31:51 -03:00
|
|
|
};
|
2022-01-05 22:05:15 -04:00
|
|
|
struct FileContent {
|
|
|
|
void reset();
|
|
|
|
void remove_and_free(file_list *victim);
|
2021-10-28 03:31:51 -03:00
|
|
|
struct file_list *head, *tail;
|
2022-04-15 05:54:56 -03:00
|
|
|
int fd{-1};
|
2021-12-01 06:10:57 -04:00
|
|
|
uint32_t offset;
|
2021-12-01 06:25:46 -04:00
|
|
|
bool fast;
|
|
|
|
uint8_t counter;
|
2021-10-28 03:31:51 -03:00
|
|
|
HAL_Semaphore sem;
|
2022-01-05 22:05:15 -04:00
|
|
|
};
|
|
|
|
FileContent normal_file_content;
|
|
|
|
FileContent at_arm_file_content;
|
|
|
|
|
|
|
|
// protect this with a semaphore?
|
|
|
|
bool file_content_prepare_for_arming;
|
|
|
|
|
2021-10-28 03:31:51 -03:00
|
|
|
void file_content_update(void);
|
2022-01-05 22:05:15 -04:00
|
|
|
|
|
|
|
void prepare_at_arming_sys_file_logging();
|
|
|
|
|
2021-10-28 03:31:51 -03:00
|
|
|
#endif
|
|
|
|
|
2017-06-18 20:43:15 -03:00
|
|
|
/* support for retrieving logs via mavlink: */
|
|
|
|
|
2019-12-04 23:29:47 -04:00
|
|
|
enum class TransferActivity {
|
2018-06-19 21:13:22 -03:00
|
|
|
IDLE, // not doing anything, all file descriptors closed
|
|
|
|
LISTING, // actively sending log_entry packets
|
|
|
|
SENDING, // actively sending log_sending packets
|
2019-12-04 23:29:47 -04:00
|
|
|
} transfer_activity = TransferActivity::IDLE;
|
2017-06-19 22:52:47 -03:00
|
|
|
|
2021-03-19 18:28:29 -03:00
|
|
|
// last time we handled a log-transfer-over-mavlink message:
|
|
|
|
uint32_t _last_mavlink_log_transfer_message_handled_ms;
|
2021-08-30 10:44:47 -03:00
|
|
|
bool _warned_log_disarm; // true if we have sent a message warning to disarm for logging
|
2021-03-19 18:28:29 -03:00
|
|
|
|
2017-06-18 20:43:15 -03:00
|
|
|
// next log list entry to send
|
|
|
|
uint16_t _log_next_list_entry;
|
|
|
|
|
|
|
|
// last log list entry to send
|
|
|
|
uint16_t _log_last_list_entry;
|
|
|
|
|
|
|
|
// number of log files
|
|
|
|
uint16_t _log_num_logs;
|
|
|
|
|
|
|
|
// log number for data send
|
|
|
|
uint16_t _log_num_data;
|
|
|
|
|
|
|
|
// offset in log
|
|
|
|
uint32_t _log_data_offset;
|
|
|
|
|
|
|
|
// size of log file
|
|
|
|
uint32_t _log_data_size;
|
|
|
|
|
|
|
|
// number of bytes left to send
|
|
|
|
uint32_t _log_data_remaining;
|
|
|
|
|
|
|
|
// start page of log data
|
2019-01-18 18:45:36 -04:00
|
|
|
uint32_t _log_data_page;
|
2017-06-18 20:43:15 -03:00
|
|
|
|
2018-03-19 00:37:21 -03:00
|
|
|
GCS_MAVLINK *_log_sending_link;
|
2020-01-18 17:57:26 -04:00
|
|
|
HAL_Semaphore _log_send_sem;
|
2017-07-16 04:04:14 -03:00
|
|
|
|
2019-06-10 18:55:30 -03:00
|
|
|
// last time arming failed, for backends
|
|
|
|
uint32_t _last_arming_failure_ms;
|
|
|
|
|
2020-12-31 17:03:06 -04:00
|
|
|
// count of number of times we've started logging
|
|
|
|
// can be used by other subsystems to detect if they should log data
|
|
|
|
uint8_t _log_start_count;
|
|
|
|
|
2019-04-30 07:22:48 -03:00
|
|
|
void handle_log_message(class GCS_MAVLINK &, const mavlink_message_t &msg);
|
2017-06-18 20:43:15 -03:00
|
|
|
|
2019-04-30 07:22:48 -03:00
|
|
|
void handle_log_request_list(class GCS_MAVLINK &, const mavlink_message_t &msg);
|
|
|
|
void handle_log_request_data(class GCS_MAVLINK &, const mavlink_message_t &msg);
|
|
|
|
void handle_log_request_erase(class GCS_MAVLINK &, const mavlink_message_t &msg);
|
|
|
|
void handle_log_request_end(class GCS_MAVLINK &, const mavlink_message_t &msg);
|
2018-06-19 21:13:22 -03:00
|
|
|
void handle_log_send_listing(); // handle LISTING state
|
|
|
|
void handle_log_sending(); // handle SENDING state
|
|
|
|
bool handle_log_send_data(); // send data chunk to client
|
2017-06-18 20:43:15 -03:00
|
|
|
|
|
|
|
void get_log_info(uint16_t log_num, uint32_t &size, uint32_t &time_utc);
|
2017-07-08 07:59:28 -03:00
|
|
|
|
|
|
|
int16_t get_log_data(uint16_t log_num, uint16_t page, uint32_t offset, uint16_t len, uint8_t *data);
|
|
|
|
|
2017-06-18 20:43:15 -03:00
|
|
|
/* end support for retrieving logs via mavlink: */
|
|
|
|
|
2022-01-05 22:05:15 -04:00
|
|
|
#if HAL_LOGGER_FILE_CONTENTS_ENABLED
|
|
|
|
void log_file_content(FileContent &file_content, const char *filename);
|
|
|
|
void file_content_update(FileContent &file_content);
|
|
|
|
#endif
|
2011-11-12 23:29:07 -04:00
|
|
|
};
|
2019-01-17 21:40:57 -04:00
|
|
|
|
|
|
|
namespace AP {
|
|
|
|
AP_Logger &logger();
|
|
|
|
};
|