Trigger cleanup init (#4222)
* extra parameter * name decoders in constructor * s
This commit is contained in:
parent
c1582007af
commit
c0d8cbfef4
|
@ -107,15 +107,13 @@ static operation_mode_e lookupOperationMode() {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void initVvtShape(TriggerWaveform& shape, const TriggerConfiguration& config, TriggerDecoderBase &initState) {
|
static void initVvtShape(TriggerWaveform& shape, const TriggerConfiguration& config, TriggerDecoderBase &initState) {
|
||||||
shape.initializeTriggerWaveform(
|
shape.initializeTriggerWaveform(FOUR_STROKE_CAM_SENSOR, config);
|
||||||
lookupOperationMode(),
|
|
||||||
engineConfiguration->vvtCamSensorUseRise, config);
|
|
||||||
|
|
||||||
shape.initializeSyncPoint(initState, config);
|
shape.initializeSyncPoint(initState, config);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Engine::updateTriggerWaveform() {
|
void Engine::updateTriggerWaveform() {
|
||||||
static TriggerDecoderBase initState;
|
static TriggerDecoderBase initState("init");
|
||||||
|
|
||||||
// Re-read config in case it's changed
|
// Re-read config in case it's changed
|
||||||
primaryTriggerConfiguration.update();
|
primaryTriggerConfiguration.update();
|
||||||
|
@ -127,9 +125,7 @@ void Engine::updateTriggerWaveform() {
|
||||||
// we have a confusing threading model so some synchronization would not hurt
|
// we have a confusing threading model so some synchronization would not hurt
|
||||||
chibios_rt::CriticalSectionLocker csl;
|
chibios_rt::CriticalSectionLocker csl;
|
||||||
|
|
||||||
TRIGGER_WAVEFORM(initializeTriggerWaveform(
|
TRIGGER_WAVEFORM(initializeTriggerWaveform(lookupOperationMode(), primaryTriggerConfiguration));
|
||||||
lookupOperationMode(),
|
|
||||||
engineConfiguration->useOnlyRisingEdgeForTrigger, primaryTriggerConfiguration));
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* this is only useful while troubleshooting a new trigger shape in the field
|
* this is only useful while troubleshooting a new trigger shape in the field
|
||||||
|
@ -160,15 +156,9 @@ void Engine::updateTriggerWaveform() {
|
||||||
calculateTriggerSynchPoint(engine->triggerCentral.triggerShape,
|
calculateTriggerSynchPoint(engine->triggerCentral.triggerShape,
|
||||||
initState);
|
initState);
|
||||||
|
|
||||||
engine->triggerCentral.triggerState.name = "TRG";
|
|
||||||
engine->engineCycleEventCount = TRIGGER_WAVEFORM(getLength());
|
engine->engineCycleEventCount = TRIGGER_WAVEFORM(getLength());
|
||||||
}
|
}
|
||||||
|
|
||||||
engine->triggerCentral.vvtState[0][0].name = "VVT B1 Int";
|
|
||||||
engine->triggerCentral.vvtState[0][1].name = "VVT B1 Exh";
|
|
||||||
engine->triggerCentral.vvtState[1][0].name = "VVT B2 Int";
|
|
||||||
engine->triggerCentral.vvtState[1][1].name = "VVT B2 Exh";
|
|
||||||
|
|
||||||
for (int camIndex = 0; camIndex < CAMS_PER_BANK; camIndex++) {
|
for (int camIndex = 0; camIndex < CAMS_PER_BANK; camIndex++) {
|
||||||
// todo: should 'vvtWithRealDecoder' be used here?
|
// todo: should 'vvtWithRealDecoder' be used here?
|
||||||
if (engineConfiguration->vvtMode[camIndex] != VVT_INACTIVE) {
|
if (engineConfiguration->vvtMode[camIndex] != VVT_INACTIVE) {
|
||||||
|
|
|
@ -446,7 +446,7 @@ void TriggerWaveform::setThirdTriggerSynchronizationGap(float syncRatio) {
|
||||||
/**
|
/**
|
||||||
* External logger is needed because at this point our logger is not yet initialized
|
* External logger is needed because at this point our logger is not yet initialized
|
||||||
*/
|
*/
|
||||||
void TriggerWaveform::initializeTriggerWaveform(operation_mode_e triggerOperationMode, bool useOnlyRisingEdgeForTrigger, const TriggerConfiguration& triggerConfig) {
|
void TriggerWaveform::initializeTriggerWaveform(operation_mode_e triggerOperationMode, const TriggerConfiguration& triggerConfig) {
|
||||||
|
|
||||||
#if EFI_PROD_CODE
|
#if EFI_PROD_CODE
|
||||||
efiAssertVoid(CUSTOM_ERR_6641, getCurrentRemainingStack() > EXPECTED_REMAINING_STACK, "init t");
|
efiAssertVoid(CUSTOM_ERR_6641, getCurrentRemainingStack() > EXPECTED_REMAINING_STACK, "init t");
|
||||||
|
@ -455,6 +455,7 @@ void TriggerWaveform::initializeTriggerWaveform(operation_mode_e triggerOperatio
|
||||||
|
|
||||||
shapeDefinitionError = false;
|
shapeDefinitionError = false;
|
||||||
|
|
||||||
|
bool useOnlyRisingEdgeForTrigger = triggerConfig.UseOnlyRisingEdgeForTrigger;
|
||||||
this->useOnlyRisingEdgeForTriggerTemp = useOnlyRisingEdgeForTrigger;
|
this->useOnlyRisingEdgeForTriggerTemp = useOnlyRisingEdgeForTrigger;
|
||||||
|
|
||||||
switch (triggerConfig.TriggerType.type) {
|
switch (triggerConfig.TriggerType.type) {
|
||||||
|
|
|
@ -73,8 +73,7 @@ class TriggerConfiguration;
|
||||||
class TriggerWaveform {
|
class TriggerWaveform {
|
||||||
public:
|
public:
|
||||||
TriggerWaveform();
|
TriggerWaveform();
|
||||||
void initializeTriggerWaveform(operation_mode_e triggerOperationMode,
|
void initializeTriggerWaveform(operation_mode_e triggerOperationMode, const TriggerConfiguration& triggerConfig);
|
||||||
bool useOnlyRisingEdgeForTrigger, const TriggerConfiguration& triggerConfig);
|
|
||||||
void setShapeDefinitionError(bool value);
|
void setShapeDefinitionError(bool value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -43,7 +43,8 @@ static scheduling_s debugToggleScheduling;
|
||||||
TriggerCentral::TriggerCentral() :
|
TriggerCentral::TriggerCentral() :
|
||||||
vvtEventRiseCounter(),
|
vvtEventRiseCounter(),
|
||||||
vvtEventFallCounter(),
|
vvtEventFallCounter(),
|
||||||
vvtPosition()
|
vvtPosition(),
|
||||||
|
triggerState("TRG")
|
||||||
{
|
{
|
||||||
memset(&hwEventCounters, 0, sizeof(hwEventCounters));
|
memset(&hwEventCounters, 0, sizeof(hwEventCounters));
|
||||||
triggerState.resetTriggerState();
|
triggerState.resetTriggerState();
|
||||||
|
|
|
@ -113,7 +113,23 @@ public:
|
||||||
|
|
||||||
TriggerWaveform triggerShape;
|
TriggerWaveform triggerShape;
|
||||||
|
|
||||||
VvtTriggerDecoder vvtState[BANKS_COUNT][CAMS_PER_BANK];
|
VvtTriggerDecoder vvtState[BANKS_COUNT][CAMS_PER_BANK] = {
|
||||||
|
{
|
||||||
|
"VVT B1 Int",
|
||||||
|
#if CAMS_PER_BANK >= 2
|
||||||
|
"VVT B1 Exh"
|
||||||
|
#endif
|
||||||
|
},
|
||||||
|
#if BANKS_COUNT >= 2
|
||||||
|
{
|
||||||
|
"VVT B2 Int",
|
||||||
|
#if CAMS_PER_BANK >= 2
|
||||||
|
"VVT B1 Exh"
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
TriggerWaveform vvtShape[CAMS_PER_BANK];
|
TriggerWaveform vvtShape[CAMS_PER_BANK];
|
||||||
|
|
||||||
TriggerFormDetails triggerFormDetails;
|
TriggerFormDetails triggerFormDetails;
|
||||||
|
|
|
@ -38,7 +38,9 @@
|
||||||
#include "sensor_chart.h"
|
#include "sensor_chart.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
TriggerDecoderBase::TriggerDecoderBase() {
|
TriggerDecoderBase::TriggerDecoderBase(const char* name)
|
||||||
|
: name(name)
|
||||||
|
{
|
||||||
resetTriggerState();
|
resetTriggerState();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,10 +92,12 @@ void TriggerDecoderBase::resetCurrentCycleState() {
|
||||||
|
|
||||||
#if EFI_SHAFT_POSITION_INPUT
|
#if EFI_SHAFT_POSITION_INPUT
|
||||||
|
|
||||||
PrimaryTriggerDecoder::PrimaryTriggerDecoder() :
|
PrimaryTriggerDecoder::PrimaryTriggerDecoder(const char* name)
|
||||||
|
: TriggerDecoderBase(name)
|
||||||
//https://en.cppreference.com/w/cpp/language/zero_initialization
|
//https://en.cppreference.com/w/cpp/language/zero_initialization
|
||||||
timeOfLastEvent(), instantRpmValue()
|
, timeOfLastEvent()
|
||||||
{
|
, instantRpmValue()
|
||||||
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ! EFI_PROD_CODE
|
#if ! EFI_PROD_CODE
|
||||||
|
@ -343,7 +347,7 @@ static trigger_value_e eventType[6] = { TV_FALL, TV_RISE, TV_FALL, TV_RISE, TV_F
|
||||||
|
|
||||||
#define nextTriggerEvent() \
|
#define nextTriggerEvent() \
|
||||||
{ \
|
{ \
|
||||||
if (triggerConfiguration.UseOnlyRisingEdgeForTrigger) {currentCycle.current_index++;} \
|
if (useOnlyRisingEdgeForTrigger) {currentCycle.current_index++;} \
|
||||||
currentCycle.current_index++; \
|
currentCycle.current_index++; \
|
||||||
PRINT_INC_INDEX; \
|
PRINT_INC_INDEX; \
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,7 +62,7 @@ struct TriggerDecodeResult {
|
||||||
*/
|
*/
|
||||||
class TriggerDecoderBase : public trigger_state_s {
|
class TriggerDecoderBase : public trigger_state_s {
|
||||||
public:
|
public:
|
||||||
TriggerDecoderBase();
|
TriggerDecoderBase(const char* name);
|
||||||
/**
|
/**
|
||||||
* current trigger processing index, between zero and #size
|
* current trigger processing index, between zero and #size
|
||||||
*/
|
*/
|
||||||
|
@ -108,7 +108,7 @@ public:
|
||||||
efitick_t toothed_previous_time;
|
efitick_t toothed_previous_time;
|
||||||
|
|
||||||
current_cycle_state_s currentCycle;
|
current_cycle_state_s currentCycle;
|
||||||
const char *name = nullptr;
|
const char* const name;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* how many times since ECU reboot we had unexpected number of teeth in trigger cycle
|
* how many times since ECU reboot we had unexpected number of teeth in trigger cycle
|
||||||
|
@ -165,7 +165,7 @@ private:
|
||||||
*/
|
*/
|
||||||
class PrimaryTriggerDecoder : public TriggerDecoderBase {
|
class PrimaryTriggerDecoder : public TriggerDecoderBase {
|
||||||
public:
|
public:
|
||||||
PrimaryTriggerDecoder();
|
PrimaryTriggerDecoder(const char* name);
|
||||||
void resetTriggerState() override;
|
void resetTriggerState() override;
|
||||||
|
|
||||||
angle_t syncEnginePhase(int divider, int remainder, angle_t engineCycle);
|
angle_t syncEnginePhase(int divider, int remainder, angle_t engineCycle);
|
||||||
|
@ -223,7 +223,10 @@ private:
|
||||||
bool m_hasSynchronizedPhase = false;
|
bool m_hasSynchronizedPhase = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
class VvtTriggerDecoder : public TriggerDecoderBase { };
|
class VvtTriggerDecoder : public TriggerDecoderBase {
|
||||||
|
public:
|
||||||
|
VvtTriggerDecoder(const char* name) : TriggerDecoderBase(name) { }
|
||||||
|
};
|
||||||
|
|
||||||
angle_t getEngineCycle(operation_mode_e operationMode);
|
angle_t getEngineCycle(operation_mode_e operationMode);
|
||||||
|
|
||||||
|
|
|
@ -64,7 +64,7 @@ static void testDodgeNeonDecoder() {
|
||||||
TriggerWaveform * shape = ð.engine.triggerCentral.triggerShape;
|
TriggerWaveform * shape = ð.engine.triggerCentral.triggerShape;
|
||||||
ASSERT_EQ(8, shape->getTriggerWaveformSynchPointIndex());
|
ASSERT_EQ(8, shape->getTriggerWaveformSynchPointIndex());
|
||||||
|
|
||||||
TriggerDecoderBase state;
|
TriggerDecoderBase state("test");
|
||||||
|
|
||||||
ASSERT_FALSE(state.getShaftSynchronized()) << "1 shaft_is_synchronized";
|
ASSERT_FALSE(state.getShaftSynchronized()) << "1 shaft_is_synchronized";
|
||||||
|
|
||||||
|
@ -111,7 +111,7 @@ static void assertTriggerPosition(event_trigger_position_s *position, int eventI
|
||||||
TEST(trigger, testSomethingWeird) {
|
TEST(trigger, testSomethingWeird) {
|
||||||
EngineTestHelper eth(FORD_INLINE_6_1995);
|
EngineTestHelper eth(FORD_INLINE_6_1995);
|
||||||
|
|
||||||
TriggerDecoderBase state_;
|
TriggerDecoderBase state_("test");
|
||||||
TriggerDecoderBase *sta = &state_;
|
TriggerDecoderBase *sta = &state_;
|
||||||
|
|
||||||
const auto& triggerConfiguration = engine->primaryTriggerConfiguration;
|
const auto& triggerConfiguration = engine->primaryTriggerConfiguration;
|
||||||
|
|
|
@ -29,12 +29,14 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
struct MockTriggerDecoder : public TriggerDecoderBase {
|
struct MockTriggerDecoder : public TriggerDecoderBase {
|
||||||
|
MockTriggerDecoder() : TriggerDecoderBase("mock") { }
|
||||||
|
|
||||||
MOCK_METHOD(void, onTriggerError, (), (override));
|
MOCK_METHOD(void, onTriggerError, (), (override));
|
||||||
};
|
};
|
||||||
|
|
||||||
static auto makeTriggerShape(operation_mode_e mode, const TriggerConfiguration& config) {
|
static auto makeTriggerShape(operation_mode_e mode, const TriggerConfiguration& config) {
|
||||||
TriggerWaveform shape;
|
TriggerWaveform shape;
|
||||||
shape.initializeTriggerWaveform(mode, true, config);
|
shape.initializeTriggerWaveform(mode, config);
|
||||||
|
|
||||||
return shape;
|
return shape;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue