auto-sync
This commit is contained in:
parent
f479be80df
commit
3f841aead2
|
@ -82,7 +82,7 @@ void setBmwE34(DECLARE_ENGINE_PARAMETER_F) {
|
||||||
boardConfiguration->idle.solenoidPinMode = OM_INVERTED;
|
boardConfiguration->idle.solenoidPinMode = OM_INVERTED;
|
||||||
boardConfiguration->idle.solenoidFrequency = 300;
|
boardConfiguration->idle.solenoidFrequency = 300;
|
||||||
// set_idle_pwm 50
|
// set_idle_pwm 50
|
||||||
boardConfiguration->idlePosition = 0.5;
|
boardConfiguration->idlePosition = 50;
|
||||||
|
|
||||||
// turbocharger boost control solenoid: TODO output: GPIOE_6
|
// turbocharger boost control solenoid: TODO output: GPIOE_6
|
||||||
// water injection #1 TODO GPIOD_7
|
// water injection #1 TODO GPIOD_7
|
||||||
|
|
|
@ -360,7 +360,7 @@ void setDefaultConfiguration(DECLARE_ENGINE_PARAMETER_F) {
|
||||||
|
|
||||||
boardConfiguration->idle.solenoidFrequency = 200;
|
boardConfiguration->idle.solenoidFrequency = 200;
|
||||||
// set_idle_position 50
|
// set_idle_position 50
|
||||||
boardConfiguration->idlePosition = 0.5;
|
boardConfiguration->idlePosition = 50;
|
||||||
engineConfiguration->targetIdleRpm = 1200;
|
engineConfiguration->targetIdleRpm = 1200;
|
||||||
// engineConfiguration->idleMode = IM_AUTO;
|
// engineConfiguration->idleMode = IM_AUTO;
|
||||||
engineConfiguration->idleMode = IM_MANUAL;
|
engineConfiguration->idleMode = IM_MANUAL;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
// this section was generated by config_definition.jar on Fri Apr 03 20:20:44 EDT 2015
|
// this section was generated by config_definition.jar on Fri Apr 03 21:10:20 EDT 2015
|
||||||
// begin
|
// begin
|
||||||
#include "rusefi_types.h"
|
#include "rusefi_types.h"
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -255,7 +255,7 @@ typedef struct {
|
||||||
*/
|
*/
|
||||||
idle_hardware_s idle;
|
idle_hardware_s idle;
|
||||||
/**
|
/**
|
||||||
* value between 0 and 1
|
* value between 0 and 100
|
||||||
* offset 20
|
* offset 20
|
||||||
*/
|
*/
|
||||||
float idlePosition;
|
float idlePosition;
|
||||||
|
@ -1235,4 +1235,4 @@ typedef struct {
|
||||||
} engine_configuration_s;
|
} engine_configuration_s;
|
||||||
|
|
||||||
// end
|
// end
|
||||||
// this section was generated by config_definition.jar on Fri Apr 03 20:20:44 EDT 2015
|
// this section was generated by config_definition.jar on Fri Apr 03 21:10:20 EDT 2015
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
#include "engine_configuration.h"
|
#include "engine_configuration.h"
|
||||||
#include "engine.h"
|
#include "engine.h"
|
||||||
|
|
||||||
#define FLASH_DATA_VERSION 7599
|
#define FLASH_DATA_VERSION 7600
|
||||||
|
|
||||||
void readFromFlash(void);
|
void readFromFlash(void);
|
||||||
void initFlash(Logging *sharedLogger, Engine *engine);
|
void initFlash(Logging *sharedLogger, Engine *engine);
|
||||||
|
|
|
@ -46,6 +46,11 @@ static SimplePwm idleValvePwm;
|
||||||
|
|
||||||
static StepperMotor iacMotor;
|
static StepperMotor iacMotor;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* that's the position with CLT and IAT corrections
|
||||||
|
*/
|
||||||
|
static float actualIdlePosition = -1.0f;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Idle level calculation algorithm lives in idle_controller.cpp
|
* Idle level calculation algorithm lives in idle_controller.cpp
|
||||||
*/
|
*/
|
||||||
|
@ -75,17 +80,17 @@ static void setIdleValvePwm(percent_t value) {
|
||||||
if (value < 0.01 || value > 99.9)
|
if (value < 0.01 || value > 99.9)
|
||||||
return;
|
return;
|
||||||
scheduleMsg(logger, "setting idle valve PWM %f", value);
|
scheduleMsg(logger, "setting idle valve PWM %f", value);
|
||||||
float f = 0.01 * value;
|
|
||||||
boardConfiguration->idlePosition = f;
|
|
||||||
showIdleInfo();
|
showIdleInfo();
|
||||||
/**
|
/**
|
||||||
* currently idle level is an percent value (0-100 range), and PWM takes a float in the 0..1 range
|
* currently idle level is an percent value (0-100 range), and PWM takes a float in the 0..1 range
|
||||||
* todo: unify?
|
* todo: unify?
|
||||||
*/
|
*/
|
||||||
idleValvePwm.setSimplePwmDutyCycle(f);
|
idleValvePwm.setSimplePwmDutyCycle(value / 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setIdleValvePosition(int position) {
|
static void setIdleValvePosition(int position) {
|
||||||
|
boardConfiguration->idlePosition = position;
|
||||||
|
|
||||||
if (boardConfiguration->useStepperIdle) {
|
if (boardConfiguration->useStepperIdle) {
|
||||||
iacMotor.targetPosition = position;
|
iacMotor.targetPosition = position;
|
||||||
} else {
|
} else {
|
||||||
|
@ -153,7 +158,7 @@ void startIdleThread(Logging*sharedLogger, Engine *engine) {
|
||||||
* Start PWM for idleValvePin
|
* Start PWM for idleValvePin
|
||||||
*/
|
*/
|
||||||
startSimplePwmExt(&idleValvePwm, "Idle Valve", boardConfiguration->idle.solenoidPin, &idlePin,
|
startSimplePwmExt(&idleValvePwm, "Idle Valve", boardConfiguration->idle.solenoidPin, &idlePin,
|
||||||
boardConfiguration->idle.solenoidFrequency, boardConfiguration->idlePosition,
|
boardConfiguration->idle.solenoidFrequency, boardConfiguration->idlePosition / 100,
|
||||||
applyIdleSolenoidPinState);
|
applyIdleSolenoidPinState);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/**
|
/**
|
||||||
* @file io_pins.c
|
* @file io_pins.cpp
|
||||||
* @brief It could be that the main purpose of this file is the status LED blinking
|
* @brief It could be that the main purpose of this file is the status LED blinking
|
||||||
*
|
*
|
||||||
* @date Jan 24, 2013
|
* @date Jan 24, 2013
|
||||||
|
@ -64,7 +64,7 @@ GPIO_TypeDef * getHwPort(brain_pin_e brainPin) {
|
||||||
firmwareError("Invalid brain_pin_e: %d", brainPin);
|
firmwareError("Invalid brain_pin_e: %d", brainPin);
|
||||||
return GPIO_NULL;
|
return GPIO_NULL;
|
||||||
}
|
}
|
||||||
return PORTS[brainPin / 16];
|
return PORTS[brainPin / PORT_SIZE];
|
||||||
}
|
}
|
||||||
|
|
||||||
ioportmask_t getHwPin(brain_pin_e brainPin) {
|
ioportmask_t getHwPin(brain_pin_e brainPin) {
|
||||||
|
@ -74,7 +74,7 @@ ioportmask_t getHwPin(brain_pin_e brainPin) {
|
||||||
firmwareError("Invalid brain_pin_e: %d", brainPin);
|
firmwareError("Invalid brain_pin_e: %d", brainPin);
|
||||||
return EFI_ERROR_CODE;
|
return EFI_ERROR_CODE;
|
||||||
}
|
}
|
||||||
return brainPin % 16;
|
return brainPin % PORT_SIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void outputPinRegisterExt2(const char *msg, OutputPin *output, brain_pin_e brainPin, pin_output_mode_e *outputMode) {
|
void outputPinRegisterExt2(const char *msg, OutputPin *output, brain_pin_e brainPin, pin_output_mode_e *outputMode) {
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
#include "chprintf.h"
|
#include "chprintf.h"
|
||||||
#include "rusefi.h"
|
#include "rusefi.h"
|
||||||
|
|
||||||
#define PIN_REPO_SIZE 7 * 16
|
#define PIN_REPO_SIZE 7 * PORT_SIZE
|
||||||
const char *PIN_USED[PIN_REPO_SIZE];
|
const char *PIN_USED[PIN_REPO_SIZE];
|
||||||
static int initialized = FALSE;
|
static int initialized = FALSE;
|
||||||
|
|
||||||
|
@ -70,8 +70,9 @@ static int getPortIndex(GPIO_TypeDef* port) {
|
||||||
static void reportPins(void) {
|
static void reportPins(void) {
|
||||||
for (int i = 0; i < PIN_REPO_SIZE; i++) {
|
for (int i = 0; i < PIN_REPO_SIZE; i++) {
|
||||||
const char *name = PIN_USED[i];
|
const char *name = PIN_USED[i];
|
||||||
if (name != NULL)
|
if (name != NULL) {
|
||||||
print("ping %d: %s\r\n", i, name);
|
print("pin %d: %s\r\n", i, name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
print("Total pins count: %d\r\n", totalPinsUsed);
|
print("Total pins count: %d\r\n", totalPinsUsed);
|
||||||
|
@ -157,7 +158,7 @@ iomode_t getInputMode(pin_input_mode_e mode) {
|
||||||
|
|
||||||
static int getIndex(ioportid_t port, ioportmask_t pin) {
|
static int getIndex(ioportid_t port, ioportmask_t pin) {
|
||||||
int portIndex = getPortIndex(port);
|
int portIndex = getPortIndex(port);
|
||||||
return portIndex * 16 + pin;
|
return portIndex * PORT_SIZE + pin;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char * getPinFunction(brain_input_pin_e brainPin) {
|
const char * getPinFunction(brain_input_pin_e brainPin) {
|
||||||
|
|
|
@ -21,27 +21,29 @@
|
||||||
void outputPinRegister(const char *msg, OutputPin *output, GPIO_TypeDef *port, uint32_t pin);
|
void outputPinRegister(const char *msg, OutputPin *output, GPIO_TypeDef *port, uint32_t pin);
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
#define PORT_SIZE 16
|
||||||
|
|
||||||
|
void initPinRepository(void);
|
||||||
|
brain_pin_e parseBrainPin(const char *str);
|
||||||
|
void mySetPadMode(const char *msg, ioportid_t port, ioportmask_t pin, iomode_t mode);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C"
|
extern "C"
|
||||||
{
|
{
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
void initPinRepository(void);
|
|
||||||
const char *hwPortname(brain_pin_e brainPin);
|
const char *hwPortname(brain_pin_e brainPin);
|
||||||
brain_pin_e parseBrainPin(const char *str);
|
|
||||||
void mySetPadMode(const char *msg, ioportid_t port, ioportmask_t pin, iomode_t mode);
|
|
||||||
const char * getPinFunction(brain_input_pin_e brainPin);
|
const char * getPinFunction(brain_input_pin_e brainPin);
|
||||||
void mySetPadMode2(const char *msg, brain_pin_e pin, iomode_t mode);
|
void mySetPadMode2(const char *msg, brain_pin_e pin, iomode_t mode);
|
||||||
const char *portname(GPIO_TypeDef* GPIOx);
|
const char *portname(GPIO_TypeDef* GPIOx);
|
||||||
iomode_t getInputMode(pin_input_mode_e mode);
|
|
||||||
|
|
||||||
ioportmask_t getHwPin(brain_pin_e brainPin);
|
|
||||||
GPIO_TypeDef * getHwPort(brain_pin_e brainPin);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
iomode_t getInputMode(pin_input_mode_e mode);
|
||||||
void efiIcuStart(ICUDriver *icup, const ICUConfig *config);
|
void efiIcuStart(ICUDriver *icup, const ICUConfig *config);
|
||||||
|
ioportmask_t getHwPin(brain_pin_e brainPin);
|
||||||
|
GPIO_TypeDef * getHwPort(brain_pin_e brainPin);
|
||||||
|
|
||||||
#endif /* PIN_REPOSITORY_H_ */
|
#endif /* PIN_REPOSITORY_H_ */
|
||||||
|
|
|
@ -54,7 +54,9 @@ StepperMotor::StepperMotor() {
|
||||||
currentPosition = 0;
|
currentPosition = 0;
|
||||||
targetPosition = 0;
|
targetPosition = 0;
|
||||||
directionPort = NULL;
|
directionPort = NULL;
|
||||||
|
directionPin = 0;
|
||||||
stepPort = NULL;
|
stepPort = NULL;
|
||||||
|
stepPin = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void StepperMotor::pulse() {
|
void StepperMotor::pulse() {
|
||||||
|
|
|
@ -267,7 +267,7 @@ struct_no_prefix board_configuration_s
|
||||||
idle_hardware_s idle;
|
idle_hardware_s idle;
|
||||||
|
|
||||||
|
|
||||||
float idlePosition;value between 0 and 1;"%", 1, 0, 0, 100, 0
|
float idlePosition;value between 0 and 100;"%", 1, 0, 0, 100, 0
|
||||||
|
|
||||||
brain_pin_e fuelPumpPin;
|
brain_pin_e fuelPumpPin;
|
||||||
pin_output_mode_e fuelPumpPinMode;
|
pin_output_mode_e fuelPumpPinMode;
|
||||||
|
|
|
@ -40,7 +40,7 @@ enable2ndByteCanID = false
|
||||||
|
|
||||||
; see PAGE_0_SIZE in C source code
|
; see PAGE_0_SIZE in C source code
|
||||||
; CONFIG_DEFINITION_START
|
; CONFIG_DEFINITION_START
|
||||||
; this section was generated by ConfigDefinition.jar on Fri Apr 03 20:20:46 EDT 2015
|
; this section was generated by ConfigDefinition.jar on Fri Apr 03 21:10:22 EDT 2015
|
||||||
|
|
||||||
pageSize = 15288
|
pageSize = 15288
|
||||||
page = 1
|
page = 1
|
||||||
|
|
|
@ -389,7 +389,7 @@ int tokenLength(const char *msgp) {
|
||||||
|
|
||||||
void initConsoleLogic(Logging *sharedLogger) {
|
void initConsoleLogic(Logging *sharedLogger) {
|
||||||
logging = sharedLogger;
|
logging = sharedLogger;
|
||||||
resetConsoleActions();
|
// resetConsoleActions();
|
||||||
addConsoleAction("help", helpCommand);
|
addConsoleAction("help", helpCommand);
|
||||||
addConsoleActionI("echo", echo);
|
addConsoleActionI("echo", echo);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue