|
Zephyr Project API 4.2.99
A Scalable Open Source RTOS
|
Bluetooth data buffer API. More...
#include <stddef.h>#include <stdint.h>#include <zephyr/autoconf.h>#include <zephyr/bluetooth/hci.h>#include <zephyr/bluetooth/hci_types.h>#include <zephyr/net_buf.h>#include <zephyr/sys/util.h>#include <zephyr/sys/util_macro.h>#include <zephyr/sys_clock.h>#include <zephyr/toolchain.h>Go to the source code of this file.
Macros | |
| #define | BT_BUF_RESERVE 1 |
| #define | BT_BUF_SIZE(size) (BT_BUF_RESERVE + (size)) |
| Helper to include reserved HCI data in buffer calculations. | |
| #define | BT_BUF_ACL_SIZE(size) BT_BUF_SIZE(BT_HCI_ACL_HDR_SIZE + (size)) |
| Helper to calculate needed buffer size for HCI ACL packets. | |
| #define | BT_BUF_EVT_SIZE(size) BT_BUF_SIZE(BT_HCI_EVT_HDR_SIZE + (size)) |
| Helper to calculate needed buffer size for HCI Event packets. | |
| #define | BT_BUF_CMD_SIZE(size) BT_BUF_SIZE(BT_HCI_CMD_HDR_SIZE + (size)) |
| Helper to calculate needed buffer size for HCI Command packets. | |
| #define | BT_BUF_ISO_SIZE(size) |
| Helper to calculate needed buffer size for HCI ISO packets. | |
| #define | BT_BUF_ACL_RX_SIZE BT_BUF_ACL_SIZE(CONFIG_BT_BUF_ACL_RX_SIZE) |
| Data size needed for HCI ACL RX buffers. | |
| #define | BT_BUF_EVT_RX_SIZE BT_BUF_EVT_SIZE(CONFIG_BT_BUF_EVT_RX_SIZE) |
| Data size needed for HCI Event RX buffers. | |
| #define | BT_BUF_ISO_RX_SIZE 0 |
| #define | BT_BUF_ISO_RX_COUNT 0 |
| #define | BT_BUF_ACL_RX_COUNT_MAX 65535 |
| #define | BT_BUF_ACL_RX_COUNT_EXTRA 0 |
| #define | BT_BUF_ACL_RX_COUNT 0 |
| #define | BT_BUF_RX_SIZE |
| Data size needed for HCI ACL, HCI ISO or Event RX buffers. | |
| #define | BT_BUF_RX_COUNT |
| Buffer count needed for HCI ACL or HCI ISO plus Event RX buffers. | |
| #define | BT_BUF_CMD_TX_SIZE BT_BUF_CMD_SIZE(CONFIG_BT_BUF_CMD_TX_SIZE) |
| Data size needed for HCI Command buffers. | |
Typedefs | |
| typedef void(* | bt_buf_rx_freed_cb_t) (enum bt_buf_type type_mask) |
| A callback to notify about freed buffer in the incoming data pool. | |
Enumerations | |
| enum | bt_buf_type { BT_BUF_TYPE_NONE = 0 , BT_BUF_CMD = BIT(0) , BT_BUF_EVT = BIT(1) , BT_BUF_ACL_OUT = BIT(2) , BT_BUF_ACL_IN = BIT(3) , BT_BUF_ISO_OUT = BIT(4) , BT_BUF_ISO_IN = BIT(5) } |
| Possible types of buffers passed around the Bluetooth stack in a form of bitmask. More... | |
| enum | bt_buf_dir { BT_BUF_IN , BT_BUF_OUT } |
| Direction of HCI packets. More... | |
Functions | |
| static uint8_t | bt_buf_type_to_h4 (enum bt_buf_type type) |
| Convert from bt_buf_type to H:4 type. | |
| static enum bt_buf_type | bt_buf_type_from_h4 (uint8_t h4_type, enum bt_buf_dir dir) |
| Convert from H:4 type to bt_buf_type. | |
| struct net_buf * | bt_buf_get_rx (enum bt_buf_type type, k_timeout_t timeout) |
| Allocate a buffer for incoming data. | |
| void | bt_buf_rx_freed_cb_set (bt_buf_rx_freed_cb_t cb) |
| Set the callback to notify about freed buffer in the incoming data pool. | |
| struct net_buf * | bt_buf_get_tx (enum bt_buf_type type, k_timeout_t timeout, const void *data, size_t size) |
| Allocate a buffer for outgoing data. | |
| struct net_buf * | bt_buf_get_evt (uint8_t evt, bool discardable, k_timeout_t timeout) |
| Allocate a buffer for an HCI Event. | |
| static void | bt_buf_set_type (struct net_buf *buf, enum bt_buf_type type) |
| Set the buffer type. | |
| static enum bt_buf_type | bt_buf_get_type (struct net_buf *buf) |
| Get the buffer type. | |
Bluetooth data buffer API.