rusefi/firmware/config/boards/hellen/hellen_common.cpp

101 lines
3.0 KiB
C++

#include "pch.h"
#include "hellen_meta.h"
void hellenWbo() {
engineConfiguration->enableAemXSeries = true;
}
void setHellenCan() {
engineConfiguration->canTxPin = Gpio::D1;
engineConfiguration->canRxPin = Gpio::D0;
}
static OutputPin megaEn;
void setHellenMegaEnPin() {
static bool initialized = false;
if (!initialized) {
initialized = true;
megaEn.initPin("mm-EN", H144_GP8); // OUT_PWR_EN
megaEn.setValue(1);
}
}
void hellenBoardStandBy() {
// we need to turn 'megaEn' and pause for a bit to make sure that WBO is off and does not wake main firmware right away
megaEn.setValue(0);
// todo: 200ms is totally random what's the science for this sleep duration?
chThdSleepMilliseconds(200);
}
/**
* dirty hack
*/
void configureHellenMegaAccCS2Pin() {
static bool initialized = false;
static OutputPin cs2pin;
if (!initialized) {
initialized = true;
cs2pin.initPin("mm-CS2", H_SPI1_CS2);
cs2pin.setValue(1);
}
}
void configureHellenCanTerminator() {
static bool initialized = false;
static OutputPin terminatorControlPin;
if (!initialized) {
initialized = true;
terminatorControlPin.initPin("CAN-term", H_SPI3_CS); // todo: make this pin configurable
terminatorControlPin.setValue(engineConfiguration->boardUseCanTerminator);
}
}
// this should be called before setHellenXXXLedPins()
void detectHellenMcuType() {
// we test the red LED1 pin because the red LED used has the smallest voltage drop,
// and thus can be detected more accurately
static const brain_pin_e led1Pins[2] = {
// LED1 pin of the 176-pin mcu module (we check it first!)
H176_LED1_RED,
// LED1 pin of the 144-pin mcu module
H144_LED1_RED,
};
int padState[2];
// check each mcu module type sequentially
for (int mcuType = 0; mcuType < 2; mcuType++) {
brain_pin_e ledPin = led1Pins[mcuType];
ioportid_t port = getBrainPinPort(ledPin);
int hwIndex = getBrainPinIndex(ledPin);
// set LED1 pin to output & clear the state (discharge parasitic capacitance)
palSetPadMode(port, hwIndex, PAL_MODE_OUTPUT_PUSHPULL);
palClearPad(port, hwIndex);
// set LED1 pin to input
palSetPadMode(port, hwIndex, PAL_MODE_INPUT); // todo: currently we don't use PAL_MODE_INPUT_PULLDOWN - needs more testing
// wait for the pin state to settle down
chThdSleepMilliseconds(1);
// get the pin states
padState[mcuType] = 1;
for (int i = 0; i < 4; i++) {
// we get "1" only if all readings are "1"
padState[mcuType] &= palReadPad(port, hwIndex);
}
// back to output mode
palSetPadMode(port, hwIndex, PAL_MODE_OUTPUT_PUSHPULL);
}
efiPrintf("Hellen board pin states = %d %d", padState[0], padState[1]);
if (padState[0] && !padState[1]) {
efiPrintf("* Hellen 176-pin mcu detected!");
}
else if (!padState[0] && padState[1]) {
efiPrintf("* Hellen 144-pin mcu detected!");
} else {
efiPrintf("* Cannot detect Hellen mcu module!");
}
}
void detectHellenBoardType() {
detectHellenMcuType();
engine->engineState.hellenBoardId = detectHellenBoardId();
}