From 1e422dd8bb8f57333afdd6af6da2cc41c5e84495 Mon Sep 17 00:00:00 2001 From: tychovrahe Date: Mon, 30 Dec 2024 09:22:26 +0100 Subject: [PATCH] fixup! feat(core): expose BLE functionality to rust --- core/embed/rust/build.rs | 2 ++ core/embed/rust/src/ui/layout/obj.rs | 18 ++++++++++-------- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/core/embed/rust/build.rs b/core/embed/rust/build.rs index 8221993afa..47179437d8 100644 --- a/core/embed/rust/build.rs +++ b/core/embed/rust/build.rs @@ -35,6 +35,7 @@ const DEFAULT_BINDGEN_MACROS_COMMON: &[&str] = &[ "-I../../vendor/micropython/lib/uzlib", "-I../rtl/inc", "-I../gfx/inc", + "-I../io/ble/inc", "-I../io/button/inc", "-I../io/display/inc", "-I../io/haptic/inc", @@ -51,6 +52,7 @@ const DEFAULT_BINDGEN_MACROS_COMMON: &[&str] = &[ "-DUSE_TOUCH", "-DUSE_HAPTIC", "-DUSE_RGB_LED", + "-DUSE_BLE", ]; #[cfg(feature = "model_tt")] diff --git a/core/embed/rust/src/ui/layout/obj.rs b/core/embed/rust/src/ui/layout/obj.rs index b80b660c0d..4ba4681d83 100644 --- a/core/embed/rust/src/ui/layout/obj.rs +++ b/core/embed/rust/src/ui/layout/obj.rs @@ -4,23 +4,25 @@ use core::{ marker::PhantomData, ops::{Deref, DerefMut}, }; + +#[cfg(feature = "touch")] +use crate::ui::{event::TouchEvent, geometry::Direction}; #[cfg(feature = "touch")] use num_traits::{FromPrimitive, ToPrimitive}; +#[cfg(feature = "ble")] +use crate::micropython::buffer::get_buffer; #[cfg(feature = "ble")] use crate::ui::event::BLEEvent; + #[cfg(feature = "button")] use crate::ui::event::ButtonEvent; -use crate::ui::{display::Color, shape::render_on_display}; - -#[cfg(feature = "touch")] -use crate::ui::{event::TouchEvent, geometry::Direction}; use crate::{ error::Error, maybe_trace::MaybeTrace, micropython::{ - buffer::{get_buffer, StrBuffer}, + buffer::StrBuffer, gc::{self, Gc, GcBox}, macros::{obj_dict, obj_fn_1, obj_fn_2, obj_fn_3, obj_fn_var, obj_map, obj_type}, map::Map, @@ -37,8 +39,9 @@ use crate::{ base::{AttachType, TimerToken}, Component, Event, EventCtx, Never, }, - display, + display::{self, Color}, event::USBEvent, + shape::render_on_display, ui_features::ModelUI, UIFeaturesCommon, }, @@ -533,9 +536,8 @@ extern "C" fn ui_layout_ble_event(n_args: usize, args: *const Obj) -> Obj { return Err(Error::TypeError); } let this: Gc = args[0].try_into()?; - let data: Obj = args[2].try_into()?; - let data = unsafe { get_buffer(data) }; + let data = unsafe { get_buffer(args[2]) }; let data = unwrap!(data);