auto-sync
This commit is contained in:
parent
e73808f0da
commit
0ceb38dd07
|
@ -58,6 +58,11 @@ extern board_configuration_s *boardConfiguration;
|
|||
persistent_config_container_s persistentState CCM_OPTIONAL
|
||||
;
|
||||
|
||||
/**
|
||||
* todo: it really looks like these fields should become 'static', i.e. private
|
||||
* the whole 'extern ...' pattern is less then perfect, I guess the 'God object' Engine
|
||||
* would be a smaller evil. Whatever is needed should be passed into methods/modules/files as an explicit parameter.
|
||||
*/
|
||||
engine_configuration_s *engineConfiguration = &persistentState.persistentConfiguration.engineConfiguration;
|
||||
board_configuration_s *boardConfiguration = &persistentState.persistentConfiguration.engineConfiguration.bc;
|
||||
|
||||
|
@ -79,6 +84,9 @@ static configuration_s cfg = { &persistentState.persistentConfiguration.engineCo
|
|||
|
||||
configuration_s * configuration = &cfg;
|
||||
|
||||
/**
|
||||
* todo: this should probably become 'static', i.e. private, and propagated around explicitly?
|
||||
*/
|
||||
Engine engine;
|
||||
|
||||
static msg_t csThread(void) {
|
||||
|
|
|
@ -219,7 +219,7 @@ float getTriggerDutyCycle(int index) {
|
|||
return triggerCentral.triggerState.getTriggerDutyCycle(index);
|
||||
}
|
||||
|
||||
void initTriggerCentral(void) {
|
||||
void initTriggerCentral(Engine *engine) {
|
||||
strcpy((char*) shaft_signal_msg_index, "_");
|
||||
|
||||
#if EFI_WAVE_CHART
|
||||
|
|
|
@ -16,6 +16,7 @@ typedef void (*ShaftPositionListener)(trigger_event_e signal, int index, void *a
|
|||
|
||||
#ifdef __cplusplus
|
||||
#include "ec2.h"
|
||||
#include "engine.h"
|
||||
|
||||
#define HW_EVENT_TYPES 6
|
||||
|
||||
|
@ -36,7 +37,7 @@ uint64_t getCrankEventCounter(void);
|
|||
uint64_t getStartOfRevolutionIndex(void);
|
||||
void hwHandleShaftSignal(trigger_event_e signal);
|
||||
float getTriggerDutyCycle(int index);
|
||||
void initTriggerCentral(void);
|
||||
void initTriggerCentral(Engine *engine);
|
||||
void printAllCallbacksHistogram(void);
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
|
|
@ -39,9 +39,7 @@
|
|||
#include "engine_configuration.h"
|
||||
#include "ec2.h"
|
||||
|
||||
extern engine_configuration_s *engineConfiguration;
|
||||
extern engine_configuration2_s * engineConfiguration2;
|
||||
extern board_configuration_s *boardConfiguration;
|
||||
|
||||
static bool isSpiInitialized[5] = { false, false, false, false, false };
|
||||
|
||||
|
@ -103,7 +101,7 @@ void turnOnSpi(spi_device_e device) {
|
|||
}
|
||||
}
|
||||
|
||||
void initSpiModules(void) {
|
||||
static void initSpiModules(board_configuration_s *boardConfiguration) {
|
||||
if (boardConfiguration->is_enabled_spi_2) {
|
||||
turnOnSpi(SPI_DEVICE_2);
|
||||
}
|
||||
|
@ -134,7 +132,10 @@ static void sendI2Cbyte(int addr, int data) {
|
|||
// i2cReleaseBus(&I2CD1);
|
||||
}
|
||||
|
||||
void initHardware(Logging *logger) {
|
||||
void initHardware(Logging *logger, Engine *engine) {
|
||||
engine_configuration_s *engineConfiguration = engine->engineConfiguration;
|
||||
board_configuration_s *boardConfiguration = &engineConfiguration->bc;
|
||||
|
||||
printMsg(logger, "initHardware()");
|
||||
// todo: enable protection. it's disabled because it takes
|
||||
// 10 extra seconds to re-flash the chip
|
||||
|
@ -211,13 +212,13 @@ void initHardware(Logging *logger) {
|
|||
// requestAdcValue(&adcState, 0);
|
||||
|
||||
// todo: figure out better startup logic
|
||||
initTriggerCentral();
|
||||
initTriggerCentral(engine);
|
||||
|
||||
#if EFI_SHAFT_POSITION_INPUT
|
||||
initShaftPositionInputCapture();
|
||||
#endif /* EFI_SHAFT_POSITION_INPUT */
|
||||
|
||||
initSpiModules();
|
||||
initSpiModules(boardConfiguration);
|
||||
|
||||
#if EFI_FILE_LOGGING
|
||||
initMmcCard();
|
||||
|
|
|
@ -25,6 +25,9 @@ void unlockSpi(void);
|
|||
|
||||
#define GET_BOARD_TEST_MODE_VALUE() (!palReadPad(getHwPort(boardConfiguration->boardTestModeJumperPin), getHwPin(boardConfiguration->boardTestModeJumperPin)))
|
||||
|
||||
void initHardware(Logging *logging);
|
||||
#ifdef __cplusplus
|
||||
#include "engine.h"
|
||||
void initHardware(Logging *logging, Engine *engine);
|
||||
#endif /* __cplusplus */
|
||||
|
||||
#endif /* HARDWARE_H_ */
|
||||
|
|
|
@ -120,6 +120,7 @@ static MemoryStream firmwareErrorMessageStream;
|
|||
uint8_t errorMessageBuffer[200];
|
||||
static bool hasFirmwareErrorFlag = FALSE;
|
||||
extern board_configuration_s *boardConfiguration;
|
||||
extern Engine engine;
|
||||
|
||||
char *getFirmwareError(void) {
|
||||
return (char*)errorMessageBuffer;
|
||||
|
@ -146,7 +147,7 @@ void runRusEfi(void) {
|
|||
/**
|
||||
* Initialize hardware drivers
|
||||
*/
|
||||
initHardware(&logging);
|
||||
initHardware(&logging, &engine);
|
||||
|
||||
initStatusLoop();
|
||||
/**
|
||||
|
@ -229,5 +230,5 @@ void firmwareError(const char *fmt, ...) {
|
|||
}
|
||||
|
||||
int getRusEfiVersion(void) {
|
||||
return 20140907;
|
||||
return 20140908;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue