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