123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- /** @file
- * @brief Bluetooth RFCOMM handling
- */
- /*
- * Copyright (c) 2015-2016 Intel Corporation
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #ifndef ZEPHYR_INCLUDE_BLUETOOTH_RFCOMM_H_
- #define ZEPHYR_INCLUDE_BLUETOOTH_RFCOMM_H_
- /**
- * @brief RFCOMM
- * @defgroup bt_rfcomm RFCOMM
- * @ingroup bluetooth
- * @{
- */
- #include <bluetooth/buf.h>
- #include <bluetooth/conn.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /* RFCOMM channels (1-30): pre-allocated for profiles to avoid conflicts */
- enum {
- BT_RFCOMM_CHAN_HFP_HF = 1,
- BT_RFCOMM_CHAN_HFP_AG,
- BT_RFCOMM_CHAN_HSP_AG,
- BT_RFCOMM_CHAN_HSP_HS,
- BT_RFCOMM_CHAN_SPP,
- };
- struct bt_rfcomm_dlc;
- /** @brief RFCOMM DLC operations structure. */
- struct bt_rfcomm_dlc_ops {
- /** DLC connected callback
- *
- * If this callback is provided it will be called whenever the
- * connection completes.
- *
- * @param dlc The dlc that has been connected
- */
- void (*connected)(struct bt_rfcomm_dlc *dlc);
- /** DLC disconnected callback
- *
- * If this callback is provided it will be called whenever the
- * dlc is disconnected, including when a connection gets
- * rejected or cancelled (both incoming and outgoing)
- *
- * @param dlc The dlc that has been Disconnected
- */
- void (*disconnected)(struct bt_rfcomm_dlc *dlc);
- /** DLC recv callback
- *
- * @param dlc The dlc receiving data.
- * @param buf Buffer containing incoming data.
- */
- void (*recv)(struct bt_rfcomm_dlc *dlc, struct net_buf *buf);
- };
- /** @brief Role of RFCOMM session and dlc. Used only by internal APIs
- */
- typedef enum bt_rfcomm_role {
- BT_RFCOMM_ROLE_ACCEPTOR,
- BT_RFCOMM_ROLE_INITIATOR
- } __packed bt_rfcomm_role_t;
- /** @brief RFCOMM DLC structure. */
- struct bt_rfcomm_dlc {
- /* Response Timeout eXpired (RTX) timer */
- struct k_work_delayable rtx_work;
- /* Queue for outgoing data */
- struct k_fifo tx_queue;
- /* TX credits, Reuse as a binary sem for MSC FC if CFC is not enabled */
- struct k_sem tx_credits;
- struct bt_rfcomm_session *session;
- struct bt_rfcomm_dlc_ops *ops;
- struct bt_rfcomm_dlc *_next;
- bt_security_t required_sec_level;
- bt_rfcomm_role_t role;
- uint16_t mtu;
- uint8_t dlci;
- uint8_t state;
- uint8_t rx_credit;
- /* Stack & kernel data for TX thread */
- struct k_thread tx_thread;
- K_KERNEL_STACK_MEMBER(stack, 256);
- };
- struct bt_rfcomm_server {
- /** Server Channel */
- uint8_t channel;
- /** Server accept callback
- *
- * This callback is called whenever a new incoming connection requires
- * authorization.
- *
- * @param conn The connection that is requesting authorization
- * @param dlc Pointer to received the allocated dlc
- *
- * @return 0 in case of success or negative value in case of error.
- */
- int (*accept)(struct bt_conn *conn, struct bt_rfcomm_dlc **dlc);
- struct bt_rfcomm_server *_next;
- };
- /** @brief Register RFCOMM server
- *
- * Register RFCOMM server for a channel, each new connection is authorized
- * using the accept() callback which in case of success shall allocate the dlc
- * structure to be used by the new connection.
- *
- * @param server Server structure.
- *
- * @return 0 in case of success or negative value in case of error.
- */
- int bt_rfcomm_server_register(struct bt_rfcomm_server *server);
- /** @brief Connect RFCOMM channel
- *
- * Connect RFCOMM dlc by channel, once the connection is completed dlc
- * connected() callback will be called. If the connection is rejected
- * disconnected() callback is called instead.
- *
- * @param conn Connection object.
- * @param dlc Dlc object.
- * @param channel Server channel to connect to.
- *
- * @return 0 in case of success or negative value in case of error.
- */
- int bt_rfcomm_dlc_connect(struct bt_conn *conn, struct bt_rfcomm_dlc *dlc,
- uint8_t channel);
- /** @brief Send data to RFCOMM
- *
- * Send data from buffer to the dlc. Length should be less than or equal to
- * mtu.
- *
- * @param dlc Dlc object.
- * @param buf Data buffer.
- *
- * @return Bytes sent in case of success or negative value in case of error.
- */
- int bt_rfcomm_dlc_send(struct bt_rfcomm_dlc *dlc, struct net_buf *buf);
- /** @brief Disconnect RFCOMM dlc
- *
- * Disconnect RFCOMM dlc, if the connection is pending it will be
- * canceled and as a result the dlc disconnected() callback is called.
- *
- * @param dlc Dlc object.
- *
- * @return 0 in case of success or negative value in case of error.
- */
- int bt_rfcomm_dlc_disconnect(struct bt_rfcomm_dlc *dlc);
- /** @brief Allocate the buffer from pool after reserving head room for RFCOMM,
- * L2CAP and ACL headers.
- *
- * @param pool Which pool to take the buffer from.
- *
- * @return New buffer.
- */
- struct net_buf *bt_rfcomm_create_pdu(struct net_buf_pool *pool);
- #ifdef __cplusplus
- }
- #endif
- /**
- * @}
- */
- #endif /* ZEPHYR_INCLUDE_BLUETOOTH_RFCOMM_H_ */
|