mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-23 09:08:30 -04:00
AP_ICEngine: reinstate STARTCHN_MIN
looking up PWM using source index
This commit is contained in:
parent
9f29cb0fba
commit
f5dee94a5d
@ -161,8 +161,7 @@ const AP_Param::GroupInfo AP_ICEngine::var_info[] = {
|
|||||||
// @Description: This is a minimum PWM value for engine start channel for an engine stop to be commanded. Setting this value will avoid RC input glitches with low PWM values from causing an unwanted engine stop. A value of zero means any PWM above 800 and below 1300 triggers an engine stop. To stop the engine start channel must above the larger of this value and 800 and below 1300.
|
// @Description: This is a minimum PWM value for engine start channel for an engine stop to be commanded. Setting this value will avoid RC input glitches with low PWM values from causing an unwanted engine stop. A value of zero means any PWM above 800 and below 1300 triggers an engine stop. To stop the engine start channel must above the larger of this value and 800 and below 1300.
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
// @Range: 0 1300
|
// @Range: 0 1300
|
||||||
|
AP_GROUPINFO("STARTCHN_MIN", 16, AP_ICEngine, start_chan_min_pwm, 0),
|
||||||
// 16 was STARTCHN_MIN
|
|
||||||
|
|
||||||
#if AP_RPM_ENABLED
|
#if AP_RPM_ENABLED
|
||||||
// @Param: REDLINE_RPM
|
// @Param: REDLINE_RPM
|
||||||
@ -282,9 +281,17 @@ void AP_ICEngine::param_conversion()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Handle incoming aux function
|
// Handle incoming aux function
|
||||||
void AP_ICEngine::do_aux_function(const RC_Channel::AuxSwitchPos ch_flag)
|
void AP_ICEngine::do_aux_function(const RC_Channel::AuxFuncTrigger &trigger)
|
||||||
{
|
{
|
||||||
aux_pos = ch_flag;
|
// If triggered from RC apply start chan min
|
||||||
|
if (trigger.source == RC_Channel::AuxFuncTrigger::Source::RC) {
|
||||||
|
RC_Channel *chan = rc().channel(trigger.source_index);
|
||||||
|
if ((chan != nullptr) && (chan->get_radio_in() < start_chan_min_pwm)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
aux_pos = trigger.pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -71,7 +71,7 @@ public:
|
|||||||
bool allow_throttle_while_disarmed(void) const;
|
bool allow_throttle_while_disarmed(void) const;
|
||||||
|
|
||||||
// Handle incoming aux function trigger
|
// Handle incoming aux function trigger
|
||||||
void do_aux_function(const RC_Channel::AuxSwitchPos ch_flag);
|
void do_aux_function(const RC_Channel::AuxFuncTrigger &trigger);
|
||||||
|
|
||||||
#if AP_RELAY_ENABLED
|
#if AP_RELAY_ENABLED
|
||||||
// Needed for param conversion from relay numbers to functions
|
// Needed for param conversion from relay numbers to functions
|
||||||
@ -97,6 +97,9 @@ private:
|
|||||||
// enable library
|
// enable library
|
||||||
AP_Int8 enable;
|
AP_Int8 enable;
|
||||||
|
|
||||||
|
// min pwm on start channel for engine stop
|
||||||
|
AP_Int16 start_chan_min_pwm;
|
||||||
|
|
||||||
#if AP_RPM_ENABLED
|
#if AP_RPM_ENABLED
|
||||||
// which RPM instance to use
|
// which RPM instance to use
|
||||||
AP_Int8 rpm_instance;
|
AP_Int8 rpm_instance;
|
||||||
|
Loading…
Reference in New Issue
Block a user