mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-08 17:08:28 -04:00
Command upload functional.
git-svn-id: https://arducopter.googlecode.com/svn/trunk@803 f9c3cf11-9bcb-44bc-f272-b75c42450872
This commit is contained in:
parent
d72c61b80a
commit
744d72ea2b
@ -42,7 +42,7 @@
|
|||||||
|
|
||||||
|
|
||||||
/// inter-byte timeout for decode (ms)
|
/// inter-byte timeout for decode (ms)
|
||||||
#define DEC_MESSAGE_TIMEOUT 100
|
#define DEC_MESSAGE_TIMEOUT 1000
|
||||||
|
|
||||||
BinComm::BinComm(const BinComm::MessageHandler *handlerTable,
|
BinComm::BinComm(const BinComm::MessageHandler *handlerTable,
|
||||||
Stream *interface) :
|
Stream *interface) :
|
||||||
@ -97,6 +97,13 @@ BinComm::update(void)
|
|||||||
//
|
//
|
||||||
// XXX we might want to further constrain this count
|
// XXX we might want to further constrain this count
|
||||||
count = _interface->available();
|
count = _interface->available();
|
||||||
|
|
||||||
|
//if (count > 0)
|
||||||
|
//{
|
||||||
|
//Serial.print("count: ");
|
||||||
|
//Serial.println(count,DEC);
|
||||||
|
//}
|
||||||
|
|
||||||
while (count--)
|
while (count--)
|
||||||
_decode(_interface->read());
|
_decode(_interface->read());
|
||||||
}
|
}
|
||||||
@ -114,6 +121,8 @@ BinComm::_decode(uint8_t inByte)
|
|||||||
|
|
||||||
// run the decode state machine
|
// run the decode state machine
|
||||||
//
|
//
|
||||||
|
//Serial.print("decode phase: "); Serial.println(_decodePhase,DEC);
|
||||||
|
//Serial.print("in byte: "); Serial.println(inByte,HEX);
|
||||||
switch (_decodePhase) {
|
switch (_decodePhase) {
|
||||||
|
|
||||||
// Preamble detection
|
// Preamble detection
|
||||||
@ -203,12 +212,21 @@ BinComm::_decode(uint8_t inByte)
|
|||||||
|
|
||||||
// call any handler interested in this message
|
// call any handler interested in this message
|
||||||
for (tableIndex = 0; MSG_NULL != _handlerTable[tableIndex].messageID; tableIndex++)
|
for (tableIndex = 0; MSG_NULL != _handlerTable[tableIndex].messageID; tableIndex++)
|
||||||
if ((_handlerTable[tableIndex].messageID == _messageID) ||
|
if(_handlerTable[tableIndex].messageID == MSG_ACKNOWLEDGE)
|
||||||
(_handlerTable[tableIndex].messageID == MSG_ANY))
|
|
||||||
{
|
{
|
||||||
_handlerTable[tableIndex].handler(_handlerTable[tableIndex].arg, _messageID, _messageVersion, &_decodeBuf);
|
// don't acknowledge, to avoid infinite ack echo
|
||||||
|
}
|
||||||
|
else if(_handlerTable[tableIndex].messageID == MSG_ANY ||
|
||||||
|
_handlerTable[tableIndex].messageID == _messageID )
|
||||||
|
{
|
||||||
|
_handlerTable[tableIndex].handler(_handlerTable[tableIndex].arg,
|
||||||
|
_messageID, _messageVersion, &_decodeBuf);
|
||||||
send_msg_acknowledge(_messageID,_sumA,_sumB);
|
send_msg_acknowledge(_messageID,_sumA,_sumB);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Serial.println("unhandled message");
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
badMessagesReceived++;
|
badMessagesReceived++;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user