auto-sync
This commit is contained in:
parent
71c69f3ac3
commit
e6dc0ab05a
|
@ -265,7 +265,7 @@ void chDbgStackOverflowPanic(Thread *otp) {
|
||||||
strcpy(panicMessage, "stack overflow: ");
|
strcpy(panicMessage, "stack overflow: ");
|
||||||
#if defined(CH_USE_REGISTRY) || defined(__DOXYGEN__)
|
#if defined(CH_USE_REGISTRY) || defined(__DOXYGEN__)
|
||||||
int p_name_len = strlen(otp->p_name);
|
int p_name_len = strlen(otp->p_name);
|
||||||
if (p_name_len < sizeof(panicMessage - 2))
|
if (p_name_len < sizeof(panicMessage) - 2)
|
||||||
strcat(panicMessage, otp->p_name);
|
strcat(panicMessage, otp->p_name);
|
||||||
#endif
|
#endif
|
||||||
chDbgPanic3(panicMessage, __FILE__, __LINE__);
|
chDbgPanic3(panicMessage, __FILE__, __LINE__);
|
||||||
|
|
|
@ -581,7 +581,7 @@ extern fuel_Map3D_t fuelMap;
|
||||||
static void assertEvent(const char *msg, int index, void *callback, efitime_t start, efitime_t momentX, long param) {
|
static void assertEvent(const char *msg, int index, void *callback, efitime_t start, efitime_t momentX, long param) {
|
||||||
assertTrueM(msg, schedulingQueue.size() > index);
|
assertTrueM(msg, schedulingQueue.size() > index);
|
||||||
scheduling_s *ev = schedulingQueue.getForUnitText(index);
|
scheduling_s *ev = schedulingQueue.getForUnitText(index);
|
||||||
assertREqualsM(msg, (void*)ev->callback, callback);
|
assertTrueM(msg, (void*)ev->callback == (void*) callback);
|
||||||
assertEqualsM(msg, momentX, ev->momentX - start);
|
assertEqualsM(msg, momentX, ev->momentX - start);
|
||||||
assertEqualsLM(msg, param, (long)ev->param);
|
assertEqualsLM(msg, param, (long)ev->param);
|
||||||
}
|
}
|
||||||
|
@ -594,6 +594,12 @@ static void assertInjectorDownEvent(const char *msg, int eventIndex, efitime_t m
|
||||||
assertEvent(msg, eventIndex, (void*)seTurnPinLow, timeNow, momentX, (long)&enginePins.injectors[injectorIndex]);
|
assertEvent(msg, eventIndex, (void*)seTurnPinLow, timeNow, momentX, (long)&enginePins.injectors[injectorIndex]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void assertInjectionEvent(InjectionEvent *ev, int injectorIndex, int eventIndex, angle_t angleOffset) {
|
||||||
|
assertEqualsM("inj index", injectorIndex, ev->injectorIndex);
|
||||||
|
assertEqualsM("event index", eventIndex, ev->injectionStart.eventIndex);
|
||||||
|
assertEqualsM("event offset", angleOffset, ev->injectionStart.angleOffset);
|
||||||
|
}
|
||||||
|
|
||||||
void testFuelSchedulerBug299(void) {
|
void testFuelSchedulerBug299(void) {
|
||||||
printf("*************************************************** testFuelSchedulerBug299\r\n");
|
printf("*************************************************** testFuelSchedulerBug299\r\n");
|
||||||
EngineTestHelper eth(TEST_ENGINE);
|
EngineTestHelper eth(TEST_ENGINE);
|
||||||
|
@ -777,6 +783,13 @@ void testFuelSchedulerBug299(void) {
|
||||||
engine->periodicFastCallback(PASS_ENGINE_PARAMETER_F);
|
engine->periodicFastCallback(PASS_ENGINE_PARAMETER_F);
|
||||||
|
|
||||||
|
|
||||||
|
FuelSchedule * t = ENGINE(engineConfiguration2)->injectionEvents;
|
||||||
|
assertEqualsM("t.s", 4, t->injectionEvents.size);
|
||||||
|
assertInjectionEvent(&t->injectionEvents.elements[0], 0, 0, 225);
|
||||||
|
assertInjectionEvent(&t->injectionEvents.elements[1], 1, 0, 405);
|
||||||
|
assertInjectionEvent(&t->injectionEvents.elements[2], 0, 0, 585);
|
||||||
|
assertInjectionEvent(&t->injectionEvents.elements[3], 1, 0, 45);
|
||||||
|
|
||||||
timeNow += MS2US(20);
|
timeNow += MS2US(20);
|
||||||
eth.firePrimaryTriggerRise();
|
eth.firePrimaryTriggerRise();
|
||||||
assertEqualsM("qs#2", 8, schedulingQueue.size());
|
assertEqualsM("qs#2", 8, schedulingQueue.size());
|
||||||
|
@ -787,11 +800,11 @@ void testFuelSchedulerBug299(void) {
|
||||||
assertInjectorUpEvent("6@0", 0, MS2US(-17.5), 1);
|
assertInjectorUpEvent("6@0", 0, MS2US(-17.5), 1);
|
||||||
assertInjectorDownEvent("6@1", 1, MS2US(-10.0), 0);
|
assertInjectorDownEvent("6@1", 1, MS2US(-10.0), 0);
|
||||||
assertInjectorUpEvent("6@2", 2, MS2US(-7.5), 0);
|
assertInjectorUpEvent("6@2", 2, MS2US(-7.5), 0);
|
||||||
// assertInjectorUpEvent("6@3", 3, MS2US(0), 1);
|
assertInjectorDownEvent("6@3", 3, MS2US(0), 1);
|
||||||
// assertInjectorUpEvent("6@4", 4, MS2US(2.5), 1);
|
assertInjectorUpEvent("6@4", 4, MS2US(2.5), 1);
|
||||||
// assertInjectorDownEvent("6@5", 5, MS2US(10.0), 0);
|
assertInjectorDownEvent("6@5", 5, MS2US(10.0), 0);
|
||||||
// assertInjectorUpEvent("6@6", 6, MS2US(12.5), 0);
|
assertInjectorUpEvent("6@6", 6, MS2US(12.5), 0);
|
||||||
// assertInjectorDownEvent("6@7", 7, MS2US(20.0), 1);
|
assertInjectorDownEvent("6@7", 7, MS2US(20.0), 1);
|
||||||
|
|
||||||
assertEqualsM("exec#7", 4, schedulingQueue.executeAll(timeNow));
|
assertEqualsM("exec#7", 4, schedulingQueue.executeAll(timeNow));
|
||||||
|
|
||||||
|
@ -805,10 +818,10 @@ void testFuelSchedulerBug299(void) {
|
||||||
// inj #0 |........|##......|........|........|........|........|........|
|
// inj #0 |........|##......|........|........|........|........|........|
|
||||||
// inj #1 |..######|########|........|........|........|........|........|
|
// inj #1 |..######|########|........|........|........|........|........|
|
||||||
assertInjectorUpEvent("7@0", 0, MS2US(-17.5), 1);
|
assertInjectorUpEvent("7@0", 0, MS2US(-17.5), 1);
|
||||||
// assertInjectorUpEvent("7@1", 1, MS2US(-10.0), 0);
|
assertInjectorDownEvent("7@1", 1, MS2US(-10.0), 0);
|
||||||
// assertInjectorDownEvent("7@2", 2, MS2US(-7.5), 0);
|
assertInjectorUpEvent("7@2", 2, MS2US(-7.5), 0);
|
||||||
// assertInjectorUpEvent("7@3", 3, MS2US(0), 1);
|
assertInjectorDownEvent("7@3", 3, MS2US(0), 1);
|
||||||
// assertEqualsM("exec#6", 4, schedulingQueue.executeAll(timeNow));
|
assertEqualsM("exec#6", 4, schedulingQueue.executeAll(timeNow));
|
||||||
|
|
||||||
|
|
||||||
timeNow += MS2US(20);
|
timeNow += MS2US(20);
|
||||||
|
|
Loading…
Reference in New Issue