84 lines
1.9 KiB
C++
84 lines
1.9 KiB
C++
/**
|
|
* @file event_registry.h
|
|
*
|
|
* @date Nov 27, 2013
|
|
* @author Andrey Belomutskiy, (c) 2012-2014
|
|
*/
|
|
|
|
#ifndef EVENT_REGISTRY_H_
|
|
#define EVENT_REGISTRY_H_
|
|
|
|
#include "global.h"
|
|
#include "signal_executor.h"
|
|
|
|
#define MAX_EVENT_COUNT 80
|
|
|
|
/**
|
|
* This structure defines an angle position within the trigger
|
|
*/
|
|
typedef struct {
|
|
/**
|
|
* That's trigger event index
|
|
*/
|
|
uint32_t eventIndex;
|
|
float eventAngle;
|
|
/**
|
|
* Angle offset from the trigger event
|
|
*/
|
|
float angleOffset;
|
|
} event_trigger_position_s;
|
|
|
|
typedef struct {
|
|
event_trigger_position_s position;
|
|
OutputSignal *actuator;
|
|
} ActuatorEvent;
|
|
|
|
typedef struct IgnitionEvent_struct IgnitionEvent;
|
|
|
|
struct IgnitionEvent_struct {
|
|
io_pin_e io_pin;
|
|
scheduling_s signalTimerUp;
|
|
scheduling_s signalTimerDown;
|
|
event_trigger_position_s dwellPosition;
|
|
float advance;
|
|
event_trigger_position_s sparkPosition;
|
|
IgnitionEvent *next;
|
|
char *name;
|
|
};
|
|
|
|
template <class Type, int Dimention>
|
|
class ArrayList {
|
|
public:
|
|
int size;
|
|
Type events[Dimention];
|
|
void resetEventList(void);
|
|
Type *getNextActuatorEvent(void);
|
|
};
|
|
|
|
template <class Type, int Dimention>
|
|
void ArrayList< Type, Dimention>::resetEventList(void) {
|
|
size = 0;
|
|
}
|
|
|
|
template <class Type, int Dimention>
|
|
Type * ArrayList< Type, Dimention>::getNextActuatorEvent(void) {
|
|
efiAssert(size < Dimention, "registerActuatorEvent() too many events", (Type *)NULL);
|
|
return &events[size++];
|
|
}
|
|
|
|
typedef ArrayList<ActuatorEvent, MAX_EVENT_COUNT> ActuatorEventList;
|
|
|
|
typedef ArrayList<IgnitionEvent, MAX_EVENT_COUNT> IgnitionEventList;
|
|
|
|
///**
|
|
// * this is an intermediate implementation of flexible event handling.
|
|
// *
|
|
// * In the future implementation we will drop the 'eventIndex' parameter and everything will be
|
|
// * angle-driven. But that's just a plan for next iteration.
|
|
// *
|
|
// * @param actuator injector or coil OutputSignal
|
|
// */
|
|
//void registerActuatorEvent(ActuatorEventList *list, int eventIndex, OutputSignal *actuator, float angleOffset);
|
|
|
|
#endif /* EVENT_REGISTRY_H_ */
|