1 /*
2  * Copyright 2019 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #pragma once
18 
19 #include <cstdint>
20 
21 #include "common/bidi_queue.h"
22 #include "l2cap/cid.h"
23 #include "l2cap/classic/dynamic_channel_configuration_option.h"
24 #include "l2cap/internal/channel_impl.h"
25 #include "l2cap/internal/data_controller.h"
26 #include "l2cap/internal/sender.h"
27 #include "l2cap/l2cap_packets.h"
28 #include "packet/base_packet_builder.h"
29 #include "packet/packet_view.h"
30 
31 namespace bluetooth {
32 namespace l2cap {
33 namespace internal {
34 
35 /**
36  * Handle the scheduling of packets through the l2cap stack.
37  * For each attached channel, dequeue its outgoing packets and enqueue it to the given LinkQueueUpEnd, according to some
38  * policy (cid).
39  *
40  * Note: If a channel cannot dequeue from ChannelQueueDownEnd so that the buffer for incoming packet is full, further
41  * incoming packets will be dropped.
42  */
43 class Scheduler {
44  public:
45   using UpperEnqueue = packet::PacketView<packet::kLittleEndian>;
46   using UpperDequeue = packet::BasePacketBuilder;
47   using UpperQueueDownEnd = common::BidiQueueEnd<UpperEnqueue, UpperDequeue>;
48   using LowerEnqueue = UpperDequeue;
49   using LowerDequeue = UpperEnqueue;
50   using LowerQueueUpEnd = common::BidiQueueEnd<LowerEnqueue, LowerDequeue>;
51 
52   /**
53    * Callback from the sender to indicate that the scheduler could dequeue number_packets from it
54    */
OnPacketsReady(Cid cid,int number_packets)55   virtual void OnPacketsReady(Cid cid, int number_packets) {}
56 
57   /**
58    * Let the scheduler send the specified cid first.
59    * Used by A2dp software encoding.
60    */
SetChannelTxPriority(Cid cid,bool high_priority)61   virtual void SetChannelTxPriority(Cid cid, bool high_priority) {}
62 
63   /**
64    * Called by data controller to indicate that a channel is closed and packets should be dropped
65    */
RemoveChannel(Cid cid)66   virtual void RemoveChannel(Cid cid) {}
67 
68   virtual ~Scheduler() = default;
69 };
70 
71 }  // namespace internal
72 }  // namespace l2cap
73 }  // namespace bluetooth
74