Zephyr Project API 4.0.99
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... | |
struct | smp_client_transport_entry |
SMP Client transport structure. More... | |
Typedefs | |
typedef int(* | smp_transport_out_fn) (struct net_buf *nb) |
SMP transmit callback for transport. | |
typedef uint16_t(* | smp_transport_get_mtu_fn) (const struct net_buf *nb) |
SMP MTU query callback for transport. | |
typedef int(* | smp_transport_ud_copy_fn) (struct net_buf *dst, const struct net_buf *src) |
SMP copy user_data callback. | |
typedef void(* | smp_transport_ud_free_fn) (void *ud) |
SMP free user_data callback. | |
typedef bool(* | smp_transport_query_valid_check_fn) (struct net_buf *nb, void *arg) |
Function for checking if queued data is still valid. | |
Enumerations | |
enum | smp_transport_type { SMP_SERIAL_TRANSPORT = 0 , SMP_BLUETOOTH_TRANSPORT , SMP_SHELL_TRANSPORT , SMP_UDP_IPV4_TRANSPORT , SMP_UDP_IPV6_TRANSPORT , SMP_LORAWAN_TRANSPORT , SMP_USER_DEFINED_TRANSPORT } |
SMP transport type for client registration. More... | |
Functions | |
int | smp_transport_init (struct smp_transport *smpt) |
Initializes a Zephyr SMP transport object. | |
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. | |
void | smp_rx_clear (struct smp_transport *zst) |
Used to clear pending queued requests for an SMP transport. | |
void | smp_client_transport_register (struct smp_client_transport_entry *entry) |
Register a Zephyr SMP transport object for client. | |
struct smp_transport * | smp_client_transport_get (int smpt_type) |
Discover a registered SMP transport client object. | |
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. |
enum smp_transport_type |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
SMP transport type for client registration.
struct smp_transport * smp_client_transport_get | ( | int | smpt_type | ) |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
Discover a registered SMP transport client object.
smpt_type | Type of transport |
void smp_client_transport_register | ( | struct smp_client_transport_entry * | entry | ) |
#include <include/zephyr/mgmt/mcumgr/transport/smp.h>
Register a Zephyr SMP transport object for client.
entry | The transport to construct. |
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. |