esb, shockburst, running on nrf5340dk's

I have 3 nrf boards connected. 2x nrf52832 and 1x nrf5340.

esb_tx is running on nrf52832(682782977)
esb_rx is running on nrf52832(682497942) & nrf5340(1050025410)

west build -b nrf5340dk_nrf5340_cpunet -p builds correctly and flashes without error

PS C:\nrf\esb_prx> west flash -d build_1
-- west flash: rebuilding
ninja: no work to do.
-- west flash: using runner nrfjprog
There are multiple boards connected.
1. 1050025410
2. 682782977
Please select one with desired serial number (1-2): 1
-- runners.nrfjprog: Flashing file: build_1\zephyr\zephyr.hex
[ #################### ] 2.055s | Erase file - Done erasing
[ #################### ] 0.243s | Program file - Done programming
[ #################### ] 0.243s | Verify file - Done verifying
Applying pin reset.
-- runners.nrfjprog: Board with serial number 1050025410 flashed successfully.

esb_rx is working on the nrf52, but not on the nrf53.

... To be through, I powered down esb_tx_nrf52832(682782977) and flashed another nrf5340dk(1050077823) and programmed it to be esb_tx:

PS C:\nrf\esb_ptx> west flash -d build_1
-- west flash: rebuilding
ninja: no work to do.
-- west flash: using runner nrfjprog
There are multiple boards connected.
1. 1050025410
2. 1050077823
3. 682497942
Please select one with desired serial number (1-3): 2
-- runners.nrfjprog: Flashing file: build_1\zephyr\zephyr.hex
[ #################### ] 2.044s | Erase file - Done erasing
[ #################### ] 0.235s | Program file - Done programming
[ #################### ] 0.236s | Verify file - Done verifying
Applying pin reset.
-- runners.nrfjprog: Board with serial number 1050077823 flashed successfully.

Although 1050077823 (nrf5340-esb_tx) flashed correctly. Blinky continues to run (as it already had) on nrf5340-esb_tx, which probably makes sense, but I'm not getting any kind of esb response from either (nrf52832 or nrf5340) esb-rx.

There is something I am not understanding about how to flash to nrf5340_CPUNET? Maybe it's flashing correctly, but esb needs to be called from CPUAPP to start it working?? I'm close, but missing something...

Ultimately the goal is to have a network of nrf5340's in a Star configuration. I see that there is shared memory between CPUAPP and CPUNET. I assume somehow it's used to pass data from CPUAPP to CPUNET for transmission/reception. I don't exactly understand how that works either, but I figure the first step is to get the esb Sample to work on nrf5340dk's without modification. But, if there are additional samples that target this use case I would be interested in reviewing those too.

The final configuration goal is to have the center of the star network also be running BLE-UART (so the central esb in the Star Network will relay the esb data from the nodes to a BLE app). I am assuming that there is no problem running both esb and BLE at the same time.

esb_prx_ptx.zip

Parents
  • Hi Michael

    Does it work if you flash the empty app core sample on the nRF5340 appcore? 

    Possibly you just miss the config on the app core side to enable the netcore:

    CONFIG_BOARD_ENABLE_CPUNET=y

    Regarding combining BLE and ESB on the nRF5340 I am working on an unofficial sample showing how to do this which you can have a look at here

    You will find a separate sample for the nRF5340 netcore, while the prx and ptx sample can be built either for the nRF5340 appcore, or for one of the nRF52 devices. 

    Best regards
    Torbjørn

  • You will find a separate sample for the nRF5340 netcore, while the prx and ptx sample can be built either for the nRF5340 appcore, or for one of the nRF52 devices. 

    It doesn't look like the prx/tx samples can be build for the nrf5340 appcore? Only for the netcore?

    Everything works as expected on my nrf52 devices.

  • Hi Michael

    It looks to me like you are trying to build the ptx sample for the netcore? 
    Your west build command targets nrf5340dk_nrf5340_cpunet, and the warning you get indicate that you are trying to build an appcore sample for the netcore, since the CONFIG_BOARD_ENABLE_CPUNET config will only work on the appcore. 

    Also, I am confused by your folder structure. If you cloned the github repo, where is the ptx folder? 
    I would recommend building the example out of the box without making any changes, before trying to adapt it to your own project. 

    Best regards
    Torbjørn

  • Thanks. Out of the box was my intention, but I redid it again just to be sure.

    1. Out of the box, esp_tx SDK example
    2. build_5340 targets cpunet, (only option, image attached). I assume there is a 5340 HW reason it has to run on cpunet
    3. build for both 5340 and 52832
    4. esb_rx running on an additional 52832. 
    5. esb_tx build_53832 works (esb_tx receiving/led flashing on nrf52832)
    6. esb_tx build_5340 does not work (flashed successfully, but no esb_tx activity is received on esb_rx.
    7. firmware previously flashed to nrf5340 cpuapp continues to operate normally (blinky or whatever previously flashed to cpuapp)
    8. "where is the ptx folder?" This is still the esp_tx sample from the SDK. Folder structure is unmodified from the SDK (attached) 

    esb_ptx_5340-2.zip

Reply
  • Thanks. Out of the box was my intention, but I redid it again just to be sure.

    1. Out of the box, esp_tx SDK example
    2. build_5340 targets cpunet, (only option, image attached). I assume there is a 5340 HW reason it has to run on cpunet
    3. build for both 5340 and 52832
    4. esb_rx running on an additional 52832. 
    5. esb_tx build_53832 works (esb_tx receiving/led flashing on nrf52832)
    6. esb_tx build_5340 does not work (flashed successfully, but no esb_tx activity is received on esb_rx.
    7. firmware previously flashed to nrf5340 cpuapp continues to operate normally (blinky or whatever previously flashed to cpuapp)
    8. "where is the ptx folder?" This is still the esp_tx sample from the SDK. Folder structure is unmodified from the SDK (attached) 

    esb_ptx_5340-2.zip

Children
  • Hi Michael

    My bad, I misunderstood and thought you were trying to build the MPSL timeslot sample. 

    mej7000 said:
    build_5340 targets cpunet, (only option, image attached). I assume there is a 5340 HW reason it has to run on cpunet

    The radio is only accessible from the network core. The idea of the 5340 is to have the wireless stack run from the network core, while the application core handles the application logic itself, as well as interfacing with sensors and doing more compute intensive tasks. 

    As such the ESB protocol can only be built for the network core, since it accesses the radio peripheral directly. 

    Thanks for sharing your code. I downloaded it and built it for NCS v2.5.1, and I don't seem to have any problems running it. 

    I flashed an nRF5340DK with the empty app core image first, and then with your code built for the netcore. On the PRX side I use an nRF52840DK. I can see the LED's toggle as expected, and can also see on the UART log that the TX_SUCCESS callback is triggered on the PTX side. 

    Do you see any log output from your 5340DK? 

    Which version of the DK do you have? 

    Best regards
    Torbjørn

  • Thanks! Problem solved-ish... As soon as I flashed "empty app core" to the cpuapp everything started working! I'm a little confused as I thought I had already tried flashing "empty app core"...

    When 5340prx and/or 52832prx are flashing normally, resetting ptx causes both 5340prx and/or 52832prx to pause (so they are all programmed and communicating correctly)

    The weird thing I notice now is that after a few minutes (5340prx and 52832prx) will stop flashing. While ptx on the 5340ptx continues to work/flash as expected.

    Serial output "Packet received" string is also terminated on prx when the leds stop flashing.

    Pressing reset on either (5340prx or 52832prx) will bring both (5340prx and 52832prx) back to flashing normally.

    When (5340prx and 52832prx) stop flashing normally, pressing reset on 5340ptx does not cause (5340prx and/or 52832prx) to start flashing again.

    The (5340prx and 52832prx) behavior is constant and repeatable. However when I had 52832ptx and 53832prx they flashed synchronously for days uninterrupted.

    Further testing:  The problem seems to be when the two prx are too close (~30cm) to each other.  Separating prx by a few meters solves the problem. That would be a problem as the final wearable products could easily be left close to each other on a desk or table, etc... 

    So one problem solved, but another discovered...

    1. Is there any solution to this "multiple prx in proximity" problem?
    2. If I were to be able to use shockburst for this or something else, right now all the shockburst logic is running on cpunet. Are there any samples or instructions on how to interact with shockburst from cpuapp? Is it all transparent or are there additional things I need to know?
    3. On my nrf5340dk I now have shockburst running on cpunet. How do I flash that back to "factory settings cpunet" for developing "non-shockbust" applications?
  • Hi Michael

    mej7000 said:
    I'm a little confused as I thought I had already tried flashing "empty app core"...

    It is easy to lose track of what is programmed where. I would strongly recommend enabling UART logging for both cores separately, and make sure to include some kind of welcome message at the start of main (not all the standard samples do this). 

    mej7000 said:
    Is there any solution to this "multiple prx in proximity" problem?

    Am I correct in assuming you are sending the same message to both PRX's on the same address, while also using ACK? 

    This is not recommended as you will get conflicts between the ACK messages sent from the two PRX's, and in some cases you can get weird issues where an ACK packet is interpreted as a normal packet. 

    The fix is to either disable ACK when sending a packet to multiple receivers, or to use different pipes for the two PRX's and send one packet to each of them. 

    mej7000 said:
    If I were to be able to use shockburst for this or something else, right now all the shockburst logic is running on cpunet. Are there any samples or instructions on how to interact with shockburst from cpuapp? Is it all transparent or are there additional things I need to know?

    This is one of the things I am trying to show in the example I linked to earlier:
    https://github.com/too1/ncs-esb-ble-mpsl-demo

    The main purpose of this sample is to show how to run ESB and BLE in parallel using timeslots, but it also shows how the communication can be established between the nRF5340 appcore and netcore in order to control the ESB communication from the appcore. 

    mej7000 said:
    On my nrf5340dk I now have shockburst running on cpunet. How do I flash that back to "factory settings cpunet" for developing "non-shockbust" applications?

    There are many way to do this:

    a) The simple way is just to perform a mass erase of your device, which will remove any application from the netcore:

    nrfjprog -e

    b) You could always disable the netcore in the appcore project, in order to prevent it from running:

    CONFIG_BOARD_ENABLE_CPUNET=n

    c) Finally there is an empty_net_core sample in the SDK, similar to the empty_app_core project, that you can flash in the netcore if you want. That said option a) or b) are simpler in my opinion. 

    Best regards
    Torbjørn

  • Am I correct in assuming you are sending the same message to both PRX's on the same address, while also using ACK? 

    Thanks! Yes, I just applied the prx sample without actually thinking about what's going on. I've used nrf24's before and should have known better...

    In reality I would like to have multiple ptx nodes and one prx parent on the same pipe. I believe that is allowable as all the ptx nodes will be in transmit mode and only switch to prx when waiting for an ACK. I anticipate having multiple ptx on one pipe and using different pipes for additional "groups" of ptx. The limited testing (3 ptx nodes on one pipe) seems to be working. I anticipate up to 10-12 ptx nodes per pipe. Does that scenario sound ok to you? 

    The main purpose of this sample is to show how to run ESB and BLE in parallel using timeslots, but it also shows how the communication can be established between the nRF5340 appcore and netcore in order to control the ESB communication from the appcore. 

    I am very anxious to get to the ESB/BLE part. I just want to make sure I have the basic ESB down before I move forward.

    I have a Hardware/Clock/k_uptime_get() Question:

    The ESB goal is to Star network multiple nodes to a single "parent timekeeper" and sync every few seconds (preload the ACK with Parent's "k_uptime_get()"). Each ptx node sends sensor data. Because we need millisecond "relative ptx node data accuracy", and because there are multiple nodes in the network, we are concerned about data collision and network delays. Therefore each data packet requires a timestamp.

    I'm not certain as to what clock is used for the cpunet and/or shockburst?  I'm using "k_uptime_get()" to time the events and it seems that it relies on CONFIG_SYS_CLOCK_TICKS_PER_SEC which is set to 32768, so I believe (guessing) the accuracy of k_uptime_get is dependent on the XL1/XL2 external oscillator?

    * @note
    * While this function returns time in milliseconds, it does
    * not mean it has millisecond resolution. The actual resolution depends on
    * @kconfig{CONFIG_SYS_CLOCK_TICKS_PER_SEC} config option.
    *
    * @return Current uptime in milliseconds.
    */
    static inline int64_t k_uptime_get(void)

    GEN_ABSOLUTE_SYM_KCONFIG(CONFIG_SYS_CLOCK_TICKS_PER_SEC, 32768);

    I need low drift, (3ppm) on the Parent. Ideally I'd like to use a 3ppm TXCO. Can I put the single output TXCO clock line on only one of the XLx pins? Is it possible to put TXCO clock on XL1 and leave XL2 floating?


    www.digikey.com/.../9645750

  • Hi Michael

    mej7000 said:
    I believe that is allowable as all the ptx nodes will be in transmit mode and only switch to prx when waiting for an ACK. I anticipate having multiple ptx on one pipe and using different pipes for additional "groups" of ptx. The limited testing (3 ptx nodes on one pipe) seems to be working. I anticipate up to 10-12 ptx nodes per pipe. Does that scenario sound ok to you? 

    Having multiple PTX's transmitting to the same PRX is a pretty common use case. Whether or not it is feasible depends more on the total number of packets you expect pr second, and what your latency requirements are, than how many PTX's you have in total.
    The ability to configure the retransmit time in ESB is a feature primarily designed for this use case: By configuring each PTX with a unique non-overlapping retransmit delay you can ensure that in case of a packet collision the two PTX's will retransmit the packet at different points in time, avoiding a collision on the next retransmit.  

    mej7000 said:
    I am very anxious to get to the ESB/BLE part. I just want to make sure I have the basic ESB down before I move forward.

    Sounds like a wise strategy Slight smile

    mej7000 said:
    I'm not certain as to what clock is used for the cpunet and/or shockburst? 

    The ESB library relies mostly on the natural timing of the radio peripheral, except for ACK timeout and retransmit timing which is handled by a TIMER module sourced from the HF clock. 

    mej7000 said:
    I'm using "k_uptime_get()" to time the events and it seems that it relies on CONFIG_SYS_CLOCK_TICKS_PER_SEC which is set to 32768, so I believe (guessing) the accuracy of k_uptime_get is dependent on the XL1/XL2 external oscillator?

    The Zephyr timing methods uses the LF clock, correct, in order to allow decent sleep currents. By default the LF clock will be sourced from the external LF crystal, but you can also use internal source if no crystal is available (at a great hit to accuracy obviously). 

    mej7000 said:
    Can I put the single output TXCO clock line on only one of the XLx pins? Is it possible to put TXCO clock on XL1 and leave XL2 floating?

    This is certainly possible from a hardware perspective. I am not sure how you would configure this in Zephyr though, I need some time to look into this. 

    Best regards
    Torbjørn

Related