2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file engine_emulator.cpp
|
|
|
|
* @brief Entry point for all the emulation and analysis code
|
|
|
|
*
|
|
|
|
* @date Mar 15, 2013
|
2018-01-20 17:55:31 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2018
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
2018-09-16 19:26:57 -07:00
|
|
|
#include "global.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
#include "engine_emulator.h"
|
|
|
|
|
|
|
|
#include "advance_map.h"
|
|
|
|
#include "fuel_math.h"
|
|
|
|
|
|
|
|
#include "status_loop.h"
|
|
|
|
#include "wave_analyzer.h"
|
|
|
|
#include "pin_repository.h"
|
|
|
|
#include "pwm_generator_logic.h"
|
|
|
|
|
|
|
|
#include "poten.h"
|
|
|
|
#include "trigger_emulator.h"
|
|
|
|
|
|
|
|
extern bool hasFirmwareErrorFlag;
|
|
|
|
|
|
|
|
static THD_WORKING_AREA(eeThreadStack, UTILITY_THREAD_STACK_SIZE);
|
|
|
|
|
2017-04-21 16:59:05 -07:00
|
|
|
#define DIAG_PIN GPIOD_0
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
void setDiag(int value) {
|
|
|
|
print("Setting diag: %d\r\n", value);
|
2017-04-21 16:59:05 -07:00
|
|
|
// todo: convert to new api palWritePad(DIAG_PORT, DIAG_PIN, value);
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#define PERIOD 3000
|
|
|
|
|
2017-04-21 11:03:08 -07:00
|
|
|
EXTERN_ENGINE;
|
|
|
|
|
|
|
|
static void emulate(void) {
|
2015-07-10 06:01:56 -07:00
|
|
|
print("Emulating...\r\n");
|
|
|
|
setDiag(1);
|
|
|
|
chThdSleep(1);
|
|
|
|
setFullLog(1);
|
|
|
|
|
|
|
|
for (int i = 400; i <= 1300; i++) {
|
|
|
|
if (i % 50 != 0)
|
|
|
|
continue;
|
2017-05-15 20:28:49 -07:00
|
|
|
setTriggerEmulatorRPM(i PASS_ENGINE_PARAMETER_SUFFIX);
|
2015-07-10 06:01:56 -07:00
|
|
|
chThdSleepMilliseconds(PERIOD);
|
|
|
|
}
|
|
|
|
|
2017-05-15 20:28:49 -07:00
|
|
|
setTriggerEmulatorRPM(0 PASS_ENGINE_PARAMETER_SUFFIX);
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
setFullLog(0);
|
|
|
|
setDiag(0);
|
|
|
|
chThdSleep(1);
|
|
|
|
print("Emulation DONE!\r\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
static int flag = FALSE;
|
|
|
|
|
2017-04-21 11:03:08 -07:00
|
|
|
static msg_t eeThread(void *arg) {
|
|
|
|
(void)arg;
|
2015-07-10 06:01:56 -07:00
|
|
|
chRegSetThreadName("Engine");
|
|
|
|
|
|
|
|
while (TRUE) {
|
|
|
|
while (!flag)
|
|
|
|
chThdSleepMilliseconds(200);
|
|
|
|
flag = FALSE;
|
2017-04-21 11:03:08 -07:00
|
|
|
emulate();
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
#if defined __GNUC__
|
|
|
|
return (msg_t)NULL;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void startEmulator(void) {
|
|
|
|
flag = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
//static void printAdvance(int rpm, int maf100) {
|
|
|
|
// float advance = getAdvance(rpm, maf100 / 100.0);
|
2018-01-23 09:05:14 -08:00
|
|
|
// print("advance for %d rpm %d maf100: %.2f\r\n", rpm, maf100, advance);
|
2015-07-10 06:01:56 -07:00
|
|
|
//}
|
|
|
|
|
|
|
|
static void initECUstimulator(Engine *engine) {
|
2017-05-15 05:40:54 -07:00
|
|
|
efiSetPadMode("TEN", DIAG_PIN, PAL_MODE_OUTPUT_PUSHPULL);
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
addConsoleActionI("diag", setDiag);
|
|
|
|
addConsoleAction("emu", startEmulator);
|
|
|
|
// addConsoleActionII("ad", printAdvance);
|
|
|
|
|
|
|
|
setDiag(1);
|
|
|
|
|
2018-12-27 06:40:40 -08:00
|
|
|
chThdCreateStatic(eeThreadStack, sizeof(eeThreadStack), NORMALPRIO, (tfunc_t)(void*) eeThread, engine);
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void initEngineEmulator(Logging *sharedLogger, Engine *engine) {
|
|
|
|
if (hasFirmwareError())
|
|
|
|
return;
|
|
|
|
|
|
|
|
#if EFI_POTENTIOMETER
|
2018-11-16 04:40:06 -08:00
|
|
|
#if HAL_USE_SPI || defined(__DOXYGEN__)
|
2015-07-10 06:01:56 -07:00
|
|
|
initPotentiometers(sharedLogger, &engine->engineConfiguration->bc);
|
2018-11-16 04:40:06 -08:00
|
|
|
#endif /* HAL_USE_SPI */
|
2015-07-10 06:01:56 -07:00
|
|
|
#endif /* EFI_POTENTIOMETER */
|
|
|
|
|
|
|
|
//initECUstimulator();
|
2017-05-15 20:28:49 -07:00
|
|
|
initTriggerEmulator(sharedLogger PASS_ENGINE_PARAMETER_SUFFIX);
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|