mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AP_ServoRelayEvents: More robust check if a channel is available
This commit is contained in:
parent
7fd8211253
commit
588d1898cd
@ -22,13 +22,18 @@
|
|||||||
#include "AP_ServoRelayEvents.h"
|
#include "AP_ServoRelayEvents.h"
|
||||||
#include <RC_Channel/RC_Channel.h>
|
#include <RC_Channel/RC_Channel.h>
|
||||||
#include <SRV_Channel/SRV_Channel.h>
|
#include <SRV_Channel/SRV_Channel.h>
|
||||||
|
#include <GCS_MAVLink/GCS.h>
|
||||||
|
|
||||||
extern const AP_HAL::HAL& hal;
|
extern const AP_HAL::HAL& hal;
|
||||||
|
|
||||||
bool AP_ServoRelayEvents::do_set_servo(uint8_t _channel, uint16_t pwm)
|
bool AP_ServoRelayEvents::do_set_servo(uint8_t _channel, uint16_t pwm)
|
||||||
{
|
{
|
||||||
if (!(mask & 1U<<(_channel-1))) {
|
SRV_Channel *c = SRV_Channels::srv_channel(_channel-1);
|
||||||
// not allowed
|
if (c == nullptr) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (c->get_function() != SRV_Channel::k_none) {
|
||||||
|
gcs().send_text(MAV_SEVERITY_INFO, "ServoRelayEvent: Channel %d is already in use", _channel);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (type == EVENT_TYPE_SERVO &&
|
if (type == EVENT_TYPE_SERVO &&
|
||||||
@ -36,10 +41,6 @@ bool AP_ServoRelayEvents::do_set_servo(uint8_t _channel, uint16_t pwm)
|
|||||||
// cancel previous repeat
|
// cancel previous repeat
|
||||||
repeat = 0;
|
repeat = 0;
|
||||||
}
|
}
|
||||||
SRV_Channel *c = SRV_Channels::srv_channel(_channel-1);
|
|
||||||
if (c == nullptr) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
c->set_output_pwm(pwm);
|
c->set_output_pwm(pwm);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -67,8 +68,12 @@ bool AP_ServoRelayEvents::do_set_relay(uint8_t relay_num, uint8_t state)
|
|||||||
bool AP_ServoRelayEvents::do_repeat_servo(uint8_t _channel, uint16_t _servo_value,
|
bool AP_ServoRelayEvents::do_repeat_servo(uint8_t _channel, uint16_t _servo_value,
|
||||||
int16_t _repeat, uint16_t _delay_ms)
|
int16_t _repeat, uint16_t _delay_ms)
|
||||||
{
|
{
|
||||||
if (!(mask & 1U<<(_channel-1))) {
|
SRV_Channel *c = SRV_Channels::srv_channel(_channel-1);
|
||||||
// not allowed
|
if (c == nullptr) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (c->get_function() != SRV_Channel::k_none) {
|
||||||
|
gcs().send_text(MAV_SEVERITY_INFO, "ServoRelayEvent: Channel %d is already in use", _channel);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
channel = _channel;
|
channel = _channel;
|
||||||
|
@ -27,9 +27,6 @@ public:
|
|||||||
return _singleton;
|
return _singleton;
|
||||||
}
|
}
|
||||||
|
|
||||||
// set allowed servo channel mask
|
|
||||||
void set_channel_mask(uint16_t _mask) { mask = _mask; }
|
|
||||||
|
|
||||||
bool do_set_servo(uint8_t channel, uint16_t pwm);
|
bool do_set_servo(uint8_t channel, uint16_t pwm);
|
||||||
bool do_set_relay(uint8_t relay_num, uint8_t state);
|
bool do_set_relay(uint8_t relay_num, uint8_t state);
|
||||||
bool do_repeat_servo(uint8_t channel, uint16_t servo_value, int16_t repeat, uint16_t delay_time_ms);
|
bool do_repeat_servo(uint8_t channel, uint16_t servo_value, int16_t repeat, uint16_t delay_time_ms);
|
||||||
@ -41,7 +38,6 @@ private:
|
|||||||
static AP_ServoRelayEvents *_singleton;
|
static AP_ServoRelayEvents *_singleton;
|
||||||
|
|
||||||
AP_Relay &relay;
|
AP_Relay &relay;
|
||||||
uint16_t mask;
|
|
||||||
|
|
||||||
// event control state
|
// event control state
|
||||||
enum event_type {
|
enum event_type {
|
||||||
|
Loading…
Reference in New Issue
Block a user