console usability: better handling of 12340005 fix #2531
This commit is contained in:
parent
6eb68aa4a1
commit
fc8fdedf34
|
@ -8,6 +8,7 @@ import com.rusefi.autodetect.PortDetector;
|
||||||
import com.rusefi.io.DfuHelper;
|
import com.rusefi.io.DfuHelper;
|
||||||
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.StatusConsumer;
|
||||||
import com.rusefi.ui.StatusWindow;
|
import com.rusefi.ui.StatusWindow;
|
||||||
import com.rusefi.ui.util.URLLabel;
|
import com.rusefi.ui.util.URLLabel;
|
||||||
|
|
||||||
|
@ -16,6 +17,7 @@ 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.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see FirmwareFlasher
|
* @see FirmwareFlasher
|
||||||
|
@ -80,13 +82,23 @@ public class DfuFlasher {
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
throw new IllegalStateException(e);
|
throw new IllegalStateException(e);
|
||||||
}
|
}
|
||||||
|
AtomicBoolean errorReported = new AtomicBoolean();
|
||||||
StringBuffer stdout = new StringBuffer();
|
StringBuffer stdout = new StringBuffer();
|
||||||
String errorResponse = ExecHelper.executeCommand(FirmwareFlasher.BINARY_LOCATION,
|
String errorResponse = ExecHelper.executeCommand(FirmwareFlasher.BINARY_LOCATION,
|
||||||
FirmwareFlasher.BINARY_LOCATION + File.separator + getDfuCommand(),
|
FirmwareFlasher.BINARY_LOCATION + File.separator + getDfuCommand(),
|
||||||
DFU_BINARY, wnd, stdout);
|
DFU_BINARY, s -> {
|
||||||
if (stdout.toString().contains("0x12340005")) {
|
if (s.contains("0x12340005") && errorReported.compareAndSet(false, true)) {
|
||||||
wnd.appendMsg("Driver issue? Maybe driver conflict with STM32Cube? rusEFI currently uses older incompatible driver");
|
wnd.appendMsg(" ***************");
|
||||||
} else if (stdout.toString().contains("Verify successful") || stdout.toString().contains("Upgrade successful")) {
|
wnd.appendMsg(" ***************");
|
||||||
|
wnd.appendMsg("ERROR: Maybe DFU device not attached? Please check Device Manager.");
|
||||||
|
wnd.appendMsg("ERROR: Maybe ST DFU Driver is missing?");
|
||||||
|
wnd.appendMsg("ERROR: Maybe driver conflict with STM32Cube?");
|
||||||
|
wnd.appendMsg(" ***************");
|
||||||
|
wnd.appendMsg(" ***************");
|
||||||
|
}
|
||||||
|
wnd.appendMsg(s);
|
||||||
|
}, stdout);
|
||||||
|
if (stdout.toString().contains("Verify successful") || stdout.toString().contains("Upgrade successful")) {
|
||||||
// looks like sometimes we are not catching the last line of the response? 'Upgrade' happens before 'Verify'
|
// looks like sometimes we are not catching the last line of the response? 'Upgrade' happens before 'Verify'
|
||||||
wnd.appendMsg("SUCCESS!");
|
wnd.appendMsg("SUCCESS!");
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -5,6 +5,7 @@ import com.rusefi.ui.StatusConsumer;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see SimulatorExecHelper
|
* @see SimulatorExecHelper
|
||||||
|
@ -66,7 +67,7 @@ public class ExecHelper {
|
||||||
Process p = Runtime.getRuntime().exec(command, null, workingDir);
|
Process p = Runtime.getRuntime().exec(command, null, workingDir);
|
||||||
startStreamThread(p, p.getInputStream(), output, wnd);
|
startStreamThread(p, p.getInputStream(), output, wnd);
|
||||||
startStreamThread(p, p.getErrorStream(), error, wnd);
|
startStreamThread(p, p.getErrorStream(), error, wnd);
|
||||||
p.waitFor();
|
p.waitFor(3, TimeUnit.MINUTES);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
wnd.appendMsg("IOError: " + e);
|
wnd.appendMsg("IOError: " + e);
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
|
|
Loading…
Reference in New Issue