auto-sync

This commit is contained in:
rusEfi 2015-07-14 22:01:24 -04:00
parent f77030123c
commit 4ee0e4ff79
8 changed files with 137 additions and 41 deletions

View File

@ -59,7 +59,7 @@ void setMazda626EngineConfiguration(DECLARE_ENGINE_PARAMETER_F) {
setCommonNTCSensor(&engineConfiguration->clt); setCommonNTCSensor(&engineConfiguration->clt);
// http://i.imgur.com/2hI67yW.jpg // http://i.imgur.com/2hI67yW.jpg
setThermistorConfiguration(&engineConfiguration->iat, 13, 56000, 50, 9000, 80.0, 2700); setThermistorConfiguration(&engineConfiguration->iat, 13, 56000, 50, 9000, 80.0, 2700);
engineConfiguration->iat.config.bias_resistor = 18000; engineConfiguration->iat.config.bias_resistor = 18200;
commonFrankensoAnalogInputs(engineConfiguration); commonFrankensoAnalogInputs(engineConfiguration);
// engineConfiguration->map.sensor.hwChannel = EFI_ADC_4; // engineConfiguration->map.sensor.hwChannel = EFI_ADC_4;

View File

@ -1,6 +1,6 @@
package com.rusefi.config; package com.rusefi.config;
// this file was generated automatically by ConfigDefinition.jar Fri Jul 03 11:19:03 EDT 2015 // this file was generated automatically by ConfigDefinition.jar Mon Jul 13 18:45:30 EDT 2015
public class Fields { public class Fields {
public static final Field ENGINETYPE = new Field("ENGINETYPE", 0, FieldType.INT); public static final Field ENGINETYPE = new Field("ENGINETYPE", 0, FieldType.INT);
public static final Field HEADERMAGICVALUE = new Field("HEADERMAGICVALUE", 4, FieldType.INT); public static final Field HEADERMAGICVALUE = new Field("HEADERMAGICVALUE", 4, FieldType.INT);
@ -175,6 +175,7 @@ public class Fields {
public static final String[] ego_sensor_e = {"BPSX", "Innovate", "14Point7", "Narrow", "PLX"}; public static final String[] ego_sensor_e = {"BPSX", "Innovate", "14Point7", "Narrow", "PLX"};
public static final Field AFR_TYPE = new Field("AFR_TYPE", 900, FieldType.INT, ego_sensor_e); public static final Field AFR_TYPE = new Field("AFR_TYPE", 900, FieldType.INT, ego_sensor_e);
public static final Field ETBDT = new Field("ETBDT", 904, FieldType.INT); public static final Field ETBDT = new Field("ETBDT", 904, FieldType.INT);
public static final Field HIP9011CSPINMODE = new Field("HIP9011CSPINMODE", 908, FieldType.INT, pin_output_mode_e);
public static final String[] brain_input_pin_e = {"INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "PA5", "INVALID", "INVALID", "PA8", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "PC6", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "PE5", "INVALID", "PE7", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "NONE", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID"}; public static final String[] brain_input_pin_e = {"INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "PA5", "INVALID", "INVALID", "PA8", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "PC6", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "PE5", "INVALID", "PE7", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "NONE", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID", "INVALID"};
public static final Field TRIGGERINPUTPINS1 = new Field("TRIGGERINPUTPINS1", 920, FieldType.INT, brain_input_pin_e); public static final Field TRIGGERINPUTPINS1 = new Field("TRIGGERINPUTPINS1", 920, FieldType.INT, brain_input_pin_e);
public static final Field TRIGGERINPUTPINS2 = new Field("TRIGGERINPUTPINS2", 924, FieldType.INT, brain_input_pin_e); public static final Field TRIGGERINPUTPINS2 = new Field("TRIGGERINPUTPINS2", 924, FieldType.INT, brain_input_pin_e);
@ -410,6 +411,9 @@ public class Fields {
public static final Field NOACCELAFTERHARDLIMITPERIODSECS = new Field("NOACCELAFTERHARDLIMITPERIODSECS", 1644, FieldType.FLOAT); public static final Field NOACCELAFTERHARDLIMITPERIODSECS = new Field("NOACCELAFTERHARDLIMITPERIODSECS", 1644, FieldType.FLOAT);
public static final Field MAPAVERAGINGSCHEDULINGATINDEX = new Field("MAPAVERAGINGSCHEDULINGATINDEX", 1648, FieldType.INT); public static final Field MAPAVERAGINGSCHEDULINGATINDEX = new Field("MAPAVERAGINGSCHEDULINGATINDEX", 1648, FieldType.INT);
public static final Field BAROCORRTABLE = new Field("BAROCORRTABLE", 1684, FieldType.INT); public static final Field BAROCORRTABLE = new Field("BAROCORRTABLE", 1684, FieldType.INT);
public static final Field SPI2SCKMODE = new Field("SPI2SCKMODE", 1748, FieldType.INT);
public static final Field SPI2MOSIMODE = new Field("SPI2MOSIMODE", 1752, FieldType.INT);
public static final Field SPI2MISOMODE = new Field("SPI2MISOMODE", 1756, FieldType.INT);
public static final Field TARGETVBATT = new Field("TARGETVBATT", 2156, FieldType.FLOAT); public static final Field TARGETVBATT = new Field("TARGETVBATT", 2156, FieldType.FLOAT);
public static final Field ALTERNATOROFFABOVETPS = new Field("ALTERNATOROFFABOVETPS", 2160, FieldType.FLOAT); public static final Field ALTERNATOROFFABOVETPS = new Field("ALTERNATOROFFABOVETPS", 2160, FieldType.FLOAT);
public static final Field ALTERNATORDT = new Field("ALTERNATORDT", 2164, FieldType.INT); public static final Field ALTERNATORDT = new Field("ALTERNATORDT", 2164, FieldType.INT);

View File

@ -32,7 +32,7 @@ import static com.rusefi.ui.storage.PersistentConfiguration.getConfig;
* @see com.rusefi.StartupFrame * @see com.rusefi.StartupFrame
*/ */
public class Launcher { public class Launcher {
public static final int CONSOLE_VERSION = 20150713; public static final int CONSOLE_VERSION = 20150714;
public static final boolean SHOW_STIMULATOR = false; public static final boolean SHOW_STIMULATOR = false;
private static final String TAB_INDEX = "main_tab"; private static final String TAB_INDEX = "main_tab";
protected static final String PORT_KEY = "port"; protected static final String PORT_KEY = "port";

View File

@ -1,6 +1,7 @@
package com.rusefi.ui; package com.rusefi.ui;
import com.rusefi.core.EngineTimeListener; import com.rusefi.core.EngineTimeListener;
import com.rusefi.core.MessagesCentral;
import com.rusefi.io.LinkManager; import com.rusefi.io.LinkManager;
import javax.swing.*; import javax.swing.*;
@ -10,13 +11,15 @@ import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList; import java.util.concurrent.CopyOnWriteArrayList;
public class ConnectionStatus { public class ConnectionStatus {
// todo: react to any message as connected? how to know if message from controller, not internal message?
private static final String FATAL_MESSAGE_PREFIX = "FATAL";
private boolean isConnected; private boolean isConnected;
public static ConnectionStatus INSTANCE = new ConnectionStatus(); public static ConnectionStatus INSTANCE = new ConnectionStatus();
private List<Listener> listeners = new CopyOnWriteArrayList<>(); private List<Listener> listeners = new CopyOnWriteArrayList<>();
private ConnectionStatus() { private ConnectionStatus() {
final Timer timer1 = new Timer(2000, new ActionListener() { final Timer timer = new Timer(2000, new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
setConnected(false); setConnected(false);
@ -26,13 +29,25 @@ public class ConnectionStatus {
LinkManager.engineState.timeListeners.add(new EngineTimeListener() { LinkManager.engineState.timeListeners.add(new EngineTimeListener() {
@Override @Override
public void onTime(double time) { public void onTime(double time) {
setConnected(true); markConnected(timer);
/**
* this timer will catch engine inactivity and display a warning
*/
timer1.restart();
} }
}); });
MessagesCentral.getInstance().addListener(new MessagesCentral.MessageListener() {
@Override
public void onMessage(Class clazz, String message) {
if (message.startsWith(FATAL_MESSAGE_PREFIX))
markConnected(timer);
}
});
}
private void markConnected(Timer timer1) {
setConnected(true);
/**
* this timer will catch engine inactivity and display a warning
*/
timer1.restart();
} }
private void setConnected(boolean isConnected) { private void setConnected(boolean isConnected) {
@ -47,6 +62,9 @@ public class ConnectionStatus {
return isConnected; return isConnected;
} }
/**
* @see #setConnected(boolean)
*/
public void addListener(Listener listener) { public void addListener(Listener listener) {
listeners.add(listener); listeners.add(listener);
} }

View File

@ -1,42 +1,61 @@
package com.rusefi.ui.config; package com.rusefi.ui.config;
import com.rusefi.ConfigurationImage;
import com.rusefi.FileLog; import com.rusefi.FileLog;
import com.rusefi.binaryprotocol.BinaryProtocol;
import com.rusefi.config.Field; import com.rusefi.config.Field;
import com.rusefi.io.CommandQueue; import com.rusefi.io.CommandQueue;
import com.rusefi.io.InvocationConfirmationListener;
import com.rusefi.ui.ConnectionStatus; import com.rusefi.ui.ConnectionStatus;
import org.jetbrains.annotations.NotNull;
import javax.swing.*; import javax.swing.*;
import java.awt.*; import java.awt.*;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
abstract class BaseConfigField { abstract class BaseConfigField {
protected final JLabel status = new JLabel("P"); protected final JLabel status = new JLabel("P");
protected final JPanel panel = new JPanel(new BorderLayout()); protected final JPanel panel = new JPanel(new BorderLayout());
protected final Field field;
public BaseConfigField(final Field field) { public BaseConfigField(final Field field) {
this.field = field;
status.setToolTipText("Pending..."); status.setToolTipText("Pending...");
}
protected void requestInitialValue(final Field field) {
/** /**
* This would request initial value * This would request initial value
*/ */
if (ConnectionStatus.INSTANCE.isConnected()) { if (ConnectionStatus.INSTANCE.isConnected()) {
requestInitialValue(field); processInitialValue(field);
} else { } else {
ConnectionStatus.INSTANCE.addListener(new ConnectionStatus.Listener() { ConnectionStatus.INSTANCE.addListener(new ConnectionStatus.Listener() {
@Override @Override
public void onConnectionStatus(boolean isConnected) { public void onConnectionStatus(boolean isConnected) {
requestInitialValue(field); processInitialValue(field);
} }
}); });
} }
} }
private void requestInitialValue(Field field) { private void processInitialValue(Field field) {
CommandQueue.getInstance().write(field.getCommand(), BinaryProtocol bp = BinaryProtocol.instance;
CommandQueue.DEFAULT_TIMEOUT, if (bp == null)
InvocationConfirmationListener.VOID, return;
false); ConfigurationImage ci = bp.getController();
if (ci == null)
return;
loadValue(ci);
// CommandQueue.getInstance().write(field.getCommand(),
// CommandQueue.DEFAULT_TIMEOUT,
// InvocationConfirmationListener.VOID,
// false);
} }
protected abstract void loadValue(ConfigurationImage ci);
protected void onValueArrived() { protected void onValueArrived() {
status.setText(""); status.setText("");
status.setToolTipText(null); status.setToolTipText(null);
@ -71,4 +90,12 @@ abstract class BaseConfigField {
public JPanel getContent() { public JPanel getContent() {
return panel; return panel;
} }
@NotNull
protected ByteBuffer getByteBuffer(ConfigurationImage ci) {
byte data[] = ci.getRange(field.getOffset(), 4);
ByteBuffer wrapped = ByteBuffer.wrap(data);
wrapped.order(ByteOrder.LITTLE_ENDIAN);
return wrapped;
}
} }

View File

@ -1,5 +1,6 @@
package com.rusefi.ui.config; package com.rusefi.ui.config;
import com.rusefi.ConfigurationImage;
import com.rusefi.config.Field; import com.rusefi.config.Field;
import com.rusefi.core.MessagesCentral; import com.rusefi.core.MessagesCentral;
@ -13,8 +14,8 @@ public class BitConfigField extends BaseConfigField {
public BitConfigField(final Field field, String caption) { public BitConfigField(final Field field, String caption) {
super(field); super(field);
createUi(caption, view); createUi(caption, view);
requestInitialValue(field); // this is not in base constructor so that view is created by the time we invoke it
MessagesCentral.getInstance().addListener(new MessagesCentral.MessageListener() { MessagesCentral.getInstance().addListener(new MessagesCentral.MessageListener() {
@Override @Override
@ -24,11 +25,7 @@ public class BitConfigField extends BaseConfigField {
if (message.startsWith(expectedPrefix) && message.length() == expectedPrefix.length() + 1) { if (message.startsWith(expectedPrefix) && message.length() == expectedPrefix.length() + 1) {
message = message.substring(expectedPrefix.length()); message = message.substring(expectedPrefix.length());
Boolean value = message.equals("1"); Boolean value = message.equals("1");
ec = true; setValue(value);
view.setEnabled(true);
view.setSelected(value);
onValueArrived();
ec = false;
} }
} }
} }
@ -43,4 +40,19 @@ public class BitConfigField extends BaseConfigField {
} }
}); });
} }
private void setValue(boolean value) {
ec = true;
view.setEnabled(true);
view.setSelected(value);
onValueArrived();
ec = false;
}
@Override
protected void loadValue(ConfigurationImage ci) {
int bits = getByteBuffer(ci).getInt();
boolean bit = ((bits >> field.getBitOffset()) & 1) == 1;
setValue(bit);
}
} }

View File

@ -1,14 +1,19 @@
package com.rusefi.ui.config; package com.rusefi.ui.config;
import com.rusefi.ConfigurationImage;
import com.rusefi.config.Field; import com.rusefi.config.Field;
import com.rusefi.config.FieldType;
import com.rusefi.core.MessagesCentral; import com.rusefi.core.MessagesCentral;
import com.rusefi.core.Pair; import com.rusefi.core.Pair;
import com.rusefi.ui.util.JTextFieldWithWidth; import com.rusefi.ui.util.JTextFieldWithWidth;
import org.jetbrains.annotations.NotNull;
import javax.swing.*; import javax.swing.*;
import java.awt.*; import java.awt.*;
import java.awt.event.KeyAdapter; import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent; import java.awt.event.KeyEvent;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
public class ConfigField extends BaseConfigField { public class ConfigField extends BaseConfigField {
private final JTextField view = new JTextFieldWithWidth(200); private final JTextField view = new JTextFieldWithWidth(200);
@ -16,6 +21,7 @@ public class ConfigField extends BaseConfigField {
public ConfigField(final Field field, String topLabel) { public ConfigField(final Field field, String topLabel) {
super(field); super(field);
createUi(topLabel, view); createUi(topLabel, view);
requestInitialValue(field); // this is not in base constructor so that view is created by the time we invoke it
MessagesCentral.getInstance().addListener(new MessagesCentral.MessageListener() { MessagesCentral.getInstance().addListener(new MessagesCentral.MessageListener() {
@Override @Override
@ -23,9 +29,8 @@ public class ConfigField extends BaseConfigField {
if (Field.isIntValueMessage(message) || Field.isFloatValueMessage(message)) { if (Field.isIntValueMessage(message) || Field.isFloatValueMessage(message)) {
Pair<Integer, ?> p = Field.parseResponse(message); Pair<Integer, ?> p = Field.parseResponse(message);
if (p != null && p.first == field.getOffset()) { if (p != null && p.first == field.getOffset()) {
view.setEnabled(true); Object value = p.second;
view.setText("" + p.second); setValue(value);
onValueArrived();
} }
} }
} }
@ -41,4 +46,22 @@ public class ConfigField extends BaseConfigField {
}); });
} }
private void setValue(Object value) {
view.setEnabled(true);
view.setText("" + value);
onValueArrived();
}
@Override
protected void loadValue(ConfigurationImage ci) {
Number value;
ByteBuffer wrapped = getByteBuffer(ci);
if (field.getType() == FieldType.INT) {
value = wrapped.getInt();
} else {
value = wrapped.getFloat();
}
setValue(value);
}
} }

View File

@ -1,5 +1,6 @@
package com.rusefi.ui.config; package com.rusefi.ui.config;
import com.rusefi.ConfigurationImage;
import com.rusefi.config.Field; import com.rusefi.config.Field;
import com.rusefi.core.MessagesCentral; import com.rusefi.core.MessagesCentral;
import com.rusefi.core.Pair; import com.rusefi.core.Pair;
@ -14,12 +15,13 @@ public class EnumConfigField extends BaseConfigField {
private final JComboBox<String> view = new JComboBox<>(); private final JComboBox<String> view = new JComboBox<>();
private boolean ec; private boolean ec;
private final Map<String, Integer> ordinals = new HashMap<>(); private final Map<String, Integer> ordinals = new HashMap<>();
private final String[] options = field.getOptions();
public EnumConfigField(final Field field, String caption) { public EnumConfigField(final Field field, String caption) {
super(field); super(field);
final String[] options = field.getOptions();
if (options == null) if (options == null)
throw new NullPointerException("options for " + field); throw new NullPointerException("options for " + field);
createUi(caption, view);
int ordinal = 0; int ordinal = 0;
for (String option : options) { for (String option : options) {
@ -29,7 +31,7 @@ public class EnumConfigField extends BaseConfigField {
view.addItem(option); view.addItem(option);
} }
createUi(caption, view); requestInitialValue(field); // this is not in base constructor so that view is created by the time we invoke it
MessagesCentral.getInstance().addListener(new MessagesCentral.MessageListener() { MessagesCentral.getInstance().addListener(new MessagesCentral.MessageListener() {
@Override @Override
@ -38,19 +40,7 @@ public class EnumConfigField extends BaseConfigField {
Pair<Integer, ?> p = Field.parseResponse(message); Pair<Integer, ?> p = Field.parseResponse(message);
if (p != null && p.first == field.getOffset()) { if (p != null && p.first == field.getOffset()) {
int ordinal = (Integer) p.second; int ordinal = (Integer) p.second;
String item; setValue(ordinal);
if (ordinal >= options.length) {
item = "unexpected_" + ordinal;
view.addItem(item);
} else {
item = options[ordinal];
}
ec = true;
view.setEnabled(true);
view.setSelectedItem(item);
onValueArrived();
ec = false;
} }
} }
} }
@ -67,4 +57,26 @@ public class EnumConfigField extends BaseConfigField {
} }
}); });
} }
private void setValue(int ordinal) {
String item;
if (ordinal >= options.length) {
item = "unexpected_" + ordinal;
view.addItem(item);
} else {
item = options[ordinal];
}
ec = true;
view.setEnabled(true);
view.setSelectedItem(item);
onValueArrived();
ec = false;
}
@Override
protected void loadValue(ConfigurationImage ci) {
int ordinal = getByteBuffer(ci).getInt();
setValue(ordinal);
}
} }