142 lines
3.4 KiB
C++
142 lines
3.4 KiB
C++
/**
|
|
* @file rpm_calculator.h
|
|
* @brief Shaft position sensor(s) decoder header
|
|
*
|
|
* @date Jan 1, 2013
|
|
* @author Andrey Belomutskiy, (c) 2012-2017
|
|
*/
|
|
|
|
#ifndef RPM_REPORTER_H_
|
|
#define RPM_REPORTER_H_
|
|
|
|
#include <global.h>
|
|
#include "engine_configuration.h"
|
|
#include "scheduler.h"
|
|
|
|
#define TOP_DEAD_CENTER_MESSAGE "r"
|
|
|
|
#define WC_DOWN "d"
|
|
#define WC_UP "u"
|
|
/**
|
|
* See also 'CRANK1' in java dev console code
|
|
*/
|
|
#define CRANK1 "t1"
|
|
#define CRANK2 "t2"
|
|
#define CRANK3 "t3"
|
|
|
|
#define VVT_NAME "VVT"
|
|
|
|
#define NOISY_RPM -1
|
|
#define UNREALISTIC_RPM 30000
|
|
|
|
#ifdef __cplusplus
|
|
|
|
typedef enum {
|
|
/**
|
|
* The engine is not spinning, RPM=0
|
|
*/
|
|
STOPPED,
|
|
/**
|
|
* The engine is cranking (0 < RPM < cranking.rpm)
|
|
*/
|
|
CRANKING,
|
|
/**
|
|
* The engine is running (RPM >= cranking.rpm)
|
|
*/
|
|
RUNNING,
|
|
} spinning_state_e;
|
|
|
|
class Engine;
|
|
|
|
#define GET_RPM() ( ENGINE(rpmCalculator.rpmValue) )
|
|
|
|
class RpmCalculator {
|
|
public:
|
|
#if !EFI_PROD_CODE
|
|
int mockRpm;
|
|
#endif /* EFI_PROD_CODE */
|
|
RpmCalculator();
|
|
/**
|
|
* Returns true if the engine is not spinning (RPM==0)
|
|
*/
|
|
bool isStopped(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
|
/**
|
|
* Returns true if the engine is cranking
|
|
*/
|
|
bool isCranking(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
|
/**
|
|
* Returns true if the engine is running and not cranking
|
|
*/
|
|
bool isRunning(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
bool checkIfSpinning(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
int getRpm(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
|
/**
|
|
* This method is invoked once per engine cycle right after we calculate new RPM value
|
|
*/
|
|
void onNewEngineCycle();
|
|
uint32_t getRevolutionCounter(void);
|
|
void setRpmValue(int value DECLARE_ENGINE_PARAMETER_SUFFIX);
|
|
uint32_t getRevolutionCounterSinceStart(void);
|
|
float getRpmAcceleration();
|
|
/**
|
|
* This is public because sometimes we cannot afford to call isRunning() and the value is good enough
|
|
* Zero if engine is not running
|
|
*/
|
|
volatile int rpmValue;
|
|
int previousRpmValue;
|
|
/**
|
|
* This is a performance optimization: let's pre-calulate this each time RPM changes
|
|
*/
|
|
volatile floatus_t oneDegreeUs;
|
|
volatile efitime_t lastRpmEventTimeNt;
|
|
private:
|
|
/**
|
|
* Should be called once we've realized engine is not spinning any more.
|
|
*/
|
|
void setStopped(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
void assignRpmValue(int value);
|
|
/**
|
|
* This counter is incremented with each revolution of one of the shafts. Could be
|
|
* crankshaft could be camshaft.
|
|
*/
|
|
volatile uint32_t revolutionCounterSinceBoot;
|
|
/**
|
|
* Same as the above, but since the engine started spinning
|
|
*/
|
|
volatile uint32_t revolutionCounterSinceStart;
|
|
|
|
spinning_state_e state;
|
|
};
|
|
|
|
/**
|
|
* @brief Current RPM
|
|
*/
|
|
#define getRpmE(engine) (engine)->rpmCalculator.getRpm(PASS_ENGINE_PARAMETER_SIGNATURE)
|
|
|
|
void rpmShaftPositionCallback(trigger_event_e ckpSignalType, uint32_t index DECLARE_ENGINE_PARAMETER_SUFFIX);
|
|
/**
|
|
* @brief Initialize RPM calculator
|
|
*/
|
|
void initRpmCalculator(Logging *sharedLogger, Engine *engine);
|
|
|
|
float getCrankshaftAngleNt(efitime_t timeNt DECLARE_ENGINE_PARAMETER_SUFFIX);
|
|
#endif
|
|
|
|
|
|
int getRevolutionCounter(void);
|
|
|
|
#define isValidRpm(rpm) ((rpm) > 0 && (rpm) < UNREALISTIC_RPM)
|
|
|
|
#if EFI_ENGINE_SNIFFER
|
|
#define addEngineSniffferEvent(name, msg) waveChart.addEvent3((name), (msg))
|
|
#else
|
|
#define addEngineSniffferEvent(n, msg) {}
|
|
#endif /* EFI_ENGINE_SNIFFER */
|
|
|
|
void scheduleByAngle(int rpm, scheduling_s *timer, angle_t angle, schfunc_t callback, void *param, RpmCalculator *calc);
|
|
|
|
#endif /* RPM_REPORTER_H_ */
|