CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX questions

Hello

I've been experimenting in increasing the number of targets that a mesh FOTA distribution server can support on nRF52840

The CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX has a maximum  65535

But for practical purposes I'd be happy if I could have at least 50-60.
Ran into build asserts in zephyr\subsys\bluetooth\mesh\dfd_srv.c
"The Firmware Distribution Receivers List message does not fit into the maximum " "outgoing SDU size"

The comparison is done to the  BT_MESH_TX_SDU_MAX which is built as follows
#define BT_MESH_TX_SDU_MAX        MAX((BT_MESH_TX_SEG_MAX *     \
                       BT_MESH_APP_SEG_SDU_MAX),    \
                      BT_MESH_APP_UNSEG_SDU_MAX)
CONFIG_BT_MESH_TX_SEG_MAX is limited to 32
BT_MESH_APP_SEG_SDU_MAX is defined as 12
BT_MESH_APP_UNSEG_SDU_MAX is defined as 15
By trial and error I was able to set the number of targets to 39 with these configurations
ONFIG_BT_MESH_MSG_CACHE_SIZE=256
CONFIG_BT_MESH_ADV_BUF_COUNT=128
CONFIG_BT_MESH_TX_SEG_MAX=32
CONFIG_BT_MESH_RX_SEG_MAX=32
CONFIG_BT_MESH_TX_SEG_MSG_COUNT=64
CONFIG_BT_MESH_RX_SEG_MSG_COUNT=64
CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX=39
Is this it? Or is there another way to increase the number of supported targets?
Thank you
 
Parents
  • Hi Andy,

    What you are trying is to try sending a large number of receive info in one shot. This will exceed the maximum size of a mesh packet (segmented packets) hence the build error you saw. With mesh, the strategy is to avoid sending a large packet. It will be redistributed to the whole network and waste a lot or resources of the network (and cause congestion). 
    The better way of doing it is to send smaller number of receive list one by one using Firmware Distribution Receivers Add messages, instead of sending them at once. 

    This is my understanding after taking a look at the doc: 
    https://docs.zephyrproject.org/latest/connectivity/bluetooth/api/mesh/dfu.html#populating-the-distributor-s-receivers-list

  • The reason for the build errors is the assert. The assert occurs if CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX is increased. My goal is to be able to have 50 or more targets. If I increase the number of targets I get the assert. If I increase the CONFIG_BT_MESH_TX_SEG_MAX build succeeds but any CONFIG_BT_MESH_TX_SEG_MAX value greater than 10 results in "SDU canceled" message during transfer and transfer fails.

    So in reality  the max number of targets I can have with CONFIG_BT_MESH_TX_SEG_MAX=10 is 22

    Is there a way to overcome this limit?

    In your internal testing, what was the largest number of targets you were able to send a DFU image to?

     

  • Hi Andy, 
    I'm finally back to the office and can actually do some tests. 
    I was doing a quick test with NCS v2.9.0 and the default distributor sample. Here is my list of commands:

    By default CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX = 8 and CONFIG_BT_MESH_TX_SEG_MAX =10. 

    So it seems to works with small number of receiver and multiple dfd receivers-add packet. 

    However, when increasing CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX  to 32 I hit what you reported earlier : 

    BUILD_ASSERT((DFD_RECEIVERS_LIST_MSG_MAXLEN + BT_MESH_MODEL_OP_LEN(BT_MESH_DFD_OP_RECEIVERS_LIST) +
              BT_MESH_MIC_SHORT) <= BT_MESH_TX_SDU_MAX,
             "The Firmware Distribution Receivers List message does not fit into the maximum "
             "outgoing SDU size.");


    So this issue is not about adding the target to the list, it's about that the report of the list can not fit into one mess message (the one what showed 8 target in my screenshot). I will check with the team how should we deal with this problem. My understanding is that this static assert can be modified so that the list can be acquired by multiple message dfd receivers-get message instead of one single message. 
    I will keep you updated. 

     

  • Yes, I'm using the same commands.
    What you're describing is only 1 problem. 
    There are actually 3

    1. When CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX is increased  the CONFIG_BT_MESH_TX_SEG_MAX must be increased as well otherwise there is a build assert. Might be good to document it somewhere, (The one you describe)

    2. Asserts check against BT_MESH_TX_SDU_MAX or BT_MESH_RX_SDU_MAX ( that the values they check are smaller)
    However those defines use 2 hard coded values :BT_MESH_APP_SEG_SDU_MAX and  BT_MESH_APP_UNSEG_SDU_MAX (12 and 15 respectively)  - see in zephyr\include\zephyr\bluetooth\mesh\access.h
    So even if CONFIG_BT_MESH_TX_SEG_MAX  is increased to 32 the CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX cannot go higher than 70 or so.

    3. Increasing CONFIG_BT_MESH_TX_SEG_MAX  to 32 causes DFD to fail almost immediately with "SDU canceled" error even if the number of targets is 1.

  • Hi Andy, 

    My opinion is that the build assert i pointed in my last reply need to be removed or change to something else. 


    I assume issue #2 and #3 you mentioned are also related to that build assert, correct ? 

    I don't think CONFIG_BT_MESH_TX_SEG_MAX  should be increased to a large number .The number of segment in a message should be kept low they use a lot of resource and can reduce the throughput of the network a lot. 

  • Only #2 is related to build asserts. 
    #3 is the "SDU canceled" error when CONFIG_BT_MESH_TX_SEG_MAX > 10 regardless of how many targets in the list.
    I commented out asserts I was getting for "Receivers List" and "Receivers add" messages  in zephyr\subsys\bluetooth\mesh\dfd_srv.c and was able to build successfully with CONFIG_BT_MESH_DFD_SRV_TARGETS_MAX  set to 100 and  CONFIG_BT_MESH_TX_SEG_MAX set to 10
    Distribution was successful without "SDU canceled" messages

    Looks like we solved the problem!
    Would be great to get that fix into the next SDK release
    Thank you for help!

  • Hi Andy, 


    I agree that that build assert should be removed. I was checking with the team and it seems that it's not mandated by the spec. We are continuing the investigation on why it's added in the first place. I suspect that we didn't think of using multiple  dfd receivers-get to get the list instead of using one single command to get the list. 

    The team has acknowledged this issue and we will have a fix. Thanks for the report. 

Reply
  • Hi Andy, 


    I agree that that build assert should be removed. I was checking with the team and it seems that it's not mandated by the spec. We are continuing the investigation on why it's added in the first place. I suspect that we didn't think of using multiple  dfd receivers-get to get the list instead of using one single command to get the list. 

    The team has acknowledged this issue and we will have a fix. Thanks for the report. 

Children
No Data
Related