2023-08-17 17:18:36 -03:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <AP_HAL/AP_HAL.h>
|
|
|
|
|
|
|
|
#if CONFIG_HAL_BOARD == HAL_BOARD_SITL
|
|
|
|
|
|
|
|
#define SITL_MCAST_IP "239.255.145.51"
|
|
|
|
#define SITL_MCAST_PORT 20721
|
|
|
|
|
|
|
|
#include <SITL/SIM_Gimbal.h>
|
|
|
|
#include <SITL/SIM_ADSB.h>
|
|
|
|
#include <SITL/SIM_Vicon.h>
|
|
|
|
#include <SITL/SIM_RF_Benewake_TF02.h>
|
|
|
|
#include <SITL/SIM_RF_Benewake_TF03.h>
|
|
|
|
#include <SITL/SIM_RF_Benewake_TFmini.h>
|
|
|
|
#include <SITL/SIM_RF_NoopLoop.h>
|
|
|
|
#include <SITL/SIM_RF_TeraRanger_Serial.h>
|
|
|
|
#include <SITL/SIM_RF_LightWareSerial.h>
|
|
|
|
#include <SITL/SIM_RF_LightWareSerialBinary.h>
|
|
|
|
#include <SITL/SIM_RF_Lanbao.h>
|
|
|
|
#include <SITL/SIM_RF_BLping.h>
|
|
|
|
#include <SITL/SIM_RF_LeddarOne.h>
|
|
|
|
#include <SITL/SIM_RF_RDS02UF.h>
|
|
|
|
#include <SITL/SIM_RF_USD1_v0.h>
|
|
|
|
#include <SITL/SIM_RF_USD1_v1.h>
|
|
|
|
#include <SITL/SIM_RF_MaxsonarSerialLV.h>
|
|
|
|
#include <SITL/SIM_RF_Wasp.h>
|
|
|
|
#include <SITL/SIM_RF_NMEA.h>
|
|
|
|
#include <SITL/SIM_RF_MAVLink.h>
|
|
|
|
#include <SITL/SIM_RF_GYUS42v2.h>
|
|
|
|
#include <SITL/SIM_VectorNav.h>
|
|
|
|
#include <SITL/SIM_MicroStrain.h>
|
|
|
|
#include <SITL/SIM_AIS.h>
|
|
|
|
#include <SITL/SIM_GPS.h>
|
|
|
|
|
|
|
|
#include <SITL/SIM_Frsky_D.h>
|
|
|
|
#include <SITL/SIM_CRSF.h>
|
|
|
|
// #include <SITL/SIM_Frsky_SPort.h>
|
|
|
|
// #include <SITL/SIM_Frsky_SPortPassthrough.h>
|
|
|
|
#include <SITL/SIM_PS_RPLidarA2.h>
|
|
|
|
#include <SITL/SIM_PS_RPLidarA1.h>
|
|
|
|
#include <SITL/SIM_PS_TeraRangerTower.h>
|
|
|
|
#include <SITL/SIM_PS_LightWare_SF45B.h>
|
|
|
|
|
|
|
|
#include <SITL/SIM_RichenPower.h>
|
|
|
|
#include <SITL/SIM_FETtecOneWireESC.h>
|
|
|
|
|
|
|
|
#include "AP_HAL_SITL.h"
|
|
|
|
#include "AP_HAL_SITL_Namespace.h"
|
|
|
|
#include "HAL_SITL_Class.h"
|
|
|
|
#include "RCInput.h"
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#include <netinet/udp.h>
|
|
|
|
#include <arpa/inet.h>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <AP_Baro/AP_Baro.h>
|
|
|
|
#include <AP_InertialSensor/AP_InertialSensor.h>
|
|
|
|
#include <AP_Compass/AP_Compass.h>
|
|
|
|
#include <AP_Terrain/AP_Terrain.h>
|
|
|
|
#include <SITL/SITL.h>
|
|
|
|
#include <SITL/SITL_Input.h>
|
|
|
|
#include <AP_HAL/utility/Socket.h>
|
|
|
|
|
|
|
|
class HAL_SITL;
|
|
|
|
|
|
|
|
class HALSITL::SITL_State_Common {
|
|
|
|
friend class HALSITL::Scheduler;
|
|
|
|
friend class HALSITL::Util;
|
|
|
|
friend class HALSITL::GPIO;
|
|
|
|
public:
|
|
|
|
void init(int argc, char * const argv[]);
|
|
|
|
|
|
|
|
enum vehicle_type {
|
2023-08-17 18:55:20 -03:00
|
|
|
NONE,
|
2023-08-17 17:18:36 -03:00
|
|
|
ArduCopter,
|
|
|
|
Rover,
|
|
|
|
ArduPlane,
|
|
|
|
ArduSub,
|
|
|
|
Blimp
|
|
|
|
};
|
|
|
|
|
|
|
|
// create a simulated serial device; type of device is given by
|
|
|
|
// name parameter
|
|
|
|
SITL::SerialDevice *create_serial_sim(const char *name, const char *arg);
|
|
|
|
|
|
|
|
// simulated airspeed, sonar and battery monitor
|
|
|
|
float sonar_pin_voltage; // pin 0
|
|
|
|
float airspeed_pin_voltage[AIRSPEED_MAX_SENSORS]; // pin 1
|
|
|
|
float voltage_pin_voltage; // pin 13
|
|
|
|
float current_pin_voltage; // pin 12
|
|
|
|
float voltage2_pin_voltage; // pin 15
|
|
|
|
float current2_pin_voltage; // pin 14
|
|
|
|
|
|
|
|
#if HAL_SIM_GIMBAL_ENABLED
|
|
|
|
// simulated gimbal
|
|
|
|
bool enable_gimbal;
|
|
|
|
SITL::Gimbal *gimbal;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if HAL_SIM_ADSB_ENABLED
|
|
|
|
// simulated ADSb
|
|
|
|
SITL::ADSB *adsb;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(HAL_BUILD_AP_PERIPH)
|
|
|
|
// simulated vicon system:
|
|
|
|
SITL::Vicon *vicon;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// simulated Benewake tf02 rangefinder:
|
|
|
|
SITL::RF_Benewake_TF02 *benewake_tf02;
|
|
|
|
// simulated Benewake tf03 rangefinder:
|
|
|
|
SITL::RF_Benewake_TF03 *benewake_tf03;
|
|
|
|
// simulated Benewake tfmini rangefinder:
|
|
|
|
SITL::RF_Benewake_TFmini *benewake_tfmini;
|
|
|
|
//simulated NoopLoop TOFSense rangefinder:
|
|
|
|
SITL::RF_Nooploop *nooploop;
|
|
|
|
// simulated TeraRanger Serial:
|
|
|
|
SITL::RF_TeraRanger_Serial *teraranger_serial;
|
|
|
|
|
|
|
|
// simulated LightWareSerial rangefinder - legacy protocol::
|
|
|
|
SITL::RF_LightWareSerial *lightwareserial;
|
|
|
|
// simulated LightWareSerial rangefinder - binary protocol:
|
|
|
|
SITL::RF_LightWareSerialBinary *lightwareserial_binary;
|
|
|
|
// simulated Lanbao rangefinder:
|
|
|
|
SITL::RF_Lanbao *lanbao;
|
|
|
|
// simulated BLping rangefinder:
|
|
|
|
SITL::RF_BLping *blping;
|
|
|
|
// simulated LeddarOne rangefinder:
|
|
|
|
SITL::RF_LeddarOne *leddarone;
|
|
|
|
// simulated RDS02UF rangefinder:
|
|
|
|
SITL::RF_RDS02UF *rds02uf;
|
|
|
|
// simulated USD1 v0 rangefinder:
|
|
|
|
SITL::RF_USD1_v0 *USD1_v0;
|
|
|
|
// simulated USD1 v1 rangefinder:
|
|
|
|
SITL::RF_USD1_v1 *USD1_v1;
|
|
|
|
// simulated MaxsonarSerialLV rangefinder:
|
|
|
|
SITL::RF_MaxsonarSerialLV *maxsonarseriallv;
|
|
|
|
// simulated Wasp rangefinder:
|
|
|
|
SITL::RF_Wasp *wasp;
|
|
|
|
// simulated NMEA rangefinder:
|
|
|
|
SITL::RF_NMEA *nmea;
|
|
|
|
// simulated MAVLink rangefinder:
|
|
|
|
SITL::RF_MAVLink *rf_mavlink;
|
|
|
|
// simulated GYUS42v2 rangefinder:
|
|
|
|
SITL::RF_GYUS42v2 *gyus42v2;
|
|
|
|
|
|
|
|
// simulated Frsky devices
|
|
|
|
SITL::Frsky_D *frsky_d;
|
|
|
|
// SITL::Frsky_SPort *frsky_sport;
|
|
|
|
// SITL::Frsky_SPortPassthrough *frsky_sportpassthrough;
|
|
|
|
|
|
|
|
#if HAL_SIM_PS_RPLIDARA2_ENABLED
|
|
|
|
// simulated RPLidarA2:
|
|
|
|
SITL::PS_RPLidarA2 *rplidara2;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// simulated FETtec OneWire ESCs:
|
|
|
|
SITL::FETtecOneWireESC *fetteconewireesc;
|
|
|
|
|
|
|
|
// simulated RPLidarA1:
|
|
|
|
SITL::PS_RPLidarA1 *rplidara1;
|
|
|
|
|
|
|
|
#if HAL_SIM_PS_LIGHTWARE_SF45B_ENABLED
|
|
|
|
// simulated SF45B proximity sensor:
|
|
|
|
SITL::PS_LightWare_SF45B *sf45b;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if HAL_SIM_PS_TERARANGERTOWER_ENABLED
|
|
|
|
SITL::PS_TeraRangerTower *terarangertower;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if AP_SIM_CRSF_ENABLED
|
|
|
|
// simulated CRSF devices
|
|
|
|
SITL::CRSF *crsf;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// simulated VectorNav system:
|
|
|
|
SITL::VectorNav *vectornav;
|
|
|
|
|
|
|
|
// simulated LORD MicroStrain system
|
|
|
|
SITL::MicroStrain *microstrain;
|
|
|
|
|
|
|
|
#if HAL_SIM_JSON_MASTER_ENABLED
|
|
|
|
// Ride along instances via JSON SITL backend
|
|
|
|
SITL::JSON_Master ride_along;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if HAL_SIM_AIS_ENABLED
|
|
|
|
// simulated AIS stream
|
|
|
|
SITL::AIS *ais;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// simulated EFI MegaSquirt device:
|
|
|
|
SITL::EFI_MegaSquirt *efi_ms;
|
|
|
|
|
|
|
|
// output socket for flightgear viewing
|
|
|
|
SocketAPM fg_socket{true};
|
|
|
|
|
|
|
|
const char *defaults_path = HAL_PARAM_DEFAULTS_PATH;
|
|
|
|
|
|
|
|
// simulated GPS devices
|
|
|
|
SITL::GPS *gps[2]; // constrained by # of parameter sets
|
|
|
|
|
|
|
|
// returns a voltage between 0V to 5V which should appear as the
|
|
|
|
// voltage from the sensor
|
|
|
|
float _sonar_pin_voltage() const;
|
|
|
|
|
|
|
|
// multicast state
|
|
|
|
int mc_out_fd = -1;
|
|
|
|
|
|
|
|
// send out SITL state as UDP multicast
|
|
|
|
void multicast_state_open(void);
|
|
|
|
void multicast_state_send(void);
|
|
|
|
|
|
|
|
protected:
|
2023-08-17 18:55:20 -03:00
|
|
|
enum vehicle_type _vehicle;
|
|
|
|
|
2023-08-17 17:18:36 -03:00
|
|
|
void sim_update(void);
|
|
|
|
|
|
|
|
// internal SITL model
|
|
|
|
SITL::Aircraft *sitl_model;
|
|
|
|
|
|
|
|
SITL::SIM *_sitl;
|
2023-08-17 18:55:20 -03:00
|
|
|
|
|
|
|
void update_voltage_current(struct sitl_input &input, float throttle);
|
2023-08-17 17:18:36 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // CONFIG_HAL_BOARD == HAL_BOARD_SITL
|