rusefi/firmware/hw_layer/joystick.cpp

126 lines
4.2 KiB
C++
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file joystick.cpp
*
2017-12-04 15:30:44 -08:00
* See lcd_controller.cpp for more information
* See void onJoystick(joystick_button_e button)
*
2018-12-09 13:46:53 -08:00
* TODO: separate EXTI layer from joystick logic
2018-12-09 13:50:22 -08:00
* You cannot use two pins with same index for EXTI (for instance PA5 and PE5) since these would
* be using same EXTI line. See https://stm32f4-discovery.net/2014/08/stm32f4-external-interrupts-tutorial/
2018-12-09 13:46:53 -08:00
* See also comments in digital_input_hw.cpp
*
2018-12-12 20:36:36 -08:00
*
* TODO: In release 18.2.0 the EXT driver is no more provided for STM32, there is a PAL demo under /testhal/STM32/multi/PAL with examples of callbacks and synchronous API.
*
2015-07-10 06:01:56 -07:00
* @date Jan 2, 2015
2018-01-20 17:55:31 -08:00
* @author Andrey Belomutskiy, (c) 2012-2018
2015-07-10 06:01:56 -07:00
*/
#include "engine.h"
2018-12-18 20:50:29 -08:00
#include "joystick.h"
2015-07-10 06:01:56 -07:00
#include "pin_repository.h"
2018-12-18 20:50:29 -08:00
#include "digital_input_exti.h"
2015-07-10 06:01:56 -07:00
#if HAL_USE_EXT || defined(__DOXYGEN__)
EXTERN_ENGINE
;
static int joyTotal = 0;
static int joyCenter;
static int joyA = 0;
static int joyB = 0;
static int joyC = 0;
static int joyD = 0;
2017-01-05 17:04:02 -08:00
// 50ms
#define NT_EVENT_GAP US2NT(50 *1000)
2015-07-10 06:01:56 -07:00
static Logging *sharedLogger;
static efitick_t lastEventTime = 0;
2018-12-12 15:02:00 -08:00
static bool isJitter() {
2015-07-10 06:01:56 -07:00
efitick_t now = getTimeNowNt();
if (now - lastEventTime < NT_EVENT_GAP)
2018-12-12 15:02:00 -08:00
return true; // two consecutive events are probably just jitter
2015-07-10 06:01:56 -07:00
lastEventTime = now;
2018-12-12 15:02:00 -08:00
return false;
}
static void extCallback(EXTDriver *extp, expchannel_t channel) {
UNUSED(extp);
if (isJitter())
return;
2015-07-10 06:01:56 -07:00
joyTotal++;
joystick_button_e button;
// todo: I guess it's time to reduce code duplication and start working with an array
2017-07-28 11:27:37 -07:00
if (channel == getHwPin("joy", boardConfiguration->joystickCenterPin)) {
2015-07-10 06:01:56 -07:00
joyCenter++;
button = JB_CENTER;
2017-07-28 11:27:37 -07:00
} else if (channel == getHwPin("joy", boardConfiguration->joystickAPin)) {
2015-07-10 06:01:56 -07:00
joyA++;
button = JB_BUTTON_A;
2018-12-12 15:02:00 -08:00
/* not used so far
2017-07-28 11:27:37 -07:00
} else if (channel == getHwPin("joy", boardConfiguration->joystickBPin)) {
2015-07-10 06:01:56 -07:00
joyB++;
2018-12-12 15:02:00 -08:00
button = JB_BUTTON_B;
2017-07-28 11:27:37 -07:00
} else if (channel == getHwPin("joy", boardConfiguration->joystickCPin)) {
2015-07-10 06:01:56 -07:00
joyC++;
2018-12-12 15:02:00 -08:00
button = JB_BUTTON_C;
*/
2017-07-28 11:27:37 -07:00
} else if (channel == getHwPin("joy", boardConfiguration->joystickDPin)) {
2015-07-10 06:01:56 -07:00
joyD++;
button = JB_BUTTON_D;
} else {
// unexpected channel
return;
}
#if EFI_HD44780_LCD || defined(__DOXYGEN__)
onJoystick(button);
#else
UNUSED(button);
2015-07-10 06:01:56 -07:00
#endif
}
static void joystickInfo(void) {
scheduleMsg(sharedLogger, "total %d center=%d@%s", joyTotal, joyCenter,
hwPortname(boardConfiguration->joystickCenterPin));
scheduleMsg(sharedLogger, "a=%d@%s", joyA, hwPortname(boardConfiguration->joystickAPin));
scheduleMsg(sharedLogger, "b=%d@%s", joyB, hwPortname(boardConfiguration->joystickBPin));
scheduleMsg(sharedLogger, "c=%d@%s", joyC, hwPortname(boardConfiguration->joystickCPin));
scheduleMsg(sharedLogger, "d=%d@%s", joyD, hwPortname(boardConfiguration->joystickDPin));
}
2016-12-27 10:02:00 -08:00
static bool isJoystickEnabled() {
return boardConfiguration->joystickCenterPin != GPIO_UNASSIGNED ||
boardConfiguration->joystickAPin != GPIO_UNASSIGNED ||
2018-12-12 19:27:44 -08:00
// not used so far boardConfiguration->joystickBPin != GPIO_UNASSIGNED ||
// not used so far boardConfiguration->joystickCPin != GPIO_UNASSIGNED ||
2016-12-27 10:02:00 -08:00
boardConfiguration->joystickDPin != GPIO_UNASSIGNED;
}
2015-07-10 06:01:56 -07:00
void initJoystick(Logging *shared) {
2016-12-27 10:02:00 -08:00
if (!isJoystickEnabled())
2015-07-10 06:01:56 -07:00
return;
sharedLogger = shared;
2018-12-18 20:50:29 -08:00
enableExti(boardConfiguration->joystickCenterPin, EXT_CH_MODE_RISING_EDGE, extCallback);
enableExti(boardConfiguration->joystickAPin, EXT_CH_MODE_RISING_EDGE, extCallback);
2018-12-12 19:27:44 -08:00
// not used so far applyPin(boardConfiguration->joystickBPin);
// not used so far applyPin(boardConfiguration->joystickCPin);
2018-12-18 20:50:29 -08:00
enableExti(boardConfiguration->joystickDPin, EXT_CH_MODE_RISING_EDGE, extCallback);
2015-07-10 06:01:56 -07:00
2017-05-15 05:40:54 -07:00
efiSetPadMode("joy center", boardConfiguration->joystickCenterPin, PAL_MODE_INPUT_PULLUP);
efiSetPadMode("joy A", boardConfiguration->joystickAPin, PAL_MODE_INPUT_PULLUP);
2018-12-12 19:27:44 -08:00
// not used so far efiSetPadMode("joy B", boardConfiguration->joystickBPin, PAL_MODE_INPUT_PULLUP);
// not used so far efiSetPadMode("joy C", boardConfiguration->joystickCPin, PAL_MODE_INPUT_PULLUP);
2017-05-15 05:40:54 -07:00
efiSetPadMode("joy D", boardConfiguration->joystickDPin, PAL_MODE_INPUT_PULLUP);
2015-07-10 06:01:56 -07:00
addConsoleAction("joystickinfo", joystickInfo);
2018-12-18 20:50:29 -08:00
// todo: this is not a great place to invoke this method. open question if we have to start only after enablng all EXTI?
myExtStart();
2015-07-10 06:01:56 -07:00
}
2018-12-18 20:50:29 -08:00
#endif /* HAL_USE_EXT */