Ardupilot2/libraries/AP_HAL_Linux/TCPServerDevice.cpp

125 lines
2.5 KiB
C++
Raw Normal View History

#include <AP_HAL/AP_HAL.h>
2015-06-19 10:58:40 -03:00
#if CONFIG_HAL_BOARD == HAL_BOARD_LINUX
#include <stdio.h>
#include <unistd.h>
#include <errno.h>
#include <stdlib.h>
2015-07-08 14:27:21 -03:00
#include "TCPServerDevice.h"
2015-06-19 10:58:40 -03:00
extern const AP_HAL::HAL& hal;
TCPServerDevice::TCPServerDevice(const char *ip, uint16_t port, bool wait):
2015-06-19 10:58:40 -03:00
_ip(ip),
_port(port),
_wait(wait)
2015-06-19 10:58:40 -03:00
{
}
2015-07-08 14:27:21 -03:00
TCPServerDevice::~TCPServerDevice()
2015-06-19 10:58:40 -03:00
{
if (sock != NULL) {
delete sock;
sock = NULL;
}
2015-06-19 10:58:40 -03:00
}
2015-07-08 14:27:21 -03:00
ssize_t TCPServerDevice::write(const uint8_t *buf, uint16_t n)
2015-06-19 10:58:40 -03:00
{
if (sock == NULL) {
return -1;
}
return sock->send(buf, n);
2015-06-19 10:58:40 -03:00
}
/*
when we try to read we accept new connections if one isn't already
established
*/
2015-07-08 14:27:21 -03:00
ssize_t TCPServerDevice::read(uint8_t *buf, uint16_t n)
2015-06-19 10:58:40 -03:00
{
if (sock == NULL) {
sock = listener.accept(0);
if (sock != NULL) {
sock->set_blocking(_blocking);
}
}
if (sock == NULL) {
return -1;
}
ssize_t ret = sock->recv(buf, n, 1);
if (ret == 0) {
// EOF, go back to waiting for a new connection
delete sock;
sock = NULL;
return -1;
}
return ret;
2015-06-19 10:58:40 -03:00
}
2015-07-08 14:27:21 -03:00
bool TCPServerDevice::open()
2015-06-19 10:58:40 -03:00
{
listener.reuseaddress();
if (!listener.bind(_ip, _port)) {
if (hal.scheduler->millis() - _last_bind_warning > 5000) {
::printf("bind failed on %s port %u - %s\n",
_ip,
_port,
strerror(errno));
_last_bind_warning = hal.scheduler->millis();
}
return false;
}
if (!listener.listen(1)) {
if (hal.scheduler->millis() - _last_bind_warning > 5000) {
::printf("listen failed on %s port %u - %s\n",
_ip,
_port,
strerror(errno));
_last_bind_warning = hal.scheduler->millis();
}
return false;
2015-06-19 10:58:40 -03:00
}
listener.set_blocking(false);
if (_wait) {
::printf("Waiting for connection on %s:%u ....\n",
_ip, (unsigned)_port);
::fflush(stdout);
while (sock == NULL) {
sock = listener.accept(1000);
}
sock->set_blocking(_blocking);
::printf("connected\n");
::fflush(stdout);
}
2015-06-19 10:58:40 -03:00
return true;
}
2015-07-08 14:27:21 -03:00
bool TCPServerDevice::close()
2015-06-19 10:58:40 -03:00
{
if (sock != NULL) {
delete sock;
sock = NULL;
}
2015-06-19 10:58:40 -03:00
return true;
}
2015-07-08 14:27:21 -03:00
void TCPServerDevice::set_blocking(bool blocking)
2015-06-19 10:58:40 -03:00
{
_blocking = blocking;
listener.set_blocking(_blocking);
2015-06-19 10:58:40 -03:00
}
2015-07-08 14:27:21 -03:00
void TCPServerDevice::set_speed(uint32_t speed)
2015-06-19 10:58:40 -03:00
{
}
#endif