2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file vehicle_speed.cpp
|
|
|
|
*
|
|
|
|
* @date Dec 26, 2014
|
2020-01-13 18:57:43 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "vehicle_speed.h"
|
|
|
|
|
2019-04-12 17:52:51 -07:00
|
|
|
#if EFI_VEHICLE_SPEED
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
#include "engine.h"
|
2019-11-11 20:32:09 -08:00
|
|
|
#include "digital_input_icu.h"
|
2020-08-13 08:27:31 -07:00
|
|
|
#include "digital_input_exti.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
#include "pin_repository.h"
|
2020-04-21 17:48:37 -07:00
|
|
|
#include "can_vss.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2020-03-29 16:06:03 -07:00
|
|
|
EXTERN_ENGINE;
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
static Logging *logger;
|
|
|
|
|
|
|
|
static efitick_t lastSignalTimeNt = 0;
|
|
|
|
static efitick_t vssDiff = 0;
|
|
|
|
|
2017-01-16 13:03:37 -08:00
|
|
|
#define DEFAULT_MOCK_SPEED -1
|
|
|
|
static float mockVehicleSpeed = DEFAULT_MOCK_SPEED; // in kilometers per hour
|
|
|
|
|
|
|
|
void setMockVehicleSpeed(float speedKPH) {
|
|
|
|
mockVehicleSpeed = speedKPH;
|
|
|
|
}
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @return vehicle speed, in kilometers per hour
|
|
|
|
*/
|
|
|
|
float getVehicleSpeed(void) {
|
2017-01-16 13:03:37 -08:00
|
|
|
if (mockVehicleSpeed != DEFAULT_MOCK_SPEED)
|
|
|
|
return mockVehicleSpeed;
|
2020-04-21 17:48:37 -07:00
|
|
|
#if EFI_CAN_SUPPORT
|
2020-04-22 10:40:08 -07:00
|
|
|
if (CONFIG(enableCanVss)) {
|
2020-04-21 17:48:37 -07:00
|
|
|
return getVehicleCanSpeed();
|
|
|
|
}
|
|
|
|
#endif /* EFI_CAN_SUPPORT */
|
2017-02-05 20:04:55 -08:00
|
|
|
if (!hasVehicleSpeedSensor())
|
2016-06-20 17:02:47 -07:00
|
|
|
return 0;
|
2015-07-10 06:01:56 -07:00
|
|
|
efitick_t nowNt = getTimeNowNt();
|
2020-01-19 19:23:41 -08:00
|
|
|
if (nowNt - lastSignalTimeNt > NT_PER_SECOND)
|
2015-07-10 06:01:56 -07:00
|
|
|
return 0; // previous signal time is too long ago - we are stopped
|
|
|
|
|
2020-01-19 19:23:41 -08:00
|
|
|
return engineConfiguration->vehicleSpeedCoef * NT_PER_SECOND / vssDiff;
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static void vsAnaWidthCallback(void) {
|
2017-05-21 20:17:08 -07:00
|
|
|
engine->engineState.vssEventCounter++;
|
2015-07-10 06:01:56 -07:00
|
|
|
efitick_t nowNt = getTimeNowNt();
|
|
|
|
vssDiff = nowNt - lastSignalTimeNt;
|
|
|
|
lastSignalTimeNt = nowNt;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void speedInfo(void) {
|
2017-02-06 16:03:19 -08:00
|
|
|
scheduleMsg(logger, "VSS input at %s",
|
2019-11-30 07:24:37 -08:00
|
|
|
hwPortname(CONFIG(vehicleSpeedSensorInputPin)));
|
2016-06-20 14:03:03 -07:00
|
|
|
|
2018-01-23 09:05:14 -08:00
|
|
|
scheduleMsg(logger, "c=%.2f eventCounter=%d speed=%.2f",
|
2015-07-10 06:01:56 -07:00
|
|
|
engineConfiguration->vehicleSpeedCoef,
|
2017-05-21 20:17:08 -07:00
|
|
|
engine->engineState.vssEventCounter,
|
2015-07-10 06:01:56 -07:00
|
|
|
getVehicleSpeed());
|
|
|
|
scheduleMsg(logger, "vss diff %d", vssDiff);
|
|
|
|
}
|
|
|
|
|
2017-02-05 20:04:55 -08:00
|
|
|
bool hasVehicleSpeedSensor() {
|
2019-11-30 07:24:37 -08:00
|
|
|
return CONFIG(vehicleSpeedSensorInputPin) != GPIO_UNASSIGNED;
|
2017-02-05 20:04:55 -08:00
|
|
|
}
|
|
|
|
|
2020-08-13 08:27:31 -07:00
|
|
|
#if HAL_VSS_USE_PAL
|
|
|
|
static void vsExtiCallback(void *) {
|
|
|
|
vsAnaWidthCallback();
|
|
|
|
}
|
|
|
|
#endif /* HAL_VSS_USE_PAL */
|
|
|
|
|
2017-04-05 15:08:36 -07:00
|
|
|
void stopVSSPins(void) {
|
2020-08-13 08:27:31 -07:00
|
|
|
#if HAL_VSS_USE_PAL
|
|
|
|
efiExtiDisablePin(activeConfiguration.vehicleSpeedSensorInputPin);
|
|
|
|
#elif HAL_USE_ICU
|
2019-11-30 07:24:37 -08:00
|
|
|
stopDigitalCapture("VSS", activeConfiguration.vehicleSpeedSensorInputPin);
|
2020-08-13 08:27:31 -07:00
|
|
|
#endif /* HAL_VSS_USE_PAL, HAL_USE_ICU */
|
2017-04-05 15:08:36 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void startVSSPins(void) {
|
2020-12-22 17:50:01 -08:00
|
|
|
if (!hasVehicleSpeedSensor()) {
|
2018-01-01 08:27:15 -08:00
|
|
|
return;
|
2020-12-22 17:50:01 -08:00
|
|
|
}
|
2020-03-08 05:57:21 -07:00
|
|
|
|
2020-12-22 18:28:51 -08:00
|
|
|
// todo: refactor https://github.com/rusefi/rusefi/issues/2123
|
2020-08-13 08:27:31 -07:00
|
|
|
#if HAL_VSS_USE_PAL
|
|
|
|
ioline_t pal_line = PAL_LINE(getHwPort("vss", CONFIG(vehicleSpeedSensorInputPin)), getHwPin("vss", CONFIG(vehicleSpeedSensorInputPin)));
|
|
|
|
efiExtiEnablePin("VSS", CONFIG(vehicleSpeedSensorInputPin), PAL_EVENT_MODE_BOTH_EDGES, vsExtiCallback, (void *)pal_line);
|
|
|
|
#elif HAL_USE_ICU
|
2020-03-08 05:57:21 -07:00
|
|
|
digital_input_s* vehicleSpeedInput = startDigitalCapture("VSS", CONFIG(vehicleSpeedSensorInputPin));
|
|
|
|
|
2018-01-01 08:27:15 -08:00
|
|
|
vehicleSpeedInput->widthListeners.registerCallback((VoidInt) vsAnaWidthCallback, NULL);
|
2020-08-13 08:27:31 -07:00
|
|
|
#else
|
|
|
|
#error "HAL_USE_ICU or HAL_VSS_USE_PAL should be enabled to use EFI_VEHICLE_SPEED"
|
|
|
|
#endif /* HAL_VSS_USE_PAL, HAL_USE_ICU */
|
2017-04-05 15:08:36 -07:00
|
|
|
}
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
void initVehicleSpeed(Logging *l) {
|
|
|
|
logger = l;
|
2016-06-20 14:03:03 -07:00
|
|
|
addConsoleAction("speedinfo", speedInfo);
|
2018-01-01 08:27:15 -08:00
|
|
|
startVSSPins();
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
2017-05-02 08:49:35 -07:00
|
|
|
#else /* EFI_VEHICLE_SPEED */
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2020-11-19 18:14:38 -08:00
|
|
|
#if EFI_UNIT_TEST
|
|
|
|
static float mockVehicleSpeed = 0.0; // in kilometers per hour
|
|
|
|
|
|
|
|
void setMockVehicleSpeed(float speedKPH) {
|
|
|
|
mockVehicleSpeed = speedKPH;
|
|
|
|
}
|
|
|
|
float getVehicleSpeed(void) {
|
|
|
|
|
|
|
|
// Mock return to be used in unit tests
|
|
|
|
return mockVehicleSpeed;
|
|
|
|
}
|
|
|
|
#else
|
2017-05-02 08:49:35 -07:00
|
|
|
float getVehicleSpeed(void) {
|
2020-04-21 17:48:37 -07:00
|
|
|
|
2017-05-02 08:49:35 -07:00
|
|
|
// no VSS support
|
2020-04-21 17:48:37 -07:00
|
|
|
return 0;
|
2017-05-02 08:49:35 -07:00
|
|
|
}
|
2020-11-19 18:14:38 -08:00
|
|
|
#endif /* EFI_UNIT_TEST */
|
2015-07-10 06:01:56 -07:00
|
|
|
#endif /* EFI_VEHICLE_SPEED */
|