BLOB Transfer Client
The Binary Large Object (BLOB) Transfer Client is the sender of the BLOB transfer. It supports sending BLOBs of any size to any number of destination nodes, whether in Push BLOB Transfer Mode or Pull BLOB Transfer Mode.
Usage
Initialization
The BLOB Transfer Client is instantiated on an element with a set of event handler callbacks:
static const struct bt_mesh_blob_cli_cb blob_cb = {
      /* Callbacks */
};
static struct bt_mesh_blob_cli blob_cli = {
      .cb = &blob_cb,
};
static const struct bt_mesh_model models[] = {
      BT_MESH_MODEL_BLOB_CLI(&blob_cli),
};
Transfer Context
Both the retrieval process and BLOB transfer utilize an instance of bt_mesh_blob_cli_inputs
to determine how to perform the transfer. Before being used in the process, the BLOB Transfer Client input structure must be initialized with at least a target list,
application key, and Time-To-Live (TTL) value:
static struct bt_mesh_blob_target targets[3] = {
        { .addr = 0x0001 },
        { .addr = 0x0002 },
        { .addr = 0x0003 },
};
static struct bt_mesh_blob_cli_inputs inputs = {
        .app_idx = MY_APP_IDX,
        .ttl = BT_MESH_TTL_DEFAULT,
};
sys_slist_init(&inputs.targets);
sys_slist_append(&inputs.targets, &targets[0].n);
sys_slist_append(&inputs.targets, &targets[1].n);
sys_slist_append(&inputs.targets, &targets[2].n);
Note that all BLOB Transfer Servers in the transfer must be bound to the chosen application key.
Logical Address
The application may additionally specify a group address in the context structure. If the group is
not BT_MESH_ADDR_UNASSIGNED, the messages in the transfer will be sent to the group
address, instead of being sent individually to each Target node. Mesh Manager must ensure that all
Target nodes having the BLOB Transfer Server model subscribe to this group address.
Transmitting BLOBs using a group address can generally increase transfer speed because the BLOB Transfer Client sends each message to all destination nodes simultaneously. However, sending large segmented messages to a group address in Bluetooth Mesh is generally less reliable than sending them to unicast addresses because groups lack a transport layer acknowledgment mechanism. This can result in longer recovery periods at the end of each block and increase the risk of losing destination nodes. Using a group address for BLOB transfers is usually only rewarding when the list of destination nodes is extensive, and the effectiveness of each addressing strategy can vary greatly between different deployments and block sizes.
Transfer Timeout
If a Target node fails to respond to an acknowledged message within the BLOB Transfer Client’s time limit, the Target node is dropped from the transfer. The application can provide additional time through the context structure to the BLOB Transfer Client, reducing this possibility. Besides the base time of 20 seconds, extra time can be set in increments of 10 seconds, up to a maximum of 182 hours. The waiting time is automatically adjusted based on the transfer TTL.
Note that the BLOB Transfer Client only moves forward with the transfer in following cases:
- All Target nodes have responded. 
- A node has been removed from the list of Target nodes. 
- The BLOB Transfer Client times out. 
Increasing the wait time will increase this delay.
BLOB Transfer Capabilities Retrieval
It is generally recommended to retrieve BLOB transfer capabilities before starting a transfer. The procedure populates the transfer capabilities from all target nodes with the most liberal set of parameters that allows all Target nodes to participate in the transfer. Any destination nodes that fail to respond, or respond with incompatible transfer parameters, will be dropped.
Destination nodes are prioritized based on their order in the list of Target nodes. If a destination node
is found to be incompatible with any of the previous destination nodes, for instance by reporting a
non-overlapping block size range, it will be dropped. Lost destination nodes will be reported through the
lost_target callback.
The end of the procedure is signalled through the caps
callback, and the resulting capabilities can be used to determine the required block and chunk sizes required
for the BLOB transfer.
BLOB Transfer
The BLOB transfer is started by calling bt_mesh_blob_cli_send() function, which (in addition
to the aforementioned transfer inputs) requires a set of transfer parameters and a BLOB stream
instance. Transfer parameters include the 64-bit BLOB ID, BLOB size, transfer mode, logarithmically represented block size, and number of blocks.
The BLOB ID is defined by the application but must match the BLOB ID that initiates the BLOB Transfer Server.
The transfer will run until the transfer to at least one destination node is successfully completed or the transfer is canceled.
The end of the transfer is communicated to the application through the end callback.
Lost Target nodes will be reported through the:c:member:lost_target <bt_mesh_blob_cli_cb.lost_target> callback.
API Reference
- group bt_mesh_blob_cli
- Defines - 
BT_MESH_MODEL_BLOB_CLI(_cli)
- BLOB Transfer Client model Composition Data entry. - Parameters:
- _cli – Pointer to a Bluetooth Mesh BLOB Transfer Client model API instance. 
 
 
 - Enums - 
enum bt_mesh_blob_cli_state
- BLOB Transfer Client state. - Values: - 
enumerator BT_MESH_BLOB_CLI_STATE_NONE
- No transfer is active. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_CAPS_GET
- Retrieving transfer capabilities. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_START
- Sending transfer start. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_BLOCK_START
- Sending block start. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_BLOCK_SEND
- Sending block chunks. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_BLOCK_CHECK
- Checking block status. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_XFER_CHECK
- Checking transfer status. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_CANCEL
- Cancelling transfer. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_SUSPENDED
- Transfer is suspended. 
 - 
enumerator BT_MESH_BLOB_CLI_STATE_XFER_PROGRESS_GET
- Checking transfer progress. 
 
- 
enumerator BT_MESH_BLOB_CLI_STATE_NONE
 - Functions - 
int bt_mesh_blob_cli_caps_get(struct bt_mesh_blob_cli *cli, const struct bt_mesh_blob_cli_inputs *inputs)
- Retrieve transfer capabilities for a list of Target nodes. - Queries the availability and capabilities of all Target nodes, producing a cumulative set of transfer capabilities for the Target nodes, and returning it through the bt_mesh_blob_cli_cb::caps callback. - Retrieving the capabilities may take several seconds, depending on the number of Target nodes and mesh network performance. The end of the procedure is indicated through the bt_mesh_blob_cli_cb::caps callback. - This procedure is not required, but strongly recommended as a preparation for a transfer to maximize performance and the chances of success. - Parameters:
- cli – BLOB Transfer Client instance. 
- inputs – Statically allocated BLOB Transfer Client transfer inputs. 
 
- Returns:
- 0 on success, or (negative) error code otherwise. 
 
 - 
int bt_mesh_blob_cli_send(struct bt_mesh_blob_cli *cli, const struct bt_mesh_blob_cli_inputs *inputs, const struct bt_mesh_blob_xfer *xfer, const struct bt_mesh_blob_io *io)
- Perform a BLOB transfer. - Starts sending the transfer to the Target nodes. Only Target nodes with a - statusof BT_MESH_BLOB_SUCCESS will be considered.- The transfer will keep going either until all Target nodes have been dropped, or the full BLOB has been sent. - The BLOB transfer may take several minutes, depending on the number of Target nodes, size of the BLOB and mesh network performance. The end of the transfer is indicated through the bt_mesh_blob_cli_cb::end callback. - A Client only supports one transfer at the time. - Parameters:
- cli – BLOB Transfer Client instance. 
- inputs – Statically allocated BLOB Transfer Client transfer inputs. 
- xfer – Statically allocated transfer parameters. 
- io – BLOB stream to read the transfer from. 
 
- Returns:
- 0 on success, or (negative) error code otherwise. 
 
 - 
int bt_mesh_blob_cli_suspend(struct bt_mesh_blob_cli *cli)
- Suspend the active transfer. - Parameters:
- cli – BLOB Transfer Client instance. 
- Returns:
- 0 on success, or (negative) error code otherwise. 
 
 - 
int bt_mesh_blob_cli_resume(struct bt_mesh_blob_cli *cli)
- Resume the suspended transfer. - Parameters:
- cli – BLOB Transfer Client instance. 
- Returns:
- 0 on success, or (negative) error code otherwise. 
 
 - 
void bt_mesh_blob_cli_cancel(struct bt_mesh_blob_cli *cli)
- Cancel an ongoing transfer. - Parameters:
- cli – BLOB Transfer Client instance. 
 
 - 
int bt_mesh_blob_cli_xfer_progress_get(struct bt_mesh_blob_cli *cli, const struct bt_mesh_blob_cli_inputs *inputs)
- Get the progress of BLOB transfer. - This function can only be used if the BLOB Transfer Client is currently not performing a BLOB transfer. To get progress of the active BLOB transfer, use the bt_mesh_blob_cli_xfer_progress_active_get function. - Parameters:
- cli – BLOB Transfer Client instance. 
- inputs – Statically allocated BLOB Transfer Client transfer inputs. 
 
- Returns:
- 0 on success, or (negative) error code otherwise. 
 
 - 
uint8_t bt_mesh_blob_cli_xfer_progress_active_get(struct bt_mesh_blob_cli *cli)
- Get the current progress of the active transfer in percent. - Parameters:
- cli – BLOB Transfer Client instance. 
- Returns:
- The current transfer progress, or 0 if no transfer is active. 
 
 - 
bool bt_mesh_blob_cli_is_busy(struct bt_mesh_blob_cli *cli)
- Get the current state of the BLOB Transfer Client. - Parameters:
- cli – BLOB Transfer Client instance. 
- Returns:
- true if the BLOB Transfer Client is currently participating in a transfer or retrieving the capabilities and false otherwise. 
 
 - 
struct bt_mesh_blob_target_pull
- Target node’s Pull mode (Pull BLOB Transfer Mode) context used while sending chunks to the Target node. 
 - 
struct bt_mesh_blob_target
- BLOB Transfer Client Target node. - Public Members - 
sys_snode_t n
- Linked list node 
 - 
uint16_t addr
- Target node address. 
 - 
struct bt_mesh_blob_target_pull *pull
- Target node’s Pull mode context. Needs to be initialized when sending a BLOB in Pull mode. 
 - 
uint8_t status
- BLOB transfer status, see bt_mesh_blob_status. 
 
- 
sys_snode_t n
 - 
struct bt_mesh_blob_xfer_info
- BLOB transfer information. - If - phaseis BT_MESH_BLOB_XFER_PHASE_INACTIVE, the fields below- phaseare not initialized. If- phaseis BT_MESH_BLOB_XFER_PHASE_WAITING_FOR_START, the fields below- idare not initialized.- Public Members - 
enum bt_mesh_blob_status status
- BLOB transfer status. 
 - 
enum bt_mesh_blob_xfer_mode mode
- BLOB transfer mode. 
 - 
enum bt_mesh_blob_xfer_phase phase
- BLOB transfer phase. 
 - 
uint64_t id
- BLOB ID. 
 - 
uint32_t size
- BLOB size in octets. 
 - 
uint8_t block_size_log
- Logarithmic representation of the block size. 
 - 
uint16_t mtu_size
- MTU size in octets. 
 - 
const uint8_t *missing_blocks
- Bit field indicating blocks that were not received. 
 
- 
enum bt_mesh_blob_status status
 - 
struct bt_mesh_blob_cli_inputs
- BLOB Transfer Client transfer inputs. - Public Members - 
sys_slist_t targets
- Linked list of Target nodes. Each node should point to bt_mesh_blob_target::n. 
 - 
uint16_t app_idx
- AppKey index to send with. 
 - 
uint16_t group
- Group address destination for the BLOB transfer, or BT_MESH_ADDR_UNASSIGNED to send every message to each Target node individually. 
 - 
uint8_t ttl
- Time to live value of BLOB transfer messages. 
 - 
uint16_t timeout_base
- Additional response time for the Target nodes, in 10-second increments. - The extra time can be used to give the Target nodes more time to respond to messages from the Client. The actual timeout will be calculated according to the following formula: - * timeout = 20 seconds + (10 seconds * timeout_base) + (100 ms * TTL) * - If a Target node fails to respond to a message from the Client within the configured transfer timeout, the Target node is dropped. 
 
- 
sys_slist_t targets
 - 
struct bt_mesh_blob_cli_caps
- Transfer capabilities of a Target node. - Public Members - 
size_t max_size
- Max BLOB size. 
 - 
uint8_t min_block_size_log
- Logarithmic representation of the minimum block size. 
 - 
uint8_t max_block_size_log
- Logarithmic representation of the maximum block size. 
 - 
uint16_t max_chunks
- Max number of chunks per block. 
 - 
uint16_t max_chunk_size
- Max chunk size. 
 - 
uint16_t mtu_size
- Max MTU size. 
 - 
enum bt_mesh_blob_xfer_mode modes
- Supported transfer modes. 
 
- 
size_t max_size
 - 
struct bt_mesh_blob_cli_cb
- Event handler callbacks for the BLOB Transfer Client model. - All handlers are optional. - Public Members - 
void (*caps)(struct bt_mesh_blob_cli *cli, const struct bt_mesh_blob_cli_caps *caps)
- Capabilities retrieval completion callback. - Called when the capabilities retrieval procedure completes, indicating that a common set of acceptable transfer parameters have been established for the given list of Target nodes. All compatible Target nodes have status code BT_MESH_BLOB_SUCCESS. - Param cli:
- BLOB Transfer Client instance. 
- Param caps:
- Safe transfer capabilities if the transfer capabilities of at least one Target node has satisfied the Client, or NULL otherwise. 
 
 - 
void (*lost_target)(struct bt_mesh_blob_cli *cli, struct bt_mesh_blob_target *target, enum bt_mesh_blob_status reason)
- Target node loss callback. - Called whenever a Target node has been lost due to some error in the transfer. Losing a Target node is not considered a fatal error for the Client until all Target nodes have been lost. - Param cli:
- BLOB Transfer Client instance. 
- Param target:
- Target node that was lost. 
- Param reason:
- Reason for the Target node loss. 
 
 - 
void (*suspended)(struct bt_mesh_blob_cli *cli)
- Transfer is suspended. - Called when the transfer is suspended due to response timeout from all Target nodes. - Param cli:
- BLOB Transfer Client instance. 
 
 - 
void (*end)(struct bt_mesh_blob_cli *cli, const struct bt_mesh_blob_xfer *xfer, bool success)
- Transfer end callback. - Called when the transfer ends. - Param cli:
- BLOB Transfer Client instance. 
- Param xfer:
- Completed transfer. 
- Param success:
- Status of the transfer. Is - trueif at least one Target node received the whole transfer.
 
 - 
void (*xfer_progress)(struct bt_mesh_blob_cli *cli, struct bt_mesh_blob_target *target, const struct bt_mesh_blob_xfer_info *info)
- Transfer progress callback. - The content of - infois invalidated upon exit from the callback. Therefore it needs to be copied if it is planned to be used later.- Param cli:
- BLOB Transfer Client instance. 
- Param target:
- Target node that responded to the request. 
- Param info:
- BLOB transfer information. 
 
 - 
void (*xfer_progress_complete)(struct bt_mesh_blob_cli *cli)
- End of Get Transfer Progress procedure. - Called when all Target nodes have responded or the procedure timed-out. - Param cli:
- BLOB Transfer Client instance. 
 
 
- 
void (*caps)(struct bt_mesh_blob_cli *cli, const struct bt_mesh_blob_cli_caps *caps)
 - 
struct bt_mesh_blob_cli
- BLOB Transfer Client model instance. - Public Members - 
const struct bt_mesh_blob_cli_cb *cb
- Event handler callbacks 
 
- 
const struct bt_mesh_blob_cli_cb *cb
 
- 
BT_MESH_MODEL_BLOB_CLI(_cli)