auto-sync
This commit is contained in:
parent
249444a7cd
commit
94bf364bc6
|
@ -26,7 +26,7 @@ public:
|
||||||
|
|
||||||
void addFuelEvents(trigger_shape_s *s,
|
void addFuelEvents(trigger_shape_s *s,
|
||||||
injection_mode_e mode DECLARE_ENGINE_PARAMETER_S);
|
injection_mode_e mode DECLARE_ENGINE_PARAMETER_S);
|
||||||
void registerInjectionEvent(trigger_shape_s *s,
|
void registerInjectionEvent(
|
||||||
io_pin_e pin, float angle, bool_t isSimultanious DECLARE_ENGINE_PARAMETER_S);
|
io_pin_e pin, float angle, bool_t isSimultanious DECLARE_ENGINE_PARAMETER_S);
|
||||||
|
|
||||||
uint8_t hasEvents[PWM_PHASE_MAX_COUNT];
|
uint8_t hasEvents[PWM_PHASE_MAX_COUNT];
|
||||||
|
|
|
@ -94,7 +94,7 @@ engine_configuration2_s * engineConfiguration2 = &ec2;
|
||||||
/**
|
/**
|
||||||
* todo: this should probably become 'static', i.e. private, and propagated around explicitly?
|
* todo: this should probably become 'static', i.e. private, and propagated around explicitly?
|
||||||
*/
|
*/
|
||||||
static Engine _engine;
|
Engine _engine;
|
||||||
Engine * engine = &_engine;
|
Engine * engine = &_engine;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,8 @@
|
||||||
EXTERN_ENGINE
|
EXTERN_ENGINE
|
||||||
;
|
;
|
||||||
|
|
||||||
|
extern OutputPin outputs[IO_PIN_COUNT];
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* default Volumetric Efficiency
|
* default Volumetric Efficiency
|
||||||
*/
|
*/
|
||||||
|
@ -88,7 +90,7 @@ void setSingleCoilDwell(engine_configuration_s *engineConfiguration) {
|
||||||
|
|
||||||
OutputSignalList injectonSignals CCM_OPTIONAL;
|
OutputSignalList injectonSignals CCM_OPTIONAL;
|
||||||
|
|
||||||
static void registerSparkEvent(trigger_shape_s * s, IgnitionEventList *list, io_pin_e pin, float localAdvance,
|
static void registerSparkEvent(IgnitionEventList *list, io_pin_e pin, float localAdvance,
|
||||||
float dwell DECLARE_ENGINE_PARAMETER_S) {
|
float dwell DECLARE_ENGINE_PARAMETER_S) {
|
||||||
|
|
||||||
IgnitionEvent *event = list->getNextActuatorEvent();
|
IgnitionEvent *event = list->getNextActuatorEvent();
|
||||||
|
@ -103,7 +105,7 @@ static void registerSparkEvent(trigger_shape_s * s, IgnitionEventList *list, io_
|
||||||
|
|
||||||
event->advance = localAdvance;
|
event->advance = localAdvance;
|
||||||
|
|
||||||
findTriggerPosition(s, &event->dwellPosition, localAdvance - dwell PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&event->dwellPosition, localAdvance - dwell PASS_ENGINE_PARAMETER);
|
||||||
}
|
}
|
||||||
|
|
||||||
void initializeIgnitionActions(float advance, float dwellAngle,
|
void initializeIgnitionActions(float advance, float dwellAngle,
|
||||||
|
@ -113,40 +115,38 @@ void initializeIgnitionActions(float advance, float dwellAngle,
|
||||||
|
|
||||||
list->resetEventList();
|
list->resetEventList();
|
||||||
|
|
||||||
switch (engineConfiguration->ignitionMode) {
|
switch (CONFIG(ignitionMode)) {
|
||||||
case IM_ONE_COIL:
|
case IM_ONE_COIL:
|
||||||
for (int i = 0; i < engineConfiguration->cylindersCount; i++) {
|
for (int i = 0; i < CONFIG(cylindersCount); i++) {
|
||||||
// todo: extract method
|
// todo: extract method
|
||||||
float localAdvance = advance
|
float localAdvance = advance
|
||||||
+ (float) engineConfiguration->engineCycle * i / engineConfiguration->cylindersCount;
|
+ (float) CONFIG(engineCycle) * i / CONFIG(cylindersCount);
|
||||||
|
|
||||||
registerSparkEvent(&engine->triggerShape, list, SPARKOUT_1_OUTPUT, localAdvance,
|
registerSparkEvent(list, SPARKOUT_1_OUTPUT, localAdvance,
|
||||||
dwellAngle PASS_ENGINE_PARAMETER);
|
dwellAngle PASS_ENGINE_PARAMETER);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case IM_WASTED_SPARK:
|
case IM_WASTED_SPARK:
|
||||||
for (int i = 0; i < engineConfiguration->cylindersCount; i++) {
|
for (int i = 0; i < CONFIG(cylindersCount); i++) {
|
||||||
float localAdvance = advance
|
float localAdvance = advance
|
||||||
+ (float) engineConfiguration->engineCycle * i / engineConfiguration->cylindersCount;
|
+ (float) CONFIG(engineCycle) * i / CONFIG(cylindersCount);
|
||||||
|
|
||||||
int wastedIndex = i % (engineConfiguration->cylindersCount / 2);
|
int wastedIndex = i % (CONFIG(cylindersCount) / 2);
|
||||||
|
|
||||||
int id = getCylinderId(engineConfiguration->firingOrder, wastedIndex) - 1;
|
int id = getCylinderId(CONFIG(firingOrder), wastedIndex) - 1;
|
||||||
io_pin_e ioPin = (io_pin_e) (SPARKOUT_1_OUTPUT + id);
|
io_pin_e ioPin = (io_pin_e) (SPARKOUT_1_OUTPUT + id);
|
||||||
|
|
||||||
registerSparkEvent(&engine->triggerShape, list, ioPin, localAdvance,
|
registerSparkEvent(list, ioPin, localAdvance, dwellAngle PASS_ENGINE_PARAMETER);
|
||||||
dwellAngle PASS_ENGINE_PARAMETER);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case IM_INDIVIDUAL_COILS:
|
case IM_INDIVIDUAL_COILS:
|
||||||
for (int i = 0; i < engineConfiguration->cylindersCount; i++) {
|
for (int i = 0; i < CONFIG(cylindersCount); i++) {
|
||||||
float localAdvance = advance
|
float localAdvance = advance
|
||||||
+ (float) engineConfiguration->engineCycle * i / engineConfiguration->cylindersCount;
|
+ (float) CONFIG(engineCycle) * i / CONFIG(cylindersCount);
|
||||||
|
|
||||||
io_pin_e pin = (io_pin_e) ((int) SPARKOUT_1_OUTPUT + getCylinderId(engineConfiguration->firingOrder, i) - 1);
|
io_pin_e pin = (io_pin_e) ((int) SPARKOUT_1_OUTPUT + getCylinderId(CONFIG(firingOrder), i) - 1);
|
||||||
registerSparkEvent(&engine->triggerShape, list, pin, localAdvance,
|
registerSparkEvent(list, pin, localAdvance,
|
||||||
dwellAngle PASS_ENGINE_PARAMETER);
|
dwellAngle PASS_ENGINE_PARAMETER);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -156,7 +156,7 @@ void initializeIgnitionActions(float advance, float dwellAngle,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FuelSchedule::registerInjectionEvent(trigger_shape_s *s, io_pin_e pin, float angle,
|
void FuelSchedule::registerInjectionEvent(io_pin_e pin, float angle,
|
||||||
bool_t isSimultanious DECLARE_ENGINE_PARAMETER_S) {
|
bool_t isSimultanious DECLARE_ENGINE_PARAMETER_S) {
|
||||||
ActuatorEventList *list = &events;
|
ActuatorEventList *list = &events;
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ void FuelSchedule::registerInjectionEvent(trigger_shape_s *s, io_pin_e pin, floa
|
||||||
|
|
||||||
ev->isSimultanious = isSimultanious;
|
ev->isSimultanious = isSimultanious;
|
||||||
|
|
||||||
efiAssertVoid(s->getSize() > 0, "uninitialized trigger_shape_s");
|
efiAssertVoid(TRIGGER_SHAPE(getSize()) > 0, "uninitialized trigger_shape_s");
|
||||||
|
|
||||||
if (ev == NULL) {
|
if (ev == NULL) {
|
||||||
// error already reported
|
// error already reported
|
||||||
|
@ -178,7 +178,7 @@ void FuelSchedule::registerInjectionEvent(trigger_shape_s *s, io_pin_e pin, floa
|
||||||
}
|
}
|
||||||
ev->actuator = actuator;
|
ev->actuator = actuator;
|
||||||
|
|
||||||
findTriggerPosition(s, &ev->position, angle PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&ev->position, angle PASS_ENGINE_PARAMETER);
|
||||||
hasEvents[ev->position.eventIndex] = true;
|
hasEvents[ev->position.eventIndex] = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -203,7 +203,7 @@ void FuelSchedule::addFuelEvents(trigger_shape_s *s, injection_mode_e mode DECLA
|
||||||
io_pin_e pin = INJECTOR_PIN_BY_INDEX(getCylinderId(engineConfiguration->firingOrder, i) - 1);
|
io_pin_e pin = INJECTOR_PIN_BY_INDEX(getCylinderId(engineConfiguration->firingOrder, i) - 1);
|
||||||
float angle = baseAngle
|
float angle = baseAngle
|
||||||
+ (float) engineConfiguration->engineCycle * i / engineConfiguration->cylindersCount;
|
+ (float) engineConfiguration->engineCycle * i / engineConfiguration->cylindersCount;
|
||||||
registerInjectionEvent(s, pin, angle, false PASS_ENGINE_PARAMETER);
|
registerInjectionEvent(pin, angle, false PASS_ENGINE_PARAMETER);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case IM_SIMULTANEOUS:
|
case IM_SIMULTANEOUS:
|
||||||
|
@ -215,7 +215,7 @@ void FuelSchedule::addFuelEvents(trigger_shape_s *s, injection_mode_e mode DECLA
|
||||||
* We do not need injector pin here because we will control all injectors
|
* We do not need injector pin here because we will control all injectors
|
||||||
* simultaniously
|
* simultaniously
|
||||||
*/
|
*/
|
||||||
registerInjectionEvent(s, IO_INVALID, angle, true PASS_ENGINE_PARAMETER);
|
registerInjectionEvent(IO_INVALID, angle, true PASS_ENGINE_PARAMETER);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case IM_BATCH:
|
case IM_BATCH:
|
||||||
|
@ -224,13 +224,13 @@ void FuelSchedule::addFuelEvents(trigger_shape_s *s, injection_mode_e mode DECLA
|
||||||
io_pin_e pin = INJECTOR_PIN_BY_INDEX(index);
|
io_pin_e pin = INJECTOR_PIN_BY_INDEX(index);
|
||||||
float angle = baseAngle
|
float angle = baseAngle
|
||||||
+ i * (float) engineConfiguration->engineCycle / engineConfiguration->cylindersCount;
|
+ i * (float) engineConfiguration->engineCycle / engineConfiguration->cylindersCount;
|
||||||
registerInjectionEvent(s, pin, angle, false PASS_ENGINE_PARAMETER);
|
registerInjectionEvent(pin, angle, false PASS_ENGINE_PARAMETER);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* also fire the 2nd half of the injectors so that we can implement a batch mode on individual wires
|
* also fire the 2nd half of the injectors so that we can implement a batch mode on individual wires
|
||||||
*/
|
*/
|
||||||
pin = INJECTOR_PIN_BY_INDEX(index + (engineConfiguration->cylindersCount / 2));
|
pin = INJECTOR_PIN_BY_INDEX(index + (engineConfiguration->cylindersCount / 2));
|
||||||
registerInjectionEvent(s, pin, angle, false PASS_ENGINE_PARAMETER);
|
registerInjectionEvent(pin, angle, false PASS_ENGINE_PARAMETER);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -256,21 +256,16 @@ float getSparkDwellMsT(int rpm DECLARE_ENGINE_PARAMETER_S) {
|
||||||
return interpolate2d(rpm, engineConfiguration->sparkDwellBins, engineConfiguration->sparkDwell, DWELL_CURVE_SIZE);
|
return interpolate2d(rpm, engineConfiguration->sparkDwellBins, engineConfiguration->sparkDwell, DWELL_CURVE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
void findTriggerPosition(event_trigger_position_s *position,
|
||||||
* Trigger event count equals engine cycle event count if we have a cam sensor.
|
|
||||||
* Two trigger cycles make one engine cycle in case of a four stroke engine If we only have a cranksensor.
|
|
||||||
*/
|
|
||||||
int getEngineCycleEventCount2(operation_mode_e mode, trigger_shape_s * s) {
|
|
||||||
return mode == FOUR_STROKE_CAM_SENSOR ? s->getSize() : 2 * s->getSize();
|
|
||||||
}
|
|
||||||
|
|
||||||
void findTriggerPosition(trigger_shape_s * s, event_trigger_position_s *position,
|
|
||||||
float angleOffset DECLARE_ENGINE_PARAMETER_S) {
|
float angleOffset DECLARE_ENGINE_PARAMETER_S) {
|
||||||
|
|
||||||
angleOffset += engineConfiguration->globalTriggerAngleOffset;
|
angleOffset += CONFIG(globalTriggerAngleOffset);
|
||||||
fixAngle(angleOffset);
|
fixAngle(angleOffset);
|
||||||
|
|
||||||
int engineCycleEventCount = getEngineCycleEventCount2(getOperationMode(engineConfiguration), s);
|
/**
|
||||||
|
* Here we rely on this to be pre-calculated, that's a performance optimization
|
||||||
|
*/
|
||||||
|
int engineCycleEventCount = engine->engineCycleEventCount;
|
||||||
|
|
||||||
efiAssertVoid(engineCycleEventCount > 0, "engineCycleEventCount");
|
efiAssertVoid(engineCycleEventCount > 0, "engineCycleEventCount");
|
||||||
|
|
||||||
|
@ -282,25 +277,23 @@ void findTriggerPosition(trigger_shape_s * s, event_trigger_position_s *position
|
||||||
* Let's find the last trigger angle which is less or equal to the desired angle
|
* Let's find the last trigger angle which is less or equal to the desired angle
|
||||||
* todo: extract binary search as template method?
|
* todo: extract binary search as template method?
|
||||||
*/
|
*/
|
||||||
|
float eventAngle;
|
||||||
while (true) {
|
while (true) {
|
||||||
middle = (left + right) / 2;
|
middle = (left + right) / 2;
|
||||||
|
eventAngle = TRIGGER_SHAPE(eventAngles[middle]);
|
||||||
|
|
||||||
if (middle == left) {
|
if (middle == left) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (angleOffset < eventAngle) {
|
||||||
if (angleOffset < s->eventAngles[middle]) {
|
|
||||||
right = middle;
|
right = middle;
|
||||||
} else if (angleOffset > s->eventAngles[middle]) {
|
} else if (angleOffset > eventAngle) {
|
||||||
left = middle;
|
left = middle;
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
float eventAngle = s->eventAngles[middle];
|
|
||||||
|
|
||||||
if (angleOffset < eventAngle) {
|
if (angleOffset < eventAngle) {
|
||||||
firmwareError("angle constraint violation in registerActuatorEventExt(): %f/%f", angleOffset, eventAngle);
|
firmwareError("angle constraint violation in registerActuatorEventExt(): %f/%f", angleOffset, eventAngle);
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
|
|
||||||
#define INJECTOR_PIN_BY_INDEX(index) (io_pin_e) ((int) INJECTOR_1_OUTPUT + (index))
|
#define INJECTOR_PIN_BY_INDEX(index) (io_pin_e) ((int) INJECTOR_1_OUTPUT + (index))
|
||||||
|
|
||||||
void findTriggerPosition(trigger_shape_s * s,
|
void findTriggerPosition(
|
||||||
event_trigger_position_s *position, float angleOffset DECLARE_ENGINE_PARAMETER_S);
|
event_trigger_position_s *position, float angleOffset DECLARE_ENGINE_PARAMETER_S);
|
||||||
|
|
||||||
int isInjectionEnabled(engine_configuration_s *engineConfiguration);
|
int isInjectionEnabled(engine_configuration_s *engineConfiguration);
|
||||||
|
|
|
@ -99,11 +99,3 @@ void setOutputPinValue(io_pin_e pin, int logicValue) {
|
||||||
doSetOutputPinValue(pin, logicValue);
|
doSetOutputPinValue(pin, logicValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool isPinAssigned(io_pin_e pin) {
|
|
||||||
#if EFI_PROD_CODE
|
|
||||||
return outputs[pin].port != GPIO_NULL;
|
|
||||||
#else
|
|
||||||
return true;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -76,9 +76,13 @@ extern "C"
|
||||||
|
|
||||||
int getOutputPinValue(io_pin_e pin);
|
int getOutputPinValue(io_pin_e pin);
|
||||||
void setOutputPinValue(io_pin_e pin, int logicValue);
|
void setOutputPinValue(io_pin_e pin, int logicValue);
|
||||||
bool isPinAssigned(io_pin_e pin);
|
|
||||||
const char *getPinName(io_pin_e io_pin);
|
const char *getPinName(io_pin_e io_pin);
|
||||||
|
|
||||||
|
#if EFI_PROD_CODE
|
||||||
|
#define isPinAssigned(pin) (outputs[(pin)].port != GPIO_NULL)
|
||||||
|
#else
|
||||||
|
#define isPinAssigned(pin) (true)
|
||||||
|
#endif
|
||||||
|
|
||||||
#if EFI_PROD_CODE
|
#if EFI_PROD_CODE
|
||||||
#define doSetOutputPinValue(pin, logicValue) { \
|
#define doSetOutputPinValue(pin, logicValue) { \
|
||||||
|
|
|
@ -219,8 +219,7 @@ static ALWAYS_INLINE void handleSparkEvent(uint32_t eventIndex, IgnitionEvent *i
|
||||||
* TODO: improve precision
|
* TODO: improve precision
|
||||||
*/
|
*/
|
||||||
|
|
||||||
findTriggerPosition(&engine->triggerShape, &iEvent->sparkPosition,
|
findTriggerPosition(&iEvent->sparkPosition, iEvent->advance PASS_ENGINE_PARAMETER);
|
||||||
iEvent->advance PASS_ENGINE_PARAMETER);
|
|
||||||
|
|
||||||
if (iEvent->sparkPosition.eventIndex == eventIndex) {
|
if (iEvent->sparkPosition.eventIndex == eventIndex) {
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -50,9 +50,6 @@ int trigger_shape_s::getTriggerShapeSynchPointIndex() {
|
||||||
return triggerShapeSynchPointIndex;
|
return triggerShapeSynchPointIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
// todo: clean-up!
|
|
||||||
int getEngineCycleEventCount2(operation_mode_e mode, trigger_shape_s * s);
|
|
||||||
|
|
||||||
void trigger_shape_s::calculateTriggerSynchPoint(engine_configuration_s *engineConfiguration, Engine *engine) {
|
void trigger_shape_s::calculateTriggerSynchPoint(engine_configuration_s *engineConfiguration, Engine *engine) {
|
||||||
trigger_config_s const*triggerConfig = &engineConfiguration->triggerConfig;
|
trigger_config_s const*triggerConfig = &engineConfiguration->triggerConfig;
|
||||||
setTriggerShapeSynchPointIndex(engineConfiguration, findTriggerZeroEventIndex(this, triggerConfig), engine);
|
setTriggerShapeSynchPointIndex(engineConfiguration, findTriggerZeroEventIndex(this, triggerConfig), engine);
|
||||||
|
@ -61,16 +58,16 @@ void trigger_shape_s::calculateTriggerSynchPoint(engine_configuration_s *engineC
|
||||||
void trigger_shape_s::setTriggerShapeSynchPointIndex(engine_configuration_s *engineConfiguration, int triggerShapeSynchPointIndex, Engine *engine) {
|
void trigger_shape_s::setTriggerShapeSynchPointIndex(engine_configuration_s *engineConfiguration, int triggerShapeSynchPointIndex, Engine *engine) {
|
||||||
this->triggerShapeSynchPointIndex = triggerShapeSynchPointIndex;
|
this->triggerShapeSynchPointIndex = triggerShapeSynchPointIndex;
|
||||||
|
|
||||||
int engineCycleEventCount = getEngineCycleEventCount2(operationMode, this);
|
engine->engineCycleEventCount = getLength();
|
||||||
|
|
||||||
float firstAngle = getAngle(triggerShapeSynchPointIndex);
|
float firstAngle = getAngle(triggerShapeSynchPointIndex);
|
||||||
|
|
||||||
for (int i = 0; i < engineCycleEventCount; i++) {
|
for (int i = 0; i < engine->engineCycleEventCount; i++) {
|
||||||
if (i == 0) {
|
if (i == 0) {
|
||||||
// explicit check for zero to avoid issues where logical zero is not exactly zero due to float nature
|
// explicit check for zero to avoid issues where logical zero is not exactly zero due to float nature
|
||||||
eventAngles[i] = 0;
|
eventAngles[i] = 0;
|
||||||
} else {
|
} else {
|
||||||
float angle = getAngle((triggerShapeSynchPointIndex + i) % engineCycleEventCount) - firstAngle;
|
float angle = getAngle((triggerShapeSynchPointIndex + i) % engine->engineCycleEventCount) - firstAngle;
|
||||||
fixAngle(angle);
|
fixAngle(angle);
|
||||||
eventAngles[i] = angle;
|
eventAngles[i] = angle;
|
||||||
}
|
}
|
||||||
|
@ -175,6 +172,10 @@ void TriggerState::clear() {
|
||||||
current_index = 0;
|
current_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Trigger event count equals engine cycle event count if we have a cam sensor.
|
||||||
|
* Two trigger cycles make one engine cycle in case of a four stroke engine If we only have a cranksensor.
|
||||||
|
*/
|
||||||
uint32_t trigger_shape_s::getLength() const {
|
uint32_t trigger_shape_s::getLength() const {
|
||||||
return operationMode == FOUR_STROKE_CAM_SENSOR ? getSize() : 2 * getSize();
|
return operationMode == FOUR_STROKE_CAM_SENSOR ? getSize() : 2 * getSize();
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,7 +72,8 @@ typedef Thread thread_t;
|
||||||
#define EXTERN_ENGINE extern Engine *engine; \
|
#define EXTERN_ENGINE extern Engine *engine; \
|
||||||
extern engine_configuration_s *engineConfiguration; \
|
extern engine_configuration_s *engineConfiguration; \
|
||||||
extern board_configuration_s *boardConfiguration; \
|
extern board_configuration_s *boardConfiguration; \
|
||||||
extern persistent_config_container_s persistentState
|
extern persistent_config_container_s persistentState; \
|
||||||
|
extern Engine _engine
|
||||||
|
|
||||||
#define DECLARE_ENGINE_PARAMETER_F void
|
#define DECLARE_ENGINE_PARAMETER_F void
|
||||||
#define DECLARE_ENGINE_PARAMETER_S
|
#define DECLARE_ENGINE_PARAMETER_S
|
||||||
|
@ -84,6 +85,6 @@ typedef Thread thread_t;
|
||||||
* optimization
|
* optimization
|
||||||
*/
|
*/
|
||||||
#define CONFIG(x) persistentState.persistentConfiguration.engineConfiguration.x
|
#define CONFIG(x) persistentState.persistentConfiguration.engineConfiguration.x
|
||||||
|
#define TRIGGER_SHAPE(x) _engine.triggerShape.x
|
||||||
|
|
||||||
#endif /* GLOBAL_H_ */
|
#endif /* GLOBAL_H_ */
|
||||||
|
|
|
@ -46,5 +46,6 @@ class Engine;
|
||||||
#define PASS_ENGINE_PARAMETER , engine, engineConfiguration
|
#define PASS_ENGINE_PARAMETER , engine, engineConfiguration
|
||||||
|
|
||||||
#define CONFIG(x) engineConfiguration->x
|
#define CONFIG(x) engineConfiguration->x
|
||||||
|
#define TRIGGER_SHAPE(x) engine->triggerShape.x
|
||||||
|
|
||||||
#endif /* GLOBAL_H_ */
|
#endif /* GLOBAL_H_ */
|
||||||
|
|
|
@ -179,14 +179,14 @@ void testAngleResolver(void) {
|
||||||
|
|
||||||
ae.resetEventList();
|
ae.resetEventList();
|
||||||
printf("*************************************************** testAngleResolver 0\r\n");
|
printf("*************************************************** testAngleResolver 0\r\n");
|
||||||
findTriggerPosition(ts, &ae.getNextActuatorEvent()->position, 53 - 175 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&ae.getNextActuatorEvent()->position, 53 - 175 PASS_ENGINE_PARAMETER);
|
||||||
assertEqualsM("size", 1, ae.size);
|
assertEqualsM("size", 1, ae.size);
|
||||||
assertEquals(1, ae.events[0].position.eventIndex);
|
assertEquals(1, ae.events[0].position.eventIndex);
|
||||||
assertEquals(3.1588, ae.events[0].position.angleOffset);
|
assertEquals(3.1588, ae.events[0].position.angleOffset);
|
||||||
|
|
||||||
printf("*************************************************** testAngleResolver 2\r\n");
|
printf("*************************************************** testAngleResolver 2\r\n");
|
||||||
ae.resetEventList();
|
ae.resetEventList();
|
||||||
findTriggerPosition(ts, &ae.getNextActuatorEvent()->position, 51 + 180 - 175 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&ae.getNextActuatorEvent()->position, 51 + 180 - 175 PASS_ENGINE_PARAMETER);
|
||||||
assertEquals(3, ae.events[0].position.eventIndex);
|
assertEquals(3, ae.events[0].position.eventIndex);
|
||||||
assertEquals(2.955, ae.events[0].position.angleOffset);
|
assertEquals(2.955, ae.events[0].position.angleOffset);
|
||||||
}
|
}
|
||||||
|
|
|
@ -123,13 +123,13 @@ static void test1995FordInline6TriggerDecoder(void) {
|
||||||
|
|
||||||
event_trigger_position_s position;
|
event_trigger_position_s position;
|
||||||
assertEqualsM("globalTriggerAngleOffset", 0, engineConfiguration->globalTriggerAngleOffset);
|
assertEqualsM("globalTriggerAngleOffset", 0, engineConfiguration->globalTriggerAngleOffset);
|
||||||
findTriggerPosition(shape, &position, 0 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 0 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 0, 0);
|
assertTriggerPosition(&position, 0, 0);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 200 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 200 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 3, 20);
|
assertTriggerPosition(&position, 3, 20);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 360 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 360 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 6, 0);
|
assertTriggerPosition(&position, 6, 0);
|
||||||
|
|
||||||
|
|
||||||
|
@ -251,39 +251,39 @@ void testMazdaMianaNbDecoder(void) {
|
||||||
|
|
||||||
event_trigger_position_s position;
|
event_trigger_position_s position;
|
||||||
assertEqualsM("globalTriggerAngleOffset", 276, ec->globalTriggerAngleOffset);
|
assertEqualsM("globalTriggerAngleOffset", 276, ec->globalTriggerAngleOffset);
|
||||||
findTriggerPosition(shape, &position, 0 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 0 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 7, 46);
|
assertTriggerPosition(&position, 7, 46);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 180 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 180 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 13, 46);
|
assertTriggerPosition(&position, 13, 46);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 360 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 360 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 17, 46);
|
assertTriggerPosition(&position, 17, 46);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 444 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 444 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 0, 0);
|
assertTriggerPosition(&position, 0, 0);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 444.1 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 444.1 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 0, 0.1);
|
assertTriggerPosition(&position, 0, 0.1);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 445 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 445 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 0, 1);
|
assertTriggerPosition(&position, 0, 1);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 494 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 494 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 3, 0);
|
assertTriggerPosition(&position, 3, 0);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, 719 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 719 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 7, 45);
|
assertTriggerPosition(&position, 7, 45);
|
||||||
|
|
||||||
ec->globalTriggerAngleOffset = 0;
|
ec->globalTriggerAngleOffset = 0;
|
||||||
findTriggerPosition(shape, &position, 0 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 0 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 0, 0);
|
assertTriggerPosition(&position, 0, 0);
|
||||||
|
|
||||||
ec->globalTriggerAngleOffset = 10;
|
ec->globalTriggerAngleOffset = 10;
|
||||||
findTriggerPosition(shape, &position, 0 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, 0 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 0, 10);
|
assertTriggerPosition(&position, 0, 10);
|
||||||
|
|
||||||
findTriggerPosition(shape, &position, -10 PASS_ENGINE_PARAMETER);
|
findTriggerPosition(&position, -10 PASS_ENGINE_PARAMETER);
|
||||||
assertTriggerPosition(&position, 0, 0);
|
assertTriggerPosition(&position, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -99,4 +99,4 @@ typedef EventListener event_listener_t;
|
||||||
#define PASS_ENGINE_PARAMETER
|
#define PASS_ENGINE_PARAMETER
|
||||||
|
|
||||||
#define CONFIG(x) persistentState.persistentConfiguration.engineConfiguration.x
|
#define CONFIG(x) persistentState.persistentConfiguration.engineConfiguration.x
|
||||||
|
#define TRIGGER_SHAPE(x) engine->triggerShape.x
|
||||||
|
|
Loading…
Reference in New Issue