rusefi-full/firmware/controllers/engine_controller_misc.cpp

129 lines
3.3 KiB
C++
Raw Normal View History

2020-03-22 21:01:59 -07:00
/*
* @file engine_controller_misc.cpp
*
* @date Mar 22, 2020
* @author Andrey Belomutskiy, (c) 2012-2020
*/
#include "pch.h"
#include "os_access.h"
2020-03-22 21:01:59 -07:00
extern ButtonDebounce startStopButtonDebounce;
2020-04-01 17:25:44 -07:00
static uint8_t nextThreadId = 0;
void threadInitHook(void* vtp) {
// No lock required, this is already under lock
auto tp = reinterpret_cast<thread_t*>(vtp);
tp->threadId = ++nextThreadId;
}
2020-03-22 21:01:59 -07:00
#if ENABLE_PERF_TRACE
void irqEnterHook() {
2020-03-22 21:01:59 -07:00
perfEventBegin(PE::ISR);
}
void irqExitHook() {
2020-03-22 21:01:59 -07:00
perfEventEnd(PE::ISR);
}
void contextSwitchHook() {
perfEventInstantGlobal(PE::ContextSwitch);
}
#else
void irqEnterHook() {}
void irqExitHook() {}
void contextSwitchHook() {}
2020-03-22 21:01:59 -07:00
#endif /* ENABLE_PERF_TRACE */
#if EFI_ENABLE_MOCK_ADC
/**
* in 2021 the api is Sensor::setMockValue
* todo: remove this mockAdcState https://github.com/rusefi/rusefi/issues/3672
*/
void setMockVoltage(int hwChannel, float voltage) {
engine->engineState.mockAdcState.setMockVoltage(hwChannel, voltage);
2020-03-22 21:01:59 -07:00
}
2021-12-07 16:45:02 -08:00
// used by HW CI testing
void setMockMafVoltage(float voltage) {
setMockVoltage(engineConfiguration->mafAdcChannel, voltage);
}
void setMockAfrVoltage(float voltage) {
setMockVoltage(engineConfiguration->afr.hwChannel, voltage);
}
void setMockMapVoltage(float voltage) {
setMockVoltage(engineConfiguration->map.sensor.hwChannel, voltage);
}
2020-03-22 21:01:59 -07:00
#endif /* EFI_ENABLE_MOCK_ADC */
#if !EFI_UNIT_TEST
2020-03-22 21:01:59 -07:00
/**
* 64-bit result would not overflow, but that's complex stuff for our 32-bit MCU
*/
efitimeus_t getTimeNowUs(void) {
ScopePerf perf(PE::GetTimeNowUs);
return NT2US(getTimeNowNt());
2020-03-22 21:01:59 -07:00
}
static WrapAround62 timeNt;
2020-03-22 21:01:59 -07:00
efitick_t getTimeNowNt() {
return timeNt.update(getTimeNowLowerNt());
}
#endif /* !EFI_UNIT_TEST */
static void onStartStopButtonToggle() {
2020-04-01 17:25:44 -07:00
engine->startStopStateToggleCounter++;
if (engine->rpmCalculator.isStopped()) {
2020-04-01 17:25:44 -07:00
bool wasStarterEngaged = enginePins.starterControl.getAndSet(1);
if (!wasStarterEngaged) {
engine->startStopStateLastPushTime = getTimeNowNt();
efiPrintf("Let's crank this engine for up to %d seconds via %s!",
engineConfiguration->startCrankingDuration,
hwPortname(engineConfiguration->starterControlPin));
2020-04-01 17:25:44 -07:00
}
} else if (engine->rpmCalculator.isRunning()) {
efiPrintf("Let's stop this engine!");
doScheduleStopEngine();
2020-04-01 17:25:44 -07:00
}
}
void slowStartStopButtonCallback() {
bool startStopState = startStopButtonDebounce.readPinEvent();
2020-04-01 17:25:44 -07:00
if (startStopState && !engine->startStopState) {
// we are here on transition from 0 to 1
onStartStopButtonToggle();
2020-04-01 17:25:44 -07:00
}
engine->startStopState = startStopState;
2020-04-01 17:25:44 -07:00
if (engine->startStopStateLastPushTime == 0) {
// nothing is going on with startStop button
return;
}
2020-04-01 17:25:44 -07:00
// todo: should this be simply FSIO?
if (engine->rpmCalculator.isRunning()) {
2020-04-01 17:25:44 -07:00
// turn starter off once engine is running
bool wasStarterEngaged = enginePins.starterControl.getAndSet(0);
if (wasStarterEngaged) {
efiPrintf("Engine runs we can disengage the starter");
engine->startStopStateLastPushTime = 0;
}
}
if (getTimeNowNt() - engine->startStopStateLastPushTime > NT_PER_SECOND * engineConfiguration->startCrankingDuration) {
bool wasStarterEngaged = enginePins.starterControl.getAndSet(0);
if (wasStarterEngaged) {
efiPrintf("Cranking timeout %d seconds", engineConfiguration->startCrankingDuration);
engine->startStopStateLastPushTime = 0;
2020-04-01 17:25:44 -07:00
}
}
}