@ -101,20 +101,19 @@ class HmRadio { 
			
		
	
		
		
			
				
					            // change the byte order of the DTU serial number and append the required 0x01 at the end
             // change the byte order of the DTU serial number and append the required 0x01 at the end
  
			
		
	
		
		
			
				
					            DTU_RADIO_ID  =  ( ( uint64_t ) ( ( ( dtuSn  > >  24 )  &  0xFF )  |  ( ( dtuSn  > >  8 )  &  0xFF00 )  |  ( ( dtuSn  < <  8 )  &  0xFF0000 )  |  ( ( dtuSn  < <  24 )  &  0xFF000000 ) )  < <  8 )  |  0x01 ;             DTU_RADIO_ID  =  ( ( uint64_t ) ( ( ( dtuSn  > >  24 )  &  0xFF )  |  ( ( dtuSn  > >  8 )  &  0xFF00 )  |  ( ( dtuSn  < <  8 )  &  0xFF0000 )  |  ( ( dtuSn  < <  24 )  &  0xFF000000 ) )  < <  8 )  |  0x01 ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            SPIClass *  spi ;  
			
		
	
		
		
			
				
					            # ifdef ESP32             # ifdef ESP32  
			
		
	
		
		
			
				
					                # if CONFIG_IDF_TARGET_ESP32C3 || CONFIG_IDF_TARGET_ESP32S3                 # if CONFIG_IDF_TARGET_ESP32C3 || CONFIG_IDF_TARGET_ESP32S3  
			
		
	
		
		
			
				
					
					                    s pi=  new  SPIClass ( FSPI ) ;                     mS pi=  new  SPIClass ( FSPI ) ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					                # else                 # else  
			
		
	
		
		
			
				
					
					                    s pi=  new  SPIClass ( VSPI ) ;                     mS pi=  new  SPIClass ( VSPI ) ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					                # endif                 # endif  
			
		
	
		
		
			
				
					
					                s pi- > begin ( sclk ,  miso ,  mosi ,  cs ) ;                 mS pi- > begin ( sclk ,  miso ,  mosi ,  cs ) ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            # else             # else  
			
		
	
		
		
			
				
					                //the old ESP82xx cannot freely place their SPI pins
                 //the old ESP82xx cannot freely place their SPI pins
  
			
		
	
		
		
			
				
					
					                s pi=  new  SPIClass ( ) ;                 mS pi=  new  SPIClass ( ) ;  
			
				
				
			
		
	
		
		
			
				
					
					                s pi- > begin ( ) ;                 mS pi- > begin ( ) ;  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					            # endif             # endif  
			
		
	
		
		
			
				
					
					            mNrf24 . begin ( s pi,  ce ,  cs ) ;             mNrf24 . begin ( mS pi,  ce ,  cs ) ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            mNrf24 . setRetries ( 3 ,  15 ) ;  // 3*250us + 250us and 15 loops -> 15ms
             mNrf24 . setRetries ( 3 ,  15 ) ;  // 3*250us + 250us and 15 loops -> 15ms
  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            mNrf24 . setChannel ( mRfChLst [ mRxChIdx ] ) ;             mNrf24 . setChannel ( mRfChLst [ mRxChIdx ] ) ;  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -124,7 +123,7 @@ class HmRadio { 
			
		
	
		
		
			
				
					            mNrf24 . enableDynamicPayloads ( ) ;             mNrf24 . enableDynamicPayloads ( ) ;  
			
		
	
		
		
			
				
					            mNrf24 . setCRCLength ( RF24_CRC_16 ) ;             mNrf24 . setCRCLength ( RF24_CRC_16 ) ;  
			
		
	
		
		
			
				
					            mNrf24 . setAddressWidth ( 5 ) ;             mNrf24 . setAddressWidth ( 5 ) ;  
			
		
	
		
		
			
				
					
					            mNrf24 . openReadingPipe ( 1 ,  reinterpret_cast < uint8_t * > ( & DTU_RADIO_ID ) ) ;             mNrf24 . openReadingPipe ( 1 ,  DTU_RADIO_ID ) ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            // enable all receiving interrupts
             // enable all receiving interrupts
  
			
		
	
		
		
			
				
					            mNrf24 . maskIRQ ( false ,  false ,  false ) ;             mNrf24 . maskIRQ ( false ,  false ,  false ) ;  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -148,36 +147,32 @@ class HmRadio { 
			
		
	
		
		
			
				
					            bool  tx_ok ,  tx_fail ,  rx_ready ;             bool  tx_ok ,  tx_fail ,  rx_ready ;  
			
		
	
		
		
			
				
					            mNrf24 . whatHappened ( tx_ok ,  tx_fail ,  rx_ready ) ;   // resets the IRQ pin to HIGH
             mNrf24 . whatHappened ( tx_ok ,  tx_fail ,  rx_ready ) ;   // resets the IRQ pin to HIGH
  
			
		
	
		
		
			
				
					            mNrf24 . flush_tx ( ) ;                               // empty TX FIFO
             mNrf24 . flush_tx ( ) ;                               // empty TX FIFO
  
			
		
	
		
		
			
				
					            //DBGPRINTLN("TX whatHappened Ch" + String(mRfChLst[mTxChIdx]) + " " + String(tx_ok) + String(tx_fail) + String(rx_ready));
  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					            // start listening
             // start listening on the default RX channel
  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            mRxChIdx  =  0 ;  
			
		
	
		
		
			
				
					            mNrf24 . setChannel ( mRfChLst [ mRxChIdx ] ) ;             mNrf24 . setChannel ( mRfChLst [ mRxChIdx ] ) ;  
			
		
	
		
		
			
				
					            mNrf24 . startListening ( ) ;             mNrf24 . startListening ( ) ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					            uint32_t  startMicros  =  micros ( ) ;             //uint32_t debug_ms = millis();
  
			
				
				
			
		
	
		
		
			
				
					
					            uint32_t  loopMillis  =  millis ( ) ;             uint16_t  cnt  =  300 ;  // that is 60 times 5 channels
  
			
				
				
			
		
	
		
		
			
				
					
					
            while  ( 0  <  cnt - - )  {  
			
				
				
			
		
	
		
		
			
				
					
					            uint32_t  timeslot  =  4088 ; //5110; //3066; //6132;//4088;
                 uint32_t  startMillis  =  millis ( ) ;  
			
				
				
			
		
	
		
		
			
				
					
					            uint64_t  tsCnt  =  0 ;                 while  ( millis ( ) - startMillis  <  4 )  {   // listen 4ms to each channel
  
			
				
				
			
		
	
		
		
			
				
					            while  ( millis ( ) - loopMillis  <  200 )  {  
			
		
	
		
		
			
				
					                while  ( micros ( ) - startMicros  <  timeslot )  {   // listen timeslot us to each channel
  
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					                    if  ( mIrqRcvd )  {                     if  ( mIrqRcvd )  {  
			
		
	
		
		
			
				
					                        mIrqRcvd  =  false ;                         mIrqRcvd  =  false ;  
			
		
	
		
		
			
				
					                        DBGPRINTLN ( " *** time:  "  +  String ( tsCnt * ( uint64_t ) timeslot  +  ( uint64_t ) ( micros ( ) - startMicros ) )  +  "  *** " ) ;  
			
		
	
		
		
			
				
					                        if  ( getReceived ( ) )  {         // everything received
                         if  ( getReceived ( ) )  {         // everything received
  
			
		
	
		
		
			
				
					                            //DBGPRINTLN("RX finished Cnt: " + String(300-cnt) + " time used: " + String(millis()-debug_ms)+ " ms");
  
			
		
	
		
		
			
				
					                            return  true ;                             return  true ;  
			
		
	
		
		
			
				
					                        }                         }  
			
		
	
		
		
			
				
					                    }                     }  
			
		
	
		
		
			
				
					                    yield ( ) ;                     yield ( ) ;  
			
		
	
		
		
			
				
					                }                 }  
			
		
	
		
		
			
				
					
					                // switch to next RX channel
                 switchRxCh ( ) ;    // switch to next RX channel
  
			
				
				
			
		
	
		
		
			
				
					                startMicros  =  micros ( ) ;  
			
		
	
		
		
			
				
					                if ( + + mRxChIdx  > =  RF_CHANNELS )  
			
		
	
		
		
			
				
					                    mRxChIdx  =  0 ;  
			
		
	
		
		
			
				
					                mNrf24 . setChannel ( mRfChLst [ mRxChIdx ] ) ;  
			
		
	
		
		
			
				
					                tsCnt + + ;  
			
		
	
		
		
	
		
		
			
				
					                yield ( ) ;                 yield ( ) ;  
			
		
	
		
		
			
				
					            }             }  
			
		
	
		
		
			
				
					            // not finished but time is over
             // not finished but time is over
  
			
		
	
		
		
			
				
					            //DBGPRINTLN("RX not finished: 300 time used: " + String(millis()-debug_ms)+ " ms");
  
			
		
	
		
		
			
				
					            return  true ;             return  true ;  
			
		
	
		
		
			
				
					        }         }  
			
		
	
		
		
			
				
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -233,7 +228,8 @@ class HmRadio { 
			
		
	
		
		
			
				
					        }         }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        void  prepareDevInformCmd ( uint64_t  invId ,  uint8_t  cmd ,  uint32_t  ts ,  uint16_t  alarmMesId ,  bool  isRetransmit ,  uint8_t  reqfld = TX_REQ_INFO )  {  // might not be necessary to add additional arg.
         void  prepareDevInformCmd ( uint64_t  invId ,  uint8_t  cmd ,  uint32_t  ts ,  uint16_t  alarmMesId ,  bool  isRetransmit ,  uint8_t  reqfld = TX_REQ_INFO )  {  // might not be necessary to add additional arg.
  
			
		
	
		
		
			
				
					
					            DPRINTLN ( DBG_DEBUG ,  F ( " prepareDevInformCmd 0x " )  +  String ( cmd ,  HEX ) ) ;             DPRINT ( DBG_DEBUG ,  F ( " prepareDevInformCmd 0x " ) ) ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            DPRINTLN ( DBG_DEBUG ,  String ( cmd ,  HEX ) ) ;  
			
		
	
		
		
			
				
					            initPacket ( invId ,  reqfld ,  ALL_FRAMES ) ;             initPacket ( invId ,  reqfld ,  ALL_FRAMES ) ;  
			
		
	
		
		
			
				
					            mTxBuf [ 10 ]  =  cmd ;  // cid
             mTxBuf [ 10 ]  =  cmd ;  // cid
  
			
		
	
		
		
			
				
					            mTxBuf [ 11 ]  =  0x00 ;             mTxBuf [ 11 ]  =  0x00 ;  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -245,9 +241,9 @@ class HmRadio { 
			
		
	
		
		
			
				
					            sendPacket ( invId ,  24 ,  isRetransmit ,  true ) ;             sendPacket ( invId ,  24 ,  isRetransmit ,  true ) ;  
			
		
	
		
		
			
				
					        }         }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					        void  sendCmdPacket ( uint64_t  invId ,  uint8_t  mid ,  uint8_t  pid ,  bool  isRetransmit ,  bool  appendCrc16 = tru e)  {         void  sendCmdPacket ( uint64_t  invId ,  uint8_t  mid ,  uint8_t  pid ,  bool  isRetransmit ,  bool  isMI = fals e)  {  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            initPacket ( invId ,  mid ,  pid ) ;             initPacket ( invId ,  mid ,  pid ) ;  
			
		
	
		
		
			
				
					
					            sendPacket ( invId ,  10 ,  isRetransmit ,  appendCrc16 ) ;             sendPacket ( invId ,  10 ,  isRetransmit ,  isMI ) ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					        }         }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        void  dumpBuf ( uint8_t  buf [ ] ,  uint8_t  len )  {         void  dumpBuf ( uint8_t  buf [ ] ,  uint8_t  len )  {  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -280,6 +276,7 @@ class HmRadio { 
			
		
	
		
		
			
				
					        bool  getReceived ( void )  {         bool  getReceived ( void )  {  
			
		
	
		
		
			
				
					            bool  tx_ok ,  tx_fail ,  rx_ready ;             bool  tx_ok ,  tx_fail ,  rx_ready ;  
			
		
	
		
		
			
				
					            mNrf24 . whatHappened ( tx_ok ,  tx_fail ,  rx_ready ) ;  // resets the IRQ pin to HIGH
             mNrf24 . whatHappened ( tx_ok ,  tx_fail ,  rx_ready ) ;  // resets the IRQ pin to HIGH
  
			
		
	
		
		
			
				
					            //DBGPRINTLN("RX whatHappened Ch" + String(mRfChLst[mRxChIdx]) + " " + String(tx_ok) + String(tx_fail) + String(rx_ready));
  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            bool  isLastPackage  =  false ;             bool  isLastPackage  =  false ;  
			
		
	
		
		
			
				
					            while ( mNrf24 . available ( ) )  {             while ( mNrf24 . available ( ) )  {  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -290,21 +287,29 @@ class HmRadio { 
			
		
	
		
		
			
				
					                    p . ch  =  mRfChLst [ mRxChIdx ] ;                     p . ch  =  mRfChLst [ mRxChIdx ] ;  
			
		
	
		
		
			
				
					                    p . len  =  len ;                     p . len  =  len ;  
			
		
	
		
		
			
				
					                    mNrf24 . read ( p . packet ,  len ) ;                     mNrf24 . read ( p . packet ,  len ) ;  
			
		
	
		
		
			
				
					                    if  ( p . packet [ 0 ]  ! =  0x00 )  {  
			
		
	
		
		
			
				
					                    mBufCtrl . push ( p ) ;                     mBufCtrl . push ( p ) ;  
			
		
	
		
		
			
				
					                    if  ( p . packet [ 0 ]  = =  ( TX_REQ_INFO  +  ALL_FRAMES ) )   // response from get information command
                     if  ( p . packet [ 0 ]  = =  ( TX_REQ_INFO  +  ALL_FRAMES ) )   // response from get information command
  
			
		
	
		
		
			
				
					
					                             isLastPackage  =  ( p . packet [ 9 ]  >  ALL_FRAMES ) ;  // > ALL_FRAMES  indicates last packet received
                        isLastPackage  =  ( p . packet [ 9 ]  >  0x81 ) ;        // > 0x81  indicates last packet received
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					                    else  if  ( p . packet [ 0 ]  = =  (  0x0f  +  ALL_FRAMES )  )   // response from MI get information command
                     else  if  ( p . packet [ 0 ]  = =  (  0x0f  +  ALL_FRAMES )  )   // response from MI get information command
  
			
		
	
		
		
			
				
					
					                            isLastPackage  =  ( p . packet [ 9 ]  >  0x10 ) ;        // > 0x10 indicates last packet received
                         isLastPackage  =  ( p . packet [ 9 ]  >  0x11 ) ;        // > 0x11 indicates last packet received
  
			
				
				
			
		
	
		
		
			
				
					
					                        else  if  ( ( p . packet [ 0 ]  ! =  0x88 )  & &  ( p . packet [ 0 ]  ! =  0x92 ) )  // ignore fragment number zero and MI status messages //#0 was p.packet[0] != 0x00 &&
                     else  if  ( p . packet [ 0 ]  ! =  0x00  & &  p . packet [ 0 ]  ! =  0x88  & &  p . packet [ 0 ]  ! =  0x92 )  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					                                                                    // ignore fragment number zero and MI status messages
  
			
		
	
		
		
			
				
					                        isLastPackage  =  true ;                        // response from dev control command
                         isLastPackage  =  true ;                        // response from dev control command
  
			
		
	
		
		
			
				
					                    }  
			
		
	
		
		
			
				
					                }  
			
		
	
		
		
			
				
					                    yield ( ) ;                     yield ( ) ;  
			
		
	
		
		
			
				
					                }                 }  
			
		
	
		
		
			
				
					            }  
			
		
	
		
		
			
				
					            return  isLastPackage ;             return  isLastPackage ;  
			
		
	
		
		
			
				
					        }         }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        void  switchRxCh ( )  {  
			
		
	
		
		
			
				
					            mNrf24 . stopListening ( ) ;  
			
		
	
		
		
			
				
					            // get next channel index
  
			
		
	
		
		
			
				
					            if ( + + mRxChIdx  > =  RF_CHANNELS )  
			
		
	
		
		
			
				
					                mRxChIdx  =  0 ;  
			
		
	
		
		
			
				
					            mNrf24 . setChannel ( mRfChLst [ mRxChIdx ] ) ;  
			
		
	
		
		
			
				
					            mNrf24 . startListening ( ) ;  
			
		
	
		
		
			
				
					        }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        void  initPacket ( uint64_t  invId ,  uint8_t  mid ,  uint8_t  pid )  {         void  initPacket ( uint64_t  invId ,  uint8_t  mid ,  uint8_t  pid )  {  
			
		
	
		
		
			
				
					            DPRINTLN ( DBG_VERBOSE ,  F ( " initPacket, mid:  " )  +  String ( mid ,  HEX )  +  F ( "  pid:  " )  +  String ( pid ,  HEX ) ) ;             DPRINTLN ( DBG_VERBOSE ,  F ( " initPacket, mid:  " )  +  String ( mid ,  HEX )  +  F ( "  pid:  " )  +  String ( pid ,  HEX ) ) ;  
			
		
	
		
		
			
				
					            memset ( mTxBuf ,  0 ,  MAX_RF_PAYLOAD_SIZE ) ;             memset ( mTxBuf ,  0 ,  MAX_RF_PAYLOAD_SIZE ) ;  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -314,12 +319,12 @@ class HmRadio { 
			
		
	
		
		
			
				
					            mTxBuf [ 9 ]   =  pid ;             mTxBuf [ 9 ]   =  pid ;  
			
		
	
		
		
			
				
					        }         }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					        void  sendPacket ( uint64_t  invId ,  uint8_t  len ,  bool  isRetransmit ,  bool  appendCrc16 = tru e)  {         void  sendPacket ( uint64_t  invId ,  uint8_t  len ,  bool  isRetransmit ,  bool  appendCrc16 = fals e)  {  
			
				
				
			
		
	
		
		
	
		
		
			
				
					            //DPRINTLN(DBG_VERBOSE, F("hmRadio.h:sendPacket"));
             //DPRINTLN(DBG_VERBOSE, F("hmRadio.h:sendPacket"));
  
			
		
	
		
		
			
				
					            //DPRINTLN(DBG_VERBOSE, "sent packet: #" + String(mSendCnt));
             //DPRINTLN(DBG_VERBOSE, "sent packet: #" + String(mSendCnt));
  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            // append crc's
             // append crc's
  
			
		
	
		
		
			
				
					
					            if  ( appendCrc16  & &  ( len  >  10 ) )  {             if  ( appendCrc16  & &  len  >  10 )  {  
			
				
				
			
		
	
		
		
	
		
		
			
				
					                // crc control data
                 // crc control data
  
			
		
	
		
		
			
				
					                uint16_t  crc  =  ah : : crc16 ( & mTxBuf [ 10 ] ,  len  -  10 ) ;                 uint16_t  crc  =  ah : : crc16 ( & mTxBuf [ 10 ] ,  len  -  10 ) ;  
			
		
	
		
		
			
				
					                mTxBuf [ len + + ]  =  ( crc  > >  8 )  &  0xff ;                 mTxBuf [ len + + ]  =  ( crc  > >  8 )  &  0xff ;  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -329,10 +334,6 @@ class HmRadio { 
			
		
	
		
		
			
				
					            mTxBuf [ len ]  =  ah : : crc8 ( mTxBuf ,  len ) ;             mTxBuf [ len ]  =  ah : : crc8 ( mTxBuf ,  len ) ;  
			
		
	
		
		
			
				
					            len + + ;             len + + ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            // set TX and RX channels
  
			
		
	
		
		
			
				
					            mTxChIdx  =  ( mTxChIdx  +  1 )  %  RF_CHANNELS ;  
			
		
	
		
		
			
				
					            mRxChIdx  =  ( mTxChIdx  +  2 )  %  RF_CHANNELS ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            if ( mSerialDebug )  {             if ( mSerialDebug )  {  
			
		
	
		
		
			
				
					                DPRINT ( DBG_INFO ,  F ( " TX  " ) ) ;                 DPRINT ( DBG_INFO ,  F ( " TX  " ) ) ;  
			
		
	
		
		
			
				
					                DBGPRINT ( String ( len ) ) ;                 DBGPRINT ( String ( len ) ) ;  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -347,6 +348,10 @@ class HmRadio { 
			
		
	
		
		
			
				
					            mNrf24 . openWritingPipe ( reinterpret_cast < uint8_t * > ( & invId ) ) ;             mNrf24 . openWritingPipe ( reinterpret_cast < uint8_t * > ( & invId ) ) ;  
			
		
	
		
		
			
				
					            mNrf24 . startWrite ( mTxBuf ,  len ,  false ) ;  // false = request ACK response
             mNrf24 . startWrite ( mTxBuf ,  len ,  false ) ;  // false = request ACK response
  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            // switch TX channel for next packet
  
			
		
	
		
		
			
				
					            if ( + + mTxChIdx  > =  RF_CHANNELS )  
			
		
	
		
		
			
				
					                mTxChIdx  =  0 ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					            if ( isRetransmit )             if ( isRetransmit )  
			
		
	
		
		
			
				
					                mRetransmits + + ;                 mRetransmits + + ;  
			
		
	
		
		
			
				
					            else             else  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -360,6 +365,7 @@ class HmRadio { 
			
		
	
		
		
			
				
					        uint8_t  mTxChIdx ;         uint8_t  mTxChIdx ;  
			
		
	
		
		
			
				
					        uint8_t  mRxChIdx ;         uint8_t  mRxChIdx ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        SPIClass *  mSpi ;  
			
		
	
		
		
			
				
					        RF24  mNrf24 ;         RF24  mNrf24 ;  
			
		
	
		
		
			
				
					        uint8_t  mTxBuf [ MAX_RF_PAYLOAD_SIZE ] ;         uint8_t  mTxBuf [ MAX_RF_PAYLOAD_SIZE ] ;  
			
		
	
		
		
			
				
					} ; } ;