mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 14:38:30 -04:00
AP_HAL_SITL: SITL_State_common: add elrs and pass portnumber in create_serial_sim
This commit is contained in:
parent
b0ceaa7610
commit
cbd5bcb694
@ -25,7 +25,7 @@ extern const AP_HAL::HAL& hal;
|
|||||||
using namespace HALSITL;
|
using namespace HALSITL;
|
||||||
|
|
||||||
#define streq(a, b) (!strcmp(a, b))
|
#define streq(a, b) (!strcmp(a, b))
|
||||||
SITL::SerialDevice *SITL_State_Common::create_serial_sim(const char *name, const char *arg)
|
SITL::SerialDevice *SITL_State_Common::create_serial_sim(const char *name, const char *arg, const uint8_t portNumber)
|
||||||
{
|
{
|
||||||
if (streq(name, "benewake_tf02")) {
|
if (streq(name, "benewake_tf02")) {
|
||||||
if (benewake_tf02 != nullptr) {
|
if (benewake_tf02 != nullptr) {
|
||||||
@ -314,6 +314,13 @@ SITL::SerialDevice *SITL_State_Common::create_serial_sim(const char *name, const
|
|||||||
}
|
}
|
||||||
gps[x-1] = new SITL::GPS(x-1);
|
gps[x-1] = new SITL::GPS(x-1);
|
||||||
return gps[x-1];
|
return gps[x-1];
|
||||||
|
} else if (streq(name, "ELRS")) {
|
||||||
|
// Only allocate if not done already
|
||||||
|
// MAVLink serial ports have begin called several times
|
||||||
|
if (elrs == nullptr) {
|
||||||
|
elrs = new SITL::ELRS(portNumber, this);
|
||||||
|
}
|
||||||
|
return elrs;
|
||||||
}
|
}
|
||||||
|
|
||||||
AP_HAL::panic("unknown simulated device: %s", name);
|
AP_HAL::panic("unknown simulated device: %s", name);
|
||||||
@ -481,6 +488,10 @@ void SITL_State_Common::sim_update(void)
|
|||||||
gps[i]->update();
|
gps[i]->update();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (elrs != nullptr) {
|
||||||
|
elrs->update();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -53,6 +53,8 @@
|
|||||||
#include <SITL/SIM_Loweheiser.h>
|
#include <SITL/SIM_Loweheiser.h>
|
||||||
#include <SITL/SIM_FETtecOneWireESC.h>
|
#include <SITL/SIM_FETtecOneWireESC.h>
|
||||||
|
|
||||||
|
#include <SITL/SIM_ELRS.h>
|
||||||
|
|
||||||
#include "AP_HAL_SITL.h"
|
#include "AP_HAL_SITL.h"
|
||||||
#include "AP_HAL_SITL_Namespace.h"
|
#include "AP_HAL_SITL_Namespace.h"
|
||||||
#include "HAL_SITL_Class.h"
|
#include "HAL_SITL_Class.h"
|
||||||
@ -88,7 +90,7 @@ public:
|
|||||||
|
|
||||||
// create a simulated serial device; type of device is given by
|
// create a simulated serial device; type of device is given by
|
||||||
// name parameter
|
// name parameter
|
||||||
SITL::SerialDevice *create_serial_sim(const char *name, const char *arg);
|
SITL::SerialDevice *create_serial_sim(const char *name, const char *arg, const uint8_t portNumber);
|
||||||
|
|
||||||
// simulated airspeed, sonar and battery monitor
|
// simulated airspeed, sonar and battery monitor
|
||||||
float sonar_pin_voltage; // pin 0
|
float sonar_pin_voltage; // pin 0
|
||||||
@ -231,6 +233,9 @@ public:
|
|||||||
// simulated GPS devices
|
// simulated GPS devices
|
||||||
SITL::GPS *gps[2]; // constrained by # of parameter sets
|
SITL::GPS *gps[2]; // constrained by # of parameter sets
|
||||||
|
|
||||||
|
// Simulated ELRS radio
|
||||||
|
SITL::ELRS *elrs;
|
||||||
|
|
||||||
// returns a voltage between 0V to 5V which should appear as the
|
// returns a voltage between 0V to 5V which should appear as the
|
||||||
// voltage from the sensor
|
// voltage from the sensor
|
||||||
float _sonar_pin_voltage() const;
|
float _sonar_pin_voltage() const;
|
||||||
|
@ -77,11 +77,11 @@ void UARTDriver::_begin(uint32_t baud, uint16_t rxSpace, uint16_t txSpace)
|
|||||||
if (strcmp(path, "GPS1") == 0) {
|
if (strcmp(path, "GPS1") == 0) {
|
||||||
/* gps */
|
/* gps */
|
||||||
_connected = true;
|
_connected = true;
|
||||||
_sim_serial_device = _sitlState->create_serial_sim("gps:1", "");
|
_sim_serial_device = _sitlState->create_serial_sim("gps:1", "", _portNumber);
|
||||||
} else if (strcmp(path, "GPS2") == 0) {
|
} else if (strcmp(path, "GPS2") == 0) {
|
||||||
/* 2nd gps */
|
/* 2nd gps */
|
||||||
_connected = true;
|
_connected = true;
|
||||||
_sim_serial_device = _sitlState->create_serial_sim("gps:2", "");
|
_sim_serial_device = _sitlState->create_serial_sim("gps:2", "", _portNumber);
|
||||||
} else {
|
} else {
|
||||||
/* parse type:args:flags string for path.
|
/* parse type:args:flags string for path.
|
||||||
For example:
|
For example:
|
||||||
@ -109,7 +109,7 @@ void UARTDriver::_begin(uint32_t baud, uint16_t rxSpace, uint16_t txSpace)
|
|||||||
// add sanity check here that we're doing mavlink on this port?
|
// add sanity check here that we're doing mavlink on this port?
|
||||||
::printf("SIM-ADSB connection on SERIAL%u\n", _portNumber);
|
::printf("SIM-ADSB connection on SERIAL%u\n", _portNumber);
|
||||||
_connected = true;
|
_connected = true;
|
||||||
_sim_serial_device = _sitlState->create_serial_sim("adsb", nullptr);
|
_sim_serial_device = _sitlState->create_serial_sim("adsb", nullptr, _portNumber);
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
if (strcmp(devtype, "tcp") == 0) {
|
if (strcmp(devtype, "tcp") == 0) {
|
||||||
@ -132,7 +132,7 @@ void UARTDriver::_begin(uint32_t baud, uint16_t rxSpace, uint16_t txSpace)
|
|||||||
if (!_connected) {
|
if (!_connected) {
|
||||||
::printf("SIM connection %s:%s on SERIAL%u\n", args1, args2, _portNumber);
|
::printf("SIM connection %s:%s on SERIAL%u\n", args1, args2, _portNumber);
|
||||||
_connected = true;
|
_connected = true;
|
||||||
_sim_serial_device = _sitlState->create_serial_sim(args1, args2);
|
_sim_serial_device = _sitlState->create_serial_sim(args1, args2, _portNumber);
|
||||||
}
|
}
|
||||||
} else if (strcmp(devtype, "udpclient") == 0) {
|
} else if (strcmp(devtype, "udpclient") == 0) {
|
||||||
// udp client connection
|
// udp client connection
|
||||||
|
Loading…
Reference in New Issue
Block a user