mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-21 04:11:48 +03:00
936a2f64b2
* FuriHal: add more supported radio stacks * Bt: correct ble stack enum value * Bt: update cli testing commands implementation * Scripts: always emitting ob data to update manifest; added ob_custradio.data for non-light radio stacks * Scripts: added stack type whitelist & disclaimer message * ble: remove scanner * ble: remove HCI and advances ble stacks support * bt: correctly close RPC session before bt reinit * Scripts: update bundler: estimating flash layout & refusing to build dangerous packages; app frame: not adding redundant log handlers * Docs: additional details on bundling updates; fixed updater error codes * Docs: wording fixes for OTA.md Co-authored-by: hedger <hedger@nanode.su> Co-authored-by: gornekich <n.gorbadey@gmail.com> Co-authored-by: SG <who.just.the.doctor@gmail.com>
60 lines
1.2 KiB
C
60 lines
1.2 KiB
C
#pragma once
|
|
|
|
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef struct Bt Bt;
|
|
|
|
typedef enum {
|
|
BtStatusUnavailable,
|
|
BtStatusOff,
|
|
BtStatusAdvertising,
|
|
BtStatusConnected,
|
|
} BtStatus;
|
|
|
|
typedef enum {
|
|
BtProfileSerial,
|
|
BtProfileHidKeyboard,
|
|
} BtProfile;
|
|
|
|
typedef void (*BtStatusChangedCallback)(BtStatus status, void* context);
|
|
|
|
/** Change BLE Profile
|
|
* @note Call of this function leads to 2nd core restart
|
|
*
|
|
* @param bt Bt instance
|
|
* @param profile BtProfile
|
|
*
|
|
* @return true on success
|
|
*/
|
|
bool bt_set_profile(Bt* bt, BtProfile profile);
|
|
|
|
/** Disconnect from Central
|
|
*
|
|
* @param bt Bt instance
|
|
*/
|
|
void bt_disconnect(Bt* bt);
|
|
|
|
/** Set callback for Bluetooth status change notification
|
|
*
|
|
* @param bt Bt instance
|
|
* @param callback BtStatusChangedCallback instance
|
|
* @param context pointer to context
|
|
*/
|
|
void bt_set_status_changed_callback(Bt* bt, BtStatusChangedCallback callback, void* context);
|
|
|
|
/** Forget bonded devices
|
|
* @note Leads to wipe ble key storage and deleting bt.keys
|
|
*
|
|
* @param bt Bt instance
|
|
*/
|
|
void bt_forget_bonded_devices(Bt* bt);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|