Zephyr Project API 4.2.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
bluetooth.h
Go to the documentation of this file.
1
15#ifndef ZEPHYR_INCLUDE_DRIVERS_BLUETOOTH_H_
16#define ZEPHYR_INCLUDE_DRIVERS_BLUETOOTH_H_
17
29#include <stdbool.h>
30#include <stdint.h>
31#include <zephyr/net_buf.h>
35#include <zephyr/device.h>
36
37#ifdef __cplusplus
38extern "C" {
39#endif
40
48
49enum {
50 /* The host should never send HCI_Reset */
52 /* The controller does not auto-initiate a DLE procedure when the
53 * initial connection data length parameters are not equal to the
54 * default data length parameters. Therefore the host should initiate
55 * the DLE procedure after connection establishment.
56 *
57 * That requirement is stated in Core Spec v5.4 Vol 6 Part B. 4.5.10
58 * Data PDU length management:
59 *
60 * > For a new connection:
61 * > - ... If either value is not 27, then the Controller should
62 * > initiate the Data Length Update procedure at the earliest
63 * > practical opportunity.
64 */
66};
67
83
84#define BT_DT_HCI_QUIRK_OR(node_id, prop, idx) \
85 UTIL_CAT(BT_HCI_QUIRK_, DT_STRING_UPPER_TOKEN_BY_IDX(node_id, prop, idx))
86#define BT_DT_HCI_QUIRKS_GET(node_id) COND_CODE_1(DT_NODE_HAS_PROP(node_id, bt_hci_quirks), \
87 (DT_FOREACH_PROP_ELEM_SEP(node_id, \
88 bt_hci_quirks, \
89 BT_DT_HCI_QUIRK_OR, \
90 (|))), \
91 (0))
92#define BT_DT_HCI_QUIRKS_INST_GET(inst) BT_DT_HCI_QUIRKS_GET(DT_DRV_INST(inst))
93
94#define BT_DT_HCI_NAME_GET(node_id) DT_PROP_OR(node_id, bt_hci_name, "HCI")
95#define BT_DT_HCI_NAME_INST_GET(inst) BT_DT_HCI_NAME_GET(DT_DRV_INST(inst))
96
97/* Fallback default when there's no property, same as "virtual" */
98#define BT_PRIV_HCI_BUS_DEFAULT (0)
99#define BT_DT_HCI_BUS_GET(node_id) DT_ENUM_IDX_OR(node_id, bt_hci_bus, BT_PRIV_HCI_BUS_DEFAULT)
100
101#define BT_DT_HCI_BUS_INST_GET(inst) BT_DT_HCI_BUS_GET(DT_DRV_INST(inst))
102
103typedef int (*bt_hci_recv_t)(const struct device *dev, struct net_buf *buf);
104
105__subsystem struct bt_hci_driver_api {
106 int (*open)(const struct device *dev, bt_hci_recv_t recv);
107 int (*close)(const struct device *dev);
108 int (*send)(const struct device *dev, struct net_buf *buf);
109#if defined(CONFIG_BT_HCI_SETUP)
110 int (*setup)(const struct device *dev,
111 const struct bt_hci_setup_params *param);
112#endif /* defined(CONFIG_BT_HCI_SETUP) */
113};
114
129static inline int bt_hci_open(const struct device *dev, bt_hci_recv_t recv)
130{
131 const struct bt_hci_driver_api *api = (const struct bt_hci_driver_api *)dev->api;
132
133 return api->open(dev, recv);
134}
135
146static inline int bt_hci_close(const struct device *dev)
147{
148 const struct bt_hci_driver_api *api = (const struct bt_hci_driver_api *)dev->api;
149
150 if (api->close == NULL) {
151 return -ENOSYS;
152 }
153
154 return api->close(dev);
155}
156
176static inline int bt_hci_send(const struct device *dev, struct net_buf *buf)
177{
178 const struct bt_hci_driver_api *api = (const struct bt_hci_driver_api *)dev->api;
179
180 return api->send(dev, buf);
181}
182
183#if defined(CONFIG_BT_HCI_SETUP) || defined(__DOXYGEN__)
196static inline int bt_hci_setup(const struct device *dev, struct bt_hci_setup_params *params)
197{
198 const struct bt_hci_driver_api *api = (const struct bt_hci_driver_api *)dev->api;
199
200 if (api->setup == NULL) {
201 return -ENOSYS;
202 }
203
204 return api->setup(dev, params);
205}
206#endif
207
212/* The following functions are not strictly part of the HCI driver API, in that
213 * they do not take as input a struct device which implements the HCI driver API.
214 */
215
227int bt_hci_transport_setup(const struct device *dev);
228
240int bt_hci_transport_teardown(const struct device *dev);
241
254
268
282
283#ifdef __cplusplus
284}
285#endif
286
287#endif /* ZEPHYR_INCLUDE_DRIVERS_BLUETOOTH_H_ */
Bluetooth device address definitions and utilities.
Bluetooth data buffer API.
struct net_buf * bt_hci_evt_create(uint8_t evt, uint8_t len)
Allocate an HCI event buffer.
struct net_buf * bt_hci_cmd_complete_create(uint16_t op, uint8_t plen)
Allocate an HCI Command Complete event buffer.
struct net_buf * bt_hci_cmd_status_create(uint16_t op, uint8_t status)
Allocate an HCI Command Status event buffer.
int bt_hci_transport_setup(const struct device *dev)
Setup the HCI transport, which usually means to reset the Bluetooth IC.
int bt_hci_transport_teardown(const struct device *dev)
Teardown the HCI transport.
static int bt_hci_setup(const struct device *dev, struct bt_hci_setup_params *params)
HCI vendor-specific setup.
Definition bluetooth.h:196
static int bt_hci_send(const struct device *dev, struct net_buf *buf)
Send HCI buffer to controller.
Definition bluetooth.h:176
int(* bt_hci_recv_t)(const struct device *dev, struct net_buf *buf)
Definition bluetooth.h:103
bt_hci_bus
Possible values for the 'bus' member of the bt_hci_driver struct.
Definition bluetooth.h:69
static int bt_hci_open(const struct device *dev, bt_hci_recv_t recv)
Open the HCI transport.
Definition bluetooth.h:129
static int bt_hci_close(const struct device *dev)
Close the HCI transport.
Definition bluetooth.h:146
@ BT_HCI_BUS_VIRTUAL
Definition bluetooth.h:70
@ BT_HCI_BUS_USB
Definition bluetooth.h:71
@ BT_HCI_BUS_PCCARD
Definition bluetooth.h:72
@ BT_HCI_BUS_VIRTIO
Definition bluetooth.h:80
@ BT_HCI_BUS_SPI
Definition bluetooth.h:77
@ BT_HCI_BUS_UART
Definition bluetooth.h:73
@ BT_HCI_BUS_IPC
Definition bluetooth.h:81
@ BT_HCI_BUS_PCI
Definition bluetooth.h:75
@ BT_HCI_BUS_RS232
Definition bluetooth.h:74
@ BT_HCI_BUS_SDIO
Definition bluetooth.h:76
@ BT_HCI_BUS_I2C
Definition bluetooth.h:78
@ BT_HCI_BUS_SMD
Definition bluetooth.h:79
@ BT_HCI_QUIRK_NO_AUTO_DLE
Definition bluetooth.h:65
@ BT_HCI_QUIRK_NO_RESET
Definition bluetooth.h:51
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
#define ENOSYS
Function not implemented.
Definition errno.h:82
#define NULL
Definition iar_missing_defs.h:20
Buffer management.
ssize_t recv(int sock, void *buf, size_t max_len, int flags)
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Bluetooth Device Address.
Definition addr.h:40
Definition bluetooth.h:105
int(* open)(const struct device *dev, bt_hci_recv_t recv)
Definition bluetooth.h:106
int(* close)(const struct device *dev)
Definition bluetooth.h:107
int(* send)(const struct device *dev, struct net_buf *buf)
Definition bluetooth.h:108
Definition bluetooth.h:41
bt_addr_t public_addr
The public identity address to give to the controller.
Definition bluetooth.h:46
Runtime device structure (in ROM) per driver instance.
Definition device.h:510
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:516
Network buffer representation.
Definition net_buf.h:1006
uint16_t len
Length of the data behind the data pointer.
Definition net_buf.h:1035