2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file event_registry.h
|
|
|
|
*
|
|
|
|
* @date Nov 27, 2013
|
2020-01-13 18:57:43 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
2019-10-07 22:49:42 -07:00
|
|
|
#pragma once
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
#include "global.h"
|
2019-10-08 00:14:21 -07:00
|
|
|
#include "efi_gpio.h"
|
|
|
|
#include "scheduler.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
#include "fl_stack.h"
|
2016-12-18 19:03:00 -08:00
|
|
|
#include "trigger_structure.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-10-07 23:13:52 -07:00
|
|
|
#define MAX_INJECTION_OUTPUT_COUNT INJECTION_PIN_COUNT
|
2019-10-07 23:35:21 -07:00
|
|
|
#define MAX_WIRES_COUNT 2
|
2019-10-07 23:13:52 -07:00
|
|
|
|
2016-11-30 19:06:43 -08:00
|
|
|
class Engine;
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
class InjectionEvent {
|
|
|
|
public:
|
|
|
|
InjectionEvent();
|
|
|
|
/**
|
2016-07-17 09:02:12 -07:00
|
|
|
* This is a performance optimization for IM_SIMULTANEOUS fuel strategy.
|
|
|
|
* It's more efficient to handle all injectors together if that's the case
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
2016-01-11 14:01:33 -08:00
|
|
|
bool isSimultanious;
|
2016-11-30 16:01:43 -08:00
|
|
|
InjectorOutputPin *outputs[MAX_WIRES_COUNT];
|
2016-11-30 19:06:43 -08:00
|
|
|
int ownIndex;
|
2019-12-02 20:08:18 -08:00
|
|
|
DECLARE_ENGINE_PTR;
|
2016-01-24 23:03:01 -08:00
|
|
|
event_trigger_position_s injectionStart;
|
2019-10-07 23:35:21 -07:00
|
|
|
|
2019-10-07 23:56:19 -07:00
|
|
|
scheduling_s signalTimerUp;
|
|
|
|
scheduling_s endOfInjectionEvent;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* we need atomic flag so that we do not schedule a new pair of up/down before previous down was executed.
|
|
|
|
*
|
|
|
|
* That's because we want to be sure that no 'down' side callback would be ignored since we are counting to see
|
|
|
|
* overlaps so we need the end counter to always have zero.
|
|
|
|
* TODO: make watchdog decrement relevant counter
|
|
|
|
*/
|
|
|
|
bool isScheduled = false;
|
2015-07-10 06:01:56 -07:00
|
|
|
};
|
|
|
|
|
2019-10-07 23:35:21 -07:00
|
|
|
|
2019-10-07 23:13:52 -07:00
|
|
|
/**
|
|
|
|
* This class knows about when to inject fuel
|
|
|
|
*/
|
|
|
|
class FuelSchedule {
|
|
|
|
public:
|
|
|
|
FuelSchedule();
|
|
|
|
/**
|
|
|
|
* this method schedules all fuel events for an engine cycle
|
|
|
|
*/
|
|
|
|
void addFuelEvents(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
bool addFuelEventsForCylinder(int cylinderIndex DECLARE_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* injection events, per cylinder
|
|
|
|
*/
|
|
|
|
InjectionEvent elements[MAX_INJECTION_OUTPUT_COUNT];
|
|
|
|
bool isReady;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void clear();
|
|
|
|
};
|
|
|
|
|
2019-11-23 16:47:53 -08:00
|
|
|
class AngleBasedEvent {
|
|
|
|
public:
|
|
|
|
scheduling_s scheduling;
|
|
|
|
event_trigger_position_s position;
|
|
|
|
action_s action;
|
2019-11-23 17:36:40 -08:00
|
|
|
/**
|
|
|
|
* Trigger-based scheduler maintains a linked list of all pending tooth-based events.
|
|
|
|
*/
|
|
|
|
AngleBasedEvent *nextToothEvent = nullptr;
|
2019-11-23 16:47:53 -08:00
|
|
|
};
|
|
|
|
|
2016-11-26 21:01:22 -08:00
|
|
|
#define MAX_OUTPUTS_FOR_IGNITION 2
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
class IgnitionEvent {
|
|
|
|
public:
|
|
|
|
IgnitionEvent();
|
2016-11-27 18:04:45 -08:00
|
|
|
IgnitionOutputPin *outputs[MAX_OUTPUTS_FOR_IGNITION];
|
2019-10-07 23:01:41 -07:00
|
|
|
scheduling_s dwellStartTimer;
|
2019-11-23 16:47:53 -08:00
|
|
|
AngleBasedEvent sparkEvent;
|
2019-10-07 23:01:41 -07:00
|
|
|
/**
|
|
|
|
* Desired timing advance
|
|
|
|
*/
|
2019-11-23 20:49:39 -08:00
|
|
|
angle_t sparkAngle = NAN;
|
2019-05-07 14:22:26 -07:00
|
|
|
floatms_t sparkDwell;
|
2019-10-07 23:01:41 -07:00
|
|
|
/**
|
|
|
|
* this timestamp allows us to measure actual dwell time
|
|
|
|
*/
|
|
|
|
uint32_t actualStartOfDwellNt;
|
2015-07-10 06:01:56 -07:00
|
|
|
event_trigger_position_s dwellPosition;
|
2016-11-28 11:01:52 -08:00
|
|
|
/**
|
2019-10-07 23:01:41 -07:00
|
|
|
* Sequential number of currently processed spark event
|
2019-10-07 22:36:03 -07:00
|
|
|
* @see globalSparkIdCounter
|
2016-11-28 11:01:52 -08:00
|
|
|
*/
|
2019-10-07 21:27:49 -07:00
|
|
|
int sparkId = 0;
|
2017-03-11 19:22:10 -08:00
|
|
|
/**
|
|
|
|
* [0, specs.cylindersCount)
|
|
|
|
*/
|
2019-10-07 21:27:49 -07:00
|
|
|
int cylinderIndex = 0;
|
2019-10-07 22:26:35 -07:00
|
|
|
char *name = nullptr;
|
2019-12-02 20:08:18 -08:00
|
|
|
DECLARE_ENGINE_PTR;
|
2016-11-27 18:04:45 -08:00
|
|
|
IgnitionOutputPin *getOutputForLoggins();
|
2015-07-10 06:01:56 -07:00
|
|
|
};
|
|
|
|
|
2016-11-28 05:03:30 -08:00
|
|
|
#define MAX_IGNITION_EVENT_COUNT IGNITION_PIN_COUNT
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2016-11-28 10:02:24 -08:00
|
|
|
class IgnitionEventList {
|
2016-11-28 09:03:02 -08:00
|
|
|
public:
|
2019-10-07 23:13:52 -07:00
|
|
|
/**
|
|
|
|
* ignition events, per cylinder
|
|
|
|
*/
|
2016-11-28 10:02:24 -08:00
|
|
|
IgnitionEvent elements[MAX_IGNITION_EVENT_COUNT];
|
2019-10-07 23:01:41 -07:00
|
|
|
bool isReady = false;
|
2016-11-28 09:03:02 -08:00
|
|
|
};
|
2019-12-02 21:29:12 -08:00
|
|
|
|
|
|
|
class AuxActor {
|
|
|
|
public:
|
|
|
|
int phaseIndex;
|
|
|
|
int valveIndex;
|
|
|
|
angle_t extra;
|
|
|
|
|
|
|
|
AngleBasedEvent open;
|
|
|
|
AngleBasedEvent close;
|
|
|
|
DECLARE_ENGINE_PTR;
|
|
|
|
};
|