ace61087a1
We only leave the parameter there for backward-compatibility. However product id on the inertial sensor is not much useful since it's only kept for the first instance. A better implementation per-gyro and per-accel is needed in order to avoid problems with sensors taking the offsets configured for another sensor.
44 lines
906 B
C++
44 lines
906 B
C++
#include <AP_HAL/AP_HAL.h>
|
|
#include "AP_InertialSensor_HIL.h"
|
|
|
|
const extern AP_HAL::HAL& hal;
|
|
|
|
AP_InertialSensor_HIL::AP_InertialSensor_HIL(AP_InertialSensor &imu) :
|
|
AP_InertialSensor_Backend(imu)
|
|
{
|
|
}
|
|
|
|
/*
|
|
detect the sensor
|
|
*/
|
|
AP_InertialSensor_Backend *AP_InertialSensor_HIL::detect(AP_InertialSensor &_imu)
|
|
{
|
|
AP_InertialSensor_HIL *sensor = new AP_InertialSensor_HIL(_imu);
|
|
if (sensor == nullptr) {
|
|
return nullptr;
|
|
}
|
|
if (!sensor->_init_sensor()) {
|
|
delete sensor;
|
|
return nullptr;
|
|
}
|
|
return sensor;
|
|
}
|
|
|
|
bool AP_InertialSensor_HIL::_init_sensor(void)
|
|
{
|
|
// grab the used instances
|
|
_imu.register_gyro(1200);
|
|
_imu.register_accel(1200);
|
|
|
|
_imu.set_hil_mode();
|
|
|
|
return true;
|
|
}
|
|
|
|
bool AP_InertialSensor_HIL::update(void)
|
|
{
|
|
// the data is stored directly in the frontend, so update()
|
|
// doesn't need to do anything
|
|
return true;
|
|
}
|