aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmessage/lltemplatemessagereader.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/llmessage/lltemplatemessagereader.cpp11
1 files changed, 7 insertions, 4 deletions
diff --git a/linden/indra/llmessage/lltemplatemessagereader.cpp b/linden/indra/llmessage/lltemplatemessagereader.cpp
index 329d2a8..4cde483 100644
--- a/linden/indra/llmessage/lltemplatemessagereader.cpp
+++ b/linden/indra/llmessage/lltemplatemessagereader.cpp
@@ -502,12 +502,15 @@ BOOL LLTemplateMessageReader::decodeTemplate(
502 return(TRUE); 502 return(TRUE);
503} 503}
504 504
505void LLTemplateMessageReader::logRanOffEndOfPacket( const LLHost& host ) 505void LLTemplateMessageReader::logRanOffEndOfPacket( const LLHost& host, const S32 where, const S32 wanted )
506{ 506{
507 // we've run off the end of the packet! 507 // we've run off the end of the packet!
508 llwarns << "Ran off end of packet " << mCurrentRMessageTemplate->mName 508 llwarns << "Ran off end of packet " << mCurrentRMessageTemplate->mName
509// << " with id " << mCurrentRecvPacketID 509// << " with id " << mCurrentRecvPacketID
510 << " from " << host 510 << " from " << host
511 << " trying to read " << wanted
512 << " bytes at position " << where
513 << " going past packet end at " << mReceiveSize
511 << llendl; 514 << llendl;
512 if(gMessageSystem->mVerboseLog) 515 if(gMessageSystem->mVerboseLog)
513 { 516 {
@@ -562,7 +565,7 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender
562 // repeat number is a single byte 565 // repeat number is a single byte
563 if (decode_pos >= mReceiveSize) 566 if (decode_pos >= mReceiveSize)
564 { 567 {
565 logRanOffEndOfPacket(sender); 568 logRanOffEndOfPacket(sender, decode_pos, 1);
566 569
567 // default to 0 repeats 570 // default to 0 repeats
568 repeat_number = 0; 571 repeat_number = 0;
@@ -621,7 +624,7 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender
621 624
622 if ((decode_pos + data_size) > mReceiveSize) 625 if ((decode_pos + data_size) > mReceiveSize)
623 { 626 {
624 logRanOffEndOfPacket(sender); 627 logRanOffEndOfPacket(sender, decode_pos, data_size);
625 628
626 // default to 0 length variable blocks 629 // default to 0 length variable blocks
627 tsize = 0; 630 tsize = 0;
@@ -657,7 +660,7 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender
657 // so, copy data pointer and set data size to fixed size 660 // so, copy data pointer and set data size to fixed size
658 if ((decode_pos + mvci.getSize()) > mReceiveSize) 661 if ((decode_pos + mvci.getSize()) > mReceiveSize)
659 { 662 {
660 logRanOffEndOfPacket(sender); 663 logRanOffEndOfPacket(sender, decode_pos, mvci.getSize());
661 664
662 // default to 0s. 665 // default to 0s.
663 U32 size = mvci.getSize(); 666 U32 size = mvci.getSize();