/*
* This file is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This file is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see .
*/
/*
decode RC input using SITL on command line
*/
#include
const AP_HAL::HAL& hal = AP_HAL::get_HAL();
void setup();
void loop();
#if CONFIG_HAL_BOARD == HAL_BOARD_LINUX || CONFIG_HAL_BOARD == HAL_BOARD_SITL
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
static AP_RCProtocol *rcprot;
// change this to the device being tested.
const char *devname = "/dev/serial/by-id/usb-FTDI_FT232R_USB_UART_A10596TP-if00-port0";
const uint32_t baudrate = 115200;
static int fd;
// setup routine
void setup()
{
// introduction
hal.console->printf("ArduPilot RC protocol decoder\n");
hal.scheduler->delay(100);
fd = open(devname, O_RDONLY|O_CLOEXEC);
if (fd == -1) {
perror(devname);
exit(1);
}
struct termios options;
tcgetattr(fd, &options);
cfsetspeed(&options, baudrate);
tcgetattr(fd, &options);
if (baudrate == 100000) {
// SBUS: 100000bps, even parity, two stop bits
options.c_cflag |= (CSTOPB | PARENB);
} else {
// DSM: 115200, one stop, no parity
options.c_cflag &= ~(PARENB|CSTOPB|CSIZE);
options.c_cflag |= CS8;
}
options.c_lflag &= ~(ICANON|ECHO|ECHOE|ISIG);
options.c_iflag &= ~(IXON|IXOFF|IXANY);
options.c_oflag &= ~OPOST;
if (tcsetattr(fd, TCSANOW, &options) != 0) {
perror("tcsetattr");
exit(1);
}
tcflush(fd, TCIOFLUSH);
rcprot = new AP_RCProtocol();
rcprot->init();
}
//Main loop where the action takes place
void loop()
{
uint8_t buf[32];
ssize_t ret = read(fd, buf, sizeof(buf));
if (ret <= 0) {
return;
}
for (uint8_t i=0; iprocess_byte(buf[i], 115200);
if (rcprot->new_input()) {
uint8_t nchan = rcprot->num_channels();
printf("%u: ", nchan);
for (uint8_t j=0; jread(j);
printf("%04u ", v);
}
printf("\n");
}
}
}
#else
// dummy implementation
void setup() {}
void loop() {}
#endif // CONFIG_HAL_BOARD
AP_HAL_MAIN();