mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-22 00:28:30 -04:00
HAL_VRBRAIN: removed hal.util->new_semaphore()
replaced with HAL_Semaphore
This commit is contained in:
parent
44009c5459
commit
725899080e
@ -68,7 +68,6 @@ VRBRAINAnalogSource::VRBRAINAnalogSource(int16_t pin, float initial_value) :
|
||||
_sum_value(0),
|
||||
_sum_ratiometric(0)
|
||||
{
|
||||
_semaphore = hal.util->new_semaphore();
|
||||
}
|
||||
|
||||
void VRBRAINAnalogSource::set_stop_pin(uint8_t p)
|
||||
@ -78,19 +77,17 @@ void VRBRAINAnalogSource::set_stop_pin(uint8_t p)
|
||||
|
||||
float VRBRAINAnalogSource::read_average()
|
||||
{
|
||||
if (_semaphore->take(1)) {
|
||||
if (_sum_count == 0) {
|
||||
_semaphore->give();
|
||||
return _value;
|
||||
}
|
||||
_value = _sum_value / _sum_count;
|
||||
_value_ratiometric = _sum_ratiometric / _sum_count;
|
||||
_sum_value = 0;
|
||||
_sum_ratiometric = 0;
|
||||
_sum_count = 0;
|
||||
_semaphore->give();
|
||||
WITH_SEMAPHORE(_semaphore);
|
||||
|
||||
if (_sum_count == 0) {
|
||||
return _value;
|
||||
}
|
||||
_value = _sum_value / _sum_count;
|
||||
_value_ratiometric = _sum_ratiometric / _sum_count;
|
||||
_sum_value = 0;
|
||||
_sum_ratiometric = 0;
|
||||
_sum_count = 0;
|
||||
|
||||
return _value;
|
||||
}
|
||||
|
||||
@ -146,16 +143,16 @@ void VRBRAINAnalogSource::set_pin(uint8_t pin)
|
||||
if (_pin == pin) {
|
||||
return;
|
||||
}
|
||||
if (_semaphore->take(HAL_SEMAPHORE_BLOCK_FOREVER)) {
|
||||
_pin = pin;
|
||||
_sum_value = 0;
|
||||
_sum_ratiometric = 0;
|
||||
_sum_count = 0;
|
||||
_latest_value = 0;
|
||||
_value = 0;
|
||||
_value_ratiometric = 0;
|
||||
_semaphore->give();
|
||||
}
|
||||
|
||||
WITH_SEMAPHORE(_semaphore);
|
||||
|
||||
_pin = pin;
|
||||
_sum_value = 0;
|
||||
_sum_ratiometric = 0;
|
||||
_sum_count = 0;
|
||||
_latest_value = 0;
|
||||
_value = 0;
|
||||
_value_ratiometric = 0;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -163,23 +160,22 @@ void VRBRAINAnalogSource::set_pin(uint8_t pin)
|
||||
*/
|
||||
void VRBRAINAnalogSource::_add_value(float v, float vcc5V)
|
||||
{
|
||||
if (_semaphore->take(1)) {
|
||||
_latest_value = v;
|
||||
_sum_value += v;
|
||||
if (vcc5V < 3.0f) {
|
||||
_sum_ratiometric += v;
|
||||
} else {
|
||||
// this compensates for changes in the 5V rail relative to the
|
||||
// 3.3V reference used by the ADC.
|
||||
_sum_ratiometric += v * 5.0f / vcc5V;
|
||||
}
|
||||
_sum_count++;
|
||||
if (_sum_count == 254) {
|
||||
_sum_value /= 2;
|
||||
_sum_ratiometric /= 2;
|
||||
_sum_count /= 2;
|
||||
}
|
||||
_semaphore->give();
|
||||
WITH_SEMAPHORE(_semaphore);
|
||||
|
||||
_latest_value = v;
|
||||
_sum_value += v;
|
||||
if (vcc5V < 3.0f) {
|
||||
_sum_ratiometric += v;
|
||||
} else {
|
||||
// this compensates for changes in the 5V rail relative to the
|
||||
// 3.3V reference used by the ADC.
|
||||
_sum_ratiometric += v * 5.0f / vcc5V;
|
||||
}
|
||||
_sum_count++;
|
||||
if (_sum_count == 254) {
|
||||
_sum_value /= 2;
|
||||
_sum_ratiometric /= 2;
|
||||
_sum_count /= 2;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -48,7 +48,7 @@ private:
|
||||
float _sum_ratiometric;
|
||||
void _add_value(float v, float vcc5V);
|
||||
float _pin_scaler();
|
||||
AP_HAL::Semaphore *_semaphore;
|
||||
HAL_Semaphore _semaphore;
|
||||
};
|
||||
|
||||
class VRBRAIN::VRBRAINAnalogIn : public AP_HAL::AnalogIn {
|
||||
|
@ -50,9 +50,6 @@ public:
|
||||
void perf_end(perf_counter_t) override;
|
||||
void perf_count(perf_counter_t) override;
|
||||
|
||||
// create a new semaphore
|
||||
AP_HAL::Semaphore *new_semaphore(void) override { return new VRBRAIN::Semaphore; }
|
||||
|
||||
void set_imu_temp(float current) override;
|
||||
void set_imu_target_temp(int8_t *target) override;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user