|  |  | @ -264,8 +264,10 @@ class Communication : public CommQueue<> { | 
			
		
	
		
			
				
					|  |  |  |                                     DBGPRINT(F(" frames missing ")); | 
			
		
	
		
			
				
					|  |  |  |                                     DBGPRINTLN(F("-> complete retransmit")); | 
			
		
	
		
			
				
					|  |  |  |                                 } | 
			
		
	
		
			
				
					|  |  |  |                                 mHeu.evalTxChQuality(q->iv, false, (q->attemptsMax - 1 - q->attempts), q->iv->curFrmCnt); | 
			
		
	
		
			
				
					|  |  |  |                                 q->iv->radioStatistics.txCnt--; | 
			
		
	
		
			
				
					|  |  |  |                                 q->iv->radioStatistics.retransmits++; | 
			
		
	
		
			
				
					|  |  |  |                                 mCompleteRetry = true; | 
			
		
	
		
			
				
					|  |  |  |                                 mState = States::RESET; | 
			
		
	
		
			
				
					|  |  |  |                                 return; | 
			
		
	
		
			
				
					|  |  |  |                             } | 
			
		
	
	
		
			
				
					|  |  | @ -511,6 +513,7 @@ class Communication : public CommQueue<> { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |                 } else | 
			
		
	
		
			
				
					|  |  |  |                     DBGPRINTLN(F("-> complete retransmit")); | 
			
		
	
		
			
				
					|  |  |  |                 mCompleteRetry = true; | 
			
		
	
		
			
				
					|  |  |  |                 mState = States::RESET; | 
			
		
	
		
			
				
					|  |  |  |                 return; | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
	
		
			
				
					|  |  | @ -611,7 +614,7 @@ class Communication : public CommQueue<> { | 
			
		
	
		
			
				
					|  |  |  |             mHeu.evalTxChQuality(q->iv, crcPass, (q->attemptsMax - 1 - q->attempts), q->iv->curFrmCnt); | 
			
		
	
		
			
				
					|  |  |  |             if(crcPass) | 
			
		
	
		
			
				
					|  |  |  |                 q->iv->radioStatistics.rxSuccess++; | 
			
		
	
		
			
				
					|  |  |  |             else if(q->iv->mGotFragment) | 
			
		
	
		
			
				
					|  |  |  |             else if(q->iv->mGotFragment || mCompleteRetry) | 
			
		
	
		
			
				
					|  |  |  |                 q->iv->radioStatistics.rxFail++; // got no complete payload
 | 
			
		
	
		
			
				
					|  |  |  |             else | 
			
		
	
		
			
				
					|  |  |  |                 q->iv->radioStatistics.rxFailNoAnser++; // got nothing
 | 
			
		
	
	
		
			
				
					|  |  | @ -626,6 +629,7 @@ class Communication : public CommQueue<> { | 
			
		
	
		
			
				
					|  |  |  |             q->iv->mGotLastMsg  = false; | 
			
		
	
		
			
				
					|  |  |  |             q->iv->miMultiParts = 0; | 
			
		
	
		
			
				
					|  |  |  |             mIsRetransmit       = false; | 
			
		
	
		
			
				
					|  |  |  |             mCompleteRetry      = false; | 
			
		
	
		
			
				
					|  |  |  |             mState              = States::RESET; | 
			
		
	
		
			
				
					|  |  |  |             DBGPRINTLN(F("-----")); | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
	
		
			
				
					|  |  | @ -1020,8 +1024,9 @@ class Communication : public CommQueue<> { | 
			
		
	
		
			
				
					|  |  |  |         uint16_t *mInverterGap; | 
			
		
	
		
			
				
					|  |  |  |         TimeMonitor mWaitTime = TimeMonitor(0, true);  // start as expired (due to code in RESET state)
 | 
			
		
	
		
			
				
					|  |  |  |         std::array<frame_t, MAX_PAYLOAD_ENTRIES> mLocalBuf; | 
			
		
	
		
			
				
					|  |  |  |         bool mFirstTry = false;     // see, if we should do a second try
 | 
			
		
	
		
			
				
					|  |  |  |         bool mIsRetransmit = false; // we already had waited one complete cycle
 | 
			
		
	
		
			
				
					|  |  |  |         bool mFirstTry = false;      // see, if we should do a second try
 | 
			
		
	
		
			
				
					|  |  |  |         bool mCompleteRetry = false; // remember if we did request a complete retransmission
 | 
			
		
	
		
			
				
					|  |  |  |         bool mIsRetransmit = false;  // we already had waited one complete cycle
 | 
			
		
	
		
			
				
					|  |  |  |         uint8_t mMaxFrameId; | 
			
		
	
		
			
				
					|  |  |  |         uint8_t mFramesExpected = 12; // 0x8c was highest last frame for alarm data
 | 
			
		
	
		
			
				
					|  |  |  |         uint16_t mTimeout = 0;       // calculating that once should be ok
 | 
			
		
	
	
		
			
				
					|  |  | 
 |