Skip to content

Commit

Permalink
rust: handle panics to show meaningful error
Browse files Browse the repository at this point in the history
In b09c333 we added the `panic_immediate_abort` to the rust cargo flags.
This caused all the panics previously handled by the handler defined in
lib.rs to just show the `hard fault` error message on the screen of the
bitbox.

This adds the manual handling of some of those panics, to provide useful
debug messages.
  • Loading branch information
Beerosagos committed Dec 9, 2024
1 parent 1281685 commit 7b5e826
Show file tree
Hide file tree
Showing 8 changed files with 39 additions and 17 deletions.
2 changes: 1 addition & 1 deletion src/rust/bitbox02-rust-c/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ mod workflow;
fn panic(info: &core::panic::PanicInfo) -> ! {
::util::log::log!("{}", info);
#[cfg(feature = "firmware")]
bitbox02_rust::print_debug!(0, "Error: {}", info);
bitbox02_rust::print_screen!(0, "Error: {}", info);
loop {}
}

Expand Down
8 changes: 8 additions & 0 deletions src/rust/bitbox02-rust/src/general.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,11 @@

#[macro_use]
pub mod screen;

/// displays the input error message on the screen and enters
/// an infinite loop.
#[allow(clippy::empty_loop)]
pub fn abort(err: &str) {
print_screen!(0, "{}", err);
loop {}
}
4 changes: 2 additions & 2 deletions src/rust/bitbox02-rust/src/general/screen.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,11 +31,11 @@ pub fn print_debug_internal(duration: Duration, msg: &str) {
/// ```no_run
/// # #[macro_use] extern crate bitbox02_rust; fn main() {
/// let my_str = "abc";
/// print_debug!(1000, "{}", &my_str);
/// print_screen!(1000, "{}", &my_str);
/// # }
/// ```
#[macro_export]
macro_rules! print_debug {
macro_rules! print_screen {
($duration:expr, $($arg:tt)*) => ({
extern crate alloc;
let duration = core::time::Duration::from_millis($duration);
Expand Down
13 changes: 10 additions & 3 deletions src/rust/bitbox02-rust/src/hww/api/restore.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ use crate::pb;

use pb::response::Response;

use crate::general::abort;
use crate::workflow::{confirm, mnemonic, password, status, unlock};

pub async fn from_file(request: &pb::RestoreBackupRequest) -> Result<Response, Error> {
Expand Down Expand Up @@ -75,7 +76,10 @@ pub async fn from_file(request: &pb::RestoreBackupRequest) -> Result<Response, E
}

bitbox02::memory::set_initialized().or(Err(Error::Memory))?;
bitbox02::keystore::unlock(&password).expect("restore_from_file: unlock failed");
match bitbox02::keystore::unlock(&password) {
Err(_) => abort("restore_from_file: unlock failed"),
_ => (),
};

// Ignore non-critical error.
let _ = bitbox02::memory::set_device_name(&metadata.name);
Expand Down Expand Up @@ -144,9 +148,12 @@ pub async fn from_mnemonic(
}

bitbox02::memory::set_initialized().or(Err(Error::Memory))?;

// This should never fail.
bitbox02::keystore::unlock(&password).expect("restore_from_mnemonic: unlock failed");
match bitbox02::keystore::unlock(&password) {
Err(_) => abort("restore_from_mnemonic: unlock failed"),
_ => (),
};

unlock::unlock_bip39().await;
Ok(Response::Success(pb::Success {}))
}
11 changes: 8 additions & 3 deletions src/rust/bitbox02-rust/src/workflow/unlock.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
// See the License for the specific language governing permissions and
// limitations under the License.

use crate::general::abort;
use crate::workflow::confirm;
use crate::workflow::password;
use crate::workflow::status::status;
Expand Down Expand Up @@ -116,9 +117,13 @@ pub async fn unlock_bip39() {
}
}

bitbox02::ui::with_lock_animation(|| {
keystore::unlock_bip39(&mnemonic_passphrase).expect("bip39 unlock failed");
});
bitbox02::ui::lock_animation_start();
let result = keystore::unlock_bip39(&mnemonic_passphrase);
bitbox02::ui::lock_animation_stop();
match result {
Err(_) => abort("bip39 unlock failed"),
_ => (),
}
}

/// Invokes the unlock workflow. This function does not finish until the keystore is unlocked, or
Expand Down
6 changes: 4 additions & 2 deletions src/rust/bitbox02/src/ui/ui.rs
Original file line number Diff line number Diff line change
Expand Up @@ -422,9 +422,11 @@ pub fn trinary_input_string_set_input(component: &mut Component, word: &str) {
}
}

pub fn with_lock_animation<F: Fn()>(f: F) {
pub fn lock_animation_start() {
unsafe { bitbox02_sys::lock_animation_start() };
f();
}

pub fn lock_animation_stop() {
unsafe { bitbox02_sys::lock_animation_stop() };
}

Expand Down
6 changes: 3 additions & 3 deletions src/rust/bitbox02/src/ui/ui_stub.rs
Original file line number Diff line number Diff line change
Expand Up @@ -151,9 +151,9 @@ pub fn trinary_input_string_set_input(_component: &mut Component, _word: &str) {
panic!("not implemented")
}

pub fn with_lock_animation<F: Fn()>(f: F) {
f()
}
pub fn lock_animation_start() {}

pub fn lock_animation_stop() {}

pub fn screen_stack_pop_all() {}

Expand Down
6 changes: 3 additions & 3 deletions src/rust/bitbox02/src/ui/ui_stub_c_unit_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -162,9 +162,9 @@ pub fn trinary_input_string_set_input(_component: &mut Component, _word: &str) {
panic!("not implemented")
}

pub fn with_lock_animation<F: Fn()>(f: F) {
f()
}
pub fn lock_animation_start() {}

pub fn lock_animation_stop() {}

pub fn screen_stack_pop_all() {}

Expand Down

0 comments on commit 7b5e826

Please sign in to comment.