custom-board-bundle-sample-.../firmware/controllers/core/efi_wave.cpp

106 lines
2.6 KiB
C++
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file EfiWave.cpp
*
* @date May 18, 2014
2018-01-20 17:55:31 -08:00
* @author Andrey Belomutskiy, (c) 2012-2018
2015-07-10 06:01:56 -07:00
*/
2018-09-16 19:26:57 -07:00
#include "global.h"
2019-03-29 06:11:13 -07:00
#include "efi_wave.h"
2015-07-10 06:01:56 -07:00
#include "trigger_structure.h"
2018-12-25 05:27:52 -08:00
SingleWave::SingleWave() {
2015-07-10 06:01:56 -07:00
init(NULL);
}
2018-12-25 05:27:52 -08:00
SingleWave::SingleWave(pin_state_t *ps) {
2015-07-10 06:01:56 -07:00
init(ps);
}
2018-12-25 05:27:52 -08:00
void SingleWave::init(pin_state_t *pinStates) {
2015-07-10 06:01:56 -07:00
this->pinStates = pinStates;
}
2019-02-02 22:19:16 -08:00
pin_state_t SingleWave::getState(int switchIndex) {
pin_state_t state = pinStates[switchIndex];
efiAssert(OBD_PCM_Processor_Fault, state == 0 || state == 1, "wave state get", TV_FALL);
return state;
2018-12-24 19:40:48 -08:00
}
2019-02-02 22:19:16 -08:00
void SingleWave::setState(int switchIndex, pin_state_t state) {
efiAssertVoid(OBD_PCM_Processor_Fault, state == 0 || state == 1, "wave state set");
2019-02-02 21:50:45 -08:00
pinStates[switchIndex] = state;
2018-12-24 19:40:48 -08:00
}
2018-12-08 13:59:16 -08:00
void MultiWave::baseConstructor() {
2018-12-25 07:13:00 -08:00
channels = NULL;
2015-07-10 06:01:56 -07:00
switchTimes = NULL;
reset();
}
2018-12-08 13:59:16 -08:00
MultiWave::MultiWave() {
2015-07-10 06:01:56 -07:00
baseConstructor();
}
2018-12-25 05:27:52 -08:00
MultiWave::MultiWave(float *switchTimes, SingleWave *waves) {
2015-07-10 06:01:56 -07:00
baseConstructor();
init(switchTimes, waves);
}
2018-12-25 07:13:00 -08:00
void MultiWave::init(float *switchTimes, SingleWave *channels) {
2015-07-10 06:01:56 -07:00
this->switchTimes = switchTimes;
2018-12-25 07:13:00 -08:00
this->channels = channels;
2015-07-10 06:01:56 -07:00
}
2018-12-08 13:59:16 -08:00
void MultiWave::reset(void) {
2015-07-10 06:01:56 -07:00
waveCount = 0;
}
2019-03-02 19:54:28 -08:00
float MultiWave::getSwitchTime(const int index) const {
2015-07-10 06:01:56 -07:00
return switchTimes[index];
}
2019-03-02 19:54:28 -08:00
void MultiWave::checkSwitchTimes(const int size) {
2015-07-10 06:01:56 -07:00
if (switchTimes[size - 1] != 1) {
2018-01-23 09:05:14 -08:00
firmwareError(CUSTOM_ERR_WAVE_1, "last switch time has to be 1 not %.2f", switchTimes[size - 1]);
2015-07-10 06:01:56 -07:00
return;
}
for (int i = 0; i < size - 1; i++) {
if (switchTimes[i] >= switchTimes[i + 1]) {
2018-01-23 09:05:14 -08:00
firmwareError(CUSTOM_ERR_WAVE_2, "invalid switchTimes @%d: %.2f/%.2f", i, switchTimes[i], switchTimes[i + 1]);
2015-07-10 06:01:56 -07:00
}
}
}
2018-12-08 13:38:44 -08:00
2019-03-02 19:54:28 -08:00
pin_state_t MultiWave::getChannelState(const int channelIndex, const int phaseIndex) const {
2019-03-03 22:10:31 -08:00
if (channelIndex >= waveCount) {
// todo: would be nice to get this asserting working
//firmwareError(OBD_PCM_Processor_Fault, "channel index %d/%d", channelIndex, waveCount);
}
2018-12-25 07:13:00 -08:00
return channels[channelIndex].pinStates[phaseIndex];
2018-12-08 13:38:44 -08:00
}
/**
* returns the index at which given value would need to be inserted into sorted array
*/
2019-03-02 19:54:28 -08:00
int MultiWave::findInsertionAngle(const float angle, const int size) const {
2018-12-08 13:38:44 -08:00
for (int i = size - 1; i >= 0; i--) {
if (angle > switchTimes[i])
return i + 1;
}
return 0;
}
2019-03-02 19:54:28 -08:00
int MultiWave::findAngleMatch(const float angle, const int size) const {
2018-12-08 13:38:44 -08:00
for (int i = 0; i < size; i++) {
if (isSameF(switchTimes[i], angle))
return i;
}
return EFI_ERROR_CODE;
}
2019-03-02 19:54:28 -08:00
void MultiWave::setSwitchTime(const int index, const float value) {
2018-12-08 13:38:44 -08:00
efiAssertVoid(CUSTOM_ERR_6690, switchTimes != NULL, "switchTimes");
switchTimes[index] = value;
}