Alain Portal 0e616af
Index: src/progs/icd2/base/icd2_serial.cpp
Alain Portal 0e616af
===================================================================
Alain Portal 0e616af
--- src/progs/icd2/base/icd2_serial.cpp	(révision 2930)
Alain Portal 0e616af
+++ src/progs/icd2/base/icd2_serial.cpp	(révision 2932)
Alain Portal 0e616af
@@ -31,16 +31,27 @@
Alain Portal 0e616af
 {
Alain Portal 0e616af
   if ( !static_cast<SerialPort *>(_port)->open(Port::Serial::S19200) ) return false;
Alain Portal 0e616af
   if ( !reset() ) return false;
Alain Portal 0e616af
+  log(Log::DebugLevel::Max, QString("Send: \"%1\"").arg("Z"));
Alain Portal 0e616af
   if ( !_port->send("Z", 1) ) return false;
Alain Portal 0e616af
   QString s;
Alain Portal 0e616af
   if ( !_port->receive(4, s) ) return false;
Alain Portal 0e616af
+  log(Log::DebugLevel::Max, QString("Received: \"%1\"").arg(s));
Alain Portal 0e616af
+
Alain Portal 0e616af
   if ( !reset() ) return false;
Alain Portal 0e616af
-  QByteArray a = toAscii(mode);
Alain Portal 0e616af
-  if ( !_port->send(a.data(), a.count()) ) return false;
Alain Portal 0e616af
-  if ( !_port->receive(1, s) ) return false;
Alain Portal 0e616af
-  if ( s.upper()!=mode ) {
Alain Portal 0e616af
-    log(Log::LineType::Error, i18n("Failed to set port mode to '%1'.").arg(mode));
Alain Portal 0e616af
-    return false;
Alain Portal 0e616af
+  for (uint i = 0; ; ++i) {
Alain Portal 0e616af
+    const QByteArray a = toAscii(mode);
Alain Portal 0e616af
+    log(Log::DebugLevel::Max, QString("Send: \"%1\"").arg(mode));
Alain Portal 0e616af
+    if ( !_port->send(a.data(), a.count()) ) return false;
Alain Portal 0e616af
+    if ( !_port->receive(1, s) ) return false;
Alain Portal 0e616af
+    log(Log::DebugLevel::Max, QString("Received: \"%1\"").arg(s));
Alain Portal 0e616af
+    if ( s.upper()==mode ) {
Alain Portal 0e616af
+      break;
Alain Portal 0e616af
+    }
Alain Portal 0e616af
+    if (i == 10) {
Alain Portal 0e616af
+      log(Log::LineType::Error, i18n("Failed to set port mode to '%1'.").arg(mode));
Alain Portal 0e616af
+      return false;
Alain Portal 0e616af
+    }
Alain Portal 0e616af
+    Port::msleep(100);
Alain Portal 0e616af
   }
Alain Portal 0e616af
   //log(Log::Debug, "set fast speed");
Alain Portal 0e616af
   //if ( !setFastSpeed() ) return false;
Alain Portal 0e616af
@@ -49,6 +60,7 @@
Alain Portal 0e616af
 
Alain Portal 0e616af
 bool Icd2::SerialHardware::reset()
Alain Portal 0e616af
 {
Alain Portal 0e616af
+  log(Log::DebugLevel::Max, QString("Reset icd2 serial port"));
Alain Portal 0e616af
   static_cast<Port::Serial *>(_port)->setPinOn(Port::Serial::DTR, false, Port::PositiveLogic); // Trigger DTR to reset icd2
Alain Portal 0e616af
   Port::msleep(10);
Alain Portal 0e616af
   static_cast<Port::Serial *>(_port)->setPinOn(Port::Serial::DTR, true, Port::PositiveLogic); // remove reset