bt.c 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. #include "bt_i.h"
  2. #include "battery_service.h"
  3. #define BT_SERVICE_TAG "BT"
  4. // static void bt_update_statusbar(void* arg) {
  5. // furi_assert(arg);
  6. // Bt* bt = arg;
  7. // BtMessage m = {.type = BtMessageTypeUpdateStatusbar};
  8. // furi_check(osMessageQueuePut(bt->message_queue, &m, 0, osWaitForever) == osOK);
  9. // }
  10. static void bt_draw_statusbar_callback(Canvas* canvas, void* context) {
  11. canvas_draw_icon(canvas, 0, 0, &I_Bluetooth_5x8);
  12. }
  13. static ViewPort* bt_statusbar_view_port_alloc() {
  14. ViewPort* statusbar_view_port = view_port_alloc();
  15. view_port_set_width(statusbar_view_port, 5);
  16. view_port_draw_callback_set(statusbar_view_port, bt_draw_statusbar_callback, NULL);
  17. view_port_enabled_set(statusbar_view_port, false);
  18. return statusbar_view_port;
  19. }
  20. Bt* bt_alloc() {
  21. Bt* bt = furi_alloc(sizeof(Bt));
  22. // Load settings
  23. if(!bt_settings_load(&bt->bt_settings)) {
  24. bt_settings_save(&bt->bt_settings);
  25. }
  26. // Alloc queue
  27. bt->message_queue = osMessageQueueNew(8, sizeof(BtMessage), NULL);
  28. // doesn't make sense if we waiting for transition on service start
  29. // bt->update_status_timer = osTimerNew(bt_update_statusbar, osTimerPeriodic, bt, NULL);
  30. // osTimerStart(bt->update_status_timer, 4000);
  31. // Setup statusbar view port
  32. bt->statusbar_view_port = bt_statusbar_view_port_alloc();
  33. // Gui
  34. bt->gui = furi_record_open("gui");
  35. gui_add_view_port(bt->gui, bt->statusbar_view_port, GuiLayerStatusBarLeft);
  36. return bt;
  37. }
  38. bool bt_update_battery_level(Bt* bt, uint8_t battery_level) {
  39. BtMessage message = {
  40. .type = BtMessageTypeUpdateBatteryLevel, .data.battery_level = battery_level};
  41. return osMessageQueuePut(bt->message_queue, &message, 0, osWaitForever) == osOK;
  42. }
  43. int32_t bt_srv() {
  44. Bt* bt = bt_alloc();
  45. furi_record_create("bt", bt);
  46. furi_hal_bt_init();
  47. if(!furi_hal_bt_wait_startup()) {
  48. FURI_LOG_E(BT_SERVICE_TAG, "Core2 startup failed");
  49. } else {
  50. view_port_enabled_set(bt->statusbar_view_port, true);
  51. if(bt->bt_settings.enabled) {
  52. bool bt_app_started = furi_hal_bt_start_app();
  53. if(!bt_app_started) {
  54. FURI_LOG_E(BT_SERVICE_TAG, "BT App start failed");
  55. } else {
  56. FURI_LOG_I(BT_SERVICE_TAG, "BT App started");
  57. }
  58. }
  59. }
  60. BtMessage message;
  61. while(1) {
  62. furi_check(osMessageQueueGet(bt->message_queue, &message, NULL, osWaitForever) == osOK);
  63. if(message.type == BtMessageTypeUpdateStatusbar) {
  64. // Update statusbar
  65. view_port_enabled_set(bt->statusbar_view_port, furi_hal_bt_is_alive());
  66. } else if(message.type == BtMessageTypeUpdateBatteryLevel) {
  67. if(furi_hal_bt_is_alive()) {
  68. battery_svc_update_level(message.data.battery_level);
  69. }
  70. }
  71. }
  72. return 0;
  73. }