2021-07-02 11:56:12 -07:00
|
|
|
/*
|
|
|
|
* @file test_nissan_vq_vvt.cpp
|
|
|
|
*
|
|
|
|
* Created on: Jul 2, 2021
|
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2021
|
|
|
|
*/
|
|
|
|
|
2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
2021-07-02 14:32:29 -07:00
|
|
|
#include "trigger_nissan.h"
|
2021-07-03 09:43:01 -07:00
|
|
|
#include "nissan_vq.h"
|
2021-07-02 14:32:29 -07:00
|
|
|
|
|
|
|
class TriggerCallback {
|
|
|
|
public:
|
|
|
|
Engine *engine;
|
2021-07-02 16:23:37 -07:00
|
|
|
int toothIndex;
|
2021-07-02 14:32:29 -07:00
|
|
|
TriggerWaveform *form;
|
2021-07-02 16:23:37 -07:00
|
|
|
bool isVvt;
|
2021-07-03 08:08:22 -07:00
|
|
|
int vvtBankIndex;
|
2021-09-05 02:56:59 -07:00
|
|
|
scheduling_s sched;
|
2021-07-02 14:32:29 -07:00
|
|
|
};
|
|
|
|
|
2021-07-03 07:15:41 -07:00
|
|
|
static void func(TriggerCallback *callback) {
|
2021-07-02 16:23:37 -07:00
|
|
|
int formIndex = callback->toothIndex % callback->form->getSize();
|
2021-07-02 14:32:29 -07:00
|
|
|
Engine *engine = callback->engine;
|
|
|
|
|
2021-11-21 01:56:07 -08:00
|
|
|
|
2022-09-10 23:57:35 -07:00
|
|
|
TriggerValue value = callback->form->wave.getChannelState(0, formIndex);
|
2021-07-02 16:23:37 -07:00
|
|
|
efitick_t nowNt = getTimeNowNt();
|
|
|
|
if (callback->isVvt) {
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(value, nowNt, callback->vvtBankIndex * CAMS_PER_BANK);
|
2021-07-02 14:32:29 -07:00
|
|
|
} else {
|
2022-09-10 23:57:35 -07:00
|
|
|
handleShaftSignal(0, value == TriggerValue::RISE, nowNt);
|
2021-07-02 14:32:29 -07:00
|
|
|
}
|
2021-07-02 16:23:37 -07:00
|
|
|
}
|
|
|
|
|
2021-07-02 14:32:29 -07:00
|
|
|
|
2021-07-03 07:15:41 -07:00
|
|
|
static void scheduleTriggerEvents(TriggerWaveform *shape,
|
|
|
|
float timeScale,
|
|
|
|
int count,
|
|
|
|
bool isVvt,
|
2021-07-03 08:08:22 -07:00
|
|
|
int vvtBankIndex,
|
2021-09-05 02:56:59 -07:00
|
|
|
int vvtOffset,
|
2021-11-16 01:15:29 -08:00
|
|
|
std::vector<std::shared_ptr<TriggerCallback>>& ptrs) {
|
2021-07-02 16:23:37 -07:00
|
|
|
int totalIndex = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* yet another approach to trigger testing: let's schedule a huge list of events from heap
|
|
|
|
* and then execute those one
|
|
|
|
*/
|
2021-07-02 16:57:26 -07:00
|
|
|
for (int r = 0; r < count; r++) {
|
2021-07-03 08:08:22 -07:00
|
|
|
for (size_t i = 0; i < shape->getSize(); i++) {
|
2021-07-02 17:28:15 -07:00
|
|
|
float angle = vvtOffset + shape->getAngle(totalIndex);
|
2021-09-05 02:56:59 -07:00
|
|
|
|
|
|
|
std::shared_ptr<TriggerCallback> param = std::make_shared<TriggerCallback>();
|
|
|
|
ptrs.push_back(param);
|
|
|
|
|
2021-07-02 16:23:37 -07:00
|
|
|
param->engine = engine;
|
|
|
|
param->toothIndex = totalIndex;
|
|
|
|
param->form = shape;
|
|
|
|
param->isVvt = isVvt;
|
2021-07-03 08:08:22 -07:00
|
|
|
param->vvtBankIndex = vvtBankIndex;
|
2021-07-02 16:23:37 -07:00
|
|
|
|
2024-07-11 16:32:55 -07:00
|
|
|
efitick_t timeNt = efitick_t{US2NT(timeScale * 1000 * angle)};
|
|
|
|
|
2024-07-11 17:03:13 -07:00
|
|
|
engine->scheduler.schedule("test", ¶m->sched, timeNt, { func, param.get() });
|
2021-07-02 16:23:37 -07:00
|
|
|
totalIndex++;
|
|
|
|
}
|
|
|
|
}
|
2021-07-02 14:32:29 -07:00
|
|
|
}
|
2021-07-02 11:56:12 -07:00
|
|
|
|
2021-07-02 16:23:37 -07:00
|
|
|
|
2021-07-02 11:56:12 -07:00
|
|
|
TEST(nissan, vq_vvt) {
|
2021-09-05 02:56:59 -07:00
|
|
|
// hold a reference to the heap allocated scheduling events until the test is done
|
|
|
|
std::vector<std::shared_ptr<TriggerCallback>> ptrs;
|
|
|
|
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth (engine_type_e::HELLEN_121_NISSAN_6_CYL);
|
2022-04-23 06:51:47 -07:00
|
|
|
engineConfiguration->isFasterEngineSpinUpEnabled = false;
|
2021-07-02 15:33:32 -07:00
|
|
|
engineConfiguration->isIgnitionEnabled = false;
|
|
|
|
engineConfiguration->isInjectionEnabled = false;
|
2021-07-02 14:32:29 -07:00
|
|
|
|
2021-07-05 19:17:26 -07:00
|
|
|
int cyclesCount = 48;
|
2021-07-02 16:57:26 -07:00
|
|
|
|
2021-07-02 14:32:29 -07:00
|
|
|
{
|
2021-07-02 15:33:32 -07:00
|
|
|
static TriggerWaveform crank;
|
2021-07-16 21:46:24 -07:00
|
|
|
initializeNissanVQ35crank(&crank);
|
2021-07-02 14:32:29 -07:00
|
|
|
|
2021-07-03 07:15:41 -07:00
|
|
|
scheduleTriggerEvents(&crank,
|
|
|
|
/* timeScale */ 1,
|
2021-11-16 01:15:29 -08:00
|
|
|
cyclesCount, false, -1, 0, ptrs);
|
2021-07-02 14:32:29 -07:00
|
|
|
}
|
2021-07-05 19:17:26 -07:00
|
|
|
float vvtTimeScale = 1;
|
2021-07-02 14:32:29 -07:00
|
|
|
|
2021-07-05 20:15:44 -07:00
|
|
|
angle_t testVvtOffset = 13;
|
2021-07-03 09:43:01 -07:00
|
|
|
|
2021-07-02 16:23:37 -07:00
|
|
|
{
|
|
|
|
static TriggerWaveform vvt;
|
|
|
|
initializeNissanVQvvt(&vvt);
|
|
|
|
|
2021-07-03 07:15:41 -07:00
|
|
|
scheduleTriggerEvents(&vvt,
|
|
|
|
/* timeScale */ vvtTimeScale,
|
|
|
|
cyclesCount / 6, true,
|
2021-07-03 08:08:22 -07:00
|
|
|
/* vvtBankIndex */ 0,
|
2021-09-05 02:56:59 -07:00
|
|
|
/* vvtOffset */ testVvtOffset,
|
2021-11-16 01:15:29 -08:00
|
|
|
ptrs);
|
2021-07-02 16:23:37 -07:00
|
|
|
}
|
|
|
|
|
2021-07-02 17:28:15 -07:00
|
|
|
{
|
|
|
|
static TriggerWaveform vvt;
|
|
|
|
initializeNissanVQvvt(&vvt);
|
|
|
|
|
2021-07-03 07:15:41 -07:00
|
|
|
scheduleTriggerEvents(&vvt,
|
|
|
|
/* timeScale */ vvtTimeScale,
|
|
|
|
cyclesCount / 6, true,
|
2021-07-03 08:08:22 -07:00
|
|
|
/* vvtBankIndex */1,
|
2024-05-02 20:32:25 -07:00
|
|
|
/* vvtOffset, making it positive */ 720 + testVvtOffset + NISSAN_VQ_CAM_OFFSET,
|
2021-11-16 01:15:29 -08:00
|
|
|
ptrs);
|
2021-07-02 17:28:15 -07:00
|
|
|
}
|
2021-07-02 16:23:37 -07:00
|
|
|
|
2024-04-25 22:17:20 -07:00
|
|
|
eth.setTimeAndInvokeEventsUs(1473000);
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ(167, round(Sensor::getOrZero(SensorType::Rpm)));
|
2021-07-02 11:56:12 -07:00
|
|
|
|
2024-04-25 22:17:20 -07:00
|
|
|
eth.setTimeAndInvokeEventsUs(1475000);
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ(167, round(Sensor::getOrZero(SensorType::Rpm)));
|
2021-07-03 07:15:41 -07:00
|
|
|
TriggerCentral *tc = &engine->triggerCentral;
|
|
|
|
|
2024-04-25 22:17:20 -07:00
|
|
|
eth.setTimeAndInvokeEventsUs(3593000);
|
2021-07-03 07:37:03 -07:00
|
|
|
ASSERT_TRUE(tc->vvtState[0][0].getShaftSynchronized());
|
2021-07-07 20:55:33 -07:00
|
|
|
|
|
|
|
scheduling_s *head;
|
2022-11-02 09:05:51 -07:00
|
|
|
|
|
|
|
int queueIndex = 0;
|
2024-07-11 17:03:13 -07:00
|
|
|
while ((head = engine->scheduler.getHead()) != nullptr) {
|
2024-05-01 08:32:17 -07:00
|
|
|
// todo: what shall we change here once we migrate unit_tests to NT?
|
|
|
|
eth.setTimeAndInvokeEventsUs(head->getMomentUs());
|
2021-07-07 20:55:33 -07:00
|
|
|
|
|
|
|
ASSERT_TRUE(tc->vvtState[0][0].getShaftSynchronized());
|
|
|
|
// let's celebrate that vvtPosition stays the same
|
2022-11-02 09:05:51 -07:00
|
|
|
ASSERT_NEAR(34, tc->vvtPosition[0][0], EPS2D) << "queueIndex=" << queueIndex;
|
|
|
|
queueIndex++;
|
2021-07-07 20:55:33 -07:00
|
|
|
}
|
2024-05-02 20:32:25 -07:00
|
|
|
ASSERT_EQ(queueIndex, 432) << "Total queueIndex=" << queueIndex;
|
2021-07-07 20:55:33 -07:00
|
|
|
|
2021-07-03 08:08:22 -07:00
|
|
|
ASSERT_TRUE(tc->vvtState[1][0].getShaftSynchronized());
|
2021-07-03 07:15:41 -07:00
|
|
|
|
2022-11-02 09:05:51 -07:00
|
|
|
ASSERT_NEAR(34, tc->vvtPosition[0][0], EPS2D);
|
|
|
|
ASSERT_NEAR(34, tc->vvtPosition[1][0], EPS2D);
|
2021-07-03 08:08:22 -07:00
|
|
|
|
2021-07-12 13:29:07 -07:00
|
|
|
EXPECT_EQ(0, eth.recentWarnings()->getCount());
|
2021-07-02 11:56:12 -07:00
|
|
|
}
|