forked from dronekit/dronekit-la
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdataflash_logger.h
102 lines (80 loc) · 2.95 KB
/
dataflash_logger.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#ifndef DATAFLASH_LOGGER_H
#define DATAFLASH_LOGGER_H
/*
* dataflash_logger
*
* Receive telemetry (mavlink) via UDP from Solo, and create dataflash log files
*
* Initiate a remote-dataflash stream
*/
#include "INIReader.h"
#include "mavlink_message_handler.h"
#include "mavlink_writer.h"
class DataFlash_Logger : public MAVLink_Message_Handler {
public:
DataFlash_Logger(MAVLink_Writer *mavlink_writer) :
MAVLink_Message_Handler(),
_mavlink_writer(mavlink_writer),
target_system_id(target_system_id_default),
target_component_id(target_component_id_default),
seqno_gap_nack_threshold(20)
{ }
private:
bool configure(INIReader *config);
void sighup_received();
void idle_tenthHz();
void idle_1Hz();
void idle_10Hz();
void idle_100Hz();
bool logging_start(mavlink_message_t &m,
mavlink_remote_log_data_block_t &msg);
void logging_stop();
void send_stop_logging_packet();
bool output_file_open();
void output_file_close();
MAVLink_Writer *_mavlink_writer = NULL;
uint8_t this_system_id = 57;
uint8_t this_component_id = 57;
enum arm_status_t : uint8_t {
ARM_STATUS_DISARMED = 0,
ARM_STATUS_ARMED = 1,
ARM_STATUS_UNKNOWN = 2,
};
const uint8_t target_system_id_default = 0;
const uint8_t target_component_id_default = 0;
uint8_t target_system_id; // who to send our request-for-logs to
uint8_t target_component_id; // who to send our request-for-logs to
uint8_t sender_system_id = 0; // who the logs areactually coming from
uint8_t sender_component_id = 0; // who the logs areactually coming from
arm_status_t sender_arm_status = ARM_STATUS_UNKNOWN;
void send_start_logging_packet();
void send_start_or_stop_logging_packet(bool is_start);
const char *_log_directory_path;
int out_fd;
bool logging_started = false;
void handle_decoded_message(uint64_t T,
mavlink_message_t &m,
mavlink_heartbeat_t &msg);
void handle_decoded_message(uint64_t T,
mavlink_message_t &m,
mavlink_remote_log_data_block_t &msg);
bool make_new_log_filename(char *buffer, uint8_t bufferlen);
void send_response(uint32_t seqno, bool status);
void push_response_queue();
#define RESPONSE_QUEUE_LENGTH 128
struct packet_status {
uint32_t seqno;
bool status; // ack == true
} responses[RESPONSE_QUEUE_LENGTH];
uint8_t response_queue_head = 0;
uint8_t response_queue_tail = 0;
uint32_t highest_seqno_seen = 0;
uint64_t _last_data_packet_time = 0;
/* if we lose > this many packets we do not nack anything in that gap: */
uint8_t seqno_gap_nack_threshold;
void queue_response(uint32_t seqno, bool status);
void queue_nack(uint32_t seqno);
void queue_ack(uint32_t seqno);
void queue_gap_nacks(uint32_t seqno);
};
#endif