Hellen says cyclic buffer
This commit is contained in:
parent
375e3b6bcc
commit
d06690b3b6
|
@ -33,7 +33,7 @@ enable2ndByteCanID = false
|
||||||
|
|
||||||
[MegaTune]
|
[MegaTune]
|
||||||
; https://rusefi.com/forum/viewtopic.php?p=36201#p36201
|
; https://rusefi.com/forum/viewtopic.php?p=36201#p36201
|
||||||
signature = @@TS_SIGNATURE@@
|
signature = @@TS_SIGNATURE@@
|
||||||
|
|
||||||
[TunerStudio]
|
[TunerStudio]
|
||||||
queryCommand = "S"
|
queryCommand = "S"
|
||||||
|
@ -285,7 +285,7 @@ enable2ndByteCanID = false
|
||||||
calibrationValue = scalar, F32, 128, "", 1, 0
|
calibrationValue = scalar, F32, 128, "", 1, 0
|
||||||
calibrationMode = scalar, U08, 132, "", 1, 0
|
calibrationMode = scalar, U08, 132, "", 1, 0
|
||||||
; 1 bytes padding1
|
; 1 bytes padding1
|
||||||
|
|
||||||
fuelingLoad = scalar, U16, 134, "%", 0.01, 0
|
fuelingLoad = scalar, U16, 134, "%", 0.01, 0
|
||||||
ignitionLoad = scalar, U16, 136, "%", 0.01, 0
|
ignitionLoad = scalar, U16, 136, "%", 0.01, 0
|
||||||
|
|
||||||
|
@ -440,7 +440,7 @@ enable2ndByteCanID = false
|
||||||
|
|
||||||
requiresPowerCycle = etb_use_two_wires
|
requiresPowerCycle = etb_use_two_wires
|
||||||
requiresPowerCycle = etbFreq
|
requiresPowerCycle = etbFreq
|
||||||
|
|
||||||
requiresPowerCycle = idle_solenoidFrequency
|
requiresPowerCycle = idle_solenoidFrequency
|
||||||
requiresPowerCycle = boostPwmFrequency
|
requiresPowerCycle = boostPwmFrequency
|
||||||
requiresPowerCycle = alternatorPwmFrequency
|
requiresPowerCycle = alternatorPwmFrequency
|
||||||
|
@ -448,7 +448,7 @@ enable2ndByteCanID = false
|
||||||
requiresPowerCycle = auxPidFrequency2
|
requiresPowerCycle = auxPidFrequency2
|
||||||
requiresPowerCycle = auxPidFrequency3
|
requiresPowerCycle = auxPidFrequency3
|
||||||
requiresPowerCycle = auxPidFrequency4
|
requiresPowerCycle = auxPidFrequency4
|
||||||
|
|
||||||
requiresPowerCycle = fsioOutputPins1
|
requiresPowerCycle = fsioOutputPins1
|
||||||
requiresPowerCycle = fsioOutputPins2
|
requiresPowerCycle = fsioOutputPins2
|
||||||
requiresPowerCycle = fsioOutputPins3
|
requiresPowerCycle = fsioOutputPins3
|
||||||
|
@ -465,7 +465,7 @@ enable2ndByteCanID = false
|
||||||
requiresPowerCycle = fsioOutputPins14
|
requiresPowerCycle = fsioOutputPins14
|
||||||
requiresPowerCycle = fsioOutputPins15
|
requiresPowerCycle = fsioOutputPins15
|
||||||
requiresPowerCycle = fsioOutputPins16
|
requiresPowerCycle = fsioOutputPins16
|
||||||
|
|
||||||
requiresPowerCycle = fsioFrequency1
|
requiresPowerCycle = fsioFrequency1
|
||||||
requiresPowerCycle = fsioFrequency2
|
requiresPowerCycle = fsioFrequency2
|
||||||
requiresPowerCycle = fsioFrequency3
|
requiresPowerCycle = fsioFrequency3
|
||||||
|
@ -482,12 +482,12 @@ enable2ndByteCanID = false
|
||||||
requiresPowerCycle = fsioFrequency14
|
requiresPowerCycle = fsioFrequency14
|
||||||
requiresPowerCycle = fsioFrequency15
|
requiresPowerCycle = fsioFrequency15
|
||||||
requiresPowerCycle = fsioFrequency16
|
requiresPowerCycle = fsioFrequency16
|
||||||
|
|
||||||
requiresPowerCycle = fsioAdc1
|
requiresPowerCycle = fsioAdc1
|
||||||
requiresPowerCycle = fsioAdc2
|
requiresPowerCycle = fsioAdc2
|
||||||
requiresPowerCycle = fsioAdc3
|
requiresPowerCycle = fsioAdc3
|
||||||
requiresPowerCycle = fsioAdc4
|
requiresPowerCycle = fsioAdc4
|
||||||
|
|
||||||
readOnly = warning_message
|
readOnly = warning_message
|
||||||
|
|
||||||
|
|
||||||
|
@ -738,7 +738,7 @@ enable2ndByteCanID = false
|
||||||
yBins = boostTpsBins, TPSValue
|
yBins = boostTpsBins, TPSValue
|
||||||
zBins = boostTableClosedLoop
|
zBins = boostTableClosedLoop
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
table = fsioTable1Tbl, fsioTable1Map, "FSIO Table #1", 1
|
table = fsioTable1Tbl, fsioTable1Map, "FSIO Table #1", 1
|
||||||
xBins = fsioTable1RpmBins, RPMValue
|
xBins = fsioTable1RpmBins, RPMValue
|
||||||
|
@ -1050,14 +1050,14 @@ gaugeCategory = Knock
|
||||||
indicator = { sd_status & 8}, "SD Log", "SD Log", white, black, green, black
|
indicator = { sd_status & 8}, "SD Log", "SD Log", white, black, green, black
|
||||||
indicator = { sd_status & 16}, "SD Err", "SD Err", white, black, red, black
|
indicator = { sd_status & 16}, "SD Err", "SD Err", white, black, red, black
|
||||||
|
|
||||||
; this is required so that the "config error" feature works in TS
|
; this is required so that the "config error" feature works in TS
|
||||||
; don't change this line - TS is looking for an indicator with particular text/styling
|
; don't change this line - TS is looking for an indicator with particular text/styling
|
||||||
; you don't even have to show it by default
|
; you don't even have to show it by default
|
||||||
indicator = { ind_hasFatalError }, "Config Error", "Config Error", white, black, red, black
|
indicator = { ind_hasFatalError }, "Config Error", "Config Error", white, black, red, black
|
||||||
|
|
||||||
; minor info
|
; minor info
|
||||||
indicator = { ind_fan}, "fan off", "fan on", white, black, green, black
|
indicator = { ind_fan}, "fan off", "fan on", white, black, green, black
|
||||||
indicator = { isCylinderCleanupActivated}, "no cyl cleanup", "cyl cleanup", white, black, yellow, black
|
indicator = { isCylinderCleanupActivated}, "no cyl cleanup", "cyl cleanup", white, black, yellow, black
|
||||||
indicator = { needBurn }, "config ok", "unsaved changes", white, black, yellow, black
|
indicator = { needBurn }, "config ok", "unsaved changes", white, black, yellow, black
|
||||||
indicator = { hasSdCard}, "no SD", "with SD", white, black, green, black
|
indicator = { hasSdCard}, "no SD", "with SD", white, black, green, black
|
||||||
indicator = { ind_fuel_pump}, "pump off", "pump on", white, black, green, black
|
indicator = { ind_fuel_pump}, "pump off", "pump on", white, black, green, black
|
||||||
|
@ -1082,7 +1082,7 @@ gaugeCategory = Knock
|
||||||
|
|
||||||
[KeyActions]
|
[KeyActions]
|
||||||
showPanel = spi, spiFunction
|
showPanel = spi, spiFunction
|
||||||
showPanel = con, connection
|
showPanel = con, connection
|
||||||
|
|
||||||
[Datalog]
|
[Datalog]
|
||||||
; Channel Label Type Format
|
; Channel Label Type Format
|
||||||
|
@ -1207,7 +1207,7 @@ gaugeCategory = Knock
|
||||||
entry = knock6, "Knock 6", int, "%d"
|
entry = knock6, "Knock 6", int, "%d"
|
||||||
entry = knock7, "Knock 7", int, "%d"
|
entry = knock7, "Knock 7", int, "%d"
|
||||||
entry = knock8, "Knock 8", int, "%d"
|
entry = knock8, "Knock 8", int, "%d"
|
||||||
|
|
||||||
; tpsADC = U16, "ADC",
|
; tpsADC = U16, "ADC",
|
||||||
; alignmet = U16, "al",
|
; alignmet = U16, "al",
|
||||||
; atmPres = F32, "pres",
|
; atmPres = F32, "pres",
|
||||||
|
@ -1315,7 +1315,7 @@ menuDialog = main
|
||||||
subMenu = cltIdleCurve, "CLT multiplier"
|
subMenu = cltIdleCurve, "CLT multiplier"
|
||||||
subMenu = iacCoastingCurve, "Coasting IAC Position for Auto-Idle", 0, {useIacTableForCoasting == 1}
|
subMenu = iacCoastingCurve, "Coasting IAC Position for Auto-Idle", 0, {useIacTableForCoasting == 1}
|
||||||
|
|
||||||
menu = "&Advanced"
|
menu = "&Advanced"
|
||||||
subMenu = boostDialog, "Boost Control"
|
subMenu = boostDialog, "Boost Control"
|
||||||
subMenu = boostPidDialog, "Closed Loop Boost", { boostType == 1 }
|
subMenu = boostPidDialog, "Closed Loop Boost", { boostType == 1 }
|
||||||
|
|
||||||
|
@ -1399,7 +1399,7 @@ menuDialog = main
|
||||||
subMenu = sdCard, "SD Card Logger" @@if_ts_show_sd_card
|
subMenu = sdCard, "SD Card Logger" @@if_ts_show_sd_card
|
||||||
subMenu = connection, "Connection"
|
subMenu = connection, "Connection"
|
||||||
subMenu = tle8888, "TLE8888"
|
subMenu = tle8888, "TLE8888"
|
||||||
|
|
||||||
subMenu = allPins1, "Full pinout 1/3" @@if_ts_show_full_pinout
|
subMenu = allPins1, "Full pinout 1/3" @@if_ts_show_full_pinout
|
||||||
subMenu = allPins2, "Full pinout 2/3" @@if_ts_show_full_pinout
|
subMenu = allPins2, "Full pinout 2/3" @@if_ts_show_full_pinout
|
||||||
subMenu = allPins3_1_and_2 "Full pinout 3/3" @@if_ts_show_full_pinout
|
subMenu = allPins3_1_and_2 "Full pinout 3/3" @@if_ts_show_full_pinout
|
||||||
|
@ -1419,7 +1419,7 @@ menuDialog = main
|
||||||
subMenu = etbDialog, "Electronic throttle body (beta version)" @@if_ts_show_etb
|
subMenu = etbDialog, "Electronic throttle body (beta version)" @@if_ts_show_etb
|
||||||
subMenu = etbTpsBiasCurve, "Electronic throttle body bias curve" @@if_ts_show_etb
|
subMenu = etbTpsBiasCurve, "Electronic throttle body bias curve" @@if_ts_show_etb
|
||||||
subMenu = pedalToTpsTbl, "Electronic Pedal Map" @@if_ts_show_etb
|
subMenu = pedalToTpsTbl, "Electronic Pedal Map" @@if_ts_show_etb
|
||||||
subMenu = std_separator
|
subMenu = std_separator
|
||||||
# subMenu = smLaunchControl, "Launch Control"
|
# subMenu = smLaunchControl, "Launch Control"
|
||||||
# subMenu = std_separator
|
# subMenu = std_separator
|
||||||
# subMenu = smRollingLaunch, "Rolling Launch"
|
# subMenu = smRollingLaunch, "Rolling Launch"
|
||||||
|
@ -1462,7 +1462,7 @@ cmd_test_spk13 = "@@TS_IO_TEST_COMMAND_char@@\x00\x12\x00\x0d"
|
||||||
cmd_test_spk14 = "@@TS_IO_TEST_COMMAND_char@@\x00\x12\x00\x0e"
|
cmd_test_spk14 = "@@TS_IO_TEST_COMMAND_char@@\x00\x12\x00\x0e"
|
||||||
cmd_test_spk15 = "@@TS_IO_TEST_COMMAND_char@@\x00\x12\x00\x0f"
|
cmd_test_spk15 = "@@TS_IO_TEST_COMMAND_char@@\x00\x12\x00\x0f"
|
||||||
cmd_test_spk16 = "@@TS_IO_TEST_COMMAND_char@@\x00\x12\x00\x10"
|
cmd_test_spk16 = "@@TS_IO_TEST_COMMAND_char@@\x00\x12\x00\x10"
|
||||||
|
|
||||||
|
|
||||||
cmd_test_inj1 = "@@TS_IO_TEST_COMMAND_char@@@@CMD_TS_INJECTOR_CATEGORY@@\x00\x01"
|
cmd_test_inj1 = "@@TS_IO_TEST_COMMAND_char@@@@CMD_TS_INJECTOR_CATEGORY@@\x00\x01"
|
||||||
cmd_test_inj2 = "@@TS_IO_TEST_COMMAND_char@@@@CMD_TS_INJECTOR_CATEGORY@@\x00\x02"
|
cmd_test_inj2 = "@@TS_IO_TEST_COMMAND_char@@@@CMD_TS_INJECTOR_CATEGORY@@\x00\x02"
|
||||||
|
@ -1588,7 +1588,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
field = "Ignition Pin 1", ignitionPins1, {isIgnitionEnabled == 1}
|
field = "Ignition Pin 1", ignitionPins1, {isIgnitionEnabled == 1}
|
||||||
; see rusefi_config.txt comment next to 'ignitionPin2logic' which says
|
; see rusefi_config.txt comment next to 'ignitionPin2logic' which says
|
||||||
; this section is auto-generated by FiringOrderTSLogic.java
|
; this section is auto-generated by FiringOrderTSLogic.java
|
||||||
@@FIRINGORDER@@
|
@@FIRINGORDER@@
|
||||||
field = "This is useful to have tachometer working"
|
field = "This is useful to have tachometer working"
|
||||||
field = " while converting from distributor"
|
field = " while converting from distributor"
|
||||||
field = "Dizzy out Pin", dizzySparkOutputPin, {isIgnitionEnabled == 1}
|
field = "Dizzy out Pin", dizzySparkOutputPin, {isIgnitionEnabled == 1}
|
||||||
|
@ -1660,7 +1660,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
field = "Invert Cam/VVT", invertCamVVTSignal
|
field = "Invert Cam/VVT", invertCamVVTSignal
|
||||||
panel = triggerInputComparator @@if_ts_show_trigger_comparator
|
panel = triggerInputComparator @@if_ts_show_trigger_comparator
|
||||||
|
|
||||||
|
|
||||||
dialog = triggerConfiguration
|
dialog = triggerConfiguration
|
||||||
panel = triggerConfiguration_settings, North, { consumeObdSensors == 0 }
|
panel = triggerConfiguration_settings, North, { consumeObdSensors == 0 }
|
||||||
panel = triggerInputs, South, { consumeObdSensors == 0 }
|
panel = triggerInputs, South, { consumeObdSensors == 0 }
|
||||||
|
@ -1834,7 +1834,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
panel = pedalSensorLeft, West
|
panel = pedalSensorLeft, West
|
||||||
panel = pedalGauges, East
|
panel = pedalGauges, East
|
||||||
|
|
||||||
dialog = mc33Dialog, "GDI Dreams"
|
dialog = mc33Dialog, "GDI Dreams"
|
||||||
field = "MC33816 cs", mc33816_cs
|
field = "MC33816 cs", mc33816_cs
|
||||||
field = "MC33816 rstb", mc33816_rstb
|
field = "MC33816 rstb", mc33816_rstb
|
||||||
field = "MC33816 flag0", mc33816_flag0
|
field = "MC33816 flag0", mc33816_flag0
|
||||||
|
@ -1853,7 +1853,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
field = "Hold current target", mc33_i_hold
|
field = "Hold current target", mc33_i_hold
|
||||||
field = "mc33_t_hold_off ?????", mc33_t_hold_off
|
field = "mc33_t_hold_off ?????", mc33_t_hold_off
|
||||||
field = "Maximum injection duration", mc33_t_hold_tot
|
field = "Maximum injection duration", mc33_t_hold_tot
|
||||||
|
|
||||||
|
|
||||||
; Sensor Inputs
|
; Sensor Inputs
|
||||||
dialog = otherSensorInputs, "Other Sensor Inputs"
|
dialog = otherSensorInputs, "Other Sensor Inputs"
|
||||||
|
@ -2044,6 +2044,10 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
field = "LIS302DLCsPin", LIS302DLCsPin
|
field = "LIS302DLCsPin", LIS302DLCsPin
|
||||||
field = "MIL / Check Engine", malfunctionIndicatorPin
|
field = "MIL / Check Engine", malfunctionIndicatorPin
|
||||||
field = "Saab CDM knock", cdmInputPin
|
field = "Saab CDM knock", cdmInputPin
|
||||||
|
field = "DRV8860 CS", drv8860_cs
|
||||||
|
field = "DRV8860 CS Mode", drv8860_csPinMode
|
||||||
|
field = "DRV8860 MISO pin", drv8860_miso
|
||||||
|
field = "DRV8860 SPI", drv8860spiDevice
|
||||||
field = "comm status light", communicationLedPin
|
field = "comm status light", communicationLedPin
|
||||||
field = "running status light", runningLedPin
|
field = "running status light", runningLedPin
|
||||||
|
|
||||||
|
@ -2142,7 +2146,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
dialog = iatSensor, "IAT Sensor", border
|
dialog = iatSensor, "IAT Sensor", border
|
||||||
panel = iat_thermistor, West
|
panel = iat_thermistor, West
|
||||||
panel = iatGauges, East
|
panel = iatGauges, East
|
||||||
|
|
||||||
; Sensors->Oil pressure sensor
|
; Sensors->Oil pressure sensor
|
||||||
dialog = oilp_settings, "Oil Pressure Sensor"
|
dialog = oilp_settings, "Oil Pressure Sensor"
|
||||||
field = "Oil Pressure ADC input", oilPressure_hwChannel
|
field = "Oil Pressure ADC input", oilPressure_hwChannel
|
||||||
|
@ -2549,7 +2553,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
panel = batteryDialog
|
panel = batteryDialog
|
||||||
panel = alternator
|
panel = alternator
|
||||||
panel = startStopDialog
|
panel = startStopDialog
|
||||||
|
|
||||||
dialog = speedSensorAnalog
|
dialog = speedSensorAnalog
|
||||||
field = "Input pin", vehicleSpeedSensorInputPin
|
field = "Input pin", vehicleSpeedSensorInputPin
|
||||||
field = "revolution to speed mult", vehicleSpeedCoef
|
field = "revolution to speed mult", vehicleSpeedCoef
|
||||||
|
@ -2565,7 +2569,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
dialog = speedSensor, "Speed sensor", xAxis
|
dialog = speedSensor, "Speed sensor", xAxis
|
||||||
panel = speedSensorLeft
|
panel = speedSensorLeft
|
||||||
gauge = VSSGauge
|
gauge = VSSGauge
|
||||||
|
|
||||||
; Engine->Other inputs
|
; Engine->Other inputs
|
||||||
dialog = analogInputSettings, "Analog Input Settings"
|
dialog = analogInputSettings, "Analog Input Settings"
|
||||||
field = "!ECU reboot needed to apply these settings"
|
field = "!ECU reboot needed to apply these settings"
|
||||||
|
@ -2841,10 +2845,10 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
|
|
||||||
field = "use FSIO #5 for critical engine stop", useFSIO5ForCriticalIssueEngineStop
|
field = "use FSIO #5 for critical engine stop", useFSIO5ForCriticalIssueEngineStop
|
||||||
field = "#5", fsioFormulas5
|
field = "#5", fsioFormulas5
|
||||||
|
|
||||||
field = "use FSIO #6 for rev limiter", useFSIO6ForRevLimiter
|
field = "use FSIO #6 for rev limiter", useFSIO6ForRevLimiter
|
||||||
field = "#6", fsioFormulas6
|
field = "#6", fsioFormulas6
|
||||||
|
|
||||||
field = "#7", fsioFormulas7
|
field = "#7", fsioFormulas7
|
||||||
|
|
||||||
field = "use FSIO #8 for servo #1", useFSIO8ForServo1
|
field = "use FSIO #8 for servo #1", useFSIO8ForServo1
|
||||||
|
@ -2889,8 +2893,8 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
field = "Control Mode", boostType, { isBoostControlEnabled }
|
field = "Control Mode", boostType, { isBoostControlEnabled }
|
||||||
field = "Output", boostControlPin, { isBoostControlEnabled }
|
field = "Output", boostControlPin, { isBoostControlEnabled }
|
||||||
field = "Output Mode", boostControlPinMode, { isBoostControlEnabled }
|
field = "Output Mode", boostControlPinMode, { isBoostControlEnabled }
|
||||||
field = "Frequency", boostPwmFrequency, { isBoostControlEnabled }
|
field = "Frequency", boostPwmFrequency, { isBoostControlEnabled }
|
||||||
|
|
||||||
dialog = boostDialog, "", border
|
dialog = boostDialog, "", border
|
||||||
panel = boost_left, West
|
panel = boost_left, West
|
||||||
panel = boostTableTbl, Center
|
panel = boostTableTbl, Center
|
||||||
|
@ -2898,20 +2902,20 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
;Boost Closed Loop
|
;Boost Closed Loop
|
||||||
|
|
||||||
dialog = boostPidleft, ""
|
dialog = boostPidleft, ""
|
||||||
field = "P Gain", boostPid_pFactor, { isBoostControlEnabled && boostType == 1 }
|
field = "P Gain", boostPid_pFactor, { isBoostControlEnabled && boostType == 1 }
|
||||||
field = "I Gain", boostPid_iFactor, { isBoostControlEnabled && boostType == 1 }
|
field = "I Gain", boostPid_iFactor, { isBoostControlEnabled && boostType == 1 }
|
||||||
field = "D Gain", boostPid_dFactor, { isBoostControlEnabled && boostType == 1 }
|
field = "D Gain", boostPid_dFactor, { isBoostControlEnabled && boostType == 1 }
|
||||||
field = "Control Period", boostPid_periodMs, { isBoostControlEnabled && boostType == 1 }
|
field = "Control Period", boostPid_periodMs, { isBoostControlEnabled && boostType == 1 }
|
||||||
field = "Min Duty", boostPid_minValue, { isBoostControlEnabled && boostType == 1 }
|
field = "Min Duty", boostPid_minValue, { isBoostControlEnabled && boostType == 1 }
|
||||||
field = "Max Duty", boostPid_maxValue, { isBoostControlEnabled && boostType == 1 }
|
field = "Max Duty", boostPid_maxValue, { isBoostControlEnabled && boostType == 1 }
|
||||||
|
|
||||||
dialog = boostTableDialog, "", card
|
dialog = boostTableDialog, "", card
|
||||||
panel = boostTable2Tbl
|
panel = boostTable2Tbl
|
||||||
|
|
||||||
dialog = boostPidDialog, "", border
|
dialog = boostPidDialog, "", border
|
||||||
panel = boostPidleft, West
|
panel = boostPidleft, West
|
||||||
panel = boostTableDialog, Center
|
panel = boostTableDialog, Center
|
||||||
|
|
||||||
help = veTableDialogHelp, "Volumetric Efficiency"
|
help = veTableDialogHelp, "Volumetric Efficiency"
|
||||||
text = "Volumetric Efficiency is used to calculate fuel in Speed Density mode"
|
text = "Volumetric Efficiency is used to calculate fuel in Speed Density mode"
|
||||||
webHelp = "https://rusefi.com/s/fuel"
|
webHelp = "https://rusefi.com/s/fuel"
|
||||||
|
@ -3096,7 +3100,7 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
|
||||||
field = "Ignition Cut", launchSparkCutEnable, {launchControlEnabled == 1}
|
field = "Ignition Cut", launchSparkCutEnable, {launchControlEnabled == 1}
|
||||||
field = "Fuel Cut", launchFuelCutEnable, {launchControlEnabled == 1}
|
field = "Fuel Cut", launchFuelCutEnable, {launchControlEnabled == 1}
|
||||||
field = "Hard Cut RPM Range", hardCutRpmRange, {launchControlEnabled == 1}
|
field = "Hard Cut RPM Range", hardCutRpmRange, {launchControlEnabled == 1}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,7 @@ class cyclic_buffer
|
||||||
volatile T elements[maxSize];
|
volatile T elements[maxSize];
|
||||||
volatile int currentIndex;
|
volatile int currentIndex;
|
||||||
|
|
||||||
private:
|
protected:
|
||||||
void baseC(int size);
|
void baseC(int size);
|
||||||
/**
|
/**
|
||||||
* number of elements added into this buffer, would be eventually bigger then size
|
* number of elements added into this buffer, would be eventually bigger then size
|
||||||
|
|
|
@ -0,0 +1,75 @@
|
||||||
|
/**
|
||||||
|
* @file fifo_buffer.h
|
||||||
|
* @brief A FIFO buffer (base on cyclic_buffer)
|
||||||
|
*
|
||||||
|
* https://en.wikipedia.org/wiki/FIFO_(computing_and_electronics)
|
||||||
|
*
|
||||||
|
* @date Aug 6, 2020
|
||||||
|
* @author andreika <prometheus.pcb@gmail.com>
|
||||||
|
* @author Andrey Belomutskiy
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef FIFO_BUFFER_H
|
||||||
|
#define FIFO_BUFFER_H
|
||||||
|
|
||||||
|
#include "cyclic_buffer.h"
|
||||||
|
|
||||||
|
// todo: this is not a thread-safe version!
|
||||||
|
template<typename T, size_t maxSize = CB_MAX_SIZE>
|
||||||
|
class fifo_buffer : public cyclic_buffer<T, maxSize> {
|
||||||
|
public:
|
||||||
|
fifo_buffer() : currentIndexRead(0) {
|
||||||
|
}
|
||||||
|
|
||||||
|
void put(T item);
|
||||||
|
T get();
|
||||||
|
void clear() /*override*/;
|
||||||
|
|
||||||
|
void put(const T *items, int numItems);
|
||||||
|
|
||||||
|
bool isEmpty() const {
|
||||||
|
return getCount() == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool isFull() const {
|
||||||
|
return getCount() >= getSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
public:
|
||||||
|
volatile int currentIndexRead; // FIFO "tail"
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename T, size_t maxSize>
|
||||||
|
void fifo_buffer<T, maxSize>::put(T item) {
|
||||||
|
// check if full
|
||||||
|
if (!isFull()) {
|
||||||
|
cyclic_buffer::add(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename T, size_t maxSize>
|
||||||
|
void fifo_buffer<T, maxSize>::put(const T *items, int numItems) {
|
||||||
|
for (int i = 0; i < numItems; i++) {
|
||||||
|
put(items[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename T, size_t maxSize>
|
||||||
|
T fifo_buffer<T, maxSize>::get() {
|
||||||
|
auto ret = elements[currentIndexRead];
|
||||||
|
if (!isEmpty()) {
|
||||||
|
currentIndexRead = (currentIndexRead + 1) % size;
|
||||||
|
count--;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename T, size_t maxSize>
|
||||||
|
void fifo_buffer<T, maxSize>::clear() {
|
||||||
|
cyclic_buffer::clear();
|
||||||
|
currentIndexRead = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* FIFO_BUFFER_H */
|
Loading…
Reference in New Issue