Zephyr Project API 4.3.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
l2cap.h
Go to the documentation of this file.
1
4
5/*
6 * Copyright (c) 2015-2016 Intel Corporation
7 * Copyright (c) 2023 Nordic Semiconductor
8 *
9 * SPDX-License-Identifier: Apache-2.0
10 */
11#ifndef ZEPHYR_INCLUDE_BLUETOOTH_L2CAP_H_
12#define ZEPHYR_INCLUDE_BLUETOOTH_L2CAP_H_
13
20
21#include <stddef.h>
22#include <stdint.h>
23
27#include <zephyr/kernel.h>
28#include <zephyr/net_buf.h>
29#include <zephyr/sys/atomic.h>
30#include <zephyr/sys/slist.h>
31#include <zephyr/sys/util.h>
32#include <sys/types.h>
33
34#ifdef __cplusplus
35extern "C" {
36#endif
37
39#define BT_L2CAP_HDR_SIZE 4
40
42#define BT_L2CAP_TX_MTU (CONFIG_BT_L2CAP_TX_MTU)
43
45#define BT_L2CAP_RX_MTU (CONFIG_BT_BUF_ACL_RX_SIZE - BT_L2CAP_HDR_SIZE)
46
54#define BT_L2CAP_BUF_SIZE(mtu) BT_BUF_ACL_SIZE(BT_L2CAP_HDR_SIZE + (mtu))
55
57#define BT_L2CAP_SDU_HDR_SIZE 2
58
67#define BT_L2CAP_SDU_TX_MTU (BT_L2CAP_TX_MTU - BT_L2CAP_SDU_HDR_SIZE)
68
79#define BT_L2CAP_SDU_RX_MTU (BT_L2CAP_RX_MTU - BT_L2CAP_SDU_HDR_SIZE)
80
90#define BT_L2CAP_SDU_BUF_SIZE(mtu) BT_L2CAP_BUF_SIZE(BT_L2CAP_SDU_HDR_SIZE + (mtu))
91
101#define BT_L2CAP_ECRED_MIN_MTU 64
102
112#define BT_L2CAP_ECRED_MIN_MPS 64
113
119#define BT_L2CAP_MAX_MTU UINT16_MAX
120
126#define BT_L2CAP_MAX_MPS 65533
127
140#define BT_L2CAP_ECRED_CHAN_MAX_PER_REQ 5
141
149
151#define BT_L2CAP_CID_BR_SIG 0x0001
153#define BT_L2CAP_CID_ATT 0x0004
155#define BT_L2CAP_CID_LE_SIG 0x0005
157#define BT_L2CAP_CID_SMP 0x0006
159#define BT_L2CAP_CID_BR_SMP 0x0007
160
162
163struct bt_l2cap_chan;
164
170typedef void (*bt_l2cap_chan_destroy_t)(struct bt_l2cap_chan *chan);
171
197
202
209
212
213 /* Total number of status - must be at the end of the enum */
216
228
240
258
261
295#if defined(CONFIG_BT_L2CAP_DYNAMIC_CHANNEL)
297 struct net_buf *_sdu;
298 uint16_t _sdu_len;
299#if defined(CONFIG_BT_L2CAP_SEG_RECV)
300 uint16_t _sdu_len_done;
301#endif /* CONFIG_BT_L2CAP_SEG_RECV */
302
303 struct k_work rx_work;
304 struct k_fifo rx_queue;
305
308 uint16_t psm;
310 uint8_t ident;
312 uint8_t pending_req;
313 bt_security_t required_sec_level;
314
315 /* Response Timeout eXpired (RTX) timer */
316 struct k_work_delayable rtx_work;
317 struct k_work_sync rtx_sync;
318#endif
319
321 sys_snode_t _pdu_ready;
323 size_t _pdu_remaining;
324};
325
335#define BT_L2CAP_LE_CHAN(_ch) CONTAINER_OF(_ch, struct bt_l2cap_le_chan, chan)
336
349
379 int (*accept)(struct bt_conn *conn, struct bt_l2cap_chan **chan);
380};
381
395#define BT_L2CAP_FIXED_CHANNEL_DEFINE(_name) \
396 static const STRUCT_SECTION_ITERABLE(bt_l2cap_fixed_chan, \
397 _CONCAT(bt_l2cap_fixed_chan, _name))
398
400#define BT_L2CAP_BR_LINK_MODE_BASIC 0x00
402#define BT_L2CAP_BR_LINK_MODE_RET 0x01
404#define BT_L2CAP_BR_LINK_MODE_FC 0x02
406#define BT_L2CAP_BR_LINK_MODE_ERET 0x03
408#define BT_L2CAP_BR_LINK_MODE_STREAM 0x04
409
411#define BT_L2CAP_BR_FCS_NO 0x00
413#define BT_L2CAP_BR_FCS_16BIT 0x01
414
421#if defined(CONFIG_BT_L2CAP_RET_FC) || defined(__DOXYGEN__)
482#endif /* CONFIG_BT_L2CAP_RET_FC */
483};
484
510
519 /* For internal use only */
521
528
529 /* Response Timeout eXpired (RTX) timer */
532
534 sys_snode_t _pdu_ready;
536 atomic_t _pdu_ready_lock;
538 sys_slist_t _pdu_tx_queue;
539
540#if defined(CONFIG_BT_L2CAP_RET_FC) || defined(__DOXYGEN__)
542 uint16_t _sdu_total_len;
543
545 size_t _pdu_remaining;
546
548 struct net_buf *_pdu_buf;
549
551 sys_slist_t _pdu_outstanding;
552
554 struct net_buf_simple_state _pdu_state;
555
557 struct k_fifo _free_tx_win;
558
560 struct bt_l2cap_br_window tx_win[CONFIG_BT_L2CAP_MAX_WINDOW_SIZE];
561
563 struct net_buf *_sdu;
565 uint16_t _sdu_len;
566#if defined(CONFIG_BT_L2CAP_SEG_RECV) || defined(__DOXYGEN__)
567 uint16_t _sdu_len_done;
568#endif /* CONFIG_BT_L2CAP_SEG_RECV */
601
608
613#endif /* CONFIG_BT_L2CAP_RET_FC */
614};
615
628 void (*connected)(struct bt_l2cap_chan *chan);
629
638 void (*disconnected)(struct bt_l2cap_chan *chan);
639
655 void (*encrypt_change)(struct bt_l2cap_chan *chan, uint8_t hci_status);
656
668 struct net_buf *(*alloc_seg)(struct bt_l2cap_chan *chan);
669
682 struct net_buf *(*alloc_buf)(struct bt_l2cap_chan *chan);
683
706 int (*recv)(struct bt_l2cap_chan *chan, struct net_buf *buf);
707
717 void (*sent)(struct bt_l2cap_chan *chan);
718
727 void (*status)(struct bt_l2cap_chan *chan, atomic_t *status);
728
729 /* @brief Channel released callback
730 *
731 * If this callback is set it is called when the stack has release all
732 * references to the channel object.
733 */
734 void (*released)(struct bt_l2cap_chan *chan);
735
744 void (*reconfigured)(struct bt_l2cap_chan *chan);
745
746#if defined(CONFIG_BT_L2CAP_SEG_RECV)
778 void (*seg_recv)(struct bt_l2cap_chan *chan, size_t sdu_len,
779 off_t seg_offset, struct net_buf_simple *seg);
780#endif /* CONFIG_BT_L2CAP_SEG_RECV */
781};
782
786#define BT_L2CAP_CHAN_SEND_RESERVE (BT_L2CAP_BUF_SIZE(0))
787
791#define BT_L2CAP_SDU_CHAN_SEND_RESERVE (BT_L2CAP_SDU_BUF_SIZE(0))
792
825
828
846 int (*accept)(struct bt_conn *conn, struct bt_l2cap_server *server,
847 struct bt_l2cap_chan **chan);
848
850};
851
872
893
903
920 struct bt_l2cap_chan **chans, uint16_t psm);
921
935
979int bt_l2cap_ecred_chan_reconfigure_explicit(struct bt_l2cap_chan **chans, size_t chan_count,
980 uint16_t mtu, uint16_t mps);
981
1003int bt_l2cap_chan_connect(struct bt_conn *conn, struct bt_l2cap_chan *chan,
1004 uint16_t psm);
1005
1018
1071int bt_l2cap_chan_send(struct bt_l2cap_chan *chan, struct net_buf *buf);
1072
1094int bt_l2cap_chan_give_credits(struct bt_l2cap_chan *chan, uint16_t additional_credits);
1095
1109 struct net_buf *buf);
1110
1111#ifdef __cplusplus
1112}
1113#endif
1114
1118
1119#endif /* ZEPHYR_INCLUDE_BLUETOOTH_L2CAP_H_ */
long atomic_t
Definition atomic_types.h:15
Bluetooth data buffer API.
Bluetooth connection handling.
#define ATOMIC_DEFINE(name, num_bits)
Define an array of atomic variables.
Definition atomic.h:113
bt_security_t
Security level.
Definition conn.h:1164
int bt_l2cap_ecred_chan_reconfigure(struct bt_l2cap_chan **chans, uint16_t mtu)
Reconfigure Enhanced Credit Based L2CAP channels.
int bt_l2cap_server_register(struct bt_l2cap_server *server)
Register L2CAP server.
bt_l2cap_chan_status
Status of L2CAP channel.
Definition l2cap.h:199
enum bt_l2cap_chan_status bt_l2cap_chan_status_t
Status of L2CAP channel.
int bt_l2cap_chan_connect(struct bt_conn *conn, struct bt_l2cap_chan *chan, uint16_t psm)
Connect L2CAP channel.
enum bt_l2cap_chan_state bt_l2cap_chan_state_t
Life-span states of L2CAP CoC channel.
int bt_l2cap_br_server_register(struct bt_l2cap_server *server)
Register L2CAP server on BR/EDR oriented connection.
bt_l2cap_chan_state
Life-span states of L2CAP CoC channel.
Definition l2cap.h:184
int bt_l2cap_ecred_chan_reconfigure_explicit(struct bt_l2cap_chan **chans, size_t chan_count, uint16_t mtu, uint16_t mps)
Reconfigure Enhanced Credit Based L2CAP channels.
int bt_l2cap_chan_disconnect(struct bt_l2cap_chan *chan)
Disconnect L2CAP channel.
int bt_l2cap_br_server_unregister(struct bt_l2cap_server *server)
Unregister L2CAP server on BR/EDR oriented connection.
void(* bt_l2cap_chan_destroy_t)(struct bt_l2cap_chan *chan)
Channel destroy callback.
Definition l2cap.h:170
int bt_l2cap_chan_send(struct bt_l2cap_chan *chan, struct net_buf *buf)
Send data to L2CAP channel.
int bt_l2cap_chan_give_credits(struct bt_l2cap_chan *chan, uint16_t additional_credits)
Give credits to the remote.
int bt_l2cap_chan_recv_complete(struct bt_l2cap_chan *chan, struct net_buf *buf)
Complete receiving L2CAP channel data.
int bt_l2cap_ecred_chan_connect(struct bt_conn *conn, struct bt_l2cap_chan **chans, uint16_t psm)
Connect Enhanced Credit Based L2CAP channels.
@ BT_L2CAP_STATUS_SHUTDOWN
Channel shutdown status.
Definition l2cap.h:208
@ BT_L2CAP_STATUS_OUT
Channel can send at least one PDU.
Definition l2cap.h:201
@ BT_L2CAP_NUM_STATUS
Definition l2cap.h:214
@ BT_L2CAP_STATUS_ENCRYPT_PENDING
Channel encryption pending status.
Definition l2cap.h:211
@ BT_L2CAP_DISCONNECTED
Channel disconnected.
Definition l2cap.h:186
@ BT_L2CAP_CONFIG
Channel in config state, BR/EDR specific.
Definition l2cap.h:190
@ BT_L2CAP_CONNECTED
Channel ready for upper layer traffic on it.
Definition l2cap.h:192
@ BT_L2CAP_DISCONNECTING
Channel in disconnecting state.
Definition l2cap.h:194
@ BT_L2CAP_CONNECTING
Channel in connecting state.
Definition l2cap.h:188
struct _slist sys_slist_t
Single-linked list structure.
Definition slist.h:49
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:39
Public kernel APIs.
__INTPTR_TYPE__ off_t
Definition types.h:36
Buffer management.
state
Definition parser_state.h:29
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
BREDR L2CAP Channel structure.
Definition l2cap.h:512
struct bt_l2cap_br_endpoint rx
Channel Receiving Endpoint.
Definition l2cap.h:516
atomic_t flags[1]
Definition l2cap.h:520
struct k_work_delayable rtx_work
Definition l2cap.h:530
bt_security_t required_sec_level
Definition l2cap.h:527
uint16_t psm
Remote PSM to be connected.
Definition l2cap.h:524
struct k_work_sync rtx_sync
Definition l2cap.h:531
struct bt_l2cap_chan chan
Common L2CAP channel reference object.
Definition l2cap.h:514
uint16_t retry_count
Definition l2cap.h:605
bt_l2cap_chan_state_t state
Definition l2cap.h:522
struct bt_l2cap_br_endpoint tx
Channel Transmission Endpoint.
Definition l2cap.h:518
struct k_work_delayable ret_work
Definition l2cap.h:610
uint16_t next_tx_seq
Definition l2cap.h:580
uint16_t expected_tx_seq
Definition l2cap.h:595
struct bt_l2cap_br_window tx_win[CONFIG_BT_L2CAP_MAX_WINDOW_SIZE]
Definition l2cap.h:560
uint16_t srej_save_req_seq
Definition l2cap.h:607
uint16_t buffer_seq
Definition l2cap.h:600
struct k_work_delayable monitor_work
Definition l2cap.h:612
uint8_t ident
Helps match request context during CoC.
Definition l2cap.h:526
uint16_t tx_seq
Definition l2cap.h:576
uint16_t expected_ack_seq
Definition l2cap.h:584
uint16_t req_seq
Definition l2cap.h:592
BREDR L2CAP Endpoint structure.
Definition l2cap.h:416
uint16_t max_window
Endpoint Maximum Window Size MAX supported window size is configured by \verbatim BT_L2CAP_MAX_WINDOW...
Definition l2cap.h:463
uint16_t monitor_timeout
Endpoint Monitor Timeout The field is configured by \verbatim BT_L2CAP_BR_MONITOR_TIMEOUT \endverbati...
Definition l2cap.h:455
uint8_t max_transmit
Endpoint Maximum Transmit The field is used to set the max retransmission count.
Definition l2cap.h:443
uint16_t mtu
Endpoint Maximum Transmission Unit.
Definition l2cap.h:420
uint16_t mps
Endpoint Maximum PDU payload Size.
Definition l2cap.h:457
bool extended_control
Endpoint Extended Control.
Definition l2cap.h:481
uint8_t fcs
Endpoint FCS Type The value is defined as BT_L2CAP_BR_FCS_* The default setting should be BT_L2CAP_BR...
Definition l2cap.h:474
uint16_t cid
Endpoint Channel Identifier (CID)
Definition l2cap.h:418
uint16_t ret_timeout
Endpoint Retransmission Timeout The field is configured by \verbatim BT_L2CAP_BR_RET_TIMEOUT \endverb...
Definition l2cap.h:450
uint8_t mode
Endpoint Link Mode.
Definition l2cap.h:425
bool optional
Whether Endpoint Link Mode is optional If the optional is true, the mode could be changed according t...
Definition l2cap.h:435
I-Frame transmission window for none BASIC mode L2cap connected channel.
Definition l2cap.h:486
uint8_t * data
data address
Definition l2cap.h:494
bool srej
srej flag
Definition l2cap.h:500
uint16_t sdu_total_len
Definition l2cap.h:508
struct net_buf_simple_state sdu_state
Definition l2cap.h:504
uint16_t len
data len
Definition l2cap.h:492
uint8_t transmit_counter
Transmit Counter.
Definition l2cap.h:496
uint8_t sar
SAR flag.
Definition l2cap.h:498
sys_snode_t node
Definition l2cap.h:487
bool retransmit
retransmit flag
Definition l2cap.h:502
uint16_t tx_seq
tx seq
Definition l2cap.h:490
struct net_buf * sdu
Definition l2cap.h:506
L2CAP Channel operations structure.
Definition l2cap.h:620
int(* recv)(struct bt_l2cap_chan *chan, struct net_buf *buf)
Channel recv callback.
Definition l2cap.h:706
void(* encrypt_change)(struct bt_l2cap_chan *chan, uint8_t hci_status)
Channel encrypt_change callback.
Definition l2cap.h:655
void(* disconnected)(struct bt_l2cap_chan *chan)
Channel disconnected callback.
Definition l2cap.h:638
void(* connected)(struct bt_l2cap_chan *chan)
Channel connected callback.
Definition l2cap.h:628
void(* status)(struct bt_l2cap_chan *chan, atomic_t *status)
Channel status callback.
Definition l2cap.h:727
void(* released)(struct bt_l2cap_chan *chan)
Definition l2cap.h:734
void(* sent)(struct bt_l2cap_chan *chan)
Channel sent callback.
Definition l2cap.h:717
void(* seg_recv)(struct bt_l2cap_chan *chan, size_t sdu_len, off_t seg_offset, struct net_buf_simple *seg)
Handle L2CAP segments directly.
Definition l2cap.h:778
void(* reconfigured)(struct bt_l2cap_chan *chan)
Channel reconfigured callback.
Definition l2cap.h:744
L2CAP Channel structure.
Definition l2cap.h:218
struct bt_conn * conn
Channel connection reference.
Definition l2cap.h:220
sys_snode_t node
Definition l2cap.h:223
const struct bt_l2cap_chan_ops * ops
Channel operations reference.
Definition l2cap.h:222
atomic_t status[ATOMIC_BITMAP_SIZE(BT_L2CAP_NUM_STATUS)]
Definition l2cap.h:226
bt_l2cap_chan_destroy_t destroy
Definition l2cap.h:224
Fixed L2CAP Channel structure.
Definition l2cap.h:340
uint16_t cid
Channel Identifier (CID)
Definition l2cap.h:348
int(* accept)(struct bt_conn *conn, struct bt_l2cap_chan **chan)
Channel accept callback.
Definition l2cap.h:379
LE L2CAP Channel structure.
Definition l2cap.h:242
struct bt_l2cap_le_endpoint tx
Channel Transmission Endpoint.
Definition l2cap.h:269
uint16_t pending_rx_mtu
Pending RX MTU on ECFC reconfigure, used internally by stack.
Definition l2cap.h:260
struct k_fifo tx_queue
Channel Transmission queue.
Definition l2cap.h:294
struct bt_l2cap_le_endpoint rx
Channel Receiving Endpoint.
Definition l2cap.h:257
struct bt_l2cap_chan chan
Common L2CAP channel reference object.
Definition l2cap.h:244
LE L2CAP Endpoint structure.
Definition l2cap.h:230
uint16_t mtu
Endpoint Maximum Transmission Unit.
Definition l2cap.h:234
uint16_t mps
Endpoint Maximum PDU payload Size.
Definition l2cap.h:236
atomic_t credits
Endpoint credits.
Definition l2cap.h:238
uint16_t cid
Endpoint Channel Identifier (CID)
Definition l2cap.h:232
L2CAP Server structure.
Definition l2cap.h:794
uint16_t psm
Server PSM.
Definition l2cap.h:824
sys_snode_t node
Definition l2cap.h:849
bt_security_t sec_level
Required minimum security level.
Definition l2cap.h:827
int(* accept)(struct bt_conn *conn, struct bt_l2cap_server *server, struct bt_l2cap_chan **chan)
Server accept callback.
Definition l2cap.h:846
Definition kernel.h:2872
A structure used to submit work after a delay.
Definition kernel.h:4531
A structure holding internal state for a pending synchronous operation on a work item or queue.
Definition kernel.h:4614
A structure used to submit work.
Definition kernel.h:4503
Parsing state of a buffer.
Definition net_buf.h:950
Simple network buffer representation.
Definition net_buf.h:89
Network buffer representation.
Definition net_buf.h:1006
Misc utilities.