2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file rpm_calculator.h
|
|
|
|
* @brief Shaft position sensor(s) decoder header
|
|
|
|
*
|
|
|
|
* @date Jan 1, 2013
|
2015-12-31 13:02:30 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2016
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#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"
|
|
|
|
|
2016-08-23 20:03:01 -07:00
|
|
|
#define VVT_NAME "VVT"
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
#define NOISY_RPM -1
|
|
|
|
#define UNREALISTIC_RPM 30000
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
|
|
|
class Engine;
|
|
|
|
|
|
|
|
class RpmCalculator {
|
|
|
|
public:
|
|
|
|
#if !EFI_PROD_CODE
|
|
|
|
int mockRpm;
|
|
|
|
#endif
|
|
|
|
RpmCalculator();
|
|
|
|
/**
|
|
|
|
* Please note that this is a relatively heavy method due to getTimeNowNt() usage
|
|
|
|
*/
|
|
|
|
bool isRunning(DECLARE_ENGINE_PARAMETER_F);
|
2016-01-18 09:03:32 -08:00
|
|
|
int getRpm(DECLARE_ENGINE_PARAMETER_F);
|
2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* This method is invoked once per engine cycle right after we calculate new RPM value
|
|
|
|
*/
|
|
|
|
void onNewEngineCycle();
|
|
|
|
uint32_t getRevolutionCounter(void);
|
2016-03-15 19:03:43 -07:00
|
|
|
void setRpmValue(int value DECLARE_ENGINE_PARAMETER_S);
|
2015-07-10 06:01:56 -07:00
|
|
|
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:
|
2016-03-15 19:03:43 -07:00
|
|
|
void assignRpmValue(int value);
|
2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Current RPM
|
|
|
|
*/
|
2016-01-18 09:03:32 -08:00
|
|
|
#define getRpmE(engine) (engine)->rpmCalculator.getRpm(PASS_ENGINE_PARAMETER_F)
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
bool isCrankingE(Engine *engine);
|
|
|
|
void rpmShaftPositionCallback(trigger_event_e ckpSignalType, uint32_t index DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
/**
|
|
|
|
* @brief Initialize RPM calculator
|
|
|
|
*/
|
|
|
|
void initRpmCalculator(Logging *sharedLogger, Engine *engine);
|
|
|
|
|
|
|
|
float getCrankshaftAngleNt(efitime_t timeNt DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
int getRevolutionCounter(void);
|
|
|
|
|
|
|
|
bool isCranking(void);
|
|
|
|
|
|
|
|
#define isValidRpm(rpm) ((rpm) > 0 && (rpm) < UNREALISTIC_RPM)
|
|
|
|
|
2015-07-15 18:01:45 -07:00
|
|
|
#if EFI_ENGINE_SNIFFER
|
2016-01-30 19:03:36 -08:00
|
|
|
#define addEngineSniffferEvent(name, msg) waveChart.addEvent3((name), (msg))
|
2015-07-10 06:01:56 -07:00
|
|
|
#else
|
2016-01-30 19:03:36 -08:00
|
|
|
#define addEngineSniffferEvent(n, msg) {}
|
2015-07-15 18:01:45 -07:00
|
|
|
#endif /* EFI_ENGINE_SNIFFER */
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
void scheduleByAngle(int rpm, scheduling_s *timer, angle_t angle, schfunc_t callback, void *param, RpmCalculator *calc);
|
|
|
|
|
|
|
|
#endif /* RPM_REPORTER_H_ */
|