Zephyr API Documentation  2.7.0-rc2
A Scalable Open Source RTOS
bt_l2cap_chan_ops Struct Reference

L2CAP Channel operations structure. More...

#include <l2cap.h>

Data Fields

void(* connected )(struct bt_l2cap_chan *chan)
 Channel connected callback. More...
 
void(* disconnected )(struct bt_l2cap_chan *chan)
 Channel disconnected callback. More...
 
void(* encrypt_change )(struct bt_l2cap_chan *chan, uint8_t hci_status)
 Channel encrypt_change callback. More...
 
struct net_buf *(* alloc_buf )(struct bt_l2cap_chan *chan)
 Channel alloc_buf callback. More...
 
int(* recv )(struct bt_l2cap_chan *chan, struct net_buf *buf)
 Channel recv callback. More...
 
void(* sent )(struct bt_l2cap_chan *chan)
 Channel sent callback. More...
 
void(* status )(struct bt_l2cap_chan *chan, atomic_t *status)
 Channel status callback. More...
 
void(* released )(struct bt_l2cap_chan *chan)
 

Detailed Description

L2CAP Channel operations structure.

Field Documentation

◆ alloc_buf

struct net_buf *(* bt_l2cap_chan_ops::alloc_buf) (struct bt_l2cap_chan *chan)

Channel alloc_buf callback.

If this callback is provided the channel will use it to allocate buffers to store incoming data. Channels that requires segmentation must set this callback. If the application has not set a callback the L2CAP SDU MTU will be truncated to BT_L2CAP_SDU_RX_MTU.

Parameters
chanThe channel requesting a buffer.
Returns
Allocated buffer.

◆ connected

void(* bt_l2cap_chan_ops::connected) (struct bt_l2cap_chan *chan)

Channel connected callback.

If this callback is provided it will be called whenever the connection completes.

Parameters
chanThe channel that has been connected

◆ disconnected

void(* bt_l2cap_chan_ops::disconnected) (struct bt_l2cap_chan *chan)

Channel disconnected callback.

If this callback is provided it will be called whenever the channel is disconnected, including when a connection gets rejected.

Parameters
chanThe channel that has been Disconnected

◆ encrypt_change

void(* bt_l2cap_chan_ops::encrypt_change) (struct bt_l2cap_chan *chan, uint8_t hci_status)

Channel encrypt_change callback.

If this callback is provided it will be called whenever the security level changed (indirectly link encryption done) or authentication procedure fails. In both cases security initiator and responder got the final status (HCI status) passed by related to encryption and authentication events from local host's controller.

Parameters
chanThe channel which has made encryption status changed.
statusHCI status of performed security procedure caused by channel security requirements. The value is populated by HCI layer and set to 0 when success and to non-zero (reference to HCI Error Codes) when security/authentication failed.

◆ recv

int(* bt_l2cap_chan_ops::recv) (struct bt_l2cap_chan *chan, struct net_buf *buf)

Channel recv callback.

Parameters
chanThe channel receiving data.
bufBuffer containing incoming data.
Returns
0 in case of success or negative value in case of error.
-EINPROGRESS in case where user has to confirm once the data has been processed by calling bt_l2cap_chan_recv_complete passing back the buffer received with its original user_data which contains the number of segments/credits used by the packet.

◆ released

void(* bt_l2cap_chan_ops::released) (struct bt_l2cap_chan *chan)

◆ sent

void(* bt_l2cap_chan_ops::sent) (struct bt_l2cap_chan *chan)

Channel sent callback.

If this callback is provided it will be called whenever a SDU has been completely sent.

Parameters
chanThe channel which has sent data.

◆ status

void(* bt_l2cap_chan_ops::status) (struct bt_l2cap_chan *chan, atomic_t *status)

Channel status callback.

If this callback is provided it will be called whenever the channel status changes.

Parameters
chanThe channel which status changed
statusThe channel status

The documentation for this struct was generated from the following file: