mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 01:58:29 -04:00
ef473a4372
this fixes an issue with EFI engines that use low throttle demand to stop the engine, instead of using an ignition channel. This option needs to be set on these aircraft to prevent the idle governor or the fwd throttle integrator in quadplanes from keeping the engine on when the pilot asks for it to be off.
141 lines
3.5 KiB
C++
141 lines
3.5 KiB
C++
/*
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/*
|
|
control of internal combustion engines (starter, ignition and choke)
|
|
*/
|
|
#pragma once
|
|
|
|
#include <AP_HAL/AP_HAL.h>
|
|
#include <AP_RPM/AP_RPM.h>
|
|
|
|
class AP_ICEngine {
|
|
public:
|
|
// constructor
|
|
AP_ICEngine(const AP_RPM &_rpm);
|
|
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
// update engine state. Should be called at 10Hz or more
|
|
void update(void);
|
|
|
|
// check for throttle override
|
|
bool throttle_override(uint8_t &percent);
|
|
|
|
enum ICE_State {
|
|
ICE_OFF=0,
|
|
ICE_START_HEIGHT_DELAY=1,
|
|
ICE_START_DELAY=2,
|
|
ICE_STARTING=3,
|
|
ICE_RUNNING=4
|
|
};
|
|
|
|
// get current engine control state
|
|
ICE_State get_state(void) const { return state; }
|
|
|
|
// handle DO_ENGINE_CONTROL messages via MAVLink or mission
|
|
bool engine_control(float start_control, float cold_start, float height_delay);
|
|
|
|
// update min throttle for idle governor
|
|
void update_idle_governor(int8_t &min_throttle);
|
|
|
|
static AP_ICEngine *get_singleton() { return _singleton; }
|
|
|
|
private:
|
|
static AP_ICEngine *_singleton;
|
|
|
|
const AP_RPM &rpm;
|
|
|
|
enum ICE_State state;
|
|
|
|
// enable library
|
|
AP_Int8 enable;
|
|
|
|
// channel for pilot to command engine start, 0 for none
|
|
AP_Int8 start_chan;
|
|
|
|
// min pwm on start channel for engine stop
|
|
AP_Int16 start_chan_min_pwm;
|
|
|
|
// which RPM instance to use
|
|
AP_Int8 rpm_instance;
|
|
|
|
// time to run starter for (seconds)
|
|
AP_Float starter_time;
|
|
|
|
// delay between start attempts (seconds)
|
|
AP_Float starter_delay;
|
|
|
|
// pwm values
|
|
AP_Int16 pwm_ignition_on;
|
|
AP_Int16 pwm_ignition_off;
|
|
AP_Int16 pwm_starter_on;
|
|
AP_Int16 pwm_starter_off;
|
|
|
|
// RPM above which engine is considered to be running
|
|
AP_Int32 rpm_threshold;
|
|
|
|
// time when we started the starter
|
|
uint32_t starter_start_time_ms;
|
|
|
|
// time when we last ran the starter
|
|
uint32_t starter_last_run_ms;
|
|
|
|
// throttle percentage for engine start
|
|
AP_Int8 start_percent;
|
|
|
|
// throttle percentage for engine idle
|
|
AP_Int8 idle_percent;
|
|
|
|
// Idle Controller RPM setpoint
|
|
AP_Int16 idle_rpm;
|
|
|
|
// Idle Controller RPM deadband
|
|
AP_Int16 idle_db;
|
|
|
|
// Idle Controller Slew Rate
|
|
AP_Float idle_slew;
|
|
|
|
// height when we enter ICE_START_HEIGHT_DELAY
|
|
float initial_height;
|
|
|
|
// height change required to start engine
|
|
float height_required;
|
|
|
|
// we are waiting for valid height data
|
|
bool height_pending:1;
|
|
|
|
// idle governor
|
|
float idle_governor_integrator;
|
|
|
|
enum class Options : uint16_t {
|
|
DISABLE_IGNITION_RC_FAILSAFE=(1U<<0),
|
|
};
|
|
AP_Int16 options;
|
|
|
|
bool option_set(Options option) const {
|
|
return (options & uint16_t(option)) != 0;
|
|
}
|
|
|
|
// start_chan debounce
|
|
uint16_t start_chan_last_value = 1500;
|
|
uint32_t start_chan_last_ms;
|
|
};
|
|
|
|
|
|
namespace AP {
|
|
AP_ICEngine *ice();
|
|
};
|