console usability: better handling of 12340005 fix #2531

This commit is contained in:
rusefi 2021-04-08 16:42:52 -04:00
parent 6eb68aa4a1
commit fc8fdedf34
2 changed files with 18 additions and 5 deletions

View File

@ -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 {

View File

@ -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) {