rusefi/firmware/controllers/algo/event_registry.h

152 lines
3.4 KiB
C
Raw Normal View History

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"
2020-07-20 00:04:05 -07:00
#include "accel_enrichment.h"
2015-07-10 06:01:56 -07:00
#define MAX_INJECTION_OUTPUT_COUNT INJECTION_PIN_COUNT
#define MAX_WIRES_COUNT 2
2016-11-30 19:06:43 -08:00
class Engine;
2015-07-10 06:01:56 -07:00
class InjectionEvent {
public:
InjectionEvent();
2020-07-24 18:26:24 -07:00
// Call this every decoded trigger tooth. It will schedule any relevant events for this injector.
void onTriggerTooth(size_t toothIndex, int rpm, efitick_t nowNt);
2015-07-10 06:01:56 -07:00
/**
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
*/
2020-07-24 18:26:24 -07:00
bool isSimultanious = false;
2016-11-30 16:01:43 -08:00
InjectorOutputPin *outputs[MAX_WIRES_COUNT];
2020-07-24 18:26:24 -07:00
int ownIndex = 0;
2019-12-02 20:08:18 -08:00
DECLARE_ENGINE_PTR;
2016-01-24 23:03:01 -08:00
event_trigger_position_s injectionStart;
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;
2020-07-20 00:04:05 -07:00
WallFuel wallFuel;
2015-07-10 06:01:56 -07:00
};
/**
* This class knows about when to inject fuel
*/
class FuelSchedule {
public:
FuelSchedule();
2020-07-24 18:26:24 -07:00
// Call this every trigger tooth. It will schedule all required injector events.
void onTriggerTooth(size_t toothIndex, int rpm, efitick_t nowNt DECLARE_ENGINE_PARAMETER_SUFFIX);
/**
* this method schedules all fuel events for an engine cycle
*/
void addFuelEvents(DECLARE_ENGINE_PARAMETER_SIGNATURE);
bool addFuelEventsForCylinder(int cylinderIndex DECLARE_ENGINE_PARAMETER_SUFFIX);
2020-07-14 23:54:41 -07:00
void resetOverlapping();
/**
* injection events, per cylinder
*/
InjectionEvent elements[MAX_INJECTION_OUTPUT_COUNT];
bool isReady;
private:
void clear();
};
class AngleBasedEvent {
public:
scheduling_s scheduling;
event_trigger_position_s position;
action_s action;
/**
* Trigger-based scheduler maintains a linked list of all pending tooth-based events.
*/
AngleBasedEvent *nextToothEvent = nullptr;
};
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;
AngleBasedEvent sparkEvent;
// How many additional sparks should we fire after the first one?
// For single sparks, this should be zero.
uint8_t sparksRemaining = 0;
2019-10-07 23:01:41 -07:00
/**
* Desired timing advance
*/
2019-11-23 20:49:39 -08:00
angle_t sparkAngle = NAN;
2020-07-29 02:22:54 -07:00
floatms_t sparkDwell = 0;
2019-10-07 23:01:41 -07:00
/**
* this timestamp allows us to measure actual dwell time
*/
2020-07-29 02:22:54 -07:00
uint32_t actualStartOfDwellNt = 0;
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
*/
int sparkId = 0;
2017-03-11 19:22:10 -08:00
/**
* [0, specs.cylindersCount)
*/
int cylinderIndex = 0;
int8_t cylinderNumber = 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:
/**
* 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;
};