|
Zephyr Project API
3.4.0
A Scalable Open Source RTOS
|
MCUmgr transport SMP API. More...
Data Structures | |
| struct | smp_transport_api_t |
| Function pointers of SMP transport functions, if a handler is NULL then it is not supported/implemented. More... | |
| struct | smp_transport |
| SMP transport object for sending SMP responses. More... | |
Typedefs | |
| typedef int(* | smp_transport_out_fn) (struct net_buf *nb) |
| SMP transmit callback for transport. More... | |
| typedef uint16_t(* | smp_transport_get_mtu_fn) (const struct net_buf *nb) |
| SMP MTU query callback for transport. More... | |
| typedef int(* | smp_transport_ud_copy_fn) (struct net_buf *dst, const struct net_buf *src) |
| SMP copy user_data callback. More... | |
| typedef void(* | smp_transport_ud_free_fn) (void *ud) |
| SMP free user_data callback. More... | |
| typedef bool(* | smp_transport_query_valid_check_fn) (struct net_buf *nb, void *arg) |
| Function for checking if queued data is still valid. More... | |
Functions | |
| int | smp_transport_init (struct smp_transport *smpt) |
| Initializes a Zephyr SMP transport object. More... | |
| void | smp_rx_remove_invalid (struct smp_transport *zst, void *arg) |
| Used to remove queued requests for an SMP transport that are no longer valid. A smp_transport_query_valid_check_fn() function must be registered for this to function. If the smp_transport_query_valid_check_fn() function returns false during a callback, the queried command will classed as invalid and dropped. More... | |
| void | smp_rx_clear (struct smp_transport *zst) |
| Used to clear pending queued requests for an SMP transport. More... | |
MCUmgr transport SMP API.
| smp_transport_get_mtu_fn |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
SMP MTU query callback for transport.
The supplied net_buf should contain a request received from the peer whose MTU is being queried. This function takes a net_buf parameter because some transports store connection-specific information in the net_buf user header (e.g., the BLE transport stores the peer address).
| nb | Contains a request from the relevant peer. |
| smp_transport_out_fn |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
SMP transmit callback for transport.
The supplied net_buf is always consumed, regardless of return code.
| nb | The net_buf to transmit. |
| smp_transport_query_valid_check_fn |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
Function for checking if queued data is still valid.
This function is used to check if queued SMP data is still valid e.g. on a remote device disconnecting, this is triggered when smp_rx_remove_invalid() is called.
| nb | net buf containing queued request. |
| arg | Argument provided when calling smp_rx_remove_invalid() function. |
| smp_transport_ud_copy_fn |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
SMP copy user_data callback.
The supplied src net_buf should contain a user_data that cannot be copied using regular memcpy function (e.g., the BLE transport net_buf user_data stores the connection reference that has to be incremented when is going to be used by another buffer).
| dst | Source buffer user_data pointer. |
| src | Destination buffer user_data pointer. |
| smp_transport_ud_free_fn |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
SMP free user_data callback.
This function frees net_buf user data, because some transports store connection-specific information in the net_buf user data (e.g., the BLE transport stores the connection reference that has to be decreased).
| ud | Contains a user_data pointer to be freed. |
| void smp_rx_clear | ( | struct smp_transport * | zst | ) |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
Used to clear pending queued requests for an SMP transport.
| zst | The transport to use. |
| void smp_rx_remove_invalid | ( | struct smp_transport * | zst, |
| void * | arg | ||
| ) |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
Used to remove queued requests for an SMP transport that are no longer valid. A smp_transport_query_valid_check_fn() function must be registered for this to function. If the smp_transport_query_valid_check_fn() function returns false during a callback, the queried command will classed as invalid and dropped.
| zst | The transport to use. |
| arg | Argument provided to callback smp_transport_query_valid_check_fn() function. |
| int smp_transport_init | ( | struct smp_transport * | smpt | ) |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
Initializes a Zephyr SMP transport object.
| smpt | The transport to construct. |