2015-07-10 06:01:56 -07:00
/**
* @ file engine_controller . cpp
* @ brief Controllers package entry point code
*
*
*
* @ date Feb 7 , 2013
2020-01-07 21:02:40 -08:00
* @ author Andrey Belomutskiy , ( c ) 2012 - 2020
2015-07-10 06:01:56 -07:00
*
* This file is part of rusEfi - see http : //rusefi.com
*
* rusEfi 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 .
*
* rusEfi 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/>.
*/
2021-07-25 22:05:17 -07:00
# include "pch.h"
2022-09-07 12:56:45 -07:00
2015-07-10 06:01:56 -07:00
# include "trigger_central.h"
2022-07-14 04:52:58 -07:00
# include "script_impl.h"
2015-07-10 06:01:56 -07:00
# include "idle_thread.h"
2023-03-04 22:13:43 -08:00
# include "hardware.h"
2019-12-23 21:03:53 -08:00
# include "advance_map.h"
2015-07-10 06:01:56 -07:00
# include "main_trigger_callback.h"
# include "flash_main.h"
2020-03-26 05:03:55 -07:00
# include "bench_test.h"
2023-03-04 22:20:03 -08:00
# include "mmc_card.h"
2015-07-10 06:01:56 -07:00
# include "electronic_throttle.h"
2023-03-05 09:45:02 -08:00
# include "trigger_emulator_algo.h"
2015-07-10 06:01:56 -07:00
# include "map_averaging.h"
2020-11-05 13:42:56 -08:00
# include "high_pressure_fuel_pump.h"
2015-07-10 06:01:56 -07:00
# include "malfunction_central.h"
# include "malfunction_indicator.h"
2019-12-23 21:03:53 -08:00
# include "speed_density.h"
2019-03-31 13:56:13 -07:00
# include "local_version_holder.h"
# include "alternator_controller.h"
2023-11-24 22:41:39 -08:00
# include "can_bench_test.h"
2023-03-04 22:53:11 -08:00
# include "engine_emulator.h"
2015-07-10 06:01:56 -07:00
# include "fuel_math.h"
2019-12-23 21:26:23 -08:00
# include "spark_logic.h"
2023-03-04 22:13:43 -08:00
# include "status_loop.h"
2019-12-23 21:26:23 -08:00
# include "aux_valves.h"
2017-08-28 17:11:32 -07:00
# include "accelerometer.h"
2021-03-14 16:31:46 -07:00
# include "vvt.h"
2020-02-02 00:56:21 -08:00
# include "boost_control.h"
2020-03-23 17:44:34 -07:00
# include "launch_control.h"
2020-04-01 16:00:56 -07:00
# include "tachometer.h"
2023-10-15 14:59:39 -07:00
# include "speedometer.h"
2020-04-26 11:06:28 -07:00
# include "gppwm.h"
2020-06-17 09:59:57 -07:00
# include "date_stamp.h"
2023-03-04 22:53:11 -08:00
# include "rusefi_lua.h"
2020-09-02 17:17:58 -07:00
# include "buttonshift.h"
2020-09-09 00:22:15 -07:00
# include "start_stop.h"
2020-12-04 17:28:48 -08:00
# include "dynoview.h"
2021-07-28 04:44:44 -07:00
# include "vr_pwm.h"
2022-10-10 04:44:20 -07:00
# include "adc_subscription.h"
2023-02-25 13:18:28 -08:00
# include "gc_generic.h"
2015-07-10 06:01:56 -07:00
2019-12-23 20:25:08 -08:00
# if EFI_SENSOR_CHART
# include "sensor_chart.h"
2020-03-22 21:01:59 -07:00
# endif /* EFI_SENSOR_CHART */
2019-12-23 20:25:08 -08:00
# if EFI_TUNER_STUDIO
# include "tunerstudio.h"
2020-03-22 21:01:59 -07:00
# endif /* EFI_TUNER_STUDIO */
2019-12-23 20:25:08 -08:00
# if EFI_LOGIC_ANALYZER
# include "logic_analyzer.h"
2020-03-22 21:01:59 -07:00
# endif /* EFI_LOGIC_ANALYZER */
2019-12-23 20:25:08 -08:00
2019-07-09 05:33:40 -07:00
# if defined(EFI_BOOTLOADER_INCLUDE_CODE)
# include "bootloader/bootloader.h"
# endif /* EFI_BOOTLOADER_INCLUDE_CODE */
# include "periodic_task.h"
2020-04-26 14:07:39 -07:00
2019-07-09 05:33:40 -07:00
2019-09-21 12:43:18 -07:00
# if ! EFI_UNIT_TEST
2019-09-21 12:33:13 -07:00
# include "init.h"
2023-11-24 15:38:17 -08:00
# include "mpu_util.h"
2019-09-22 14:19:08 -07:00
# endif /* EFI_UNIT_TEST */
2019-09-21 12:43:18 -07:00
2020-03-22 21:01:59 -07:00
# if !EFI_UNIT_TEST
/**
2020-08-26 17:49:21 -07:00
* Would love to pass reference to configuration object into constructor but C + + does allow attributes after parenthesized initializer
2020-03-22 21:01:59 -07:00
*/
Engine ___engine CCM_OPTIONAL ;
2021-11-15 21:23:14 -08:00
# else // EFI_UNIT_TEST
Engine * engine ;
2020-03-22 21:01:59 -07:00
# endif /* EFI_UNIT_TEST */
2021-11-16 01:15:29 -08:00
void initDataStructures ( ) {
2020-02-26 15:16:35 -08:00
# if EFI_ENGINE_CONTROL
2021-11-16 01:15:29 -08:00
initFuelMap ( ) ;
initSpeedDensity ( ) ;
2024-04-17 15:47:17 -07:00
IgnitionEventList & events = engine - > ignitionEvents ;
for ( size_t i = 0 ; i < efi : : size ( events . elements ) ; i + + ) {
// above-zero value helps distinguish events
events . elements [ i ] . sparkCounter = 1 ;
}
// above-zero value helps distinguish events
engine - > engineState . globalSparkCounter = 1 ;
2020-02-26 15:16:35 -08:00
# endif // EFI_ENGINE_CONTROL
2019-12-23 21:03:53 -08:00
}
2020-03-22 21:01:59 -07:00
# if !EFI_UNIT_TEST
2015-07-10 06:01:56 -07:00
2021-11-16 01:15:29 -08:00
static void doPeriodicSlowCallback ( ) ;
2015-07-10 06:01:56 -07:00
2019-07-09 05:33:40 -07:00
class PeriodicFastController : public PeriodicTimerController {
void PeriodicTask ( ) override {
engine - > periodicFastCallback ( ) ;
}
int getPeriodMs ( ) override {
return FAST_CALLBACK_PERIOD_MS ;
}
} ;
class PeriodicSlowController : public PeriodicTimerController {
void PeriodicTask ( ) override {
2021-11-16 01:15:29 -08:00
doPeriodicSlowCallback ( ) ;
2019-07-09 05:33:40 -07:00
}
int getPeriodMs ( ) override {
2020-06-13 19:46:10 -07:00
// no reason to have this configurable, looks like everyone is happy with 20Hz
2020-11-11 18:47:19 -08:00
return SLOW_CALLBACK_PERIOD_MS ;
2019-07-09 05:33:40 -07:00
}
} ;
static PeriodicFastController fastController ;
static PeriodicSlowController slowController ;
2015-07-10 06:01:56 -07:00
2019-07-13 08:06:03 -07:00
class EngineStateBlinkingTask : public PeriodicTimerController {
int getPeriodMs ( ) override {
return 50 ;
}
void PeriodicTask ( ) override {
2020-02-26 15:16:35 -08:00
# if EFI_SHAFT_POSITION_INPUT
2021-11-17 00:54:21 -08:00
bool is_running = engine - > rpmCalculator . isRunning ( ) ;
2020-02-26 15:16:35 -08:00
# else
bool is_running = false ;
2020-03-22 21:01:59 -07:00
# endif /* EFI_SHAFT_POSITION_INPUT */
2019-07-13 08:06:03 -07:00
2015-07-10 06:01:56 -07:00
if ( is_running ) {
2019-07-13 08:06:03 -07:00
// blink in running mode
2022-08-01 15:16:13 -07:00
enginePins . runningLedPin . toggle ( ) ;
2015-07-10 06:01:56 -07:00
} else {
2024-06-27 16:13:53 -07:00
bool is_cranking = engine - > rpmCalculator . isCranking ( ) ;
2018-07-26 12:51:06 -07:00
enginePins . runningLedPin . setValue ( is_cranking ) ;
2015-07-10 06:01:56 -07:00
}
}
2019-07-13 08:06:03 -07:00
} ;
static EngineStateBlinkingTask engineStateBlinkingTask ;
2015-07-10 06:01:56 -07:00
2021-11-15 04:02:34 -08:00
static void resetAccel ( ) {
2024-08-01 21:45:54 -07:00
engine - > module < TpsAccelEnrichment > ( ) - > resetAE ( ) ;
2023-05-23 21:52:52 -07:00
# if EFI_ENGINE_CONTROL
2021-03-20 05:40:36 -07:00
for ( size_t i = 0 ; i < efi : : size ( engine - > injectionEvents . elements ) ; i + + )
2019-10-16 21:06:54 -07:00
{
2023-10-12 21:23:09 -07:00
engine - > injectionEvents . elements [ i ] . getWallFuel ( ) . resetWF ( ) ;
2019-10-16 21:06:54 -07:00
}
2023-05-23 21:52:52 -07:00
# endif // EFI_ENGINE_CONTROL
2016-01-08 12:01:38 -08:00
}
2021-11-16 01:15:29 -08:00
static void doPeriodicSlowCallback ( ) {
2023-10-12 06:09:29 -07:00
# if EFI_SHAFT_POSITION_INPUT
2023-04-11 17:01:34 -07:00
efiAssertVoid ( ObdCode : : CUSTOM_ERR_6661 , getCurrentRemainingStack ( ) > 64 , " lowStckOnEv " ) ;
2020-11-18 17:53:03 -08:00
2021-11-16 01:15:29 -08:00
slowStartStopButtonCallback ( ) ;
2020-11-18 17:53:03 -08:00
2021-11-20 03:59:02 -08:00
engine - > rpmCalculator . onSlowCallback ( ) ;
2023-12-17 18:55:17 -08:00
if ( engine - > rpmCalculator . isStopped ( ) ) {
resetAccel ( ) ;
}
# endif /* EFI_SHAFT_POSITION_INPUT */
engine - > periodicSlowCallback ( ) ;
# if EFI_SHAFT_POSITION_INPUT
2022-09-13 23:06:52 -07:00
if ( engine - > triggerCentral . directSelfStimulation | | engine - > rpmCalculator . isStopped ( ) ) {
2020-04-08 15:03:46 -07:00
/**
* rusEfi usually runs on hardware which halts execution while writing to internal flash , so we
* postpone writes to until engine is stopped . Writes in case of self - stimulation are fine .
*
* todo : allow writing if 2 nd bank of flash is used
*/
2024-05-05 12:38:21 -07:00
# if EFI_CONFIGURATION_STORAGE
2015-07-10 06:01:56 -07:00
writeToFlashIfPending ( ) ;
2024-05-05 12:38:21 -07:00
# endif /* EFI_CONFIGURATION_STORAGE */
2020-04-08 15:03:46 -07:00
}
2023-11-08 19:21:13 -08:00
# else /* if EFI_SHAFT_POSITION_INPUT */
2024-05-05 12:52:39 -07:00
# if EFI_CONFIGURATION_STORAGE
2023-09-06 14:48:59 -07:00
writeToFlashIfPending ( ) ;
2024-05-05 12:52:39 -07:00
# endif /* EFI_CONFIGURATION_STORAGE */
2023-10-12 06:09:29 -07:00
# endif /* EFI_SHAFT_POSITION_INPUT */
2020-09-02 12:39:50 -07:00
2022-04-23 04:34:39 -07:00
# if EFI_TCU
2022-04-06 14:37:30 -07:00
if ( engineConfiguration - > tcuEnabled & & engineConfiguration - > gearControllerMode ! = GearControllerMode : : None ) {
if ( engine - > gearController = = NULL ) {
initGearController ( ) ;
2022-04-18 17:09:27 -07:00
} else if ( engine - > gearController - > getMode ( ) ! = engineConfiguration - > gearControllerMode ) {
2022-04-06 14:37:30 -07:00
initGearController ( ) ;
}
2020-09-02 12:39:50 -07:00
engine - > gearController - > update ( ) ;
}
2023-10-12 06:09:29 -07:00
# endif // EFI_TCU
2022-04-23 04:34:39 -07:00
2023-11-24 15:15:50 -08:00
tryResetWatchdog ( ) ;
2015-07-10 06:01:56 -07:00
}
2021-11-16 01:15:29 -08:00
void initPeriodicEvents ( ) {
2022-07-21 12:17:32 -07:00
slowController . start ( ) ;
fastController . start ( ) ;
2015-07-10 06:01:56 -07:00
}
2024-07-20 14:02:21 -07:00
char * getPinNameByAdcChannel ( const char * msg , adc_channel_e hwChannel , char * buffer , size_t bufferSize ) {
2019-04-12 19:07:03 -07:00
# if HAL_USE_ADC
2021-01-05 13:02:20 -08:00
if ( ! isAdcChannelValid ( hwChannel ) ) {
2024-07-20 14:02:21 -07:00
snprintf ( buffer , bufferSize , " NONE " ) ;
2016-12-27 11:04:04 -08:00
} else {
2024-07-20 14:02:21 -07:00
const char * name = portname ( getAdcChannelPort ( msg , hwChannel ) ) ;
snprintf ( buffer , bufferSize , " %s%d " , name ? name : " null " , getAdcChannelPin ( hwChannel ) ) ;
2016-12-27 11:04:04 -08:00
}
2015-07-10 06:01:56 -07:00
# else
2024-07-20 14:02:21 -07:00
snprintf ( buffer , bufferSize , " NONE " ) ;
2020-03-22 21:01:59 -07:00
# endif /* HAL_USE_ADC */
2020-05-20 22:08:07 -07:00
return buffer ;
2015-07-10 06:01:56 -07:00
}
2024-03-15 11:42:01 -07:00
# if EFI_PROD_CODE
2022-10-10 04:44:20 -07:00
static void printSensorInfo ( ) {
2022-11-18 18:43:26 -08:00
# if HAL_USE_ADC
2022-10-10 04:44:20 -07:00
// Print info about analog mappings
AdcSubscription : : PrintInfo ( ) ;
2022-11-18 18:43:26 -08:00
# endif // HAL_USE_ADC
2020-03-23 20:16:57 -07:00
2022-10-10 04:44:20 -07:00
// Print info about all sensors
Sensor : : showAllSensorInfo ( ) ;
2015-07-10 06:01:56 -07:00
}
2024-03-15 11:42:01 -07:00
# endif // EFI_PROD_CODE
2015-07-10 06:01:56 -07:00
# define isOutOfBounds(offset) ((offset<0) || (offset) >= (int) sizeof(engine_configuration_s))
static void getShort ( int offset ) {
if ( isOutOfBounds ( offset ) )
return ;
uint16_t * ptr = ( uint16_t * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
uint16_t value = * ptr ;
/**
2019-05-02 14:52:48 -07:00
* this response is part of rusEfi console API
2015-07-10 06:01:56 -07:00
*/
2021-04-21 09:53:13 -07:00
efiPrintf ( " short%s%d is %d " , CONSOLE_DATA_PROTOCOL_TAG , offset , value ) ;
2019-04-08 08:19:07 -07:00
}
static void getByte ( int offset ) {
if ( isOutOfBounds ( offset ) )
return ;
uint8_t * ptr = ( uint8_t * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
uint8_t value = * ptr ;
/**
2019-05-02 14:52:48 -07:00
* this response is part of rusEfi console API
2019-04-08 08:19:07 -07:00
*/
2021-04-21 09:53:13 -07:00
efiPrintf ( " byte%s%d is %d " , CONSOLE_DATA_PROTOCOL_TAG , offset , value ) ;
2015-07-10 06:01:56 -07:00
}
static void setBit ( const char * offsetStr , const char * bitStr , const char * valueStr ) {
int offset = atoi ( offsetStr ) ;
2022-10-27 19:17:50 -07:00
if ( absI ( offset ) = = absI ( ATOI_ERROR_CODE ) ) {
2021-04-21 09:53:13 -07:00
efiPrintf ( " invalid offset [%s] " , offsetStr ) ;
2015-07-10 06:01:56 -07:00
return ;
}
if ( isOutOfBounds ( offset ) ) {
return ;
}
int bit = atoi ( bitStr ) ;
2022-10-27 19:17:50 -07:00
if ( absI ( bit ) = = absI ( ATOI_ERROR_CODE ) ) {
2021-04-21 09:53:13 -07:00
efiPrintf ( " invalid bit [%s] " , bitStr ) ;
2015-07-10 06:01:56 -07:00
return ;
}
int value = atoi ( valueStr ) ;
2022-10-27 19:17:50 -07:00
if ( absI ( value ) = = absI ( ATOI_ERROR_CODE ) ) {
2021-04-21 09:53:13 -07:00
efiPrintf ( " invalid value [%s] " , valueStr ) ;
2015-07-10 06:01:56 -07:00
return ;
}
int * ptr = ( int * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
* ptr ^ = ( - value ^ * ptr ) & ( 1 < < bit ) ;
/**
2019-05-02 14:52:48 -07:00
* this response is part of rusEfi console API
2015-07-10 06:01:56 -07:00
*/
2021-04-21 09:53:13 -07:00
efiPrintf ( " bit%s%d/%d is %d " , CONSOLE_DATA_PROTOCOL_TAG , offset , bit , value ) ;
2023-04-19 19:09:48 -07:00
incrementGlobalConfigurationVersion ( " setBit " ) ;
2015-07-10 06:01:56 -07:00
}
static void setShort ( const int offset , const int value ) {
if ( isOutOfBounds ( offset ) )
return ;
uint16_t * ptr = ( uint16_t * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
* ptr = ( uint16_t ) value ;
getShort ( offset ) ;
2023-04-19 19:09:48 -07:00
incrementGlobalConfigurationVersion ( " setShort " ) ;
2015-07-10 06:01:56 -07:00
}
2019-04-08 08:19:07 -07:00
static void setByte ( const int offset , const int value ) {
if ( isOutOfBounds ( offset ) )
return ;
uint8_t * ptr = ( uint8_t * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
* ptr = ( uint8_t ) value ;
getByte ( offset ) ;
2023-04-19 19:09:48 -07:00
incrementGlobalConfigurationVersion ( " setByte " ) ;
2019-04-08 08:19:07 -07:00
}
2015-07-10 06:01:56 -07:00
static void getBit ( int offset , int bit ) {
if ( isOutOfBounds ( offset ) )
return ;
int * ptr = ( int * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
int value = ( * ptr > > bit ) & 1 ;
/**
2019-05-02 14:52:48 -07:00
* this response is part of rusEfi console API
2015-07-10 06:01:56 -07:00
*/
2021-04-21 09:53:13 -07:00
efiPrintf ( " bit%s%d/%d is %d " , CONSOLE_DATA_PROTOCOL_TAG , offset , bit , value ) ;
2015-07-10 06:01:56 -07:00
}
static void getInt ( int offset ) {
if ( isOutOfBounds ( offset ) )
return ;
int * ptr = ( int * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
int value = * ptr ;
/**
2019-05-02 14:52:48 -07:00
* this response is part of rusEfi console API
2015-07-10 06:01:56 -07:00
*/
2021-04-21 09:53:13 -07:00
efiPrintf ( " int%s%d is %d " , CONSOLE_DATA_PROTOCOL_TAG , offset , value ) ;
2015-07-10 06:01:56 -07:00
}
static void setInt ( const int offset , const int value ) {
if ( isOutOfBounds ( offset ) )
return ;
int * ptr = ( int * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
* ptr = value ;
getInt ( offset ) ;
2023-04-19 19:09:48 -07:00
incrementGlobalConfigurationVersion ( " setInt " ) ;
2015-07-10 06:01:56 -07:00
}
static void getFloat ( int offset ) {
if ( isOutOfBounds ( offset ) )
return ;
float * ptr = ( float * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
float value = * ptr ;
/**
2019-05-02 14:52:48 -07:00
* this response is part of rusEfi console API
2015-07-10 06:01:56 -07:00
*/
2021-04-21 09:53:13 -07:00
efiPrintf ( " float%s%d is %.5f " , CONSOLE_DATA_PROTOCOL_TAG , offset , value ) ;
2015-07-10 06:01:56 -07:00
}
static void setFloat ( const char * offsetStr , const char * valueStr ) {
int offset = atoi ( offsetStr ) ;
2022-10-27 19:17:50 -07:00
if ( absI ( offset ) = = absI ( ATOI_ERROR_CODE ) ) {
2021-04-21 09:53:13 -07:00
efiPrintf ( " invalid offset [%s] " , offsetStr ) ;
2015-07-10 06:01:56 -07:00
return ;
}
if ( isOutOfBounds ( offset ) )
return ;
float value = atoff ( valueStr ) ;
2024-07-22 16:00:59 -07:00
if ( std : : isnan ( value ) ) {
2021-04-21 09:53:13 -07:00
efiPrintf ( " invalid value [%s] " , valueStr ) ;
2015-07-10 06:01:56 -07:00
return ;
}
2019-01-04 21:57:09 -08:00
float * ptr = ( float * ) ( & ( ( char * ) engineConfiguration ) [ offset ] ) ;
2015-07-10 06:01:56 -07:00
* ptr = value ;
getFloat ( offset ) ;
2023-04-19 19:09:48 -07:00
incrementGlobalConfigurationVersion ( " setFloat " ) ;
2015-07-10 06:01:56 -07:00
}
2019-09-22 14:19:08 -07:00
2021-11-15 04:02:34 -08:00
static void initConfigActions ( ) {
2015-07-10 06:01:56 -07:00
addConsoleActionSS ( " set_float " , ( VoidCharPtrCharPtr ) setFloat ) ;
addConsoleActionII ( " set_int " , ( VoidIntInt ) setInt ) ;
addConsoleActionII ( " set_short " , ( VoidIntInt ) setShort ) ;
2019-04-08 08:19:07 -07:00
addConsoleActionII ( " set_byte " , ( VoidIntInt ) setByte ) ;
2015-07-10 06:01:56 -07:00
addConsoleActionSSS ( " set_bit " , setBit ) ;
2019-04-08 08:19:07 -07:00
2015-07-10 06:01:56 -07:00
addConsoleActionI ( " get_float " , getFloat ) ;
addConsoleActionI ( " get_int " , getInt ) ;
addConsoleActionI ( " get_short " , getShort ) ;
2019-04-08 08:19:07 -07:00
addConsoleActionI ( " get_byte " , getByte ) ;
2015-07-10 06:01:56 -07:00
addConsoleActionII ( " get_bit " , getBit ) ;
}
2019-12-23 19:30:58 -08:00
# endif /* EFI_UNIT_TEST */
2015-07-10 06:01:56 -07:00
2023-09-25 09:49:44 -07:00
// one-time start-up
2019-12-23 19:30:58 -08:00
// this method is used by real firmware and simulator and unit test
2021-11-16 01:15:29 -08:00
void commonInitEngineController ( ) {
2023-09-25 09:49:44 -07:00
# if EFI_PROD_CODE
addConsoleAction ( " sensorinfo " , printSensorInfo ) ;
addConsoleAction ( " reset_accel " , resetAccel ) ;
# endif /* EFI_PROD_CODE */
2022-11-28 23:21:36 -08:00
# if EFI_SIMULATOR || EFI_UNIT_TEST
2018-01-30 11:53:13 -08:00
printf ( " commonInitEngineController \n " ) ;
# endif
2019-12-23 19:30:58 -08:00
# if !EFI_UNIT_TEST
2015-07-10 06:01:56 -07:00
initConfigActions ( ) ;
2019-12-23 19:30:58 -08:00
# endif /* EFI_UNIT_TEST */
2019-12-23 20:32:43 -08:00
# if EFI_ENGINE_CONTROL
/**
2020-03-26 05:03:55 -07:00
* This has to go after ' enginePins . startPins ( ) ' in order to
2019-12-23 20:32:43 -08:00
* properly detect un - assigned output pins
*/
2022-09-13 22:24:19 -07:00
prepareOutputSignals ( ) ;
engine - > injectionEvents . addFuelEvents ( ) ;
# endif // EFI_ENGINE_CONTROL
2019-12-23 20:32:43 -08:00
2019-04-12 19:07:03 -07:00
# if EFI_SENSOR_CHART
2016-05-28 16:02:28 -07:00
initSensorChart ( ) ;
# endif /* EFI_SENSOR_CHART */
2019-12-23 19:30:58 -08:00
# if EFI_PROD_CODE || EFI_SIMULATOR
initSettings ( ) ;
2015-07-10 06:01:56 -07:00
if ( hasFirmwareError ( ) ) {
return ;
}
2019-12-23 19:30:58 -08:00
# endif
2023-10-14 12:59:33 -07:00
# if ! EFI_UNIT_TEST && EFI_ENGINE_CONTROL
initBenchTest ( ) ;
# endif /* ! EFI_UNIT_TEST && EFI_ENGINE_CONTROL */
# if EFI_ALTERNATOR_CONTROL
initAlternatorCtrl ( ) ;
# endif /* EFI_ALTERNATOR_CONTROL */
# if EFI_VVT_PID
initVvtActuators ( ) ;
# endif /* EFI_VVT_PID */
# if EFI_MALFUNCTION_INDICATOR
initMalfunctionIndicator ( ) ;
# endif /* EFI_MALFUNCTION_INDICATOR */
2020-04-26 14:50:03 -07:00
# if !EFI_UNIT_TEST
// This is tested independently - don't configure sensors for tests.
// This lets us selectively mock them for each test.
2021-04-18 17:02:32 -07:00
initNewSensors ( ) ;
2020-04-26 14:50:03 -07:00
# endif /* EFI_UNIT_TEST */
2021-11-16 01:15:29 -08:00
initSensors ( ) ;
2020-04-26 14:50:03 -07:00
2021-11-16 01:15:29 -08:00
initAccelEnrichment ( ) ;
2020-04-26 14:50:03 -07:00
2022-07-14 04:52:58 -07:00
initScriptImpl ( ) ;
2020-04-26 14:50:03 -07:00
2021-11-16 01:15:29 -08:00
initGpPwm ( ) ;
2020-04-26 14:50:03 -07:00
# if EFI_IDLE_CONTROL
2021-11-16 01:15:29 -08:00
startIdleThread ( ) ;
2020-04-26 14:50:03 -07:00
# endif /* EFI_IDLE_CONTROL */
2022-04-23 04:34:39 -07:00
# if EFI_TCU
2022-04-06 14:37:30 -07:00
initGearController ( ) ;
2022-04-23 04:34:39 -07:00
# endif
2020-09-02 17:17:58 -07:00
2021-04-21 09:53:13 -07:00
initButtonDebounce ( ) ;
2020-09-09 00:22:15 -07:00
2020-04-26 14:50:03 -07:00
# if EFI_ELECTRONIC_THROTTLE_BODY
2021-11-16 01:15:29 -08:00
initElectronicThrottle ( ) ;
2020-04-26 14:50:03 -07:00
# endif /* EFI_ELECTRONIC_THROTTLE_BODY */
# if EFI_MAP_AVERAGING
if ( engineConfiguration - > isMapAveragingEnabled ) {
2021-11-16 01:15:29 -08:00
initMapAveraging ( ) ;
2020-04-26 14:50:03 -07:00
}
# endif /* EFI_MAP_AVERAGING */
# if EFI_BOOST_CONTROL
2021-11-16 01:15:29 -08:00
initBoostCtrl ( ) ;
2020-04-26 14:50:03 -07:00
# endif /* EFI_BOOST_CONTROL */
# if EFI_LAUNCH_CONTROL
2021-11-16 01:15:29 -08:00
initLaunchControl ( ) ;
2020-12-04 17:28:48 -08:00
# endif
2024-02-03 14:02:30 -08:00
initIgnitionAdvanceControl ( ) ;
2022-10-21 20:57:37 -07:00
# if EFI_UNIT_TEST
engine - > rpmCalculator . Register ( ) ;
# endif /* EFI_UNIT_TEST */
2024-09-04 20:40:12 -07:00
# if EFI_AUX_VALVES
2023-03-13 13:25:45 -07:00
initAuxValves ( ) ;
2024-09-04 20:40:12 -07:00
# endif /* EFI_AUX_VALVES */
2019-12-23 20:25:08 -08:00
2021-11-16 01:15:29 -08:00
initTachometer ( ) ;
2023-10-15 14:59:39 -07:00
initSpeedometer ( ) ;
2016-01-12 19:01:53 -08:00
}
2024-06-09 08:39:29 -07:00
PUBLIC_API_WEAK bool validateBoardConfig ( ) {
return true ;
}
2021-08-16 03:59:43 -07:00
// Returns false if there's an obvious problem with the loaded configuration
2024-06-09 08:42:06 -07:00
bool validateConfigOnStartUpOrBurn ( ) {
2024-06-09 08:39:29 -07:00
if ( ! validateBoardConfig ( ) ) {
return false ;
}
2023-03-27 00:58:18 -07:00
if ( engineConfiguration - > cylindersCount > MAX_CYLINDER_COUNT ) {
2023-08-20 19:23:44 -07:00
criticalError ( " Invalid cylinder count: %d " , engineConfiguration - > cylindersCount ) ;
2021-08-16 03:59:43 -07:00
return false ;
}
2024-06-09 08:33:17 -07:00
if ( engineConfiguration - > adcVcc > 5.0f | | engineConfiguration - > adcVcc < 1.0f ) {
criticalError ( " Invalid adcVcc: %f " , engineConfiguration - > adcVcc ) ;
return false ;
}
2024-06-14 22:54:42 -07:00
if ( engineConfiguration - > mapExpAverageAlpha < = 0 | | engineConfiguration - > mapExpAverageAlpha > 1 ) {
engineConfiguration - > mapExpAverageAlpha = 1 ;
}
2021-08-16 03:59:43 -07:00
2024-07-08 15:33:40 -07:00
ensureArrayIsAscending ( " Injector deadtime " , engineConfiguration - > injector . battLagCorrBins ) ;
2022-12-13 13:36:38 -08:00
2023-12-12 19:05:29 -08:00
# if EFI_ENGINE_CONTROL
2021-08-16 03:59:43 -07:00
// Fueling
{
ensureArrayIsAscending ( " VE load " , config - > veLoadBins ) ;
ensureArrayIsAscending ( " VE RPM " , config - > veRpmBins ) ;
ensureArrayIsAscending ( " Lambda/AFR load " , config - > lambdaLoadBins ) ;
ensureArrayIsAscending ( " Lambda/AFR RPM " , config - > lambdaRpmBins ) ;
ensureArrayIsAscending ( " Fuel CLT mult " , config - > cltFuelCorrBins ) ;
ensureArrayIsAscending ( " Fuel IAT mult " , config - > iatFuelCorrBins ) ;
2024-07-26 08:09:06 -07:00
ensureArrayIsAscendingOrDefault ( " Boost CLT mult " , config - > cltBoostCorrBins ) ;
ensureArrayIsAscendingOrDefault ( " Boost IAT mult " , config - > iatBoostCorrBins ) ;
2021-08-16 03:59:43 -07:00
ensureArrayIsAscending ( " Injection phase load " , config - > injPhaseLoadBins ) ;
ensureArrayIsAscending ( " Injection phase RPM " , config - > injPhaseRpmBins ) ;
2024-03-20 07:54:01 -07:00
ensureArrayIsAscendingOrDefault ( " Fuel Level Sensor " , config - > fuelLevelBins ) ;
2023-11-13 15:34:46 -08:00
ensureArrayIsAscendingOrDefault ( " Fuel Trim Rpm " , config - > fuelTrimRpmBins ) ;
ensureArrayIsAscendingOrDefault ( " Fuel Trim Load " , config - > fuelTrimLoadBins ) ;
2023-06-06 16:26:21 -07:00
2023-12-31 17:02:53 -08:00
ensureArrayIsAscendingOrDefault ( " TC slip " , engineConfiguration - > tractionControlSlipBins ) ;
2023-12-31 11:37:23 -08:00
ensureArrayIsAscendingOrDefault ( " TC speed " , engineConfiguration - > tractionControlSpeedBins ) ;
2021-08-16 03:59:43 -07:00
ensureArrayIsAscending ( " TPS/TPS AE from " , config - > tpsTpsAccelFromRpmBins ) ;
ensureArrayIsAscending ( " TPS/TPS AE to " , config - > tpsTpsAccelToRpmBins ) ;
2022-12-13 13:36:38 -08:00
2024-03-20 07:54:01 -07:00
ensureArrayIsAscendingOrDefault ( " TPS TPS RPM correction " , config - > tpsTspCorrValuesBins ) ;
2024-01-08 08:58:45 -08:00
ensureArrayIsAscendingOrDefault ( " Staging Load " , config - > injectorStagingLoadBins ) ;
ensureArrayIsAscendingOrDefault ( " Staging RPM " , config - > injectorStagingRpmBins ) ;
2021-08-16 03:59:43 -07:00
}
// Ignition
{
2022-05-01 20:43:43 -07:00
ensureArrayIsAscending ( " Dwell RPM " , config - > sparkDwellRpmBins ) ;
2021-08-16 03:59:43 -07:00
ensureArrayIsAscending ( " Ignition load " , config - > ignitionLoadBins ) ;
ensureArrayIsAscending ( " Ignition RPM " , config - > ignitionRpmBins ) ;
2023-11-13 15:34:46 -08:00
ensureArrayIsAscendingOrDefault ( " Ign Trim Rpm " , config - > ignTrimRpmBins ) ;
ensureArrayIsAscendingOrDefault ( " Ign Trim Load " , config - > ignTrimLoadBins ) ;
2021-08-16 03:59:43 -07:00
2022-05-01 20:43:43 -07:00
ensureArrayIsAscending ( " Ignition CLT corr " , config - > cltTimingBins ) ;
2021-08-16 03:59:43 -07:00
2023-01-07 14:48:43 -08:00
ensureArrayIsAscending ( " Ignition IAT corr IAT " , config - > ignitionIatCorrTempBins ) ;
2023-01-06 18:59:34 -08:00
ensureArrayIsAscending ( " Ignition IAT corr Load " , config - > ignitionIatCorrLoadBins ) ;
2021-08-16 03:59:43 -07:00
}
2022-04-13 12:21:31 -07:00
ensureArrayIsAscendingOrDefault ( " Map estimate TPS " , config - > mapEstimateTpsBins ) ;
ensureArrayIsAscendingOrDefault ( " Map estimate RPM " , config - > mapEstimateRpmBins ) ;
2023-12-12 19:05:29 -08:00
# endif // EFI_ENGINE_CONTROL
2021-08-16 03:59:43 -07:00
2022-06-27 20:57:56 -07:00
ensureArrayIsAscendingOrDefault ( " Script Curve 1 " , config - > scriptCurve1Bins ) ;
ensureArrayIsAscendingOrDefault ( " Script Curve 2 " , config - > scriptCurve2Bins ) ;
ensureArrayIsAscendingOrDefault ( " Script Curve 3 " , config - > scriptCurve3Bins ) ;
ensureArrayIsAscendingOrDefault ( " Script Curve 4 " , config - > scriptCurve4Bins ) ;
ensureArrayIsAscendingOrDefault ( " Script Curve 5 " , config - > scriptCurve5Bins ) ;
ensureArrayIsAscendingOrDefault ( " Script Curve 6 " , config - > scriptCurve6Bins ) ;
2022-04-13 13:05:01 -07:00
// todo: huh? why does this not work on CI? ensureArrayIsAscendingOrDefault("Dwell Correction Voltage", engineConfiguration->dwellVoltageCorrVoltBins);
2021-08-16 04:21:07 -07:00
2024-07-08 15:33:40 -07:00
ensureArrayIsAscending ( " MAF transfer function " , config - > mafDecodingBins ) ;
2021-08-16 03:59:43 -07:00
// Cranking tables
ensureArrayIsAscending ( " Cranking fuel mult " , config - > crankingFuelBins ) ;
ensureArrayIsAscending ( " Cranking duration " , config - > crankingCycleBins ) ;
2024-06-09 08:12:29 -07:00
ensureArrayIsAscending ( " Cranking Fuel CLT " , config - > crankingCycleFuelCltBins ) ;
2022-05-01 20:43:43 -07:00
ensureArrayIsAscending ( " Cranking TPS " , config - > crankingTpsBins ) ;
2021-08-16 03:59:43 -07:00
// Idle tables
2022-05-01 20:43:43 -07:00
ensureArrayIsAscending ( " Idle target RPM " , config - > cltIdleRpmBins ) ;
2021-08-16 03:59:43 -07:00
ensureArrayIsAscending ( " Idle warmup mult " , config - > cltIdleCorrBins ) ;
2022-08-29 05:15:04 -07:00
ensureArrayIsAscendingOrDefault ( " Idle coasting RPM " , config - > iacCoastingRpmBins ) ;
2022-04-13 12:21:31 -07:00
ensureArrayIsAscendingOrDefault ( " Idle VE RPM " , config - > idleVeRpmBins ) ;
ensureArrayIsAscendingOrDefault ( " Idle VE Load " , config - > idleVeLoadBins ) ;
ensureArrayIsAscendingOrDefault ( " Idle timing " , config - > idleAdvanceBins ) ;
2021-08-16 04:21:07 -07:00
2021-11-17 00:54:21 -08:00
for ( size_t index = 0 ; index < efi : : size ( engineConfiguration - > vrThreshold ) ; index + + ) {
auto & cfg = engineConfiguration - > vrThreshold [ index ] ;
2021-09-18 19:12:22 -07:00
2022-04-28 14:32:39 -07:00
if ( cfg . pin = = Gpio : : Unassigned ) {
2021-09-18 19:12:22 -07:00
continue ;
}
2024-07-08 15:33:40 -07:00
ensureArrayIsAscending ( " VR threshold " , cfg . rpmBins ) ;
2021-09-18 19:12:22 -07:00
}
2021-08-16 03:59:43 -07:00
2022-02-06 16:17:22 -08:00
# if EFI_BOOST_CONTROL
2021-08-16 03:59:43 -07:00
// Boost
2024-08-22 08:30:53 -07:00
ensureArrayIsAscending ( " Boost control Load " , config - > boostLoadBins ) ;
2021-08-16 03:59:43 -07:00
ensureArrayIsAscending ( " Boost control RPM " , config - > boostRpmBins ) ;
2022-02-06 16:17:22 -08:00
# endif // EFI_BOOST_CONTROL
2021-08-16 03:59:43 -07:00
2022-12-21 18:29:01 -08:00
# if EFI_ANTILAG_SYSTEM
// ALS
2022-12-22 11:38:40 -08:00
ensureArrayIsAscendingOrDefault ( " ign ALS TPS " , config - > alsIgnRetardLoadBins ) ;
ensureArrayIsAscendingOrDefault ( " ign ALS RPM " , config - > alsIgnRetardrpmBins ) ;
ensureArrayIsAscendingOrDefault ( " fuel ALS TPS " , config - > alsFuelAdjustmentLoadBins ) ;
ensureArrayIsAscendingOrDefault ( " fuel ALS RPM " , config - > alsFuelAdjustmentrpmBins ) ;
2022-12-21 18:29:01 -08:00
# endif // EFI_ANTILAG_SYSTEM
2023-12-12 19:05:29 -08:00
# if EFI_ELECTRONIC_THROTTLE_BODY
2021-08-16 03:59:43 -07:00
// ETB
ensureArrayIsAscending ( " Pedal map pedal " , config - > pedalToTpsPedalBins ) ;
ensureArrayIsAscending ( " Pedal map RPM " , config - > pedalToTpsRpmBins ) ;
2023-12-12 19:05:29 -08:00
# endif // EFI_ELECTRONIC_THROTTLE_BODY
2021-08-16 03:59:43 -07:00
2023-07-20 12:40:10 -07:00
if ( isGdiEngine ( ) ) {
2024-03-20 08:18:56 -07:00
ensureArrayIsAscending ( " HPFP compensation " , config - > hpfpCompensationRpmBins ) ;
ensureArrayIsAscending ( " HPFP deadtime " , config - > hpfpDeadtimeVoltsBins ) ;
ensureArrayIsAscending ( " HPFP lobe profile " , config - > hpfpLobeProfileQuantityBins ) ;
ensureArrayIsAscending ( " HPFP target rpm " , config - > hpfpTargetRpmBins ) ;
ensureArrayIsAscending ( " HPFP target load " , config - > hpfpTargetLoadBins ) ;
2021-12-31 16:08:47 -08:00
}
2021-08-16 03:59:43 -07:00
// VVT
2022-10-22 05:39:55 -07:00
if ( isBrainPinValid ( engineConfiguration - > camInputs [ 0 ] ) ) {
2021-09-09 11:11:48 -07:00
ensureArrayIsAscending ( " VVT intake load " , config - > vvtTable1LoadBins ) ;
ensureArrayIsAscending ( " VVT intake RPM " , config - > vvtTable1RpmBins ) ;
}
# if CAM_INPUTS_COUNT != 1
2022-10-22 05:39:55 -07:00
if ( isBrainPinValid ( engineConfiguration - > camInputs [ 1 ] ) ) {
2021-09-09 11:11:48 -07:00
ensureArrayIsAscending ( " VVT exhaust load " , config - > vvtTable2LoadBins ) ;
ensureArrayIsAscending ( " VVT exhaust RPM " , config - > vvtTable2RpmBins ) ;
}
# endif
2021-08-16 03:59:43 -07:00
2024-08-06 13:10:10 -07:00
if ( engineConfiguration - > enableOilPressureProtect ) {
ensureArrayIsAscending ( " Oil pressure protection " , config - > minimumOilPressureBins ) ;
}
2021-08-16 03:59:43 -07:00
return true ;
}
2019-12-23 19:30:58 -08:00
# if !EFI_UNIT_TEST
2023-03-04 22:13:43 -08:00
void commonEarlyInit ( ) {
// Start this early - it will start LED blinking and such
startStatusThreads ( ) ;
2023-03-04 23:42:54 -08:00
# if EFI_SHAFT_POSITION_INPUT
// todo: figure out better startup logic
initTriggerCentral ( ) ;
# endif /* EFI_SHAFT_POSITION_INPUT */
2023-03-04 22:13:43 -08:00
/**
* Initialize hardware drivers
*/
initHardware ( ) ;
2023-03-04 22:20:03 -08:00
2024-01-19 16:04:48 -08:00
initQcBenchControls ( ) ;
2023-11-24 22:41:39 -08:00
2023-03-04 22:20:03 -08:00
# if EFI_FILE_LOGGING
initMmcCard ( ) ;
# endif /* EFI_FILE_LOGGING */
2023-03-04 22:53:11 -08:00
# if EFI_ENGINE_EMULATOR
initEngineEmulator ( ) ;
# endif
# if EFI_LUA
startLua ( ) ;
# endif // EFI_LUA
# if EFI_CAN_SERIAL
// needs to be called after initCan() inside initHardware()
startCanConsole ( ) ;
# endif /* EFI_CAN_SERIAL */
# if HW_CHECK_ALWAYS_STIMULATE
// we need a special binary for final assembly check. We cannot afford to require too much software or too many steps
// to be executed at the place of assembly
2023-04-19 17:29:33 -07:00
enableTriggerStimulator ( /*incGlobalConfiguration*/ false ) ;
2023-03-04 22:53:11 -08:00
# endif // HW_CHECK_ALWAYS_STIMULATE
2023-03-04 22:13:43 -08:00
}
2023-09-25 09:49:44 -07:00
// one-time start-up
void initRealHardwareEngineController ( ) {
2021-04-21 11:28:48 -07:00
commonInitEngineController ( ) ;
2023-11-10 14:15:16 -08:00
initWarningRunningPins ( ) ;
2016-01-12 19:01:53 -08:00
2019-12-03 22:11:10 -08:00
# if EFI_LOGIC_ANALYZER
2015-07-10 06:01:56 -07:00
if ( engineConfiguration - > isWaveAnalyzerEnabled ) {
2021-04-21 11:28:48 -07:00
initWaveAnalyzer ( ) ;
2015-07-10 06:01:56 -07:00
}
2019-12-03 22:11:10 -08:00
# endif /* EFI_LOGIC_ANALYZER */
2015-07-10 06:01:56 -07:00
2016-06-01 17:01:36 -07:00
if ( hasFirmwareError ( ) ) {
return ;
}
2022-07-21 12:17:32 -07:00
engineStateBlinkingTask . start ( ) ;
2015-07-10 06:01:56 -07:00
2023-09-16 08:03:14 -07:00
initVrThresholdPwm ( ) ;
2015-07-10 06:01:56 -07:00
}
2018-03-24 18:13:08 -07:00
2020-05-03 09:40:43 -07:00
/**
* these two variables are here only to let us know how much RAM is available , also these
* help to notice when RAM usage goes up - if a code change adds to RAM usage these variables would fail
* linking process which is the way to raise the alarm
*
* You get " cannot move location counter backwards " linker error when you run out of RAM . When you run out of RAM you shall reduce these
2020-08-02 14:21:07 -07:00
* UNUSED_SIZE constants .
2020-05-03 09:40:43 -07:00
*/
2019-02-06 20:30:53 -08:00
# ifndef RAM_UNUSED_SIZE
2024-05-04 04:28:00 -07:00
# define RAM_UNUSED_SIZE 17400
2019-02-06 20:30:53 -08:00
# endif
# ifndef CCM_UNUSED_SIZE
2022-10-21 09:22:08 -07:00
# define CCM_UNUSED_SIZE 512
2019-02-06 20:30:53 -08:00
# endif
2023-11-17 09:06:21 -08:00
static volatile char UNUSED_RAM_SIZE [ RAM_UNUSED_SIZE ] ;
static volatile char UNUSED_CCM_SIZE [ CCM_UNUSED_SIZE ] CCM_OPTIONAL ;
2018-03-24 18:13:08 -07:00
/**
2024-05-29 14:55:04 -07:00
* See also SIGNATURE_HASH
2018-03-24 18:13:08 -07:00
*/
2024-09-26 17:10:08 -07:00
int getRusEfiVersion ( ) {
2018-03-24 18:13:08 -07:00
if ( UNUSED_RAM_SIZE [ 0 ] ! = 0 )
return 123 ; // this is here to make the compiler happy about the unused array
if ( UNUSED_CCM_SIZE [ 0 ] * 0 ! = 0 )
return 3211 ; // this is here to make the compiler happy about the unused array
2019-04-12 19:07:03 -07:00
# if defined(EFI_BOOTLOADER_INCLUDE_CODE)
2018-03-24 18:13:08 -07:00
// make bootloader code happy too
if ( initBootloader ( ) ! = 0 )
return 123 ;
# endif /* EFI_BOOTLOADER_INCLUDE_CODE */
2020-06-17 09:59:57 -07:00
return VCS_DATE ;
2018-03-24 18:13:08 -07:00
}
2019-04-09 20:00:17 -07:00
# endif /* EFI_UNIT_TEST */