88 lines
2.5 KiB
C++
88 lines
2.5 KiB
C++
/**
|
|
* @file trigger_decoder.h
|
|
*
|
|
* @date Dec 24, 2013
|
|
* @author Andrey Belomutskiy, (c) 2012-2014
|
|
*/
|
|
|
|
#ifndef TRIGGER_DECODER_H_
|
|
#define TRIGGER_DECODER_H_
|
|
|
|
#include "trigger_structure.h"
|
|
#include "engine_configuration.h"
|
|
#include "ec2.h"
|
|
|
|
class TriggerState;
|
|
|
|
typedef void (*TriggerStateCallback)(TriggerState *);
|
|
|
|
class TriggerState {
|
|
public:
|
|
TriggerState();
|
|
int getCurrentIndex();
|
|
int getTotalRevolutionCounter();
|
|
uint64_t getTotalEventCounter();
|
|
uint64_t getStartOfRevolutionIndex();
|
|
void nextRevolution(int triggerEventCount, uint64_t nowUs);
|
|
void nextTriggerEvent(trigger_wheel_e triggerWheel, uint64_t nowUs);
|
|
void decodeTriggerEvent(trigger_shape_s const*triggerShape, trigger_config_s const*triggerConfig, trigger_event_e const signal, uint64_t nowUs);
|
|
|
|
float getTriggerDutyCycle(int index);
|
|
TriggerStateCallback cycleCallback;
|
|
|
|
/**
|
|
* TRUE if we know where we are
|
|
*/
|
|
bool shaft_is_synchronized;
|
|
|
|
uint64_t toothed_previous_duration;
|
|
uint64_t toothed_previous_time;
|
|
|
|
/**
|
|
* Here we accumulate the amount of time this signal was ON within current trigger cycle
|
|
*/
|
|
int totalTime[PWM_PHASE_MAX_WAVE_PER_PWM];
|
|
/**
|
|
* Total time result for previous trigger cycle
|
|
*/
|
|
uint32_t prevTotalTime[PWM_PHASE_MAX_WAVE_PER_PWM];
|
|
int expectedTotalTime[PWM_PHASE_MAX_WAVE_PER_PWM];
|
|
|
|
private:
|
|
void clear();
|
|
/**
|
|
* index within trigger revolution, from 0 to trigger event count
|
|
*/
|
|
uint32_t current_index;
|
|
/**
|
|
* Number of actual events within current trigger cycle
|
|
* see trigger_shape_s
|
|
*/
|
|
uint32_t eventCount[PWM_PHASE_MAX_WAVE_PER_PWM];
|
|
uint64_t timeOfPreviousEvent[PWM_PHASE_MAX_WAVE_PER_PWM];
|
|
uint64_t totalEventCountBase;
|
|
uint32_t totalRevolutionCounter;
|
|
bool isFirstEvent;
|
|
uint64_t prevCycleDuration;
|
|
uint64_t startOfCycle;
|
|
};
|
|
|
|
class TriggerStimulatorHelper {
|
|
public:
|
|
TriggerStimulatorHelper();
|
|
void nextStep(TriggerState *state, trigger_shape_s * shape, int i, trigger_config_s const*triggerConfig);
|
|
private:
|
|
bool primaryWheelState;
|
|
bool secondaryWheelState;
|
|
bool thirdWheelState;
|
|
};
|
|
|
|
void initializeSkippedToothTriggerShapeExt(trigger_shape_s *s, int totalTeethCount, int skippedCount, operation_mode_e operationMode);
|
|
uint32_t findTriggerZeroEventIndex(trigger_shape_s * shape, trigger_config_s const*triggerConfig);
|
|
void initializeTriggerShape(Logging *logger, engine_configuration_s const *engineConfiguration, engine_configuration2_s *engineConfiguration2);
|
|
void initTriggerDecoder(void);
|
|
|
|
int isTriggerDecoderError(void);
|
|
|
|
#endif /* TRIGGER_DECODER_H_ */
|