auto-sync
This commit is contained in:
parent
ee48146c4b
commit
4467102b2c
|
@ -32,8 +32,11 @@ extern board_configuration_s *boardConfiguration;
|
||||||
|
|
||||||
extern engine_configuration_s *engineConfiguration;
|
extern engine_configuration_s *engineConfiguration;
|
||||||
|
|
||||||
static volatile uint32_t ckpPeriodUs; // difference between current crank signal and previous crank signal
|
/**
|
||||||
static volatile uint64_t previousCrankSignalStart = 0;
|
* Difference between current 1st trigger event and previous 1st trigger event.
|
||||||
|
*/
|
||||||
|
static volatile uint32_t engineCycleDurationUs;
|
||||||
|
static volatile uint64_t previousEngineCycleTimeUs = 0;
|
||||||
|
|
||||||
#define MAX_ICU_COUNT 5
|
#define MAX_ICU_COUNT 5
|
||||||
|
|
||||||
|
@ -81,29 +84,14 @@ void WaveReader::onFallEvent() {
|
||||||
currentRevolutionCounter = revolutionCounter;
|
currentRevolutionCounter = revolutionCounter;
|
||||||
prevTotalOnTimeUs = totalOnTimeAccumulatorUs;
|
prevTotalOnTimeUs = totalOnTimeAccumulatorUs;
|
||||||
totalOnTimeAccumulatorUs = 0;
|
totalOnTimeAccumulatorUs = 0;
|
||||||
|
|
||||||
|
waveOffsetUs = nowUs - previousEngineCycleTimeUs;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
periodEventTimeUs = nowUs;
|
periodEventTimeUs = nowUs;
|
||||||
|
|
||||||
//scheduleSimpleMsg(&irqLogging, "co", reader->chart.counter);
|
// uint32_t period = engineCycleDurationUs; // local copy of volatile variable
|
||||||
|
|
||||||
// dbAdd(&wavePeriodTime, now);
|
|
||||||
|
|
||||||
uint32_t period = ckpPeriodUs; // local copy of volatile variable
|
|
||||||
|
|
||||||
uint32_t offset = nowUs - previousCrankSignalStart;
|
|
||||||
|
|
||||||
if (offset > period / 2) {
|
|
||||||
/**
|
|
||||||
* here we calculate the offset in relation to future cranking signal
|
|
||||||
*/
|
|
||||||
offset -= period;
|
|
||||||
}
|
|
||||||
waveOffsetUs = offset;
|
|
||||||
|
|
||||||
// we want only the low phase length, so we subsctract high width from period
|
|
||||||
// processSignal(1, &dataPinReader, last_period - last_adc_response_width);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void waIcuPeriodCallback(WaveReader *reader) {
|
static void waIcuPeriodCallback(WaveReader *reader) {
|
||||||
|
@ -149,13 +137,13 @@ static void initWave(const char *name, int index) {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void onWaveShaftSignal(trigger_event_e ckpSignalType, int index, void *arg) {
|
static void waTriggerEventListener(trigger_event_e ckpSignalType, int index, void *arg) {
|
||||||
if (index != 0) {
|
if (index != 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
uint64_t nowUs = getTimeNowUs();
|
uint64_t nowUs = getTimeNowUs();
|
||||||
ckpPeriodUs = nowUs - previousCrankSignalStart;
|
engineCycleDurationUs = nowUs - previousEngineCycleTimeUs;
|
||||||
previousCrankSignalStart = nowUs;
|
previousEngineCycleTimeUs = nowUs;
|
||||||
}
|
}
|
||||||
|
|
||||||
static THD_WORKING_AREA(waThreadStack, UTILITY_THREAD_STACK_SIZE);
|
static THD_WORKING_AREA(waThreadStack, UTILITY_THREAD_STACK_SIZE);
|
||||||
|
@ -227,6 +215,9 @@ static void reportWave(Logging *logging, int index) {
|
||||||
appendFloat(logging, dwellMs, 2);
|
appendFloat(logging, dwellMs, 2);
|
||||||
appendPrintf(logging, "%s", DELIMETER);
|
appendPrintf(logging, "%s", DELIMETER);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* that's the total ON time during the previous engine cycle
|
||||||
|
*/
|
||||||
appendPrintf(logging, "total_dwell%d%s", index, DELIMETER);
|
appendPrintf(logging, "total_dwell%d%s", index, DELIMETER);
|
||||||
appendFloat(logging, readers[index].prevTotalOnTimeUs / 1000.0f, 2);
|
appendFloat(logging, readers[index].prevTotalOnTimeUs / 1000.0f, 2);
|
||||||
appendPrintf(logging, "%s", DELIMETER);
|
appendPrintf(logging, "%s", DELIMETER);
|
||||||
|
@ -236,11 +227,11 @@ static void reportWave(Logging *logging, int index) {
|
||||||
appendFloat(logging, periodMs, 2);
|
appendFloat(logging, periodMs, 2);
|
||||||
appendPrintf(logging, "%s", DELIMETER);
|
appendPrintf(logging, "%s", DELIMETER);
|
||||||
|
|
||||||
int offset = getWaveOffset(index);
|
uint32_t offsetUs = getWaveOffset(index);
|
||||||
int crank = getOneDegreeTimeMs(getRpm()) * 360;
|
float oneDegreeUs = getOneDegreeTimeUs(getRpm());
|
||||||
|
|
||||||
appendPrintf(logging, "advance%d%s", index, DELIMETER);
|
appendPrintf(logging, "advance%d%s", index, DELIMETER);
|
||||||
appendFloat(logging, 90.0 * offset / crank, 3);
|
appendFloat(logging, fixAngle((offsetUs / oneDegreeUs) - engineConfiguration->globalTriggerAngleOffset), 3);
|
||||||
appendPrintf(logging, "%s", DELIMETER);
|
appendPrintf(logging, "%s", DELIMETER);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -256,7 +247,7 @@ void initWaveAnalyzer(void) {
|
||||||
initWave(WA_CHANNEL_1, 0);
|
initWave(WA_CHANNEL_1, 0);
|
||||||
initWave(WA_CHANNEL_2, 1);
|
initWave(WA_CHANNEL_2, 1);
|
||||||
|
|
||||||
addTriggerEventListener(&onWaveShaftSignal, "wave analyzer", (void*) NULL);
|
addTriggerEventListener(&waTriggerEventListener, "wave analyzer", (void*) NULL);
|
||||||
|
|
||||||
addConsoleActionII("set_logic_input_mode", setWaveModeSilent);
|
addConsoleActionII("set_logic_input_mode", setWaveModeSilent);
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,10 @@ public:
|
||||||
|
|
||||||
volatile uint32_t signalPeriodUs; // period between two signal rises in microseconds
|
volatile uint32_t signalPeriodUs; // period between two signal rises in microseconds
|
||||||
|
|
||||||
volatile uint64_t waveOffsetUs; // offset from CKP signal in systimer ticks
|
/**
|
||||||
|
* offset from engine cycle start in microseconds
|
||||||
|
*/
|
||||||
|
volatile uint64_t waveOffsetUs;
|
||||||
volatile uint32_t last_wave_low_widthUs; // time period in systimer ticks
|
volatile uint32_t last_wave_low_widthUs; // time period in systimer ticks
|
||||||
volatile uint64_t last_wave_high_widthUs; // time period in systimer ticks
|
volatile uint64_t last_wave_high_widthUs; // time period in systimer ticks
|
||||||
};
|
};
|
||||||
|
|
|
@ -229,5 +229,5 @@ void firmwareError(const char *fmt, ...) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int getRusEfiVersion(void) {
|
int getRusEfiVersion(void) {
|
||||||
return 20140831;
|
return 20140901;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue