1 /*
2  * Copyright 2019 HIMSA II K/S - www.himsa.com.
3  * Represented by EHIMA - www.ehima.com
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17 
18 #ifndef BLE_SCANNER_HCI_INTERFACE_H
19 #define BLE_SCANNER_HCI_INTERFACE_H
20 
21 #include <base/functional/callback.h>
22 
23 #include <vector>
24 
25 #include "types/raw_address.h"
26 
27 class BleScannerHciInterface {
28  public:
29   using status_cb = base::Callback<void(uint8_t /* status */)>;
30   using list_size_cb = base::Callback<void(int8_t /* list_size */)>;
31   using handle_cb =
32       base::Callback<void(uint8_t /* status */, uint16_t /* adv_handle */)>;
33 
34   static void Initialize();
35   static BleScannerHciInterface* Get();
36   static void CleanUp();
37 
38   virtual ~BleScannerHciInterface() = default;
39 
40   class ScanEventObserver {
41    public:
42     virtual ~ScanEventObserver() = default;
43     virtual void OnPeriodicScanResult(uint16_t sync_handle, uint8_t tx_power,
44                                       int8_t rssi, uint8_t cte_type,
45                                       uint8_t pkt_data_status,
46                                       uint8_t pkt_data_len,
47                                       const uint8_t* pkt_data) = 0;
48     virtual void OnPeriodicScanEstablished(
49         uint8_t status, uint16_t sync_handle, uint8_t set_id,
50         uint8_t adv_addr_type, const RawAddress& adv_addr, uint8_t adv_phy,
51         uint16_t adv_interval, uint8_t adv_clock_accuracy) = 0;
52     virtual void OnPeriodicScanLost(uint16_t sync_handle) = 0;
53   };
54 
55   virtual void SetScanEventObserver(ScanEventObserver* observer) = 0;
56 
57   /**
58    * Used to synchronize with a periodic advertising train from an advertiser
59    * and begin receiving periodic advertising packets.
60    *
61    * @param options bit 0: whether to use advertiser list, adv_sid,
62    * adv_addr_type and adv_addr parameters are being used otherwise, bit 1:
63    * whether reporting is initially disabled, all other bits: Reserved for
64    * future use
65    * @param adv_sid advertising set ID
66    * @param adv_addr_type advertiser device address type
67    * @param adv_addr advertiser device address
68    * @param skip_num the maximum number of periodic advertising events that can
69    * be skipped after a successful receive. Range: 0x0000 to 0x01F3.
70    * @param sync_timeout synchronization timeout for the periodic advertising
71    * train, Range: 0x000A to 0x4000, Time = N*10 ms, Range: 100 ms to 163.84s
72    * @param sync_cte_type bit 0: do not sync to packets with an AoA Constant
73    * Tone Extension, bit 1: do not sync to packets with an AoD Constant Tone
74    * Extension with 1 μs slots, bit 2: do not sync to packets with an AoD
75    * Constant Tone Extension with 2 μs slots, bit 3: do not sync to packets with
76    * a type 3 Constant Tone Extension (currently reserved for future use),
77    * bit 4: do not sync to packets without a Constant Tone Extension, all other
78    * bits: reserved for future use.
79    */
80   virtual void PeriodicScanStart(uint8_t options, uint8_t set_id,
81                                  uint8_t adv_addr_type,
82                                  const RawAddress& adv_addr, uint16_t skip_num,
83                                  uint16_t sync_timeout,
84                                  uint8_t sync_cte_type) = 0;
85 
86   /**
87    * Used to cancel the HCI_LE_Periodic_Advertising_Create_Sync command while it
88    * is pending.
89    *
90    * @param cb status callback
91    */
92   virtual void PeriodicScanCancelStart(status_cb cb) = 0;
93 
94   /**
95    * Used to stop reception of the periodic advertising train identified by the
96    * Sync_Handle parameter.
97    *
98    * @param sync_handle synced advertising handle
99    * @param cb status callback
100    */
101   virtual void PeriodicScanTerminate(uint16_t sync_handle, status_cb cb) = 0;
102 
103   /**
104    * Enable or disable reports for the periodic advertising train defined by the
105    * sync_handle.
106    *
107    * @param sync_handle synced advewrtising handle
108    * @param enable whether enable or disable the advertising reports
109    * @param cb  status callback
110    */
111   virtual void PeriodicScanResultEvtEnable(uint16_t sync_handle, bool enable,
112                                            status_cb cb) = 0;
113 
114   /**
115    * Used to add an entry, consisting of a single device address and SID, to the
116    * Periodic Advertiser list stored in the Controller. Any additions to the
117    * Periodic Advertiser list take effect immediately. If the entry is already
118    * on the list, the Controller shall return the error code Invalid HCI Command
119    * Parameters (0x12).
120    *
121    * @param adv_addr_type advertiser device address type
122    * @param adv_addr advertiser device address
123    * @param adv_sid advertising set ID
124    * @param cb status callback
125    */
126   virtual void PeriodicAdvertiserListAddDevice(uint8_t adv_addr_type,
127                                                RawAddress& adv_addr,
128                                                uint8_t adv_sid,
129                                                status_cb cb) = 0;
130   /**
131    * Remove one entry from the list of Periodic Advertisers stored in the
132    * Controller. Removals from the Periodic Advertisers List take effect
133    * immediately.
134    *
135    * @param adv_addr_type advertiser device address type
136    * @param adv_addr advertiser device address
137    * @param adv_sid advertising set ID
138    * @param cb status callback
139    */
140   virtual void PeriodicAdvertiserListRemoveDevice(uint8_t adv_addr_type,
141                                                   RawAddress& adv_addr,
142                                                   uint8_t adv_sid,
143                                                   status_cb cb) = 0;
144 
145   /**
146    * Remove all entries from the list of Periodic Advertisers in the Controller.
147    *
148    * @param cb status callback
149    */
150   virtual void PeriodicAdvertiserListClear(status_cb cb) = 0;
151 
152   /**
153    * Read the total number of Periodic Advertiser list entries that can be
154    * stored in the Controller.
155    *
156    * @param cb status and advertiser list size callback
157    */
158   virtual void PeriodicAdvertiserListGetSize(list_size_cb cb) = 0;
159 
160   /**
161    * Send synchronization information about the periodic advertising train
162    * identified by the sync_handle parameter to a connected device.
163    *
164    * @param bd_addr connected peer device address to whom sync data is
165    * transferred
166    * @param service_data a value provided by the Host
167    * @param sync_handle synced advewrtising handle
168    * @param cb status and connection handle callback
169    */
170   virtual void PeriodicAdvSyncTransfer(const RawAddress& bd_addr,
171                                        uint16_t service_data,
172                                        uint16_t sync_handle, handle_cb cb) = 0;
173 
174   /**
175    * Send synchronization information about the periodic advertising in an
176    * advertising set to a connected device.
177    *
178    * @param bd_addr connected peer device address to whom set info is
179    * transferred
180    * @param service_data a value provided by the Host
181    * @param sync_handle synced advertising handle
182    * @param cb status and connection handle callback
183    */
184   virtual void PeriodicAdvSetInfoTransfer(const RawAddress& bd_addr,
185                                           uint16_t service_data,
186                                           uint8_t sync_handle,
187                                           handle_cb cb) = 0;
188 
189   /**
190    * Specify how the Controller will process periodic advertising
191    * synchronization information received from the device identified by the
192    * bd_addr
193    *
194    * @param bd_addr connected peer device address who transfers the sync data
195    * @param mode 0x00: No attempt is made to synchronize to the periodic
196    * advertising and no HCI_LE_Periodic_Advertising_Sync_Transfer_Received event
197    * is sent to the Host. 0x01: An
198    * HCI_LE_Periodic_Advertising_Sync_Transfer_Received event is sent to the
199    * Host. HCI_LE_Periodic_Advertising_Report events will be disabled. 0x02: An
200    * HCI_LE_Periodic_Advertising_Sync_Transfer_Received event is sent to the
201    * Host. HCI_LE_Periodic_Advertising_Report events will be enabled. All other
202    * values: Reserved for future use.
203    * @param skip The number of periodic advertising packets that can be skipped
204    * after a successful receive, Range: 0x0000 to 0x01F3
205    * @param sync_timeout Synchronization timeout for the periodic advertising
206    * train. Range: 0x000A to 0x4000. Time = N*10 ms. Time Range: 100 ms to
207    * 163.84 s
208    * @param cte_type bit 0: do not sync to packets with an AoA Constant Tone
209    * Extension, bit 1: do not sync to packets with an AoD Constant Tone
210    * Extension with 1 μs slots, bit 2: do not sync to packets with an AoD
211    * Constant Tone Extension with 2 μs slots, bit 4: do not sync to packets
212    * without a Constant Tone Extension, all other values: reserved for future
213    * use.
214    * @param set_defaults whether to send
215    * HCI_LE_SET_DEFAULT_PERIODIC_ADVERTISING_SYNC_TRANSFER_PARAM or
216    * HCI_LE_SET_PERIODIC_ADVERTISING_SYNC_TRANSFER_PARAM.
217    * @param cb status callback
218    */
219   virtual void SetPeriodicAdvSyncTransferParams(const RawAddress& bd_addr,
220                                                 uint8_t mode, uint16_t skip,
221                                                 uint16_t sync_timeout,
222                                                 uint8_t cte_type,
223                                                 bool set_defaults,
224                                                 status_cb cb) = 0;
225 
226   static constexpr uint8_t kOptUseAdvertiserList = 0x01;
227   static constexpr uint8_t kOptReportsInitiallyEnabled = 0x02;
228 };
229 
230 #endif  // BLE_SCANNER_HCI_INTERFACE_H
231