2013-01-12 02:21:04 -04:00
|
|
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
|
2011-11-12 23:29:07 -04:00
|
|
|
/* ************************************************************ */
|
|
|
|
/* Test for DataFlash Log library */
|
|
|
|
/* ************************************************************ */
|
|
|
|
#ifndef DataFlash_h
|
|
|
|
#define DataFlash_h
|
|
|
|
|
2015-08-11 03:28:46 -03:00
|
|
|
#include <AP_HAL/AP_HAL.h>
|
|
|
|
#include <AP_Common/AP_Common.h>
|
|
|
|
#include <AP_Param/AP_Param.h>
|
|
|
|
#include <AP_GPS/AP_GPS.h>
|
|
|
|
#include <AP_InertialSensor/AP_InertialSensor.h>
|
2015-09-04 12:50:23 -03:00
|
|
|
#include <AP_RSSI/AP_RSSI.h>
|
2015-08-11 03:28:46 -03:00
|
|
|
#include <AP_Baro/AP_Baro.h>
|
|
|
|
#include <AP_AHRS/AP_AHRS.h>
|
|
|
|
#include <AP_Vehicle/AP_Vehicle.h>
|
|
|
|
#include <AP_Mission/AP_Mission.h>
|
2015-08-15 19:53:26 -03:00
|
|
|
#include <AP_Airspeed/AP_Airspeed.h>
|
|
|
|
#include <AP_BattMonitor/AP_BattMonitor.h>
|
|
|
|
#include <AP_RPM/AP_RPM.h>
|
2015-09-14 03:44:45 -03:00
|
|
|
#include <AP_RangeFinder/AP_RangeFinder.h>
|
2011-11-12 23:29:07 -04:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2014-11-20 23:48:44 -04:00
|
|
|
#if CONFIG_HAL_BOARD == HAL_BOARD_PX4
|
2014-11-13 06:38:33 -04:00
|
|
|
#include <uORB/topics/esc_status.h>
|
2014-11-20 23:48:44 -04:00
|
|
|
#endif
|
2014-11-13 06:38:33 -04:00
|
|
|
|
2015-08-06 09:18:28 -03:00
|
|
|
#include "DFMessageWriter.h"
|
2014-11-13 06:38:33 -04:00
|
|
|
|
2015-06-25 10:53:20 -03:00
|
|
|
class DataFlash_Backend;
|
2015-08-06 09:18:28 -03:00
|
|
|
class DFMessageWriter;
|
2014-08-01 02:57:15 -03:00
|
|
|
|
2011-11-12 23:29:07 -04:00
|
|
|
class DataFlash_Class
|
|
|
|
{
|
2015-08-06 09:18:28 -03:00
|
|
|
friend class DFMessageWriter_DFLogStart; // for access to _num_types etc
|
|
|
|
|
2013-02-22 20:17:34 -04:00
|
|
|
public:
|
2015-05-24 18:55:06 -03:00
|
|
|
FUNCTOR_TYPEDEF(print_mode_fn, void, AP_HAL::BetterStream*, uint8_t);
|
2015-08-06 09:18:28 -03:00
|
|
|
FUNCTOR_TYPEDEF(vehicle_startup_message_Log_Writer, void);
|
|
|
|
DataFlash_Class(const prog_char_t *firmware_string) :
|
|
|
|
_startup_messagewriter(DFMessageWriter_DFLogStart(*this,firmware_string)),
|
|
|
|
_vehicle_messages(NULL)
|
|
|
|
{ }
|
|
|
|
|
|
|
|
void set_mission(const AP_Mission *mission);
|
2015-05-12 03:59:55 -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);
|
|
|
|
bool CardInserted(void);
|
2013-02-22 20:17:34 -04:00
|
|
|
|
|
|
|
// erase handling
|
2015-06-25 10:53:20 -03:00
|
|
|
bool NeedErase(void);
|
|
|
|
void EraseAll();
|
2013-02-22 20:17:34 -04:00
|
|
|
|
2015-08-08 03:13:38 -03:00
|
|
|
// possibly expensive calls to start log system:
|
|
|
|
bool NeedPrep();
|
|
|
|
void Prep();
|
|
|
|
|
2013-02-22 20:17:34 -04:00
|
|
|
/* Write a block of data at current offset */
|
2015-08-06 09:18:28 -03:00
|
|
|
bool WriteBlock(const void *pBuffer, uint16_t size);
|
|
|
|
/* Write an *important* block of data at current offset */
|
|
|
|
bool WriteCriticalBlock(const void *pBuffer, uint16_t size);
|
2013-02-22 20:17:34 -04:00
|
|
|
|
|
|
|
// high level interface
|
2015-06-25 10:53:20 -03:00
|
|
|
uint16_t find_last_log(void);
|
|
|
|
void get_log_boundaries(uint16_t log_num, uint16_t & start_page, uint16_t & end_page);
|
|
|
|
void get_log_info(uint16_t log_num, uint32_t &size, uint32_t &time_utc);
|
|
|
|
int16_t get_log_data(uint16_t log_num, uint16_t page, uint32_t offset, uint16_t len, uint8_t *data);
|
|
|
|
uint16_t get_num_logs(void);
|
2014-08-01 02:57:15 -03:00
|
|
|
#ifndef DATAFLASH_NO_CLI
|
2015-06-25 10:53:20 -03:00
|
|
|
void LogReadProcess(uint16_t log_num,
|
2013-04-19 04:49:16 -03:00
|
|
|
uint16_t start_page, uint16_t end_page,
|
2015-05-12 03:59:55 -03:00
|
|
|
print_mode_fn printMode,
|
2015-06-25 10:53:20 -03:00
|
|
|
AP_HAL::BetterStream *port);
|
|
|
|
void DumpPageInfo(AP_HAL::BetterStream *port);
|
|
|
|
void ShowDeviceInfo(AP_HAL::BetterStream *port);
|
|
|
|
void ListAvailableLogs(AP_HAL::BetterStream *port);
|
2014-08-01 02:57:15 -03:00
|
|
|
#endif // DATAFLASH_NO_CLI
|
2013-02-22 20:17:34 -04:00
|
|
|
|
2015-08-06 09:18:28 -03:00
|
|
|
uint16_t bufferspace_available();
|
|
|
|
|
|
|
|
void setVehicle_Startup_Log_Writer(vehicle_startup_message_Log_Writer writer);
|
|
|
|
|
2013-12-16 20:12:42 -04:00
|
|
|
uint16_t StartNewLog(void);
|
2014-03-23 22:03:31 -03:00
|
|
|
void AddLogFormats(const struct LogStructure *structures, uint8_t num_types);
|
2015-06-25 10:53:20 -03:00
|
|
|
void EnableWrites(bool enable);
|
2015-06-23 22:09:01 -03:00
|
|
|
void Log_Write_SysInfo(const prog_char_t *firmware_string);
|
2015-08-06 09:18:28 -03:00
|
|
|
bool Log_Write_Format(const struct LogStructure *structure);
|
|
|
|
bool Log_Write_Parameter(const char *name, float value);
|
2014-04-09 21:29:30 -03:00
|
|
|
void Log_Write_GPS(const AP_GPS &gps, uint8_t instance, int32_t relative_alt);
|
2015-09-10 07:27:47 -03:00
|
|
|
void Log_Write_RFND(const RangeFinder &rangefinder);
|
2013-11-03 23:36:14 -04:00
|
|
|
void Log_Write_IMU(const AP_InertialSensor &ins);
|
2015-06-13 10:06:49 -03:00
|
|
|
void Log_Write_IMUDT(const AP_InertialSensor &ins);
|
2015-06-11 10:26:45 -03:00
|
|
|
void Log_Write_Vibration(const AP_InertialSensor &ins);
|
2013-11-25 17:44:00 -04:00
|
|
|
void Log_Write_RCIN(void);
|
2013-11-27 07:14:17 -04:00
|
|
|
void Log_Write_RCOUT(void);
|
2015-09-04 12:50:23 -03:00
|
|
|
void Log_Write_RSSI(AP_RSSI &rssi);
|
2014-01-27 19:35:18 -04:00
|
|
|
void Log_Write_Baro(AP_Baro &baro);
|
2014-02-13 07:07:32 -04:00
|
|
|
void Log_Write_Power(void);
|
2014-01-03 01:01:08 -04:00
|
|
|
void Log_Write_AHRS2(AP_AHRS &ahrs);
|
2015-05-14 22:59:40 -03:00
|
|
|
void Log_Write_POS(AP_AHRS &ahrs);
|
2014-01-03 20:51:22 -04:00
|
|
|
#if AP_AHRS_NAVEKF_AVAILABLE
|
2014-12-23 16:39:23 -04:00
|
|
|
void Log_Write_EKF(AP_AHRS_NavEKF &ahrs, bool optFlowEnabled);
|
2015-09-22 23:09:48 -03:00
|
|
|
void Log_Write_EKF2(AP_AHRS_NavEKF &ahrs, bool optFlowEnabled);
|
2014-01-03 20:51:22 -04:00
|
|
|
#endif
|
2015-08-06 09:18:28 -03:00
|
|
|
bool Log_Write_MavCmd(uint16_t cmd_total, const mavlink_mission_item_t& mav_cmd);
|
2014-03-11 14:05:02 -03:00
|
|
|
void Log_Write_Radio(const mavlink_radio_t &packet);
|
2015-08-06 09:18:28 -03:00
|
|
|
bool Log_Write_Message(const char *message);
|
|
|
|
bool Log_Write_Message_P(const prog_char_t *message);
|
2014-06-10 23:55:04 -03:00
|
|
|
void Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc);
|
2014-11-13 06:38:33 -04:00
|
|
|
void Log_Write_ESC(void);
|
2015-01-19 18:10:33 -04:00
|
|
|
void Log_Write_Airspeed(AP_Airspeed &airspeed);
|
2015-01-20 15:44:39 -04:00
|
|
|
void Log_Write_Attitude(AP_AHRS &ahrs, const Vector3f &targets);
|
2015-05-21 22:42:08 -03:00
|
|
|
void Log_Write_Current(const AP_BattMonitor &battery, int16_t throttle);
|
2015-01-16 18:27:01 -04:00
|
|
|
void Log_Write_Compass(const Compass &compass);
|
2015-08-06 09:18:28 -03:00
|
|
|
bool Log_Write_Mode(uint8_t mode);
|
2015-05-29 23:09:07 -03:00
|
|
|
void Log_Write_Parameters(void);
|
2013-04-19 04:49:16 -03:00
|
|
|
|
2015-06-30 01:33:50 -03:00
|
|
|
void Log_Write_EntireMission(const AP_Mission &mission);
|
2015-08-06 09:18:28 -03:00
|
|
|
bool Log_Write_Mission_Cmd(const AP_Mission &mission,
|
2015-06-30 01:33:50 -03:00
|
|
|
const AP_Mission::Mission_Command &cmd);
|
2015-07-03 08:49:45 -03:00
|
|
|
void Log_Write_Origin(uint8_t origin_type, const Location &loc);
|
2015-08-07 07:34:14 -03:00
|
|
|
void Log_Write_RPM(const AP_RPM &rpm_sensor);
|
2015-06-30 01:33:50 -03:00
|
|
|
|
2015-05-21 22:42:08 -03:00
|
|
|
// This structure provides information on the internal member data of a PID for logging purposes
|
|
|
|
struct PID_Info {
|
2015-05-22 19:56:05 -03:00
|
|
|
float desired;
|
2015-05-21 22:42:08 -03:00
|
|
|
float P;
|
|
|
|
float I;
|
|
|
|
float D;
|
|
|
|
float FF;
|
2015-05-22 20:57:49 -03:00
|
|
|
float AFF;
|
2015-05-21 22:42:08 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
void Log_Write_PID(uint8_t msg_type, const PID_Info &info);
|
|
|
|
|
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
|
|
|
|
// currently only DataFlash_File support this:
|
|
|
|
void flush(void);
|
|
|
|
#endif
|
|
|
|
|
2015-08-06 09:18:28 -03:00
|
|
|
void periodic_tasks(); // may want to split this into GCS/non-GCS duties
|
|
|
|
|
|
|
|
// this is out here for the trickle-startup-messages logging.
|
|
|
|
// Think before calling.
|
|
|
|
bool Log_Write_Parameter(const AP_Param *ap, const AP_Param::ParamToken &token,
|
|
|
|
enum ap_var_type type);
|
|
|
|
|
|
|
|
DFMessageWriter_DFLogStart _startup_messagewriter;
|
|
|
|
vehicle_startup_message_Log_Writer _vehicle_messages;
|
|
|
|
|
2013-04-19 04:49:16 -03:00
|
|
|
protected:
|
2013-12-16 20:12:42 -04:00
|
|
|
void Log_Fill_Format(const struct LogStructure *structure, struct log_Format &pkt);
|
2015-06-25 10:53:20 -03:00
|
|
|
uint16_t start_new_log(void);
|
2013-04-19 21:25:10 -03:00
|
|
|
|
2015-08-06 09:18:28 -03:00
|
|
|
void WroteStartupFormat();
|
|
|
|
void WroteStartupParam();
|
|
|
|
|
2013-12-16 20:12:42 -04:00
|
|
|
const struct LogStructure *_structures;
|
|
|
|
uint8_t _num_types;
|
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... */
|
|
|
|
bool WritePrioritisedBlock(const void *pBuffer, uint16_t size,
|
|
|
|
bool is_critical);
|
|
|
|
|
2015-06-25 10:53:20 -03:00
|
|
|
private:
|
|
|
|
DataFlash_Backend *backend;
|
2011-11-12 23:29:07 -04:00
|
|
|
};
|
|
|
|
|
2013-01-12 07:16:15 -04:00
|
|
|
/*
|
|
|
|
unfortunately these need to be macros because of a limitation of
|
|
|
|
named member structure initialisation in g++
|
|
|
|
*/
|
|
|
|
#define LOG_PACKET_HEADER uint8_t head1, head2, msgid;
|
|
|
|
#define LOG_PACKET_HEADER_INIT(id) head1 : HEAD_BYTE1, head2 : HEAD_BYTE2, msgid : id
|
|
|
|
|
|
|
|
// once the logging code is all converted we will remove these from
|
|
|
|
// this header
|
|
|
|
#define HEAD_BYTE1 0xA3 // Decimal 163
|
|
|
|
#define HEAD_BYTE2 0x95 // Decimal 149
|
|
|
|
|
2013-04-19 04:49:16 -03:00
|
|
|
// structure used to define logging format
|
|
|
|
struct LogStructure {
|
|
|
|
uint8_t msg_type;
|
|
|
|
uint8_t msg_len;
|
|
|
|
const char name[5];
|
|
|
|
const char format[16];
|
|
|
|
const char labels[64];
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
log structures common to all vehicle types
|
|
|
|
*/
|
2013-04-19 10:19:16 -03:00
|
|
|
struct PACKED log_Format {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint8_t type;
|
|
|
|
uint8_t length;
|
|
|
|
char name[4];
|
|
|
|
char format[16];
|
2013-04-23 06:46:22 -03:00
|
|
|
char labels[64];
|
2013-04-19 10:19:16 -03:00
|
|
|
};
|
|
|
|
|
2013-04-19 04:49:16 -03:00
|
|
|
struct PACKED log_Parameter {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2013-04-19 04:49:16 -03:00
|
|
|
char name[16];
|
|
|
|
float value;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct PACKED log_GPS {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-04-30 02:30:29 -03:00
|
|
|
uint64_t time_us;
|
2013-04-19 04:49:16 -03:00
|
|
|
uint8_t status;
|
2013-10-23 08:14:48 -03:00
|
|
|
uint32_t gps_week_ms;
|
|
|
|
uint16_t gps_week;
|
2013-04-19 04:49:16 -03:00
|
|
|
uint8_t num_sats;
|
2014-04-01 17:49:39 -03:00
|
|
|
uint16_t hdop;
|
2013-04-19 04:49:16 -03:00
|
|
|
int32_t latitude;
|
|
|
|
int32_t longitude;
|
|
|
|
int32_t rel_altitude;
|
|
|
|
int32_t altitude;
|
|
|
|
uint32_t ground_speed;
|
|
|
|
int32_t ground_course;
|
2013-11-04 01:56:55 -04:00
|
|
|
float vel_z;
|
2015-08-05 03:25:48 -03:00
|
|
|
uint8_t used;
|
2013-12-21 07:24:51 -04:00
|
|
|
};
|
|
|
|
|
2015-09-09 01:52:52 -03:00
|
|
|
struct PACKED log_GPA {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
uint16_t vdop;
|
|
|
|
uint16_t hacc;
|
|
|
|
uint16_t vacc;
|
|
|
|
uint16_t sacc;
|
|
|
|
};
|
|
|
|
|
2013-05-02 20:18:14 -03:00
|
|
|
struct PACKED log_Message {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2013-05-02 20:18:14 -03:00
|
|
|
char msg[64];
|
|
|
|
};
|
|
|
|
|
2013-04-19 04:49:16 -03:00
|
|
|
struct PACKED log_IMU {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2013-04-19 04:49:16 -03:00
|
|
|
float gyro_x, gyro_y, gyro_z;
|
|
|
|
float accel_x, accel_y, accel_z;
|
2014-12-29 06:19:50 -04:00
|
|
|
uint32_t gyro_error, accel_error;
|
2015-03-16 23:33:26 -03:00
|
|
|
float temperature;
|
2015-05-12 16:49:17 -03:00
|
|
|
uint8_t gyro_health, accel_health;
|
2013-04-19 04:49:16 -03:00
|
|
|
};
|
|
|
|
|
2015-06-13 10:06:49 -03:00
|
|
|
struct PACKED log_IMUDT {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
float delta_time, delta_vel_dt;
|
|
|
|
float delta_ang_x, delta_ang_y, delta_ang_z;
|
|
|
|
float delta_vel_x, delta_vel_y, delta_vel_z;
|
|
|
|
};
|
|
|
|
|
2015-06-11 10:26:45 -03:00
|
|
|
struct PACKED log_Vibe {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
float vibe_x, vibe_y, vibe_z;
|
|
|
|
uint32_t clipping_0, clipping_1, clipping_2;
|
|
|
|
};
|
|
|
|
|
2013-11-25 17:44:00 -04:00
|
|
|
struct PACKED log_RCIN {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2013-11-25 17:44:00 -04:00
|
|
|
uint16_t chan1;
|
|
|
|
uint16_t chan2;
|
|
|
|
uint16_t chan3;
|
|
|
|
uint16_t chan4;
|
|
|
|
uint16_t chan5;
|
|
|
|
uint16_t chan6;
|
|
|
|
uint16_t chan7;
|
|
|
|
uint16_t chan8;
|
2014-03-25 02:39:19 -03:00
|
|
|
uint16_t chan9;
|
|
|
|
uint16_t chan10;
|
|
|
|
uint16_t chan11;
|
|
|
|
uint16_t chan12;
|
|
|
|
uint16_t chan13;
|
|
|
|
uint16_t chan14;
|
2013-11-25 17:44:00 -04:00
|
|
|
};
|
|
|
|
|
2013-11-27 07:14:17 -04:00
|
|
|
struct PACKED log_RCOUT {
|
2013-11-25 17:44:00 -04:00
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2013-11-25 17:44:00 -04:00
|
|
|
uint16_t chan1;
|
|
|
|
uint16_t chan2;
|
|
|
|
uint16_t chan3;
|
|
|
|
uint16_t chan4;
|
|
|
|
uint16_t chan5;
|
|
|
|
uint16_t chan6;
|
|
|
|
uint16_t chan7;
|
|
|
|
uint16_t chan8;
|
2014-08-12 12:08:17 -03:00
|
|
|
uint16_t chan9;
|
|
|
|
uint16_t chan10;
|
|
|
|
uint16_t chan11;
|
|
|
|
uint16_t chan12;
|
2013-11-25 17:44:00 -04:00
|
|
|
};
|
|
|
|
|
2015-09-04 12:50:23 -03:00
|
|
|
struct PACKED log_RSSI {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
float RXRSSI;
|
|
|
|
};
|
|
|
|
|
2014-01-27 19:35:18 -04:00
|
|
|
struct PACKED log_BARO {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-01-27 19:35:18 -04:00
|
|
|
float altitude;
|
|
|
|
float pressure;
|
|
|
|
int16_t temperature;
|
2014-10-22 04:29:25 -03:00
|
|
|
float climbrate;
|
2014-01-30 18:33:12 -04:00
|
|
|
};
|
2014-01-03 01:01:08 -04:00
|
|
|
|
|
|
|
struct PACKED log_AHRS {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-01-03 01:01:08 -04:00
|
|
|
int16_t roll;
|
|
|
|
int16_t pitch;
|
|
|
|
uint16_t yaw;
|
|
|
|
float alt;
|
|
|
|
int32_t lat;
|
|
|
|
int32_t lng;
|
2014-01-27 19:35:18 -04:00
|
|
|
};
|
|
|
|
|
2015-05-14 22:59:40 -03:00
|
|
|
struct PACKED log_POS {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2015-05-14 22:59:40 -03:00
|
|
|
int32_t lat;
|
|
|
|
int32_t lng;
|
|
|
|
float alt;
|
|
|
|
float rel_alt;
|
|
|
|
};
|
|
|
|
|
2014-02-13 07:07:32 -04:00
|
|
|
struct PACKED log_POWR {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-02-13 07:07:32 -04:00
|
|
|
uint16_t Vcc;
|
|
|
|
uint16_t Vservo;
|
|
|
|
uint16_t flags;
|
|
|
|
};
|
|
|
|
|
2014-01-03 20:51:22 -04:00
|
|
|
struct PACKED log_EKF1 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-01-03 20:51:22 -04:00
|
|
|
int16_t roll;
|
|
|
|
int16_t pitch;
|
|
|
|
uint16_t yaw;
|
|
|
|
float velN;
|
|
|
|
float velE;
|
|
|
|
float velD;
|
|
|
|
float posN;
|
|
|
|
float posE;
|
|
|
|
float posD;
|
2014-01-30 18:33:12 -04:00
|
|
|
int16_t gyrX;
|
|
|
|
int16_t gyrY;
|
|
|
|
int16_t gyrZ;
|
2014-01-03 20:51:22 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct PACKED log_EKF2 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-10-06 06:04:55 -03:00
|
|
|
int8_t Ratio;
|
|
|
|
int8_t AZ1bias;
|
|
|
|
int8_t AZ2bias;
|
2014-01-03 20:51:22 -04:00
|
|
|
int16_t windN;
|
|
|
|
int16_t windE;
|
|
|
|
int16_t magN;
|
|
|
|
int16_t magE;
|
|
|
|
int16_t magD;
|
|
|
|
int16_t magX;
|
|
|
|
int16_t magY;
|
|
|
|
int16_t magZ;
|
|
|
|
};
|
|
|
|
|
2015-09-23 22:10:34 -03:00
|
|
|
struct PACKED log_NKF2 {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
int8_t AZbias;
|
|
|
|
int16_t scaleX;
|
|
|
|
int16_t scaleY;
|
|
|
|
int16_t scaleZ;
|
|
|
|
int16_t windN;
|
|
|
|
int16_t windE;
|
|
|
|
int16_t magN;
|
|
|
|
int16_t magE;
|
|
|
|
int16_t magD;
|
|
|
|
int16_t magX;
|
|
|
|
int16_t magY;
|
|
|
|
int16_t magZ;
|
|
|
|
};
|
|
|
|
|
2014-01-30 18:33:12 -04:00
|
|
|
struct PACKED log_EKF3 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-01-30 18:33:12 -04:00
|
|
|
int16_t innovVN;
|
|
|
|
int16_t innovVE;
|
|
|
|
int16_t innovVD;
|
|
|
|
int16_t innovPN;
|
|
|
|
int16_t innovPE;
|
|
|
|
int16_t innovPD;
|
|
|
|
int16_t innovMX;
|
|
|
|
int16_t innovMY;
|
|
|
|
int16_t innovMZ;
|
|
|
|
int16_t innovVT;
|
|
|
|
};
|
2014-01-03 20:51:22 -04:00
|
|
|
|
2015-09-23 22:10:34 -03:00
|
|
|
struct PACKED log_NKF3 {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
int16_t innovVN;
|
|
|
|
int16_t innovVE;
|
|
|
|
int16_t innovVD;
|
|
|
|
int16_t innovPN;
|
|
|
|
int16_t innovPE;
|
|
|
|
int16_t innovPD;
|
|
|
|
int16_t innovMX;
|
|
|
|
int16_t innovMY;
|
|
|
|
int16_t innovMZ;
|
|
|
|
int16_t innovYaw;
|
|
|
|
int16_t innovVT;
|
|
|
|
};
|
|
|
|
|
2014-01-30 18:33:12 -04:00
|
|
|
struct PACKED log_EKF4 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-03-31 20:05:07 -03:00
|
|
|
int16_t sqrtvarV;
|
|
|
|
int16_t sqrtvarP;
|
|
|
|
int16_t sqrtvarH;
|
2014-01-30 18:33:12 -04:00
|
|
|
int16_t sqrtvarMX;
|
|
|
|
int16_t sqrtvarMY;
|
|
|
|
int16_t sqrtvarMZ;
|
|
|
|
int16_t sqrtvarVT;
|
2014-03-31 20:05:07 -03:00
|
|
|
int8_t offsetNorth;
|
|
|
|
int8_t offsetEast;
|
2014-05-14 05:18:28 -03:00
|
|
|
uint8_t faults;
|
2014-11-01 04:04:57 -03:00
|
|
|
uint8_t timeouts;
|
2015-01-05 08:38:41 -04:00
|
|
|
uint16_t solution;
|
2014-01-30 18:33:12 -04:00
|
|
|
};
|
2014-01-03 20:51:22 -04:00
|
|
|
|
2014-08-06 21:32:12 -03:00
|
|
|
struct PACKED log_EKF5 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2015-01-03 19:29:37 -04:00
|
|
|
uint8_t normInnov;
|
2014-10-31 23:27:52 -03:00
|
|
|
int16_t FIX;
|
|
|
|
int16_t FIY;
|
2015-01-03 19:29:37 -04:00
|
|
|
int16_t AFI;
|
2015-01-06 02:17:39 -04:00
|
|
|
int16_t HAGL;
|
2015-01-03 19:29:37 -04:00
|
|
|
int16_t offset;
|
2014-10-31 23:27:52 -03:00
|
|
|
int16_t RI;
|
2015-01-02 22:50:47 -04:00
|
|
|
uint16_t meaRng;
|
|
|
|
uint16_t errHAGL;
|
2014-08-06 21:32:12 -03:00
|
|
|
};
|
|
|
|
|
2014-03-12 05:17:13 -03:00
|
|
|
struct PACKED log_Cmd {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-03-12 05:17:13 -03:00
|
|
|
uint16_t command_total;
|
2014-03-16 05:40:30 -03:00
|
|
|
uint16_t sequence;
|
|
|
|
uint16_t command;
|
|
|
|
float param1;
|
|
|
|
float param2;
|
|
|
|
float param3;
|
|
|
|
float param4;
|
|
|
|
float latitude;
|
|
|
|
float longitude;
|
|
|
|
float altitude;
|
2014-03-12 05:17:13 -03:00
|
|
|
};
|
|
|
|
|
2014-03-11 14:05:02 -03:00
|
|
|
struct PACKED log_Radio {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-03-11 14:05:02 -03:00
|
|
|
uint8_t rssi;
|
|
|
|
uint8_t remrssi;
|
|
|
|
uint8_t txbuf;
|
|
|
|
uint8_t noise;
|
|
|
|
uint8_t remnoise;
|
|
|
|
uint16_t rxerrors;
|
|
|
|
uint16_t fixed;
|
|
|
|
};
|
|
|
|
|
2014-06-10 23:55:04 -03:00
|
|
|
struct PACKED log_Camera {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-04-30 02:30:29 -03:00
|
|
|
uint64_t time_us;
|
2014-06-10 23:55:04 -03:00
|
|
|
uint32_t gps_time;
|
|
|
|
uint16_t gps_week;
|
|
|
|
int32_t latitude;
|
|
|
|
int32_t longitude;
|
|
|
|
int32_t altitude;
|
|
|
|
int32_t altitude_rel;
|
|
|
|
int16_t roll;
|
|
|
|
int16_t pitch;
|
|
|
|
uint16_t yaw;
|
|
|
|
};
|
|
|
|
|
2014-12-18 12:55:11 -04:00
|
|
|
struct PACKED log_Attitude {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-12-18 12:55:11 -04:00
|
|
|
int16_t control_roll;
|
|
|
|
int16_t roll;
|
|
|
|
int16_t control_pitch;
|
|
|
|
int16_t pitch;
|
|
|
|
uint16_t control_yaw;
|
|
|
|
uint16_t yaw;
|
|
|
|
uint16_t error_rp;
|
|
|
|
uint16_t error_yaw;
|
|
|
|
};
|
|
|
|
|
2015-05-21 22:42:08 -03:00
|
|
|
struct PACKED log_PID {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
2015-05-23 18:50:32 -03:00
|
|
|
float desired;
|
2015-05-21 22:42:08 -03:00
|
|
|
float P;
|
|
|
|
float I;
|
|
|
|
float D;
|
|
|
|
float FF;
|
2015-05-22 20:57:49 -03:00
|
|
|
float AFF;
|
2015-05-21 22:42:08 -03:00
|
|
|
};
|
|
|
|
|
2014-12-18 17:34:29 -04:00
|
|
|
struct PACKED log_Current {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-12-18 17:34:29 -04:00
|
|
|
int16_t throttle;
|
|
|
|
int16_t battery_voltage;
|
|
|
|
int16_t current_amps;
|
|
|
|
uint16_t board_voltage;
|
|
|
|
float current_total;
|
2015-05-21 22:42:08 -03:00
|
|
|
int16_t battery2_voltage;
|
2014-12-18 17:34:29 -04:00
|
|
|
};
|
|
|
|
|
2014-12-20 15:08:13 -04:00
|
|
|
struct PACKED log_Compass {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-12-20 15:08:13 -04:00
|
|
|
int16_t mag_x;
|
|
|
|
int16_t mag_y;
|
|
|
|
int16_t mag_z;
|
|
|
|
int16_t offset_x;
|
|
|
|
int16_t offset_y;
|
|
|
|
int16_t offset_z;
|
|
|
|
int16_t motor_offset_x;
|
|
|
|
int16_t motor_offset_y;
|
|
|
|
int16_t motor_offset_z;
|
2015-04-18 09:31:48 -03:00
|
|
|
uint8_t health;
|
2014-12-20 15:08:13 -04:00
|
|
|
};
|
|
|
|
|
2014-12-22 16:10:02 -04:00
|
|
|
struct PACKED log_Mode {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-12-22 16:10:02 -04:00
|
|
|
uint8_t mode;
|
|
|
|
uint8_t mode_num;
|
|
|
|
};
|
|
|
|
|
2015-09-10 07:27:47 -03:00
|
|
|
/*
|
|
|
|
rangefinder - support for 4 sensors
|
|
|
|
*/
|
|
|
|
struct PACKED log_RFND {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
uint16_t dist1;
|
|
|
|
uint16_t dist2;
|
|
|
|
};
|
|
|
|
|
2014-08-05 23:16:07 -03:00
|
|
|
/*
|
|
|
|
terrain log structure
|
|
|
|
*/
|
|
|
|
struct PACKED log_TERRAIN {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-08-05 23:16:07 -03:00
|
|
|
uint8_t status;
|
|
|
|
int32_t lat;
|
|
|
|
int32_t lng;
|
|
|
|
uint16_t spacing;
|
|
|
|
float terrain_height;
|
|
|
|
float current_height;
|
|
|
|
uint16_t pending;
|
|
|
|
uint16_t loaded;
|
|
|
|
};
|
|
|
|
|
2014-08-17 08:45:11 -03:00
|
|
|
/*
|
|
|
|
UBlox logging
|
|
|
|
*/
|
|
|
|
struct PACKED log_Ubx1 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-08-17 08:45:11 -03:00
|
|
|
uint8_t instance;
|
|
|
|
uint16_t noisePerMS;
|
|
|
|
uint8_t jamInd;
|
|
|
|
uint8_t aPower;
|
2014-10-28 16:50:51 -03:00
|
|
|
uint16_t agcCnt;
|
2014-08-17 08:45:11 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
struct PACKED log_Ubx2 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-08-17 08:45:11 -03:00
|
|
|
uint8_t instance;
|
|
|
|
int8_t ofsI;
|
|
|
|
uint8_t magI;
|
|
|
|
int8_t ofsQ;
|
|
|
|
uint8_t magQ;
|
|
|
|
};
|
|
|
|
|
2014-10-29 20:44:14 -03:00
|
|
|
struct PACKED log_Ubx3 {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-10-29 20:44:14 -03:00
|
|
|
uint8_t instance;
|
|
|
|
float hAcc;
|
|
|
|
float vAcc;
|
|
|
|
float sAcc;
|
|
|
|
};
|
|
|
|
|
2015-05-04 05:17:42 -03:00
|
|
|
struct PACKED log_GPS_RAW {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2015-05-04 05:17:42 -03:00
|
|
|
int32_t iTOW;
|
|
|
|
int16_t week;
|
|
|
|
uint8_t numSV;
|
|
|
|
uint8_t sv;
|
|
|
|
double cpMes;
|
|
|
|
double prMes;
|
|
|
|
float doMes;
|
|
|
|
int8_t mesQI;
|
|
|
|
int8_t cno;
|
|
|
|
uint8_t lli;
|
|
|
|
};
|
|
|
|
|
2015-06-29 18:55:13 -03:00
|
|
|
struct PACKED log_GPS_RAWH {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
double rcvTow;
|
|
|
|
uint16_t week;
|
|
|
|
int8_t leapS;
|
|
|
|
uint8_t numMeas;
|
|
|
|
uint8_t recStat;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct PACKED log_GPS_RAWS {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
double prMes;
|
|
|
|
double cpMes;
|
|
|
|
float doMes;
|
|
|
|
uint8_t gnssId;
|
|
|
|
uint8_t svId;
|
|
|
|
uint8_t freqId;
|
|
|
|
uint16_t locktime;
|
|
|
|
uint8_t cno;
|
|
|
|
uint8_t prStdev;
|
|
|
|
uint8_t cpStdev;
|
|
|
|
uint8_t doStdev;
|
|
|
|
uint8_t trkStat;
|
|
|
|
};
|
|
|
|
|
2015-08-30 03:53:47 -03:00
|
|
|
struct PACKED log_GPS_SBF_EVENT {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
uint32_t TOW;
|
|
|
|
uint16_t WNc;
|
|
|
|
uint8_t Mode;
|
|
|
|
uint8_t Error;
|
|
|
|
double Latitude;
|
|
|
|
double Longitude;
|
|
|
|
double Height;
|
|
|
|
float Undulation;
|
|
|
|
float Vn;
|
|
|
|
float Ve;
|
|
|
|
float Vu;
|
|
|
|
float COG;
|
|
|
|
};
|
|
|
|
|
2014-11-13 06:38:33 -04:00
|
|
|
struct PACKED log_Esc {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2014-11-20 06:53:12 -04:00
|
|
|
int16_t rpm;
|
|
|
|
int16_t voltage;
|
|
|
|
int16_t current;
|
|
|
|
int16_t temperature;
|
2014-11-13 06:38:33 -04:00
|
|
|
};
|
|
|
|
|
2015-01-19 18:10:33 -04:00
|
|
|
struct PACKED log_AIRSPEED {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-21 22:34:05 -03:00
|
|
|
uint64_t time_us;
|
2015-01-19 18:10:33 -04:00
|
|
|
float airspeed;
|
|
|
|
float diffpressure;
|
|
|
|
int16_t temperature;
|
|
|
|
float rawpressure;
|
|
|
|
float offset;
|
|
|
|
};
|
|
|
|
|
2015-05-06 23:08:04 -03:00
|
|
|
struct PACKED log_ACCEL {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-22 21:02:22 -03:00
|
|
|
uint64_t time_us;
|
|
|
|
uint64_t sample_us;
|
2015-05-06 23:08:04 -03:00
|
|
|
float AccX, AccY, AccZ;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct PACKED log_GYRO {
|
|
|
|
LOG_PACKET_HEADER;
|
2015-05-22 21:02:22 -03:00
|
|
|
uint64_t time_us;
|
|
|
|
uint64_t sample_us;
|
2015-05-06 23:08:04 -03:00
|
|
|
float GyrX, GyrY, GyrZ;
|
|
|
|
};
|
|
|
|
|
2015-07-03 08:49:45 -03:00
|
|
|
struct PACKED log_ORGN {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
uint8_t origin_type;
|
|
|
|
int32_t latitude;
|
|
|
|
int32_t longitude;
|
|
|
|
int32_t altitude;
|
|
|
|
};
|
|
|
|
|
2015-08-07 07:34:14 -03:00
|
|
|
struct PACKED log_RPM {
|
|
|
|
LOG_PACKET_HEADER;
|
|
|
|
uint64_t time_us;
|
|
|
|
float rpm1;
|
|
|
|
float rpm2;
|
|
|
|
};
|
|
|
|
|
2014-12-19 11:04:25 -04:00
|
|
|
/*
|
|
|
|
Format characters in the format string for binary log messages
|
|
|
|
b : int8_t
|
|
|
|
B : uint8_t
|
|
|
|
h : int16_t
|
|
|
|
H : uint16_t
|
|
|
|
i : int32_t
|
|
|
|
I : uint32_t
|
|
|
|
f : float
|
2015-05-15 08:14:49 -03:00
|
|
|
d : double
|
2014-12-19 11:04:25 -04:00
|
|
|
n : char[4]
|
|
|
|
N : char[16]
|
|
|
|
Z : char[64]
|
|
|
|
c : int16_t * 100
|
|
|
|
C : uint16_t * 100
|
|
|
|
e : int32_t * 100
|
|
|
|
E : uint32_t * 100
|
|
|
|
L : int32_t latitude/longitude
|
|
|
|
M : uint8_t flight mode
|
2015-05-21 22:34:05 -03:00
|
|
|
q : int64_t
|
|
|
|
Q : uint64_t
|
2014-12-19 11:04:25 -04:00
|
|
|
*/
|
|
|
|
|
2014-06-26 21:28:21 -03:00
|
|
|
// messages for all boards
|
|
|
|
#define LOG_BASE_STRUCTURES \
|
2013-04-23 06:46:22 -03:00
|
|
|
{ LOG_FORMAT_MSG, sizeof(log_Format), \
|
2014-01-02 20:58:41 -04:00
|
|
|
"FMT", "BBnNZ", "Type,Length,Name,Format,Columns" }, \
|
2013-04-19 04:49:16 -03:00
|
|
|
{ LOG_PARAMETER_MSG, sizeof(log_Parameter), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"PARM", "QNf", "TimeUS,Name,Value" }, \
|
2013-04-19 04:49:16 -03:00
|
|
|
{ LOG_GPS_MSG, sizeof(log_GPS), \
|
2015-09-09 01:52:52 -03:00
|
|
|
"GPS", "QBIHBcLLeeEefB", "TimeUS,Status,GMS,GWk,NSats,HDop,Lat,Lng,RAlt,Alt,Spd,GCrs,VZ,U" }, \
|
|
|
|
{ LOG_GPS2_MSG, sizeof(log_GPS), \
|
|
|
|
"GPS2", "QBIHBcLLeeEefB", "TimeUS,Status,GMS,GWk,NSats,HDop,Lat,Lng,RAlt,Alt,Spd,GCrs,VZ,U" }, \
|
|
|
|
{ LOG_GPA_MSG, sizeof(log_GPA), \
|
|
|
|
"GPA", "QCCCC", "TimeUS,VDop,HAcc,VAcc,SAcc" }, \
|
|
|
|
{ LOG_GPA2_MSG, sizeof(log_GPA), \
|
|
|
|
"GPA2", "QCCCC", "TimeUS,VDop,HAcc,VAcc,SAcc" }, \
|
2013-04-19 04:49:16 -03:00
|
|
|
{ LOG_IMU_MSG, sizeof(log_IMU), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"IMU", "QffffffIIfBB", "TimeUS,GyrX,GyrY,GyrZ,AccX,AccY,AccZ,ErrG,ErrA,Temp,GyHlt,AcHlt" }, \
|
2013-05-02 20:18:14 -03:00
|
|
|
{ LOG_MESSAGE_MSG, sizeof(log_Message), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"MSG", "QZ", "TimeUS,Message"}, \
|
2013-11-25 17:44:00 -04:00
|
|
|
{ LOG_RCIN_MSG, sizeof(log_RCIN), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"RCIN", "Qhhhhhhhhhhhhhh", "TimeUS,C1,C2,C3,C4,C5,C6,C7,C8,C9,C10,C11,C12,C13,C14" }, \
|
2013-11-27 07:14:17 -04:00
|
|
|
{ LOG_RCOUT_MSG, sizeof(log_RCOUT), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"RCOU", "Qhhhhhhhhhhhh", "TimeUS,Ch1,Ch2,Ch3,Ch4,Ch5,Ch6,Ch7,Ch8,Ch9,Ch10,Ch11,Ch12" }, \
|
2015-09-04 12:50:23 -03:00
|
|
|
{ LOG_RSSI_MSG, sizeof(log_RSSI), \
|
|
|
|
"RSSI", "Qf", "TimeUS,RXRSSI" }, \
|
2014-01-27 19:35:18 -04:00
|
|
|
{ LOG_BARO_MSG, sizeof(log_BARO), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"BARO", "Qffcf", "TimeUS,Alt,Press,Temp,CRt" }, \
|
2014-02-13 07:07:32 -04:00
|
|
|
{ LOG_POWR_MSG, sizeof(log_POWR), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"POWR","QCCH","TimeUS,Vcc,VServo,Flags" }, \
|
2014-06-26 21:28:21 -03:00
|
|
|
{ LOG_CMD_MSG, sizeof(log_Cmd), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"CMD", "QHHHfffffff","TimeUS,CTot,CNum,CId,Prm1,Prm2,Prm3,Prm4,Lat,Lng,Alt" }, \
|
2014-06-26 21:28:21 -03:00
|
|
|
{ LOG_RADIO_MSG, sizeof(log_Radio), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"RAD", "QBBBBBHH", "TimeUS,RSSI,RemRSSI,TxBuf,Noise,RemNoise,RxErrors,Fixed" }, \
|
2014-06-26 21:28:21 -03:00
|
|
|
{ LOG_CAMERA_MSG, sizeof(log_Camera), \
|
2015-05-27 08:31:33 -03:00
|
|
|
"CAM", "QIHLLeeccC","TimeUS,GPSTime,GPSWeek,Lat,Lng,Alt,RelAlt,Roll,Pitch,Yaw" }, \
|
2015-01-19 18:10:33 -04:00
|
|
|
{ LOG_ARSP_MSG, sizeof(log_AIRSPEED), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ARSP", "Qffcff", "TimeUS,Airspeed,DiffPress,Temp,RawPress,Offset" }, \
|
2015-01-14 22:38:16 -04:00
|
|
|
{ LOG_CURRENT_MSG, sizeof(log_Current), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"CURR", "QhhhHfh","TimeUS,Throttle,Volt,Curr,Vcc,CurrTot,Volt2" },\
|
2014-12-19 11:07:06 -04:00
|
|
|
{ LOG_ATTITUDE_MSG, sizeof(log_Attitude),\
|
2015-05-21 22:34:05 -03:00
|
|
|
"ATT", "QccccCCCC", "TimeUS,DesRoll,Roll,DesPitch,Pitch,DesYaw,Yaw,ErrRP,ErrYaw" }, \
|
2015-01-14 22:38:16 -04:00
|
|
|
{ LOG_COMPASS_MSG, sizeof(log_Compass), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"MAG", "QhhhhhhhhhB", "TimeUS,MagX,MagY,MagZ,OfsX,OfsY,OfsZ,MOfsX,MOfsY,MOfsZ,Health" }, \
|
2015-01-14 22:38:16 -04:00
|
|
|
{ LOG_MODE_MSG, sizeof(log_Mode), \
|
2015-09-10 07:27:47 -03:00
|
|
|
"MODE", "QMB", "TimeUS,Mode,ModeNum" }, \
|
|
|
|
{ LOG_RFND_MSG, sizeof(log_RFND), \
|
2015-09-21 20:24:55 -03:00
|
|
|
"RFND", "QCC", "TimeUS,Dist1,Dist2" }
|
2014-06-26 21:28:21 -03:00
|
|
|
|
|
|
|
// messages for more advanced boards
|
|
|
|
#define LOG_EXTRA_STRUCTURES \
|
|
|
|
{ LOG_IMU2_MSG, sizeof(log_IMU), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"IMU2", "QffffffIIfBB", "TimeUS,GyrX,GyrY,GyrZ,AccX,AccY,AccZ,ErrG,ErrA,Temp,GyHlt,AcHlt" }, \
|
2014-06-26 21:28:21 -03:00
|
|
|
{ LOG_IMU3_MSG, sizeof(log_IMU), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"IMU3", "QffffffIIfBB", "TimeUS,GyrX,GyrY,GyrZ,AccX,AccY,AccZ,ErrG,ErrA,Temp,GyHlt,AcHlt" }, \
|
2014-01-03 01:01:08 -04:00
|
|
|
{ LOG_AHR2_MSG, sizeof(log_AHRS), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"AHR2","QccCfLL","TimeUS,Roll,Pitch,Yaw,Alt,Lat,Lng" }, \
|
2015-05-14 22:59:40 -03:00
|
|
|
{ LOG_POS_MSG, sizeof(log_POS), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"POS","QLLff","TimeUS,Lat,Lng,Alt,RelAlt" }, \
|
2014-01-03 01:01:08 -04:00
|
|
|
{ LOG_SIMSTATE_MSG, sizeof(log_AHRS), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"SIM","QccCfLL","TimeUS,Roll,Pitch,Yaw,Alt,Lat,Lng" }, \
|
2014-01-03 20:51:22 -04:00
|
|
|
{ LOG_EKF1_MSG, sizeof(log_EKF1), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"EKF1","QccCffffffccc","TimeUS,Roll,Pitch,Yaw,VN,VE,VD,PN,PE,PD,GX,GY,GZ" }, \
|
2014-01-03 20:51:22 -04:00
|
|
|
{ LOG_EKF2_MSG, sizeof(log_EKF2), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"EKF2","Qbbbcchhhhhh","TimeUS,Ratio,AZ1bias,AZ2bias,VWN,VWE,MN,ME,MD,MX,MY,MZ" }, \
|
2014-01-30 18:33:12 -04:00
|
|
|
{ LOG_EKF3_MSG, sizeof(log_EKF3), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"EKF3","Qcccccchhhc","TimeUS,IVN,IVE,IVD,IPN,IPE,IPD,IMX,IMY,IMZ,IVT" }, \
|
2014-01-30 18:33:12 -04:00
|
|
|
{ LOG_EKF4_MSG, sizeof(log_EKF4), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"EKF4","QcccccccbbBBH","TimeUS,SV,SP,SH,SMX,SMY,SMZ,SVT,OFN,EFE,FS,TS,SS" }, \
|
2015-09-22 23:09:48 -03:00
|
|
|
{ LOG_EKF5_MSG, sizeof(log_EKF5), \
|
|
|
|
"EKF5","QBhhhcccCC","TimeUS,normInnov,FIX,FIY,AFI,HAGL,offset,RI,meaRng,errHAGL" }, \
|
|
|
|
{ LOG_NKF1_MSG, sizeof(log_EKF1), \
|
|
|
|
"NKF1","QccCffffffccc","TimeUS,Roll,Pitch,Yaw,VN,VE,VD,PN,PE,PD,GX,GY,GZ" }, \
|
2015-09-23 22:10:34 -03:00
|
|
|
{ LOG_NKF2_MSG, sizeof(log_NKF2), \
|
|
|
|
"NKF2","Qcccbcchhhhhh","TimeUS,AZbias,GSX,GSY,GSZ,VWN,VWE,MN,ME,MD,MX,MY,MZ" }, \
|
|
|
|
{ LOG_NKF3_MSG, sizeof(log_NKF3), \
|
|
|
|
"NKF3","Qcccccchhhcc","TimeUS,IVN,IVE,IVD,IPN,IPE,IPD,IMX,IMY,IMZ,IYAW,IVT" }, \
|
2015-09-22 23:09:48 -03:00
|
|
|
{ LOG_NKF4_MSG, sizeof(log_EKF4), \
|
|
|
|
"NKF4","QcccccccbbBBH","TimeUS,SV,SP,SH,SMX,SMY,SMZ,SVT,OFN,EFE,FS,TS,SS" }, \
|
|
|
|
{ LOG_NKF5_MSG, sizeof(log_EKF5), \
|
|
|
|
"NKF5","QBhhhcccCC","TimeUS,normInnov,FIX,FIY,AFI,HAGL,offset,RI,meaRng,errHAGL" }, \
|
2014-08-05 23:16:07 -03:00
|
|
|
{ LOG_TERRAIN_MSG, sizeof(log_TERRAIN), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"TERR","QBLLHffHH","TimeUS,Status,Lat,Lng,Spacing,TerrH,CHeight,Pending,Loaded" }, \
|
2014-08-17 08:45:11 -03:00
|
|
|
{ LOG_UBX1_MSG, sizeof(log_Ubx1), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"UBX1", "QBHBBH", "TimeUS,Instance,noisePerMS,jamInd,aPower,agcCnt" }, \
|
2014-08-17 08:45:11 -03:00
|
|
|
{ LOG_UBX2_MSG, sizeof(log_Ubx2), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"UBX2", "QBbBbB", "TimeUS,Instance,ofsI,magI,ofsQ,magQ" }, \
|
2014-10-29 20:44:14 -03:00
|
|
|
{ LOG_UBX3_MSG, sizeof(log_Ubx3), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"UBX3", "QBfff", "TimeUS,Instance,hAcc,vAcc,sAcc" }, \
|
2015-05-04 05:17:42 -03:00
|
|
|
{ LOG_GPS_RAW_MSG, sizeof(log_GPS_RAW), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"GRAW", "QIHBBddfBbB", "TimeUS,WkMS,Week,numSV,sv,cpMes,prMes,doMes,mesQI,cno,lli" }, \
|
2015-06-29 18:55:13 -03:00
|
|
|
{ LOG_GPS_RAWH_MSG, sizeof(log_GPS_RAWH), \
|
|
|
|
"GRXH", "QdHbBB", "TimeUS,rcvTime,week,leapS,numMeas,recStat" }, \
|
|
|
|
{ LOG_GPS_RAWS_MSG, sizeof(log_GPS_RAWS), \
|
|
|
|
"GRXS", "QddfBBBHBBBBB", "TimeUS,prMes,cpMes,doMes,gnss,sv,freq,lock,cno,prD,cpD,doD,trk" }, \
|
2015-08-30 03:53:47 -03:00
|
|
|
{ LOG_GPS_SBF_EVENT_MSG, sizeof(log_GPS_SBF_EVENT), \
|
|
|
|
"SBFE", "QIHBBdddfffff", "TimeUS,TOW,WN,Mode,Err,Lat,Long,Height,Undul,Vn,Ve,Vu,COG" }, \
|
2014-11-13 06:38:33 -04:00
|
|
|
{ LOG_ESC1_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC1", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2014-11-13 06:38:33 -04:00
|
|
|
{ LOG_ESC2_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC2", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2014-11-13 06:38:33 -04:00
|
|
|
{ LOG_ESC3_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC3", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2014-11-13 06:38:33 -04:00
|
|
|
{ LOG_ESC4_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC4", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2014-11-20 06:53:12 -04:00
|
|
|
{ LOG_ESC5_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC5", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2014-11-20 06:53:12 -04:00
|
|
|
{ LOG_ESC6_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC6", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2014-11-20 06:53:12 -04:00
|
|
|
{ LOG_ESC7_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC7", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2014-11-20 06:53:12 -04:00
|
|
|
{ LOG_ESC8_MSG, sizeof(log_Esc), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"ESC8", "Qcccc", "TimeUS,RPM,Volt,Curr,Temp" }, \
|
2015-01-21 01:23:42 -04:00
|
|
|
{ LOG_COMPASS2_MSG, sizeof(log_Compass), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"MAG2","QhhhhhhhhhB", "TimeUS,MagX,MagY,MagZ,OfsX,OfsY,OfsZ,MOfsX,MOfsY,MOfsZ,Health" }, \
|
2015-01-21 01:23:42 -04:00
|
|
|
{ LOG_COMPASS3_MSG, sizeof(log_Compass), \
|
2015-05-21 22:34:05 -03:00
|
|
|
"MAG3","QhhhhhhhhhB", "TimeUS,MagX,MagY,MagZ,OfsX,OfsY,OfsZ,MOfsX,MOfsY,MOfsZ,Health" }, \
|
2015-05-06 23:08:04 -03:00
|
|
|
{ LOG_ACC1_MSG, sizeof(log_ACCEL), \
|
2015-05-22 21:02:22 -03:00
|
|
|
"ACC1", "QQfff", "TimeUS,SampleUS,AccX,AccY,AccZ" }, \
|
2015-05-06 23:08:04 -03:00
|
|
|
{ LOG_ACC2_MSG, sizeof(log_ACCEL), \
|
2015-05-22 21:02:22 -03:00
|
|
|
"ACC2", "QQfff", "TimeUS,SampleUS,AccX,AccY,AccZ" }, \
|
2015-05-06 23:08:04 -03:00
|
|
|
{ LOG_ACC3_MSG, sizeof(log_ACCEL), \
|
2015-05-22 21:02:22 -03:00
|
|
|
"ACC3", "QQfff", "TimeUS,SampleUS,AccX,AccY,AccZ" }, \
|
2015-05-06 23:08:04 -03:00
|
|
|
{ LOG_GYR1_MSG, sizeof(log_GYRO), \
|
2015-05-22 21:02:22 -03:00
|
|
|
"GYR1", "QQfff", "TimeUS,SampleUS,GyrX,GyrY,GyrZ" }, \
|
2015-05-06 23:08:04 -03:00
|
|
|
{ LOG_GYR2_MSG, sizeof(log_GYRO), \
|
2015-05-22 21:02:22 -03:00
|
|
|
"GYR2", "QQfff", "TimeUS,SampleUS,GyrX,GyrY,GyrZ" }, \
|
2015-05-06 23:08:04 -03:00
|
|
|
{ LOG_GYR3_MSG, sizeof(log_GYRO), \
|
2015-05-28 00:54:42 -03:00
|
|
|
"GYR3", "QQfff", "TimeUS,SampleUS,GyrX,GyrY,GyrZ" }, \
|
|
|
|
{ LOG_PIDR_MSG, sizeof(log_PID), \
|
|
|
|
"PIDR", "Qffffff", "TimeUS,Des,P,I,D,FF,AFF" }, \
|
|
|
|
{ LOG_PIDP_MSG, sizeof(log_PID), \
|
|
|
|
"PIDP", "Qffffff", "TimeUS,Des,P,I,D,FF,AFF" }, \
|
|
|
|
{ LOG_PIDY_MSG, sizeof(log_PID), \
|
|
|
|
"PIDY", "Qffffff", "TimeUS,Des,P,I,D,FF,AFF" }, \
|
|
|
|
{ LOG_PIDA_MSG, sizeof(log_PID), \
|
|
|
|
"PIDA", "Qffffff", "TimeUS,Des,P,I,D,FF,AFF" }, \
|
2015-06-22 02:32:14 -03:00
|
|
|
{ LOG_PIDS_MSG, sizeof(log_PID), \
|
|
|
|
"PIDS", "Qffffff", "TimeUS,Des,P,I,D,FF,AFF" }, \
|
2015-05-28 00:54:42 -03:00
|
|
|
{ LOG_BAR2_MSG, sizeof(log_BARO), \
|
2015-06-11 10:26:45 -03:00
|
|
|
"BAR2", "Qffcf", "TimeUS,Alt,Press,Temp,CRt" }, \
|
2015-09-10 07:27:47 -03:00
|
|
|
{ LOG_BAR3_MSG, sizeof(log_BARO), \
|
|
|
|
"BAR3", "Qffcf", "TimeUS,Alt,Press,Temp,CRt" }, \
|
2015-06-11 10:26:45 -03:00
|
|
|
{ LOG_VIBE_MSG, sizeof(log_Vibe), \
|
2015-06-13 10:06:49 -03:00
|
|
|
"VIBE", "QfffIII", "TimeUS,VibeX,VibeY,VibeZ,Clip0,Clip1,Clip2" }, \
|
|
|
|
{ LOG_IMUDT_MSG, sizeof(log_IMUDT), \
|
|
|
|
"IMT","Qffffffff","TimeUS,DelT,DelvT,DelAX,DelAY,DelAZ,DelVX,DelVY,DelVZ" }, \
|
|
|
|
{ LOG_IMUDT2_MSG, sizeof(log_IMUDT), \
|
|
|
|
"IMT2","Qffffffff","TimeUS,DelT,DelvT,DelAX,DelAY,DelAZ,DelVX,DelVY,DelVZ" }, \
|
|
|
|
{ LOG_IMUDT3_MSG, sizeof(log_IMUDT), \
|
2015-07-03 08:49:45 -03:00
|
|
|
"IMT3","Qffffffff","TimeUS,DelT,DelvT,DelAX,DelAY,DelAZ,DelVX,DelVY,DelVZ" }, \
|
|
|
|
{ LOG_ORGN_MSG, sizeof(log_ORGN), \
|
2015-08-07 07:34:14 -03:00
|
|
|
"ORGN","QBLLe","TimeUS,Type,Lat,Lng,Alt" }, \
|
|
|
|
{ LOG_RPM_MSG, sizeof(log_RPM), \
|
|
|
|
"RPM", "Qff", "TimeUS,rpm1,rpm2" }
|
2014-06-26 21:28:21 -03:00
|
|
|
|
|
|
|
#if HAL_CPU_CLASS >= HAL_CPU_CLASS_75
|
|
|
|
#define LOG_COMMON_STRUCTURES LOG_BASE_STRUCTURES, LOG_EXTRA_STRUCTURES
|
|
|
|
#else
|
|
|
|
#define LOG_COMMON_STRUCTURES LOG_BASE_STRUCTURES
|
|
|
|
#endif
|
2013-04-19 04:49:16 -03:00
|
|
|
|
2015-06-20 03:18:50 -03:00
|
|
|
// message types 0 to 128 reversed for vehicle specific use
|
2014-03-23 22:03:31 -03:00
|
|
|
|
2013-04-19 04:49:16 -03:00
|
|
|
// message types for common messages
|
2015-06-20 03:18:50 -03:00
|
|
|
enum LogMessages {
|
|
|
|
LOG_FORMAT_MSG = 128,
|
|
|
|
LOG_PARAMETER_MSG,
|
|
|
|
LOG_GPS_MSG,
|
2015-08-05 03:25:48 -03:00
|
|
|
LOG_GPS2_MSG,
|
2015-06-20 03:18:50 -03:00
|
|
|
LOG_IMU_MSG,
|
|
|
|
LOG_MESSAGE_MSG,
|
|
|
|
LOG_RCIN_MSG,
|
|
|
|
LOG_RCOUT_MSG,
|
2015-09-04 12:50:23 -03:00
|
|
|
LOG_RSSI_MSG,
|
2015-06-20 03:18:50 -03:00
|
|
|
LOG_IMU2_MSG,
|
|
|
|
LOG_BARO_MSG,
|
|
|
|
LOG_POWR_MSG,
|
|
|
|
LOG_AHR2_MSG,
|
|
|
|
LOG_SIMSTATE_MSG,
|
|
|
|
LOG_EKF1_MSG,
|
|
|
|
LOG_EKF2_MSG,
|
|
|
|
LOG_EKF3_MSG,
|
|
|
|
LOG_EKF4_MSG,
|
|
|
|
LOG_CMD_MSG,
|
|
|
|
LOG_RADIO_MSG,
|
|
|
|
LOG_ATRP_MSG,
|
|
|
|
LOG_CAMERA_MSG,
|
|
|
|
LOG_IMU3_MSG,
|
|
|
|
LOG_TERRAIN_MSG,
|
|
|
|
LOG_UBX1_MSG,
|
|
|
|
LOG_UBX2_MSG,
|
|
|
|
LOG_UBX3_MSG,
|
|
|
|
LOG_ESC1_MSG,
|
|
|
|
LOG_ESC2_MSG,
|
|
|
|
LOG_ESC3_MSG,
|
|
|
|
LOG_ESC4_MSG,
|
|
|
|
LOG_ESC5_MSG,
|
|
|
|
LOG_ESC6_MSG,
|
|
|
|
LOG_ESC7_MSG,
|
|
|
|
LOG_ESC8_MSG,
|
|
|
|
LOG_EKF5_MSG,
|
|
|
|
LOG_BAR2_MSG,
|
|
|
|
LOG_ARSP_MSG,
|
|
|
|
LOG_ATTITUDE_MSG,
|
|
|
|
LOG_CURRENT_MSG,
|
|
|
|
LOG_COMPASS_MSG,
|
|
|
|
LOG_COMPASS2_MSG,
|
|
|
|
LOG_COMPASS3_MSG,
|
|
|
|
LOG_MODE_MSG,
|
|
|
|
LOG_GPS_RAW_MSG,
|
2015-06-29 18:55:13 -03:00
|
|
|
LOG_GPS_RAWH_MSG,
|
|
|
|
LOG_GPS_RAWS_MSG,
|
2015-08-30 03:53:47 -03:00
|
|
|
LOG_GPS_SBF_EVENT_MSG,
|
2015-06-20 03:18:50 -03:00
|
|
|
LOG_ACC1_MSG,
|
|
|
|
LOG_ACC2_MSG,
|
|
|
|
LOG_ACC3_MSG,
|
|
|
|
LOG_GYR1_MSG,
|
|
|
|
LOG_GYR2_MSG,
|
|
|
|
LOG_GYR3_MSG,
|
|
|
|
LOG_POS_MSG,
|
|
|
|
LOG_PIDR_MSG,
|
|
|
|
LOG_PIDP_MSG,
|
|
|
|
LOG_PIDY_MSG,
|
|
|
|
LOG_PIDA_MSG,
|
2015-06-22 02:32:14 -03:00
|
|
|
LOG_PIDS_MSG,
|
2015-06-20 03:18:50 -03:00
|
|
|
LOG_VIBE_MSG,
|
|
|
|
LOG_IMUDT_MSG,
|
|
|
|
LOG_IMUDT2_MSG,
|
2015-07-03 08:49:45 -03:00
|
|
|
LOG_IMUDT3_MSG,
|
2015-08-07 07:34:14 -03:00
|
|
|
LOG_ORGN_MSG,
|
2015-09-09 01:52:52 -03:00
|
|
|
LOG_RPM_MSG,
|
|
|
|
LOG_GPA_MSG,
|
|
|
|
LOG_GPA2_MSG,
|
2015-09-10 07:27:47 -03:00
|
|
|
LOG_RFND_MSG,
|
|
|
|
LOG_BAR3_MSG,
|
2015-09-22 23:09:48 -03:00
|
|
|
LOG_NKF1_MSG,
|
|
|
|
LOG_NKF2_MSG,
|
|
|
|
LOG_NKF3_MSG,
|
|
|
|
LOG_NKF4_MSG,
|
|
|
|
LOG_NKF5_MSG,
|
2015-07-03 08:49:45 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
enum LogOriginType {
|
|
|
|
ekf_origin = 0,
|
|
|
|
ahrs_home = 1
|
2015-06-20 03:18:50 -03:00
|
|
|
};
|
2013-04-19 04:49:16 -03:00
|
|
|
|
2014-03-23 22:03:31 -03:00
|
|
|
// message types 200 to 210 reversed for GPS driver use
|
2014-04-12 05:21:31 -03:00
|
|
|
// message types 211 to 220 reversed for autotune use
|
2014-03-23 22:03:31 -03:00
|
|
|
|
2011-11-07 07:21:29 -04:00
|
|
|
#endif
|