2013-09-22 03:01:24 -03:00
|
|
|
|
|
|
|
#ifndef __AP_HAL_LINUX_UARTDRIVER_H__
|
|
|
|
#define __AP_HAL_LINUX_UARTDRIVER_H__
|
|
|
|
|
|
|
|
#include <AP_HAL_Linux.h>
|
|
|
|
|
|
|
|
class Linux::LinuxUARTDriver : public AP_HAL::UARTDriver {
|
|
|
|
public:
|
2013-09-30 23:49:58 -03:00
|
|
|
LinuxUARTDriver(bool default_console);
|
2013-09-22 03:01:24 -03:00
|
|
|
/* Linux implementations of UARTDriver virtual methods */
|
|
|
|
void begin(uint32_t b);
|
|
|
|
void begin(uint32_t b, uint16_t rxS, uint16_t txS);
|
|
|
|
void end();
|
|
|
|
void flush();
|
|
|
|
bool is_initialized();
|
|
|
|
void set_blocking_writes(bool blocking);
|
|
|
|
bool tx_pending();
|
|
|
|
|
|
|
|
/* Linux implementations of Stream virtual methods */
|
|
|
|
int16_t available();
|
|
|
|
int16_t txspace();
|
|
|
|
int16_t read();
|
|
|
|
|
|
|
|
/* Linux implementations of Print virtual methods */
|
|
|
|
size_t write(uint8_t c);
|
2013-09-28 21:13:51 -03:00
|
|
|
size_t write(const uint8_t *buffer, size_t size);
|
2013-09-22 03:01:24 -03:00
|
|
|
|
2014-06-11 03:34:07 -03:00
|
|
|
void set_device_path(char *path);
|
2013-09-22 03:01:24 -03:00
|
|
|
|
2013-09-28 21:13:51 -03:00
|
|
|
void _timer_tick(void);
|
|
|
|
|
2014-10-08 22:21:50 -03:00
|
|
|
enum flow_control get_flow_control(void) { return _flow_control; }
|
|
|
|
|
2013-09-22 03:01:24 -03:00
|
|
|
private:
|
2014-06-11 03:34:07 -03:00
|
|
|
char *device_path;
|
2013-09-30 23:49:58 -03:00
|
|
|
int _rd_fd;
|
|
|
|
int _wr_fd;
|
2013-09-28 21:13:51 -03:00
|
|
|
bool _nonblocking_writes;
|
2013-09-30 23:49:58 -03:00
|
|
|
bool _console;
|
2013-09-28 21:13:51 -03:00
|
|
|
volatile bool _initialised;
|
|
|
|
volatile bool _in_timer;
|
2014-06-11 03:34:07 -03:00
|
|
|
uint16_t _base_port;
|
|
|
|
char *_ip;
|
|
|
|
char *_flag;
|
|
|
|
bool _connected; // true if a client has connected
|
2014-10-06 01:10:48 -03:00
|
|
|
bool _packetise; // true if writes should try to be on mavlink boundaries
|
2013-09-28 21:13:51 -03:00
|
|
|
|
|
|
|
// we use in-task ring buffers to reduce the system call cost
|
|
|
|
// of ::read() and ::write() in the main loop
|
|
|
|
uint8_t *_readbuf;
|
|
|
|
uint16_t _readbuf_size;
|
2014-10-08 22:21:50 -03:00
|
|
|
enum flow_control _flow_control;
|
2013-09-28 21:13:51 -03:00
|
|
|
|
|
|
|
// _head is where the next available data is. _tail is where new
|
|
|
|
// data is put
|
|
|
|
volatile uint16_t _readbuf_head;
|
|
|
|
volatile uint16_t _readbuf_tail;
|
|
|
|
|
|
|
|
uint8_t *_writebuf;
|
|
|
|
uint16_t _writebuf_size;
|
|
|
|
volatile uint16_t _writebuf_head;
|
|
|
|
volatile uint16_t _writebuf_tail;
|
|
|
|
|
|
|
|
int _write_fd(const uint8_t *buf, uint16_t n);
|
|
|
|
int _read_fd(uint8_t *buf, uint16_t n);
|
2014-06-11 03:34:07 -03:00
|
|
|
void _tcp_start_connection(bool wait_for_connection);
|
2014-10-06 01:10:48 -03:00
|
|
|
void _udp_start_connection(void);
|
|
|
|
|
|
|
|
enum device_type {
|
|
|
|
DEVICE_TCP,
|
|
|
|
DEVICE_UDP,
|
|
|
|
DEVICE_SERIAL,
|
|
|
|
DEVICE_UNKNOWN
|
|
|
|
};
|
|
|
|
|
|
|
|
enum device_type _parseDevicePath(const char *arg);
|
2014-06-11 03:34:07 -03:00
|
|
|
uint64_t _last_write_time;
|
2013-09-22 03:01:24 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // __AP_HAL_LINUX_UARTDRIVER_H__
|