microRusefi Default Configuration (#895)
* poke * working MRE * why was this on? * comment, cleanup * default silent trigger error on * comment * remove extra * sensible default
This commit is contained in:
parent
8370022266
commit
1ec07af6e2
|
@ -3,16 +3,8 @@ cd ../../..
|
||||||
|
|
||||||
set LDSCRIPT = config/boards/NUCLEO_F767/STM32F76xxI.ld
|
set LDSCRIPT = config/boards/NUCLEO_F767/STM32F76xxI.ld
|
||||||
|
|
||||||
set PROJECT_BOARD=nucleo_f767
|
set PROJECT_BOARD=microrusefi
|
||||||
set PROJECT_CPU=ARCH_STM32F7
|
set PROJECT_CPU=ARCH_STM32F7
|
||||||
set EXTRA_PARAMS=-DDUMMY ^
|
|
||||||
-DSTM32F767xx ^
|
|
||||||
-DEFI_USE_OSC=TRUE ^
|
|
||||||
-DFIRMWARE_ID=\"microRusEfi\" ^
|
|
||||||
-DEFI_COMMUNICATION_PIN=GPIOE_1 ^
|
|
||||||
-DEFI_FATAL_ERROR_PIN=GPIOE_2 ^
|
|
||||||
-DEFI_RUNNING_PIN=GPIOE_3 ^
|
|
||||||
-DEFI_WARNING_PIN=GPIOE_4
|
|
||||||
|
|
||||||
call config/boards/common_make.bat
|
call config/boards/common_make.bat
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
# List of all the board related files.
|
||||||
|
BOARDSRC = $(CHIBIOS)/os/hal/boards/ST_NUCLEO144_F767ZI/board.c
|
||||||
|
BOARDSRC_CPP = $(PROJECT_DIR)/config/boards/microrusefi/board_configuration.cpp
|
||||||
|
|
||||||
|
# Required include directories
|
||||||
|
BOARDINC = $(PROJECT_DIR)/config/boards/nucleo_f767 $(PROJECT_DIR)/config/stm32f7ems
|
||||||
|
|
||||||
|
LDSCRIPT= $(PROJECT_DIR)/config/boards/nucleo_f767/STM32F76xxI.ld
|
||||||
|
|
||||||
|
# Override DEFAULT_ENGINE_TYPE
|
||||||
|
DDEFS += -DDEFAULT_ENGINE_TYPE=MICRO_RUS_EFI -DSTM32F767xx -DEFI_USE_OSC=TRUE -DFIRMWARE_ID=\"microRusEfi\"
|
|
@ -0,0 +1,172 @@
|
||||||
|
/**
|
||||||
|
* @file boards/microrusefi/board_configuration.cpp
|
||||||
|
*
|
||||||
|
* @brief Configuration defaults for the microRusefi board
|
||||||
|
*
|
||||||
|
* @author Matthew Kennedy, (c) 2019
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "global.h"
|
||||||
|
#include "engine.h"
|
||||||
|
#include "engine_math.h"
|
||||||
|
#include "allsensors.h"
|
||||||
|
#include "fsio_impl.h"
|
||||||
|
#include "engine_configuration.h"
|
||||||
|
|
||||||
|
EXTERN_ENGINE;
|
||||||
|
|
||||||
|
static void setInjectorPins()
|
||||||
|
{
|
||||||
|
boardConfiguration->injectionPins[0] = GPIOE_14;
|
||||||
|
boardConfiguration->injectionPins[1] = GPIOE_13;
|
||||||
|
boardConfiguration->injectionPins[2] = GPIOE_12;
|
||||||
|
boardConfiguration->injectionPins[3] = GPIOE_11;
|
||||||
|
|
||||||
|
// Disable remainder
|
||||||
|
for (int i = 4; i < INJECTION_PIN_COUNT;i++) {
|
||||||
|
boardConfiguration->injectionPins[i] = GPIO_UNASSIGNED;
|
||||||
|
}
|
||||||
|
|
||||||
|
boardConfiguration->injectionPinMode = OM_DEFAULT;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void setIgnitionPins()
|
||||||
|
{
|
||||||
|
boardConfiguration->ignitionPins[0] = GPIOD_4;
|
||||||
|
boardConfiguration->ignitionPins[1] = GPIOD_3;
|
||||||
|
boardConfiguration->ignitionPins[2] = GPIOD_2;
|
||||||
|
boardConfiguration->ignitionPins[3] = GPIOD_1;
|
||||||
|
|
||||||
|
// disable remainder
|
||||||
|
for (int i = 4; i < IGNITION_PIN_COUNT; i++) {
|
||||||
|
boardConfiguration->ignitionPins[i] = GPIO_UNASSIGNED;
|
||||||
|
}
|
||||||
|
|
||||||
|
boardConfiguration->ignitionPinMode = OM_DEFAULT;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void setLedPins()
|
||||||
|
{
|
||||||
|
engineConfiguration->fatalErrorPin = GPIOE_3; // d21 = red
|
||||||
|
engineConfiguration->communicationLedPin = GPIOE_2; // d23 = blue
|
||||||
|
engineConfiguration->runningLedPin = GPIOE_4; // d22 = green
|
||||||
|
boardConfiguration->triggerErrorPin = GPIOE_1; // d27 = orange
|
||||||
|
}
|
||||||
|
|
||||||
|
static void setupVbatt()
|
||||||
|
{
|
||||||
|
engineConfiguration->vbattDividerCoeff = 8.166666f;
|
||||||
|
engineConfiguration->vbattAdcChannel = EFI_ADC_11;
|
||||||
|
|
||||||
|
// 1k high side/1.5k low side = 1.6667 ratio divider
|
||||||
|
engineConfiguration->analogInputDividerCoefficient = 2.5f / 1.5f;
|
||||||
|
|
||||||
|
engineConfiguration->adcVcc = 3.29f;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void setupTle8888()
|
||||||
|
{
|
||||||
|
// Enable spi3
|
||||||
|
boardConfiguration->is_enabled_spi_3 = true;
|
||||||
|
|
||||||
|
// Wire up spi3
|
||||||
|
boardConfiguration->spi3mosiPin = GPIOB_5;
|
||||||
|
boardConfiguration->spi3misoPin = GPIOB_4;
|
||||||
|
boardConfiguration->spi3sckPin = GPIOB_3;
|
||||||
|
|
||||||
|
// Chip select
|
||||||
|
engineConfiguration->tle8888_cs = GPIOD_5;
|
||||||
|
|
||||||
|
// SPI device
|
||||||
|
engineConfiguration->tle8888spiDevice = SPI_DEVICE_3;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void setupEtb()
|
||||||
|
{
|
||||||
|
// TLE9201 driver
|
||||||
|
// This chip has three control pins:
|
||||||
|
// DIR - sets direction of the motor
|
||||||
|
// PWM - pwm control (enable high, coast low)
|
||||||
|
// DIS - disables motor (enable low)
|
||||||
|
|
||||||
|
// PWM pin
|
||||||
|
boardConfiguration->etb1.controlPin1 = GPIOC_7;
|
||||||
|
// DIR pin
|
||||||
|
boardConfiguration->etb1.directionPin1 = GPIOA_8;
|
||||||
|
|
||||||
|
// Unused
|
||||||
|
boardConfiguration->etb1.controlPin2 = GPIO_UNASSIGNED;
|
||||||
|
boardConfiguration->etb1.directionPin2 = GPIO_UNASSIGNED;
|
||||||
|
|
||||||
|
// we only have pwm/dir, no dira/dirb
|
||||||
|
engineConfiguration->etb1_use_two_wires = false;
|
||||||
|
|
||||||
|
engineConfiguration->etbFreq = 800;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void setupDefaultSensorInputs()
|
||||||
|
{
|
||||||
|
// trigger inputs
|
||||||
|
// tle8888 VR conditioner
|
||||||
|
boardConfiguration->triggerInputPins[0] = GPIOC_6;
|
||||||
|
boardConfiguration->triggerInputPins[1] = GPIO_UNASSIGNED;
|
||||||
|
boardConfiguration->triggerInputPins[2] = GPIO_UNASSIGNED;
|
||||||
|
// Direct hall-only cam input
|
||||||
|
engineConfiguration->camInputs[0] = GPIOA_5;
|
||||||
|
|
||||||
|
// tps
|
||||||
|
engineConfiguration->tps1_1AdcChannel = EFI_ADC_13;
|
||||||
|
engineConfiguration->tps2_1AdcChannel = EFI_ADC_NONE;
|
||||||
|
|
||||||
|
// clt = AN temp 1
|
||||||
|
engineConfiguration->clt.adcChannel = EFI_ADC_0;
|
||||||
|
engineConfiguration->clt.config.bias_resistor = 2700;
|
||||||
|
|
||||||
|
// iat = AN temp 2
|
||||||
|
engineConfiguration->iat.adcChannel = EFI_ADC_1;
|
||||||
|
engineConfiguration->iat.config.bias_resistor = 2700;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setPinConfigurationOverrides(void) {
|
||||||
|
}
|
||||||
|
|
||||||
|
void setSerialConfigurationOverrides(void) {
|
||||||
|
boardConfiguration->useSerialPort = false;
|
||||||
|
engineConfiguration->binarySerialTxPin = GPIO_UNASSIGNED;
|
||||||
|
engineConfiguration->binarySerialRxPin = GPIO_UNASSIGNED;
|
||||||
|
engineConfiguration->consoleSerialTxPin = GPIO_UNASSIGNED;
|
||||||
|
engineConfiguration->consoleSerialRxPin = GPIO_UNASSIGNED;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Board-specific configuration code overrides.
|
||||||
|
* @todo Add your board-specific code, if any.
|
||||||
|
*/
|
||||||
|
void setBoardConfigurationOverrides(void) {
|
||||||
|
setInjectorPins();
|
||||||
|
setIgnitionPins();
|
||||||
|
setLedPins();
|
||||||
|
setupVbatt();
|
||||||
|
setupTle8888();
|
||||||
|
setupEtb();
|
||||||
|
|
||||||
|
// "required" hardware is done - set some reasonable defaults
|
||||||
|
setupDefaultSensorInputs();
|
||||||
|
|
||||||
|
// Some sensible defaults for other options
|
||||||
|
setOperationMode(engineConfiguration, FOUR_STROKE_CRANK_SENSOR);
|
||||||
|
engineConfiguration->trigger.type = TT_TOOTHED_WHEEL_60_2;
|
||||||
|
engineConfiguration->useOnlyRisingEdgeForTrigger = true;
|
||||||
|
setAlgorithm(LM_SPEED_DENSITY PASS_CONFIG_PARAMETER_SUFFIX);
|
||||||
|
|
||||||
|
engineConfiguration->specs.cylindersCount = 4;
|
||||||
|
engineConfiguration->specs.firingOrder = FO_1_3_4_2;
|
||||||
|
|
||||||
|
engineConfiguration->ignitionMode = IM_INDIVIDUAL_COILS; // IM_WASTED_SPARK
|
||||||
|
engineConfiguration->crankingInjectionMode = IM_SIMULTANEOUS;
|
||||||
|
engineConfiguration->injectionMode = IM_SIMULTANEOUS;//IM_BATCH;// IM_SEQUENTIAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setAdcChannelOverrides(void) {
|
||||||
|
}
|
|
@ -843,8 +843,6 @@ static void setDefaultEngineConfiguration(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
// todo: start using this for custom MAP
|
// todo: start using this for custom MAP
|
||||||
engineConfiguration->mapHighValueVoltage = 5;
|
engineConfiguration->mapHighValueVoltage = 5;
|
||||||
|
|
||||||
engineConfiguration->displayMode = DM_HD44780;
|
|
||||||
|
|
||||||
engineConfiguration->logFormat = LF_NATIVE;
|
engineConfiguration->logFormat = LF_NATIVE;
|
||||||
engineConfiguration->directSelfStimulation = false;
|
engineConfiguration->directSelfStimulation = false;
|
||||||
|
|
||||||
|
@ -869,6 +867,8 @@ static void setDefaultEngineConfiguration(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
engineConfiguration->isEngineChartEnabled = true;
|
engineConfiguration->isEngineChartEnabled = true;
|
||||||
|
|
||||||
engineConfiguration->useOnlyRisingEdgeForTrigger = false;
|
engineConfiguration->useOnlyRisingEdgeForTrigger = false;
|
||||||
|
// Default this to on - if you want to diagnose, turn it off.
|
||||||
|
engineConfiguration->silentTriggerError = true;
|
||||||
|
|
||||||
#if EFI_PROD_CODE
|
#if EFI_PROD_CODE
|
||||||
engineConfiguration->engineChartSize = 300;
|
engineConfiguration->engineChartSize = 300;
|
||||||
|
@ -909,7 +909,7 @@ static void setDefaultEngineConfiguration(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
|
|
||||||
engineConfiguration->cj125isUaDivided = true;
|
engineConfiguration->cj125isUaDivided = true;
|
||||||
|
|
||||||
engineConfiguration->isAlternatorControlEnabled = true;
|
engineConfiguration->isAlternatorControlEnabled = false;
|
||||||
|
|
||||||
engineConfiguration->vehicleSpeedCoef = 1.0f;
|
engineConfiguration->vehicleSpeedCoef = 1.0f;
|
||||||
|
|
||||||
|
@ -1111,6 +1111,8 @@ void resetConfigurationExt(Logging * logger, engine_type_e engineType DECLARE_EN
|
||||||
setEtbTestConfiguration(PASS_CONFIG_PARAMETER_SIGNATURE);
|
setEtbTestConfiguration(PASS_CONFIG_PARAMETER_SIGNATURE);
|
||||||
break;
|
break;
|
||||||
case MICRO_RUS_EFI:
|
case MICRO_RUS_EFI:
|
||||||
|
// nothing to do - we do it all in setBoardConfigurationOverrides
|
||||||
|
break;
|
||||||
case TLE8888_BENCH_ENGINE:
|
case TLE8888_BENCH_ENGINE:
|
||||||
setTle8888TestConfiguration(PASS_CONFIG_PARAMETER_SIGNATURE);
|
setTle8888TestConfiguration(PASS_CONFIG_PARAMETER_SIGNATURE);
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue