2014-08-29 07:52:33 -07:00
|
|
|
/*
|
|
|
|
* @brief dead code
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* map_multiplier.cpp
|
|
|
|
*
|
|
|
|
* @date Jul 23, 2013
|
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2014
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "main.h"
|
|
|
|
#include "map_multiplier_thread.h"
|
|
|
|
#include "map_adjuster.h"
|
|
|
|
#include "rpm_calculator.h"
|
|
|
|
#include "main_trigger_callback.h"
|
|
|
|
#include "allsensors.h"
|
|
|
|
#include "engine_math.h"
|
|
|
|
#include "engine.h"
|
|
|
|
|
|
|
|
extern engine_configuration_s *engineConfiguration;
|
|
|
|
|
|
|
|
static Logging logger;
|
|
|
|
|
|
|
|
extern Engine engine;
|
|
|
|
|
|
|
|
static THD_WORKING_AREA(maThreadStack, UTILITY_THREAD_STACK_SIZE);
|
|
|
|
|
|
|
|
static void mapCallback(int rpm, float key, float value) {
|
|
|
|
Logging *logging = &logger;
|
|
|
|
appendPrintf(logging, "msg%s", DELIMETER);
|
|
|
|
|
|
|
|
appendPrintf(logging, "map_adjusted: ");
|
|
|
|
appendPrintf(logging, "%d", rpm);
|
|
|
|
appendPrintf(logging, " ");
|
|
|
|
appendPrintf(logging, "%d", 100 * key);
|
|
|
|
appendPrintf(logging, " ");
|
|
|
|
appendPrintf(logging, "%d", 100 * value);
|
|
|
|
|
|
|
|
appendMsgPostfix(logging);
|
|
|
|
scheduleLogging(logging);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int timeAtNotRunning = 0;
|
|
|
|
|
|
|
|
static int isNewState = TRUE;
|
|
|
|
|
|
|
|
static void maThread(int param) {
|
|
|
|
chRegSetThreadName("map adjustment");
|
|
|
|
|
|
|
|
while (TRUE) {
|
|
|
|
chThdSleepMilliseconds(100);
|
|
|
|
|
|
|
|
systime_t now = chTimeNow();
|
2014-09-11 13:03:00 -07:00
|
|
|
//todo? if (!isRunning()) {
|
|
|
|
// timeAtNotRunning = now;
|
|
|
|
// continue;
|
|
|
|
// }
|
2014-08-29 07:52:33 -07:00
|
|
|
|
|
|
|
int wasNotRunningRecently = overflowDiff(now, timeAtNotRunning) < 60 * CH_FREQUENCY;
|
|
|
|
if (!wasNotRunningRecently)
|
|
|
|
continue;
|
|
|
|
if (isNewState)
|
|
|
|
scheduleMsg(&logger, "starting fuel map adjustment at %d", now);
|
|
|
|
isNewState = FALSE;
|
|
|
|
|
|
|
|
// ideally this should be atomic, but hopefully it's good enough
|
|
|
|
int rpm = getRpm();
|
|
|
|
float load = getEngineLoad();
|
|
|
|
float afr = getAfr();
|
|
|
|
|
|
|
|
addAfr(rpm, load, afr);
|
|
|
|
int total = runMapAdjustments(mapCallback);
|
|
|
|
if (total > 0) {
|
|
|
|
// scheduleSimpleMsg(&logger, "map adjusted for maf ", 100 * key);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void initMapAdjusterThread(void) {
|
|
|
|
initLogging(&logger, "Map self learning thread");
|
|
|
|
|
|
|
|
initMapAdjuster();
|
|
|
|
|
|
|
|
chThdCreateStatic(maThreadStack, sizeof(maThreadStack), NORMALPRIO, (tfunc_t)maThread, NULL);
|
|
|
|
}
|