auto-sync

This commit is contained in:
rusEfi 2014-09-03 15:02:56 -05:00
parent 760ac7850f
commit cb07c7d50b
7 changed files with 72 additions and 16 deletions

View File

@ -2,6 +2,7 @@
* @file citroenBerlingoTU3JP.cpp * @file citroenBerlingoTU3JP.cpp
* *
* CITROEN_TU3JP: engine_type 15 * CITROEN_TU3JP: engine_type 15
* Board pin out for Frankenstein
* *
* This config overrides some values of the default configuration which is set by setDefaultConfiguration() method * This config overrides some values of the default configuration which is set by setDefaultConfiguration() method
* *
@ -10,22 +11,73 @@
* @author Andrey Belomutskiy, (c) 2012-2014 * @author Andrey Belomutskiy, (c) 2012-2014
*/ */
#include "thermistors.h"
#include "citroenBerlingoTU3JP.h" #include "citroenBerlingoTU3JP.h"
void setCitroenBerlingoTU3JPConfiguration(engine_configuration_s *engineConfiguration, board_configuration_s *boardConfiguration) { void setCitroenBerlingoTU3JPConfiguration(engine_configuration_s *engineConfiguration, board_configuration_s *boardConfiguration) {
engineConfiguration->engineType = CITROEN_TU3JP; engineConfiguration->engineType = CITROEN_TU3JP;
// base engine setting
engineConfiguration->triggerConfig.triggerType = TT_TOOTHED_WHEEL_60_2; engineConfiguration->triggerConfig.triggerType = TT_TOOTHED_WHEEL_60_2;
engineConfiguration->cylindersCount = 4;
// set_cranking_injection_mode 0 engineConfiguration->displacement = 1.390;
engineConfiguration->crankingInjectionMode = IM_SIMULTANEOUS;
// set_injection_mode 2
engineConfiguration->injectionMode = IM_BATCH;
// set_ignition_mode 2
engineConfiguration->ignitionMode = IM_WASTED_SPARK;
// set_firing_order 2
engineConfiguration->firingOrder = FO_1_THEN_3_THEN_4_THEN2; engineConfiguration->firingOrder = FO_1_THEN_3_THEN_4_THEN2;
engineConfiguration->ignitionMode = IM_WASTED_SPARK;
engineConfiguration->injectionMode = IM_BATCH;
engineConfiguration->crankingInjectionMode = IM_SIMULTANEOUS;
// rpm limiter
engineConfiguration->rpmHardLimit = 5000;
// set thermistor
setThermistorConfiguration(&engineConfiguration->cltThermistorConf, -40.0, 100700.0, 25.0, 2796.0, 100.0, 177.0);
engineConfiguration->cltThermistorConf.bias_resistor = 2700; // eah winter is hard, sensor as LADA Samara :)
setThermistorConfiguration(&engineConfiguration->iatThermistorConf, -20.0, 15600.0, 23.0, 2250.0, 92.0, 240.0);
engineConfiguration->iatThermistorConf.bias_resistor = 2700; // same as OEM ECU
/**
* Outputs
*/
// Frankenstain low out #3: PE6 injector 1-4
// Frankenstain low out #4: PC13 injector 2-3
// boardConfiguration->o2heaterPin = GPIOC_13;
boardConfiguration->injectionPins[0] = GPIOE_6;
boardConfiguration->injectionPins[1] = GPIOC_13;
boardConfiguration->injectionPins[2] = GPIO_NONE;
boardConfiguration->injectionPins[3] = GPIO_NONE;
// boardConfiguration->ignitionPins[0] = GPIOE_NONE;
// boardConfiguration->ignitionPins[1] = GPIO_NONE;
// boardConfiguration->ignitionPins[2] = GPIO_NONE;
// boardConfiguration->ignitionPins[3] = GPIO_NONE;
boardConfiguration->fuelPumpPin = GPIOE_3; // temporary value pin
boardConfiguration->fuelPumpPinMode = OM_DEFAULT;
// boardConfiguration->logicAnalyzerPins[1] = GPIO_NONE;
// Frankenstein analog input #1: adc1
// Frankenstein analog input #2: adc3
// Frankenstein analog input #3: adc13
// Frankenstein analog input #4: adc11
// todo: see https://docs.google.com/spreadsheet/ccc?key=0Arl1FeMZcfisdEdGdUlHdWh6cVBoSzFIbkxqa1QtZ3c
// Frankenstein analog input #5: adc
// Frankenstein analog input #6: adc
// Frankenstein analog input #7: adc
// Frankenstein analog input #8: adc
// Frankenstein analog input #9: adc
// Frankenstein analog input #10: adc
// Frankenstein analog input #11: adc
// Frankenstein analog input #12: adc
engineConfiguration->mafAdcChannel = EFI_ADC_1;
engineConfiguration->tpsAdcChannel = EFI_ADC_3;
engineConfiguration->cltAdcChannel = EFI_ADC_11;
engineConfiguration->map.sensor.sensorType = MT_CUSTOM;
engineConfiguration->map.sensor.customValueAt0 = 20;
engineConfiguration->map.sensor.customValueAt5 = 200;
} }

View File

@ -71,6 +71,7 @@ static void common079721_2351(engine_configuration_s *engineConfiguration, board
// Frankenstein analog input #2: adc3 // Frankenstein analog input #2: adc3
// Frankenstein analog input #3: adc13 // Frankenstein analog input #3: adc13
// Frankenstein analog input #4: adc11 // Frankenstein analog input #4: adc11
// todo: see https://docs.google.com/spreadsheet/ccc?key=0Arl1FeMZcfisdEdGdUlHdWh6cVBoSzFIbkxqa1QtZ3c
// Frankenstein analog input #5: adc // Frankenstein analog input #5: adc
// Frankenstein analog input #6: adc // Frankenstein analog input #6: adc
// Frankenstein analog input #7: adc // Frankenstein analog input #7: adc

View File

@ -232,8 +232,8 @@ void setDefaultConfiguration(engine_configuration_s *engineConfiguration, board_
engineConfiguration->map.sensor.sensorType = MT_MPX4250; engineConfiguration->map.sensor.sensorType = MT_MPX4250;
engineConfiguration->baroSensor.sensorType = MT_CUSTOM; engineConfiguration->baroSensor.sensorType = MT_CUSTOM;
engineConfiguration->baroSensor.Min = 0; engineConfiguration->baroSensor.customValueAt0 = 0;
engineConfiguration->baroSensor.Max = 500; engineConfiguration->baroSensor.customValueAt5 = 500;
engineConfiguration->diffLoadEnrichmentCoef = 1; engineConfiguration->diffLoadEnrichmentCoef = 1;

View File

@ -30,7 +30,7 @@ float decodePressure(float voltage, air_pressure_sensor_config_s * config) {
switch (config->sensorType) { switch (config->sensorType) {
case MT_CUSTOM: case MT_CUSTOM:
// todo: introduce 'FastInterpolation customMap' // todo: introduce 'FastInterpolation customMap'
return interpolate(0, config->Min, 5, config->Max, voltage); return interpolate(0, config->customValueAt0, 5, config->customValueAt5, voltage);
case MT_DENSO183: case MT_DENSO183:
return denso183.getValue(voltage); return denso183.getValue(voltage);
case MT_MPX4250: case MT_MPX4250:

View File

@ -17,8 +17,11 @@ typedef struct {
/** /**
* kPa value at zero volts * kPa value at zero volts
*/ */
float Min; float customValueAt0;
float Max; /**
* kPa value at 5 volts
*/
float customValueAt5;
air_pressure_sensor_type_e sensorType; air_pressure_sensor_type_e sensorType;
adc_channel_e hwChannel; adc_channel_e hwChannel;
} air_pressure_sensor_config_s; } air_pressure_sensor_config_s;

View File

@ -314,12 +314,12 @@ static void printMAPInfo(void) {
scheduleMsg(&logger, "map type=%d raw=%f MAP=%f", engineConfiguration->map.sensor.sensorType, getRawMap(), scheduleMsg(&logger, "map type=%d raw=%f MAP=%f", engineConfiguration->map.sensor.sensorType, getRawMap(),
getMap()); getMap());
if (engineConfiguration->map.sensor.sensorType == MT_CUSTOM) { if (engineConfiguration->map.sensor.sensorType == MT_CUSTOM) {
scheduleMsg(&logger, "min=%f max=%f", engineConfiguration->map.sensor.Min, engineConfiguration->map.sensor.Max); scheduleMsg(&logger, "at0=%f at5=%f", engineConfiguration->map.sensor.customValueAt0, engineConfiguration->map.sensor.customValueAt5);
} }
scheduleMsg(&logger, "baro type=%d value=%f", engineConfiguration->baroSensor.sensorType, getBaroPressure()); scheduleMsg(&logger, "baro type=%d value=%f", engineConfiguration->baroSensor.sensorType, getBaroPressure());
if (engineConfiguration->baroSensor.sensorType == MT_CUSTOM) { if (engineConfiguration->baroSensor.sensorType == MT_CUSTOM) {
scheduleMsg(&logger, "min=%f max=%f", engineConfiguration->baroSensor.Min, engineConfiguration->baroSensor.Max); scheduleMsg(&logger, "min=%f max=%f", engineConfiguration->baroSensor.customValueAt0, engineConfiguration->baroSensor.customValueAt5);
} }
} }
#endif #endif

View File

@ -229,5 +229,5 @@ void firmwareError(const char *fmt, ...) {
} }
int getRusEfiVersion(void) { int getRusEfiVersion(void) {
return 20140901; return 20140903;
} }