/** * @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 * * @date Dec 30, 2012 * @author Andrey Belomutskiy, (c) 2012-2021 */ #include "global.h" #if EFI_SHAFT_POSITION_INPUT && (HAL_TRIGGER_USE_PAL == TRUE) #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 EXTERN_ENGINE; static ioline_t shaftLines[TRIGGER_SUPPORTED_CHANNELS]; static ioline_t camLines[CAM_INPUTS_COUNT]; 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); // todo: support for 3rd trigger input channel // todo: start using real event time from HW event, not just software timer? hwHandleShaftSignal(index, rise, stamp); } 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]; bool rise = (palReadLine(pal_line) == PAL_HIGH); if (rise ^ engineConfiguration->invertCamVVTSignal) { hwHandleVvtCamSignal(TV_RISE, stamp, index); } else { hwHandleVvtCamSignal(TV_FALL, stamp, index); } } /*==========================================================================*/ /* Exported functions. */ /*==========================================================================*/ int extiTriggerTurnOnInputPin(const char *msg, int index, bool isTriggerShaft) { brain_pin_e brainPin = isTriggerShaft ? CONFIG(triggerInputPins)[index] : engineConfiguration->camInputs[index]; efiPrintf("extiTriggerTurnOnInputPin %s %s", msg, hwPortname(brainPin)); /* 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; } void extiTriggerTurnOffInputPin(brain_pin_e brainPin) { efiExtiDisablePin(brainPin); } void extiTriggerTurnOnInputPins() { } #endif /* (EFI_SHAFT_POSITION_INPUT && (HAL_TRIGGER_USE_PAL == TRUE)) */