This post is older than 2 years and might not be relevant anymore
More Info: Consider searching for newer posts

What distinguishes an ACK packet on-air from a regular packet?

I would like to implement a simple wireless sensor network, using Enhanced Shockburst with Auto-ACK. The idea is that there will be many sensor nodes (SNs) reporting to one master node (MN). The MN will listen on address P0 (say 0x0011223344) and all SNs will transmit to this address on an intermittent, periodic basis.

Assume I have auto-ack enabled everywhere.

  1. Node SN0 transmits a packet with PID=1, it begins listening on P0 for an ACK from MN.
  2. Before the ACK can be sent, a second node SN1 transmits a packet with PID=1 also.
  3. Since SN0 is listening on P0 while SN1 is transmitting on P0, will SN0 mistakenly identify SN1's data packet as an ack from MN?

As far as I can tell, for the same PID, there is no difference between a regular data packet and an ack-with-payload: I am assuming that ACKs are always sent with the NO_ACK bit of the PCF set to 1, and that a PTX detects a valid ack if ((ack_pid == last_tx_pid) && (ack_nak == 0)) ???

If this is the case, then I can assume that the answer to my question above is "no", but what about this:

  1. Node SN0 transmits a packet with PID=1, it begins listening on P0 for an ACK from MN.
  2. Before the ACK can be sent, a second node SN1 transmits a packet with PID=1 also, and listens
  3. MN sends ACK on P0 with PID=1.
  4. Presumably both SN0 and SN1 will interpret this as a valid ACK, even though it was meant for only one of them?

This would seem to make sense; I am happy to burn some payload bytes to identify individual transmitters, I'd just like to verify that my assumptions are correct.

Parents
  • Hi,

    Thank you for the further info; it is interesting and illuminating, and answers the second point in my original post, but I am still unclear as to what distinguishes an ACK on-air from a regular data packet. My fault, I am not making the question sufficiently clear.

    A sensor sends a packet with a payload length of 1. EN_DPL is enabled, hence PCF[len] is equal to 1. The single payload byte is 0x55:

        
    PKT: { 
      addr: [011,0x22,0x33],   // three byte address
      PCF: {
         len:1,    // DPL is 1 byte
         PID: 1,                         
         NAK:0    // NO_ACK is FALSE for ESB
      }, 
      payload: [0x55],    // single payload byte
      CRC: x    // some 16-bit value
    }
    

    ie 01010101, 00010001 00100010 00110011, 000001 01 0, 01010101, x

    A co-ordinator node receives this packet and sends an ACK. This ACK has a single byte payload. The single byte payload is also the value 0x55, by some strange coincidence. What does this ACK packet look like?

    Is it like this? (answer A)

        
    PKT: { 
      addr: [0x11,0x22,0x33],   // return to sender
      PCF: {
        len:1,    //  DPL is 1 byte
        PID: 1,    // ACK PID same as REQ PID
        NAK:1    // NO_ACK is true!!
      }, 
      payload: [0x55],    // single payload byte
      CRC: y    // CRC must therefore be different!
    }
    

    ie 01010101, 00010001 00100010 00110011, 000001 01 1, 01010101,y

    Or is it like this? (answer B)

        
    PKT: { 
      addr: [0x11,0x22,0x33],   // return to sender
      PCF: {
        len:1,    // DPL 1 byte
        PID: 1,    // ACK PID same as REQ PID
        NAK:0    // NO_ACK is false here too!
      }, 
      payload: [0x55],     // single payload byte
      CRC: x    // CRC same as orig, therefore!
    }
    

    ie 01010101, 00010001 00100010 00110011, 000001 01 0, 01010101, x

    This is my first question. What's the format of the ACK? 'A' or 'B' ? Or something else?

    My second question: if it is 'B', how does PTX's internal ESB logic know this is an ACK? How can it tell ACK from a duplicate identical packet (same address, same length, same PID, same NAK, same payload, same CRC) sent by a second sensor, for example?

    Thanks for your help and patience!

    ant

  • The closest is answer B. However, len = 0, so the payload field will not be present. And therefore, the CRC will also be different.

    If you setup two PRX with the same RF config (EN_DPL/DYN_ACK enabled), and one PTX that sends whenever it can, you will sooner or later observe a payload of 0 byte on one of the PRX.

Reply Children
No Data
Related