• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2021 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 #include "chre_api/chre/ble.h"
18 
19 #include "chre/core/event_loop_manager.h"
20 #include "chre/util/macros.h"
21 #include "chre/util/system/napp_permissions.h"
22 
23 using chre::EventLoopManager;
24 using chre::EventLoopManagerSingleton;
25 using chre::NanoappPermissions;
26 
chreBleGetCapabilities()27 DLL_EXPORT uint32_t chreBleGetCapabilities() {
28 #ifdef CHRE_BLE_SUPPORT_ENABLED
29   return EventLoopManagerSingleton::get()
30       ->getBleRequestManager()
31       .getCapabilities();
32 #else
33   return CHRE_BLE_CAPABILITIES_NONE;
34 #endif  // CHRE_BLE_SUPPORT_ENABLED
35 }
36 
chreBleGetFilterCapabilities()37 DLL_EXPORT uint32_t chreBleGetFilterCapabilities() {
38 #ifdef CHRE_BLE_SUPPORT_ENABLED
39   return EventLoopManagerSingleton::get()
40       ->getBleRequestManager()
41       .getFilterCapabilities();
42 #else
43   return CHRE_BLE_FILTER_CAPABILITIES_NONE;
44 #endif  // CHRE_BLE_SUPPORT_ENABLED
45 }
46 
chreBleFlushAsync(const void *)47 DLL_EXPORT bool chreBleFlushAsync(const void * /* cookie */) {
48   return false;
49 }
50 
chreBleStartScanAsync(chreBleScanMode mode,uint32_t reportDelayMs,const struct chreBleScanFilter * filter)51 DLL_EXPORT bool chreBleStartScanAsync(chreBleScanMode mode,
52                                       uint32_t reportDelayMs,
53                                       const struct chreBleScanFilter *filter) {
54 #ifdef CHRE_BLE_SUPPORT_ENABLED
55   chre::Nanoapp *nanoapp = EventLoopManager::validateChreApiCall(__func__);
56   return nanoapp->permitPermissionUse(NanoappPermissions::CHRE_PERMS_BLE) &&
57          EventLoopManagerSingleton::get()
58              ->getBleRequestManager()
59              .startScanAsync(nanoapp, mode, reportDelayMs, filter);
60 #else
61   UNUSED_VAR(mode);
62   UNUSED_VAR(reportDelayMs);
63   UNUSED_VAR(filter);
64   return false;
65 #endif  // CHRE_BLE_SUPPORT_ENABLED
66 }
67 
chreBleStopScanAsync()68 DLL_EXPORT bool chreBleStopScanAsync() {
69 #ifdef CHRE_BLE_SUPPORT_ENABLED
70   chre::Nanoapp *nanoapp = EventLoopManager::validateChreApiCall(__func__);
71   return nanoapp->permitPermissionUse(NanoappPermissions::CHRE_PERMS_BLE) &&
72          EventLoopManagerSingleton::get()->getBleRequestManager().stopScanAsync(
73              nanoapp);
74 #else
75   return false;
76 #endif  // CHRE_BLE_SUPPORT_ENABLED
77 }
78 
chreBleReadRssiAsync(uint16_t connectionHandle,const void * cookie)79 DLL_EXPORT bool chreBleReadRssiAsync(uint16_t connectionHandle,
80                                      const void *cookie) {
81 #ifdef CHRE_BLE_READ_RSSI_SUPPORT_ENABLED
82   chre::Nanoapp *nanoapp = EventLoopManager::validateChreApiCall(__func__);
83   return nanoapp->permitPermissionUse(NanoappPermissions::CHRE_PERMS_BLE) &&
84          EventLoopManagerSingleton::get()->getBleRequestManager().readRssiAsync(
85              nanoapp, connectionHandle, cookie);
86 #else
87   UNUSED_VAR(connectionHandle);
88   UNUSED_VAR(cookie);
89   return false;
90 #endif  // CHRE_BLE_READ_RSSI_SUPPORT_ENABLED
91 }
92 
chreBleGetScanStatus(struct chreBleScanStatus * status)93 DLL_EXPORT bool chreBleGetScanStatus(struct chreBleScanStatus *status) {
94 #ifdef CHRE_BLE_SUPPORT_ENABLED
95   chre::Nanoapp *nanoapp = EventLoopManager::validateChreApiCall(__func__);
96   return nanoapp->permitPermissionUse(NanoappPermissions::CHRE_PERMS_BLE) &&
97          EventLoopManagerSingleton::get()->getBleRequestManager().getScanStatus(
98              status);
99 #else
100   UNUSED_VAR(status);
101   return false;
102 #endif  // CHRE_BLE_SUPPORT_ENABLED
103 }