rusefi/firmware/bootloader/bootloader_main.cpp

135 lines
3.3 KiB
C++
Raw Normal View History

2017-05-30 15:38:51 -07:00
#include "pch.h"
2023-12-26 12:31:31 -08:00
#include "usbconsole.h"
2017-05-30 15:38:51 -07:00
#include "hardware.h"
2023-12-26 12:31:31 -08:00
extern "C" {
#include "boot.h"
#include "flash.h"
2023-12-26 12:31:31 -08:00
#include "shared_params.h"
}
static blt_bool waitedLongerThanTimeout = BLT_FALSE;
class BlinkyThread : public chibios_rt::BaseStaticThread<256> {
protected:
void main(void) override {
Gpio yellow = getWarningLedPin();
2024-03-13 00:59:06 -07:00
Gpio blue = getCommsLedPin();
Gpio green = getRunningLedPin();
2024-04-06 18:30:43 -07:00
Gpio red = LED_CRITICAL_ERROR_BRAIN_PIN;
efiSetPadMode("yellow", yellow, PAL_MODE_OUTPUT_PUSHPULL);
2024-03-13 00:59:06 -07:00
efiSetPadMode("blue", blue, PAL_MODE_OUTPUT_PUSHPULL);
efiSetPadMode("green", green, PAL_MODE_OUTPUT_PUSHPULL);
2024-04-06 18:30:43 -07:00
efiSetPadMode("red", red, PAL_MODE_OUTPUT_PUSHPULL);
auto yellowPort = getBrainPinPort(yellow);
auto yellowPin = getBrainPinIndex(yellow);
2024-03-13 00:59:06 -07:00
auto bluePort = getBrainPinPort(blue);
auto bluePin = getBrainPinIndex(blue);
auto greenPort = getBrainPinPort(green);
auto greenPin = getBrainPinIndex(green);
2024-04-06 18:30:43 -07:00
auto redPort = getBrainPinPort(red);
auto redPin = getBrainPinIndex(red);
2024-03-13 00:59:06 -07:00
if (yellowPort) {
palSetPad(yellowPort, yellowPin);
}
if (bluePort) {
palSetPad(bluePort, bluePin);
}
if (greenPort) {
palSetPad(greenPort, greenPin);
}
2024-04-06 18:30:43 -07:00
if (redPort) {
palSetPad(redPort, redPin);
}
while (true) {
2024-03-13 00:59:06 -07:00
if (yellowPort) {
palTogglePad(yellowPort, yellowPin);
}
if (bluePort) {
palTogglePad(bluePort, bluePin);
}
if (greenPort) {
palTogglePad(greenPort, greenPin);
}
2024-04-06 18:30:43 -07:00
if (redPort) {
palTogglePad(redPort, redPin);
}
// blink 3 times faster if Dual Bank is not enabled
auto delay = isFlashDualBank() ? 125 : 40;
// blink faster if not in the waiting mode
chThdSleepMilliseconds(waitedLongerThanTimeout ? (delay * 2) : delay);
}
}
};
static BlinkyThread blinky;
static blt_bool checkIfRebootIntoOpenBltRequested(void) {
uint8_t value = 0x00;
if (SharedParamsReadByIndex(0, &value) && (value == 0x01)) {
/* clear */
SharedParamsWriteByIndex(0, 0x00);
return BLT_TRUE;
}
return BLT_FALSE;
}
2017-05-30 15:38:51 -07:00
int main(void) {
halInit();
chSysInit();
2023-08-25 22:34:36 -07:00
2023-12-26 12:31:31 -08:00
baseMCUInit();
// start the blinky thread
blinky.start(NORMALPRIO + 10);
2023-12-26 12:31:31 -08:00
// Init openblt shared params
SharedParamsInit();
// Init openblt itself
BootInit();
2017-05-30 15:38:51 -07:00
blt_bool stayInBootloader = checkIfRebootIntoOpenBltRequested();
blt_bool wasConnected = BLT_FALSE;
2023-08-25 22:34:36 -07:00
while (true) {
2023-12-26 12:31:31 -08:00
BootTask();
// since BOOT_BACKDOOR_HOOKS_ENABLE==TRUE, BackDoorCheck() is not working
// so we have to manually check if we need to jump to the main firmware
if (ComIsConnected() == BLT_TRUE) {
// remember we had connection attempt
wasConnected = BLT_TRUE;
continue;
}
if (stayInBootloader || wasConnected)
continue;
#if (BOOT_BACKDOOR_ENTRY_TIMEOUT_MS > 0)
blt_bool isTimeout = (TIME_I2MS(chVTGetSystemTime()) >= BOOT_BACKDOOR_ENTRY_TIMEOUT_MS);
#else
blt_bool isTimeout = BLT_TRUE;
#endif // BOOT_BACKDOOR_ENTRY_TIMEOUT_MS
if (isTimeout == BLT_TRUE) {
waitedLongerThanTimeout = BLT_TRUE;
CpuStartUserProgram();
}
2023-08-25 22:34:36 -07:00
}
2017-05-30 15:38:51 -07:00
}
2023-12-26 12:31:31 -08:00
// very basic version, supports on chip pins only (really only used for USB)
void efiSetPadMode(const char* msg, brain_pin_e brainPin, iomode_t mode) {
ioportid_t port = getHwPort(msg, brainPin);
ioportmask_t pin = getHwPin(msg, brainPin);
/* paranoid */
if (port == GPIO_NULL) {
return;
}
palSetPadMode(port, pin, mode);
}