Shadowtrance 5c78d55b04
Bluetooth (#518)
* Bluetooth LE addition

* fixes

* use the psram!

helps a little on S3 (t-deck)

* custom device name

* Update symbols.c

* Feedback + fixes

Fixes external app start/stop server (child devices)
Fixes BtManage causing a full system hang upon disabling bt when a device is connected to the host.

* updoot

* more updoot

* move back!

* Revert "move back!"

This reverts commit d3694365c634acc5db62ac59771c496cb971a727.

* fix some of the things

* Addressing feedback? hmm

* Fixes

Bug 1 — Reconnect loop / Reconnect not working fixed
Bug 2 — Name-only advertising overwrites HID advertising
Bug 3 — BleHidDeviceCtx leak on re-enable
Enhancement — HID device auto-start on radio re-enable

* stuff...

* update for consistency with others

* fix crashes

and some bonus symbols

* a few symbols, i2c speed, cdn message

100kHz i2c speed seems to be more compatible with m5stack modules...and probably in general.
cdn message no longer applies

* Hide BT Settings when bt not enabled

* Addressing things and device fixes

* Missed one!

* stuff
2026-05-22 22:49:37 +02:00

104 lines
3.0 KiB
C++

#include <tactility/drivers/bluetooth.h>
#include <tactility/device.h>
#include <tactility/driver.h>
#define BT_API(device) ((const struct BluetoothApi*)device_get_driver(device)->api)
extern "C" {
// ---- Device lookup ----
struct Device* bluetooth_find_first_ready_device() {
struct Device* found = nullptr;
device_for_each_of_type(&BLUETOOTH_TYPE, &found, [](struct Device* dev, void* ctx) -> bool {
if (device_is_ready(dev)) {
*static_cast<struct Device**>(ctx) = dev;
return false;
}
return true;
});
return found;
}
// ---- Core radio / scan ----
error_t bluetooth_get_radio_state(struct Device* device, enum BtRadioState* state) {
return BT_API(device)->get_radio_state(device, state);
}
error_t bluetooth_set_radio_enabled(struct Device* device, bool enabled) {
return BT_API(device)->set_radio_enabled(device, enabled);
}
error_t bluetooth_scan_start(struct Device* device) {
return BT_API(device)->scan_start(device);
}
error_t bluetooth_scan_stop(struct Device* device) {
return BT_API(device)->scan_stop(device);
}
bool bluetooth_is_scanning(struct Device* device) {
return BT_API(device)->is_scanning(device);
}
// ---- Pairing ----
error_t bluetooth_pair(struct Device* device, const BtAddr addr) {
return BT_API(device)->pair(device, addr);
}
error_t bluetooth_unpair(struct Device* device, const BtAddr addr) {
return BT_API(device)->unpair(device, addr);
}
error_t bluetooth_get_paired_peers(struct Device* device, struct BtPeerRecord* out, size_t* count) {
return BT_API(device)->get_paired_peers(device, out, count);
}
// ---- Connect / disconnect ----
error_t bluetooth_connect(struct Device* device, const BtAddr addr, enum BtProfileId profile) {
return BT_API(device)->connect(device, addr, profile);
}
error_t bluetooth_disconnect(struct Device* device, const BtAddr addr, enum BtProfileId profile) {
return BT_API(device)->disconnect(device, addr, profile);
}
// ---- Event callbacks ----
error_t bluetooth_add_event_callback(struct Device* device, void* context, BtEventCallback callback) {
return BT_API(device)->add_event_callback(device, context, callback);
}
error_t bluetooth_remove_event_callback(struct Device* device, BtEventCallback callback) {
return BT_API(device)->remove_event_callback(device, callback);
}
error_t bluetooth_set_device_name(struct Device* device, const char* name) {
return BT_API(device)->set_device_name(device, name);
}
error_t bluetooth_get_device_name(struct Device* device, char* buf, size_t buf_len) {
return BT_API(device)->get_device_name(device, buf, buf_len);
}
// ---- HID host active flag ----
void bluetooth_set_hid_host_active(struct Device* device, bool active) {
BT_API(device)->set_hid_host_active(device, active);
}
void bluetooth_fire_event(struct Device* device, struct BtEvent event) {
BT_API(device)->fire_event(device, event);
}
// ---- Device type ----
const struct DeviceType BLUETOOTH_TYPE = {
.name = "bluetooth",
};
} // extern "C"