2016-02-17 21:25:26 -04:00
|
|
|
#pragma once
|
2013-09-22 03:01:24 -03:00
|
|
|
|
2016-07-07 10:44:05 -03:00
|
|
|
#include <AP_HAL/utility/OwnPtr.h>
|
2016-07-29 21:40:56 -03:00
|
|
|
#include <AP_HAL/utility/RingBuffer.h>
|
2013-09-22 03:01:24 -03:00
|
|
|
|
2016-07-07 10:44:05 -03:00
|
|
|
#include "AP_HAL_Linux.h"
|
2015-06-11 15:30:36 -03:00
|
|
|
#include "SerialDevice.h"
|
2018-08-06 03:23:24 -03:00
|
|
|
#include "Semaphores.h"
|
2015-06-11 15:30:36 -03:00
|
|
|
|
2016-07-29 16:14:02 -03:00
|
|
|
namespace Linux {
|
|
|
|
|
|
|
|
class UARTDriver : public AP_HAL::UARTDriver {
|
2013-09-22 03:01:24 -03:00
|
|
|
public:
|
2015-10-20 18:13:25 -03:00
|
|
|
UARTDriver(bool default_console);
|
2015-09-13 15:28:02 -03:00
|
|
|
|
2015-10-20 18:13:25 -03:00
|
|
|
static UARTDriver *from(AP_HAL::UARTDriver *uart) {
|
|
|
|
return static_cast<UARTDriver*>(uart);
|
2015-09-13 15:28:02 -03:00
|
|
|
}
|
|
|
|
|
2019-02-21 19:08:12 -04:00
|
|
|
bool is_initialized() override;
|
|
|
|
bool tx_pending() override;
|
2013-09-22 03:01:24 -03:00
|
|
|
|
2016-08-02 10:42:50 -03:00
|
|
|
uint32_t txspace() override;
|
2013-09-22 03:01:24 -03:00
|
|
|
|
2015-06-28 15:57:19 -03:00
|
|
|
void set_device_path(const char *path);
|
2013-09-22 03:01:24 -03:00
|
|
|
|
2015-07-29 01:03:30 -03:00
|
|
|
bool _write_pending_bytes(void);
|
2018-01-21 15:45:31 -04:00
|
|
|
virtual void _timer_tick(void) override;
|
2013-09-28 21:13:51 -03:00
|
|
|
|
2016-07-07 12:46:12 -03:00
|
|
|
virtual enum flow_control get_flow_control(void) override
|
|
|
|
{
|
|
|
|
return _device->get_flow_control();
|
|
|
|
}
|
|
|
|
|
2019-05-24 10:26:26 -03:00
|
|
|
void configure_parity(uint8_t v) override;
|
2019-04-11 11:26:35 -03:00
|
|
|
|
2016-07-07 12:46:12 -03:00
|
|
|
virtual void set_flow_control(enum flow_control flow_control_setting) override
|
|
|
|
{
|
|
|
|
_device->set_flow_control(flow_control_setting);
|
|
|
|
}
|
2014-10-08 22:21:50 -03:00
|
|
|
|
2018-05-15 21:47:42 -03:00
|
|
|
/*
|
|
|
|
return timestamp estimate in microseconds for when the start of
|
|
|
|
a nbytes packet arrived on the uart. This should be treated as a
|
|
|
|
time constraint, not an exact time. It is guaranteed that the
|
|
|
|
packet did not start being received after this time, but it
|
|
|
|
could have been in a system buffer before the returned time.
|
|
|
|
|
|
|
|
This takes account of the baudrate of the link. For transports
|
|
|
|
that have no baudrate (such as USB) the time estimate may be
|
|
|
|
less accurate.
|
|
|
|
|
|
|
|
A return value of zero means the HAL does not support this API
|
|
|
|
*/
|
2018-05-16 18:01:14 -03:00
|
|
|
uint64_t receive_time_constraint_us(uint16_t nbytes) override;
|
2019-07-21 19:36:13 -03:00
|
|
|
|
2023-10-24 19:42:14 -03:00
|
|
|
uint32_t bw_in_bytes_per_second() const override;
|
|
|
|
|
2024-05-06 22:42:24 -03:00
|
|
|
virtual uint32_t get_baud_rate() const override { return _baudrate; }
|
2024-02-28 02:11:31 -04:00
|
|
|
|
2013-09-22 03:01:24 -03:00
|
|
|
private:
|
2016-07-07 10:44:05 -03:00
|
|
|
AP_HAL::OwnPtr<SerialDevice> _device;
|
2013-09-30 23:49:58 -03:00
|
|
|
bool _console;
|
2013-09-28 21:13:51 -03:00
|
|
|
volatile bool _in_timer;
|
2014-06-11 03:34:07 -03:00
|
|
|
uint16_t _base_port;
|
2018-05-15 21:47:42 -03:00
|
|
|
uint32_t _baudrate;
|
2014-06-11 03:34:07 -03:00
|
|
|
char *_ip;
|
|
|
|
char *_flag;
|
2016-07-29 16:14:02 -03:00
|
|
|
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
|
2014-11-07 06:17:50 -04:00
|
|
|
|
2015-06-11 08:53:52 -03:00
|
|
|
void _allocate_buffers(uint16_t rxS, uint16_t txS);
|
2015-06-11 15:35:48 -03:00
|
|
|
void _deallocate_buffers();
|
2016-07-07 14:57:06 -03:00
|
|
|
|
|
|
|
AP_HAL::OwnPtr<SerialDevice> _parseDevicePath(const char *arg);
|
2013-09-28 21:13:51 -03:00
|
|
|
|
2018-05-15 21:47:42 -03:00
|
|
|
// timestamp for receiving data on the UART, avoiding a lock
|
|
|
|
uint64_t _receive_timestamp[2];
|
|
|
|
uint8_t _receive_timestamp_idx;
|
2019-07-21 19:36:13 -03:00
|
|
|
|
2014-11-07 06:17:50 -04:00
|
|
|
protected:
|
2015-06-28 15:57:19 -03:00
|
|
|
const char *device_path;
|
2014-11-07 06:17:50 -04:00
|
|
|
volatile bool _initialised;
|
2016-07-29 21:40:56 -03:00
|
|
|
|
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
|
2016-07-29 21:40:56 -03:00
|
|
|
ByteBuffer _readbuf{0};
|
|
|
|
ByteBuffer _writebuf{0};
|
2013-09-28 21:13:51 -03:00
|
|
|
|
2014-11-07 06:17:50 -04:00
|
|
|
virtual int _write_fd(const uint8_t *buf, uint16_t n);
|
|
|
|
virtual int _read_fd(uint8_t *buf, uint16_t n);
|
2018-08-06 03:23:24 -03:00
|
|
|
|
2019-07-21 19:36:13 -03:00
|
|
|
Linux::Semaphore _write_mutex;
|
2023-07-07 05:46:52 -03:00
|
|
|
|
|
|
|
bool _discard_input() override;
|
|
|
|
void _begin(uint32_t b, uint16_t rxS, uint16_t txS) override;
|
|
|
|
void _end() override;
|
|
|
|
void _flush() override;
|
|
|
|
uint32_t _available() override;
|
|
|
|
size_t _write(const uint8_t *buffer, size_t size) override;
|
|
|
|
ssize_t _read(uint8_t *buffer, uint16_t count) override WARN_IF_UNUSED;
|
2013-09-22 03:01:24 -03:00
|
|
|
};
|
2016-07-29 16:14:02 -03:00
|
|
|
|
|
|
|
}
|