rusefi-full/firmware/hw_layer/digital_input/trigger/trigger_input_exti.cpp

117 lines
3.3 KiB
C++
Raw Normal View History

2019-11-11 18:25:40 -08:00
/**
* @file trigger_input_exti.cpp
* @brief Position sensor hardware layer - PAL version
*
* todo: VVT implementation is a nasty copy-paste :(
*
* see digital_input_icu.cp
2019-11-11 18:25:40 -08:00
*
* @date Dec 30, 2012
* @author Andrey Belomutskiy, (c) 2012-2021
2019-11-11 18:25:40 -08:00
*/
#include "global.h"
#if EFI_SHAFT_POSITION_INPUT && (HAL_TRIGGER_USE_PAL == TRUE)
2019-11-11 18:25:40 -08:00
2019-11-11 19:19:35 -08:00
#include "trigger_input.h"
#include "digital_input_exti.h"
#if (PAL_USE_CALLBACKS == FALSE)
#error "PAL_USE_CALLBACKS should be enabled to use HAL_TRIGGER_USE_PAL"
#endif
2019-11-11 19:19:35 -08:00
static Logging *logger;
EXTERN_ENGINE;
static ioline_t shaftLines[TRIGGER_SUPPORTED_CHANNELS];
static ioline_t camLines[CAM_INPUTS_COUNT];
2019-11-11 19:19:35 -08:00
static void shaft_callback(void *arg) {
// do the time sensitive things as early as possible!
efitick_t stamp = getTimeNowNt();
TRIGGER_BAIL_IF_DISABLED
#if HW_CHECK_MODE
TRIGGER_BAIL_IF_SELF_STIM
#endif
int index = (int)arg;
ioline_t pal_line = shaftLines[index];
bool rise = (palReadLine(pal_line) == PAL_HIGH);
2019-11-11 19:19:35 -08:00
// todo: support for 3rd trigger input channel
// todo: start using real event time from HW event, not just software timer?
bool isPrimary = index == 0;
if (!isPrimary && !TRIGGER_WAVEFORM(needSecondTriggerInput)) {
2019-11-11 19:19:35 -08:00
return;
}
trigger_event_e signal;
// todo: add support for 3rd channel
if (rise) {
signal = isPrimary ?
(engineConfiguration->invertPrimaryTriggerSignal ? SHAFT_PRIMARY_FALLING : SHAFT_PRIMARY_RISING) :
(engineConfiguration->invertSecondaryTriggerSignal ? SHAFT_SECONDARY_FALLING : SHAFT_SECONDARY_RISING);
} else {
signal = isPrimary ?
(engineConfiguration->invertPrimaryTriggerSignal ? SHAFT_PRIMARY_RISING : SHAFT_PRIMARY_FALLING) :
(engineConfiguration->invertSecondaryTriggerSignal ? SHAFT_SECONDARY_RISING : SHAFT_SECONDARY_FALLING);
}
hwHandleShaftSignal(signal, stamp);
2019-11-11 19:19:35 -08:00
}
static void cam_callback(void *arg) {
efitick_t stamp = getTimeNowNt();
TRIGGER_BAIL_IF_DISABLED
#if HW_CHECK_MODE
TRIGGER_BAIL_IF_SELF_STIM
#endif
int index = (int)arg;
ioline_t pal_line = camLines[index];
2019-11-11 19:19:35 -08:00
bool rise = (palReadLine(pal_line) == PAL_HIGH);
2020-08-29 15:13:00 -07:00
if (rise ^ engineConfiguration->invertCamVVTSignal) {
2021-01-31 19:24:45 -08:00
hwHandleVvtCamSignal(TV_RISE, stamp, index);
2019-11-11 19:19:35 -08:00
} else {
2021-01-31 19:24:45 -08:00
hwHandleVvtCamSignal(TV_FALL, stamp, index);
2019-11-11 19:19:35 -08:00
}
}
/*==========================================================================*/
/* Exported functions. */
/*==========================================================================*/
int extiTriggerTurnOnInputPin(const char *msg, int index, bool isTriggerShaft) {
brain_pin_e brainPin = isTriggerShaft ? CONFIG(triggerInputPins)[index] : engineConfiguration->camInputs[index];
scheduleMsg(logger, "extiTriggerTurnOnInputPin %s %s", msg, hwPortname(brainPin));
2019-11-11 19:19:35 -08:00
/* TODO:
* * do not set to both edges if we need only one
* * simplify callback in case of one edge */
ioline_t pal_line = PAL_LINE(getHwPort("trg", brainPin), getHwPin("trg", brainPin));
if (isTriggerShaft) {
shaftLines[index] = pal_line;
} else {
camLines[index] = pal_line;
}
efiExtiEnablePin(msg, brainPin, PAL_EVENT_MODE_BOTH_EDGES, isTriggerShaft ? shaft_callback : cam_callback, (void *)index);
return 0;
2019-11-11 19:19:35 -08:00
}
void extiTriggerTurnOffInputPin(brain_pin_e brainPin) {
2019-12-05 18:10:29 -08:00
efiExtiDisablePin(brainPin);
2019-11-11 19:19:35 -08:00
}
void extiTriggerTurnOnInputPins(Logging *sharedLogger) {
2019-11-11 19:19:35 -08:00
logger = sharedLogger;
}
#endif /* (EFI_SHAFT_POSITION_INPUT && (HAL_TRIGGER_USE_PAL == TRUE)) */