AP_InertialSensor: fixed locking issue in delta accumulation
this fixes a bug in calculating delta velocity and delta acceleration between threads.
This commit is contained in:
parent
657fcb7f59
commit
4fdc1ebc30
@ -1495,14 +1495,6 @@ void AP_InertialSensor::update(void)
|
|||||||
_backends[i]->update();
|
_backends[i]->update();
|
||||||
}
|
}
|
||||||
|
|
||||||
// clear accumulators
|
|
||||||
for (uint8_t i = 0; i < INS_MAX_INSTANCES; i++) {
|
|
||||||
_delta_velocity_acc[i].zero();
|
|
||||||
_delta_velocity_acc_dt[i] = 0;
|
|
||||||
_delta_angle_acc[i].zero();
|
|
||||||
_delta_angle_acc_dt[i] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!_startup_error_counts_set) {
|
if (!_startup_error_counts_set) {
|
||||||
for (uint8_t i=0; i<INS_MAX_INSTANCES; i++) {
|
for (uint8_t i=0; i<INS_MAX_INSTANCES; i++) {
|
||||||
_accel_startup_error_count[i] = _accel_error_count[i];
|
_accel_startup_error_count[i] = _accel_error_count[i];
|
||||||
|
@ -175,6 +175,9 @@ void AP_InertialSensor_Backend::_publish_gyro(uint8_t instance, const Vector3f &
|
|||||||
_imu._delta_angle[instance] = _imu._delta_angle_acc[instance];
|
_imu._delta_angle[instance] = _imu._delta_angle_acc[instance];
|
||||||
_imu._delta_angle_dt[instance] = _imu._delta_angle_acc_dt[instance];
|
_imu._delta_angle_dt[instance] = _imu._delta_angle_acc_dt[instance];
|
||||||
_imu._delta_angle_valid[instance] = true;
|
_imu._delta_angle_valid[instance] = true;
|
||||||
|
|
||||||
|
_imu._delta_angle_acc[instance].zero();
|
||||||
|
_imu._delta_angle_acc_dt[instance] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AP_InertialSensor_Backend::_notify_new_gyro_raw_sample(uint8_t instance,
|
void AP_InertialSensor_Backend::_notify_new_gyro_raw_sample(uint8_t instance,
|
||||||
@ -334,6 +337,8 @@ void AP_InertialSensor_Backend::_publish_accel(uint8_t instance, const Vector3f
|
|||||||
_imu._delta_velocity_dt[instance] = _imu._delta_velocity_acc_dt[instance];
|
_imu._delta_velocity_dt[instance] = _imu._delta_velocity_acc_dt[instance];
|
||||||
_imu._delta_velocity_valid[instance] = true;
|
_imu._delta_velocity_valid[instance] = true;
|
||||||
|
|
||||||
|
_imu._delta_velocity_acc[instance].zero();
|
||||||
|
_imu._delta_velocity_acc_dt[instance] = 0;
|
||||||
|
|
||||||
if (_imu._accel_calibrator != nullptr && _imu._accel_calibrator[instance].get_status() == ACCEL_CAL_COLLECTING_SAMPLE) {
|
if (_imu._accel_calibrator != nullptr && _imu._accel_calibrator[instance].get_status() == ACCEL_CAL_COLLECTING_SAMPLE) {
|
||||||
Vector3f cal_sample = _imu._delta_velocity[instance];
|
Vector3f cal_sample = _imu._delta_velocity[instance];
|
||||||
|
Loading…
Reference in New Issue
Block a user