fome-fw/firmware/controllers/trigger/trigger_structure.h

128 lines
3.2 KiB
C
Raw Normal View History

2014-08-29 07:52:33 -07:00
/**
* @file trigger_structure.h
*
* @date Dec 22, 2013
* @author Andrey Belomutskiy, (c) 2012-2014
*/
#ifndef TRIGGER_STRUCTURE_H_
#define TRIGGER_STRUCTURE_H_
2014-10-29 13:04:17 -07:00
#include "global.h"
2014-08-29 07:52:33 -07:00
#include "rusefi_enums.h"
#include "EfiWave.h"
#include "engine_configuration.h"
class trigger_shape_s;
#define TRIGGER_CHANNEL_COUNT 3
class trigger_shape_helper {
int pinStates[TRIGGER_CHANNEL_COUNT][PWM_PHASE_MAX_COUNT];
public:
trigger_shape_helper();
single_wave_s waves[TRIGGER_CHANNEL_COUNT];
};
2014-11-12 14:03:12 -08:00
class Engine;
2014-08-29 07:52:33 -07:00
class trigger_shape_s {
public:
trigger_shape_s();
2014-11-25 13:03:16 -08:00
bool_t isSynchronizationNeeded;
2014-08-29 07:52:33 -07:00
int totalToothCount;
int skippedToothCount;
float dutyCycle[PWM_PHASE_MAX_WAVE_PER_PWM];
float syncRatioFrom;
float syncRatioTo;
2014-10-29 14:03:10 -07:00
/**
* Should we use falls or rises for gap ratio detection?
*/
2014-10-29 13:04:17 -07:00
bool_t useRiseEdge;
2014-10-29 14:03:10 -07:00
/**
* Should we measure gaps with events of both kinds?
*/
bool_t gapBothDirections;
2014-08-29 07:52:33 -07:00
/**
* This is used for signal validation
*/
2014-09-24 12:03:03 -07:00
uint32_t expectedEventCount[PWM_PHASE_MAX_WAVE_PER_PWM];
2014-08-29 07:52:33 -07:00
void addEvent(float angle, trigger_wheel_e const waveIndex, trigger_value_e const state);
void reset(operation_mode_e operationMode);
int getSize() const;
multi_wave_s wave;
/**
* this one is per CRANKshaft revolution
*/
uint32_t getLength() const;
// todo: add a runtime validation which would verify that this field was set properly
// tood: maybe even automate this flag calculation?
int initialState[PWM_PHASE_MAX_WAVE_PER_PWM];
int getTriggerShapeSynchPointIndex();
2014-11-24 13:03:32 -08:00
void calculateTriggerSynchPoint(engine_configuration_s *engineConfiguration, Engine *engine);
2014-08-29 07:52:33 -07:00
2014-11-12 14:03:12 -08:00
void setTriggerShapeSynchPointIndex(engine_configuration_s *engineConfiguration, int triggerShapeSynchPointIndex, Engine *engine);
2014-08-29 07:52:33 -07:00
/**
* These angles are in event coordinates - with synchronization point located at angle zero.
* These values are pre-calculated for performance reasons.
*/
float eventAngles[PWM_PHASE_MAX_COUNT];
2014-11-03 12:06:53 -08:00
bool_t invertOnAdd;
2014-11-25 08:04:15 -08:00
/**
* Total count of shaft events per CAM or CRANK shaft revolution.
* TODO this should be migrated to CRANKshaft revolution, this would go together
* TODO with eliminating RPM_MULT magic constant
*/
2014-08-29 07:52:33 -07:00
int size;
2014-11-26 12:04:04 -08:00
private:
trigger_shape_helper h;
2014-08-29 07:52:33 -07:00
/**
* index of synchronization event within trigger_shape_s
* See findTriggerZeroEventIndex()
*/
int triggerShapeSynchPointIndex;
/**
* Values are in the 0..1 range
*/
float switchTimesBuffer[PWM_PHASE_MAX_COUNT];
/**
* These angles are in trigger DESCRIPTION coordinates - i.e. the way you add events while declaring trigger shape
*/
float getSwitchAngle(int index) const;
float previousAngle;
/**
* this is part of performance optimization
*/
operation_mode_e operationMode;
/**
* This private method should only be used to prepare the array of pre-calculated values
* See eventAngles array
*/
float getAngle(int phaseIndex) const;
int getCycleDuration() const;
};
void setTriggerSynchronizationGap(trigger_shape_s *s, float synchGap);
2014-11-02 12:03:03 -08:00
void setTriggerSynchronizationGap2(trigger_shape_s *s, float syncGapFrom, float syncRatioTo);
2014-08-29 07:52:33 -07:00
void setToothedWheelConfiguration(trigger_shape_s *s, int total, int skipped, engine_configuration_s const *engineConfiguration);
#endif /* TRIGGER_STRUCTURE_H_ */