• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /******************************************************************************
2  *
3  *  Copyright (C) 2014 Google, Inc.
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 
19 #pragma once
20 
21 #include <stdbool.h>
22 #include <stdint.h>
23 
24 #include "bdaddr.h"
25 #include "device_features.h"
26 #include "hci_layer.h"
27 #include "hci_packet_factory.h"
28 #include "hci_packet_parser.h"
29 
30 static const char CONTROLLER_MODULE[] = "controller_module";
31 
32 typedef struct controller_t {
33   bool (*get_is_ready)(void);
34 
35   const bt_bdaddr_t *(*get_address)(void);
36   const bt_version_t *(*get_bt_version)(void);
37 
38   const bt_device_features_t *(*get_features_classic)(int index);
39   uint8_t (*get_last_features_classic_index)(void);
40 
41   const bt_device_features_t *(*get_features_ble)(void);
42   const uint8_t *(*get_ble_supported_states)(void);
43 
44   bool (*supports_simple_pairing)(void);
45   bool (*supports_secure_connections)(void);
46   bool (*supports_simultaneous_le_bredr)(void);
47   bool (*supports_reading_remote_extended_features)(void);
48   bool (*supports_interlaced_inquiry_scan)(void);
49   bool (*supports_rssi_with_inquiry_results)(void);
50   bool (*supports_extended_inquiry_response)(void);
51   bool (*supports_master_slave_role_switch)(void);
52 
53   bool (*supports_ble)(void);
54   bool (*supports_ble_packet_extension)(void);
55   bool (*supports_ble_connection_parameters_request)(void);
56   bool (*supports_ble_privacy)(void);
57 
58   // Get the cached acl data sizes for the controller.
59   uint16_t (*get_acl_data_size_classic)(void);
60   uint16_t (*get_acl_data_size_ble)(void);
61 
62   // Get the cached acl packet sizes for the controller.
63   // This is a convenience function for the respective
64   // acl data size + size of the acl header.
65   uint16_t (*get_acl_packet_size_classic)(void);
66   uint16_t (*get_acl_packet_size_ble)(void);
67 
68   uint16_t (*get_ble_default_data_packet_length)(void);
69 
70   // Get the number of acl packets the controller can buffer.
71   uint16_t (*get_acl_buffer_count_classic)(void);
72   uint8_t (*get_acl_buffer_count_ble)(void);
73 
74   uint8_t (*get_ble_white_list_size)(void);
75 
76   uint8_t (*get_ble_resolving_list_max_size)(void);
77   void (*set_ble_resolving_list_max_size)(int resolving_list_max_size);
78 } controller_t;
79 
80 const controller_t *controller_get_interface();
81 
82 const controller_t *controller_get_test_interface(
83     const hci_t *hci_interface,
84     const hci_packet_factory_t *packet_factory_interface,
85     const hci_packet_parser_t *packet_parser_interface);
86