steps towards Android
This commit is contained in:
parent
015293ee43
commit
882ed55611
|
@ -0,0 +1,20 @@
|
||||||
|
package com.rusefi.io;
|
||||||
|
|
||||||
|
import com.opensr5.Logger;
|
||||||
|
import com.rusefi.binaryprotocol.BinaryProtocol;
|
||||||
|
import com.rusefi.config.generated.Fields;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class DfuHelper {
|
||||||
|
public static void sendDfuRebootCommand(IoStream stream, StringBuilder messages, Logger logger) {
|
||||||
|
byte[] command = BinaryProtocol.getTextCommandBytes(Fields.CMD_REBOOT_DFU);
|
||||||
|
try {
|
||||||
|
stream.sendPacket(command, logger);
|
||||||
|
stream.close();
|
||||||
|
messages.append("Reboot command sent!\n");
|
||||||
|
} catch (IOException e) {
|
||||||
|
messages.append("Error " + e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -6,8 +6,7 @@ import com.rusefi.FileLog;
|
||||||
import com.rusefi.Launcher;
|
import com.rusefi.Launcher;
|
||||||
import com.rusefi.Timeouts;
|
import com.rusefi.Timeouts;
|
||||||
import com.rusefi.autodetect.PortDetector;
|
import com.rusefi.autodetect.PortDetector;
|
||||||
import com.rusefi.binaryprotocol.BinaryProtocol;
|
import com.rusefi.io.DfuHelper;
|
||||||
import com.rusefi.config.generated.Fields;
|
|
||||||
import com.rusefi.io.IoStream;
|
import com.rusefi.io.IoStream;
|
||||||
import com.rusefi.io.serial.SerialIoStreamJSerialComm;
|
import com.rusefi.io.serial.SerialIoStreamJSerialComm;
|
||||||
import com.rusefi.ui.StatusWindow;
|
import com.rusefi.ui.StatusWindow;
|
||||||
|
@ -18,7 +17,6 @@ import java.awt.*;
|
||||||
import java.awt.event.ActionEvent;
|
import java.awt.event.ActionEvent;
|
||||||
import java.awt.event.ActionListener;
|
import java.awt.event.ActionListener;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see FirmwareFlasher
|
* @see FirmwareFlasher
|
||||||
|
@ -48,13 +46,13 @@ public class DfuFlasher {
|
||||||
if (!PortDetector.isAutoPort(port)) {
|
if (!PortDetector.isAutoPort(port)) {
|
||||||
messages.append("Using selected " + port + "\n");
|
messages.append("Using selected " + port + "\n");
|
||||||
IoStream stream = SerialIoStreamJSerialComm.openPort(port, FileLog.LOGGER);
|
IoStream stream = SerialIoStreamJSerialComm.openPort(port, FileLog.LOGGER);
|
||||||
sendDfuRebootCommand(stream, messages);
|
DfuHelper.sendDfuRebootCommand(stream, messages, FileLog.LOGGER);
|
||||||
} else {
|
} else {
|
||||||
messages.append("Auto-detecting port...\n");
|
messages.append("Auto-detecting port...\n");
|
||||||
// instead of opening the just-detected port we execute the command using the same stream we used to discover port
|
// instead of opening the just-detected port we execute the command using the same stream we used to discover port
|
||||||
// it's more reliable this way
|
// it's more reliable this way
|
||||||
port = PortDetector.autoDetectSerial(stream -> {
|
port = PortDetector.autoDetectSerial(stream -> {
|
||||||
sendDfuRebootCommand(stream, messages);
|
DfuHelper.sendDfuRebootCommand(stream, messages, FileLog.LOGGER);
|
||||||
return null;
|
return null;
|
||||||
});
|
});
|
||||||
if (port == null) {
|
if (port == null) {
|
||||||
|
@ -70,17 +68,6 @@ public class DfuFlasher {
|
||||||
ExecHelper.submitAction(() -> executeDFU(wnd), DfuFlasher.class + " thread");
|
ExecHelper.submitAction(() -> executeDFU(wnd), DfuFlasher.class + " thread");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void sendDfuRebootCommand(IoStream stream, StringBuilder messages) {
|
|
||||||
byte[] command = BinaryProtocol.getTextCommandBytes(Fields.CMD_REBOOT_DFU);
|
|
||||||
try {
|
|
||||||
stream.sendPacket(command, FileLog.LOGGER);
|
|
||||||
stream.close();
|
|
||||||
messages.append("Reboot command sent!\n");
|
|
||||||
} catch (IOException e) {
|
|
||||||
messages.append("Error " + e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void runDfuProgramming() {
|
public static void runDfuProgramming() {
|
||||||
StatusWindow wnd = new StatusWindow();
|
StatusWindow wnd = new StatusWindow();
|
||||||
wnd.showFrame("DFU status " + Launcher.CONSOLE_VERSION);
|
wnd.showFrame("DFU status " + Launcher.CONSOLE_VERSION);
|
||||||
|
|
Loading…
Reference in New Issue