Pushes all work done in the topic-ble-llcp branch into main branch This is a refactoring of the LL control procedures; the refactored control procedures are hidden behind a KConfig option and per default disabled Goal of the refactoring: close issue Link Layer Control Procedure overhaul #15256 make it easier to add/update control procedures Refactoring consists in principal of writing explicit state machines for the control procedures. To reduce the risk of regression errors unit-tests have been added Following control procedures are implemented: Connection update procedure Channel map update procedure Encryption procedure Feature exchange procedure Version exchange procedure ACL termination procedure Connection parameters request procedure LE Ping procedure Data Length Update procedure PHY update procedure Min. nr. Of channels used procedure Constant Tone extension request procedure This is a joined work by the people listed in the signed-off-by list (in alphabetical order) Signed-off-by: Andries Kruithof Andries.Kruithof@nordicsemi.no Signed-off-by: Erik Brockhoff erbr@oticon.com Signed-off-by: Piotr Pryga piotr.pryga@nordicsemi.no Signed-off-by: Szymon Janc szymon.janc@codecoup.pl Signed-off-by: Thomas Ebert Hansen thoh@oticon.com Signed-off-by: Tommie Skriver tosk@demant.com Signed-off-by: Andries Kruithof <Andries.Kruithof@nordicsemi.no>
66 lines
1.3 KiB
C
66 lines
1.3 KiB
C
/*
|
|
* Copyright (c) 2020 Demant
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include "ull_tx_queue.h"
|
|
|
|
void ull_tx_q_init(struct ull_tx_q *queue)
|
|
{
|
|
queue->pause_data = 0;
|
|
sys_slist_init(&queue->tx_list);
|
|
sys_slist_init(&queue->data_list);
|
|
}
|
|
|
|
void ull_tx_q_pause_data(struct ull_tx_q *queue)
|
|
{
|
|
queue->pause_data = 1U;
|
|
}
|
|
|
|
void ull_tx_q_resume_data(struct ull_tx_q *queue)
|
|
{
|
|
queue->pause_data = 0U;
|
|
|
|
/* move all paused data to the tail of tx list */
|
|
sys_slist_merge_slist(&queue->tx_list, &queue->data_list);
|
|
}
|
|
|
|
void ull_tx_q_enqueue_data(struct ull_tx_q *queue, struct node_tx *tx)
|
|
{
|
|
sys_slist_t *list;
|
|
|
|
if (queue->pause_data) {
|
|
/* enqueue data pdu into paused data wait list */
|
|
list = &queue->data_list;
|
|
} else {
|
|
/* enqueue data pdu into tx list */
|
|
list = &queue->tx_list;
|
|
}
|
|
|
|
sys_slist_append(list, (sys_snode_t *)tx);
|
|
}
|
|
|
|
void ull_tx_q_enqueue_ctrl(struct ull_tx_q *queue, struct node_tx *tx)
|
|
{
|
|
/* enqueue ctrl pdu into tx list */
|
|
sys_slist_append(&queue->tx_list, (sys_snode_t *)tx);
|
|
}
|
|
|
|
struct node_tx *ull_tx_q_peek(struct ull_tx_q *queue)
|
|
{
|
|
struct node_tx *tx;
|
|
|
|
tx = (struct node_tx *)sys_slist_peek_head(&queue->tx_list);
|
|
|
|
return tx;
|
|
}
|
|
|
|
struct node_tx *ull_tx_q_dequeue(struct ull_tx_q *queue)
|
|
{
|
|
struct node_tx *tx;
|
|
|
|
tx = (struct node_tx *)sys_slist_get(&queue->tx_list);
|
|
|
|
return tx;
|
|
}
|