auto-sync

This commit is contained in:
rusEfi 2014-11-06 19:04:40 -06:00
parent 47e55aa2b6
commit 2efd31b095
6 changed files with 26 additions and 23 deletions

View File

@ -209,7 +209,8 @@ void setDefaultConfiguration(engine_configuration_s *engineConfiguration, board_
engineConfiguration->timingMode = TM_DYNAMIC;
engineConfiguration->fixedModeTiming = 50;
engineConfiguration->analogChartMode = AC_TRIGGER;
// performance optimization
engineConfiguration->analogChartMode = AC_OFF;
engineConfiguration->map.sensor.hwChannel = EFI_ADC_4;
engineConfiguration->baroSensor.hwChannel = EFI_ADC_4;

View File

@ -98,7 +98,7 @@ void mapAveragingCallback(adcsample_t value) {
#if EFI_ANALOG_CHART
if (engineConfiguration->analogChartMode == AC_MAP)
if (perRevolutionCounter % FAST_MAP_CHART_SKIP_FACTOR == 0)
acAddData(getCrankshaftAngle(getTimeNowUs()), currentPressure);
acAddData(getCrankshaftAngleNt(getTimeNowNt()), currentPressure);
#endif /* EFI_ANALOG_CHART */
chSysLockFromIsr()

View File

@ -46,6 +46,8 @@ inline float getOneDegreeTimeMs(int rpm) {
*/
#define getOneDegreeTimeUs(rpm) (1000000.0f * 60 / 360 / (rpm))
#define getOneDegreeTimeNt(rpm) (US2NT(1000000.0f) * 60 / 360 / (rpm))
float getCrankshaftRevolutionTimeMs(int rpm);
int isCrankingRT(engine_configuration_s *engineConfiguration, int rpm);

View File

@ -63,7 +63,7 @@ RpmCalculator::RpmCalculator() {
rpmValue = 0;
// we need this initial to have not_running at first invocation
lastRpmEventTimeUs = (uint64_t) -10 * US_PER_SECOND;
lastRpmEventTimeNt = (uint64_t) -10 * US2NT(US_PER_SECOND);
revolutionCounterSinceStart = 0;
revolutionCounterSinceBoot = 0;
}
@ -72,8 +72,8 @@ RpmCalculator::RpmCalculator() {
* @return true if there was a full shaft revolution within the last second
*/
bool RpmCalculator::isRunning(void) {
uint64_t nowUs = getTimeNowUs();
return nowUs - lastRpmEventTimeUs < US_PER_SECOND;
uint64_t nowNt = getTimeNowNt();
return nowNt - lastRpmEventTimeNt < US2NT(US_PER_SECOND);
}
void RpmCalculator::onNewEngineCycle() {
@ -89,13 +89,12 @@ uint32_t RpmCalculator::getRevolutionCounterSinceStart(void) {
return revolutionCounterSinceStart;
}
// todo: migrate to float return result or add a float verion? this would have with calculations
// todo: add a version which does not check time & saves time? need to profile
int RpmCalculator::rpm(void) {
#if !EFI_PROD_CODE
if (mockRpm != MOCK_UNDEFINED)
return mockRpm;
return mockRpm;
#endif
if (!isRunning()) {
revolutionCounterSinceStart = 0;
@ -130,12 +129,12 @@ bool isCranking(void) {
* This callback is invoked on interrupt thread.
*/
void rpmShaftPositionCallback(trigger_event_e ckpSignalType, uint32_t index, RpmCalculator *rpmState) {
uint64_t nowUs = getTimeNowUs();
uint64_t nowNt = getTimeNowNt();
if (index != 0) {
#if EFI_ANALOG_CHART || defined(__DOXYGEN__)
if (engineConfiguration->analogChartMode == AC_TRIGGER)
acAddData(getCrankshaftAngle(nowUs), 1000 * ckpSignalType + index);
acAddData(getCrankshaftAngleNt(nowNt), 1000 * ckpSignalType + index);
#endif
return;
}
@ -144,7 +143,7 @@ void rpmShaftPositionCallback(trigger_event_e ckpSignalType, uint32_t index, Rpm
bool hadRpmRecently = rpmState->isRunning();
if (hadRpmRecently) {
uint64_t diff = nowUs - rpmState->lastRpmEventTimeUs;
uint64_t diffNt = nowNt - rpmState->lastRpmEventTimeNt;
/**
* Four stroke cycle is two crankshaft revolutions
*
@ -152,17 +151,18 @@ void rpmShaftPositionCallback(trigger_event_e ckpSignalType, uint32_t index, Rpm
* and each revolution of crankshaft consists of two engine cycles revolutions
*
*/
if (diff == 0) {
if (diffNt == 0) {
rpmState->rpmValue = NOISY_RPM;
} else {
int rpm = (int) (60 * US_PER_SECOND * 2 / diff);
// todo: interesting what is this *2 about? four stroke magic constant?
int rpm = (int) (60 * US2NT(US_PER_SECOND) * 2 / diffNt);
rpmState->rpmValue = rpm > UNREALISTIC_RPM ? NOISY_RPM : rpm;
}
}
rpmState->lastRpmEventTimeUs = nowUs;
rpmState->lastRpmEventTimeNt = nowNt;
#if EFI_ANALOG_CHART || defined(__DOXYGEN__)
if (engineConfiguration->analogChartMode == AC_TRIGGER)
acAddData(getCrankshaftAngle(nowUs), index);
acAddData(getCrankshaftAngleNt(nowNt), index);
#endif
}
@ -184,8 +184,8 @@ static void onTdcCallback(void) {
* This trigger callback schedules the actual physical TDC callback in relation to trigger synchronization point.
*/
static void tdcMarkCallback(trigger_event_e ckpSignalType, uint32_t index0, void *arg) {
(void)arg;
(void)ckpSignalType;
(void) arg;
(void) ckpSignalType;
bool isTriggerSynchronizationPoint = index0 == 0;
if (isTriggerSynchronizationPoint) {
int revIndex2 = getRevolutionCounter() % 2;
@ -199,7 +199,7 @@ static void tdcMarkCallback(trigger_event_e ckpSignalType, uint32_t index0, void
static RpmCalculator rpmState;
uint64_t getLastRpmEventTime(void) {
return rpmState.lastRpmEventTimeUs;
return NT2US(rpmState.lastRpmEventTimeNt);
}
int getRevolutionCounter(void) {
@ -209,15 +209,15 @@ int getRevolutionCounter(void) {
/**
* @return Current crankshaft angle, 0 to 720 for four-stroke
*/
float getCrankshaftAngle(uint64_t timeUs) {
uint64_t timeSinceZeroAngleUs = timeUs - rpmState.lastRpmEventTimeUs;
float getCrankshaftAngleNt(uint64_t timeNt) {
uint64_t timeSinceZeroAngleNt = timeNt - rpmState.lastRpmEventTimeNt;
/**
* even if we use 'getOneDegreeTimeUs' macros here, it looks like the
* compiler is not smart enough to figure out that "A / ( B / C)" could be optimized into
* "A * C / B" in order to replace a slower division with a faster multiplication.
*/
return timeSinceZeroAngleUs / getOneDegreeTimeUs(rpmState.rpm());
return timeSinceZeroAngleNt / getOneDegreeTimeNt(rpmState.rpm());
}
void initRpmCalculator(void) {

View File

@ -34,7 +34,7 @@ public:
uint32_t getRevolutionCounter(void);
uint32_t getRevolutionCounterSinceStart(void);
volatile int rpmValue;
volatile uint64_t lastRpmEventTimeUs;
volatile uint64_t lastRpmEventTimeNt;
private:
/**
* This counter is incremented with each revolution of one of the shafts. Could be
@ -69,7 +69,7 @@ bool isCranking(void);
uint64_t getLastRpmEventTime(void);
int getRevolutionCounter(void);
float getCrankshaftAngle(uint64_t timeUs);
float getCrankshaftAngleNt(uint64_t timeNt);
bool isValidRpm(int rpm);
void addWaveChartEvent(const char *name, const char *msg, const char *msg2);

View File

@ -43,7 +43,7 @@ extern "C"
// 168 ticks in microsecond
#define US_TO_NT_MULTIPLIER 168
#define US2NT(x) ((x)*US_TO_NT_MULTIPLIER)
#define US2NT(x) (((uint64_t)(x))*US_TO_NT_MULTIPLIER)
#define NT2US(x) ((x) / US_TO_NT_MULTIPLIER)