From b65c6691a50962d82244de08ca6a267de0997fde Mon Sep 17 00:00:00 2001 From: GroM Date: Fri, 20 Dec 2024 15:38:11 +0100 Subject: [PATCH 1/3] appflags should be set at device level --- Cargo.lock | 2 +- cargo-ledger/Cargo.toml | 4 ++-- cargo-ledger/src/main.rs | 29 +++++++++++++++++++---------- 3 files changed, 22 insertions(+), 13 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index f04b0d6d..f71651fb 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -127,7 +127,7 @@ checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" [[package]] name = "cargo-ledger" -version = "1.5.1" +version = "1.6.0" dependencies = [ "cargo_metadata", "clap", diff --git a/cargo-ledger/Cargo.toml b/cargo-ledger/Cargo.toml index 6ab648d0..60634adb 100644 --- a/cargo-ledger/Cargo.toml +++ b/cargo-ledger/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "cargo-ledger" -version = "1.5.1" -authors = ["yhql", "agrojean-ledger"] +version = "1.6.0" +authors = ["yhql", "agrojean-ledger", "y333"] description = "Build and sideload Ledger devices apps" categories = ["development-tools::cargo-plugins"] repository = "https://github.com/LedgerHQ/cargo-ledger" diff --git a/cargo-ledger/src/main.rs b/cargo-ledger/src/main.rs index b6b97feb..95b0cc02 100644 --- a/cargo-ledger/src/main.rs +++ b/cargo-ledger/src/main.rs @@ -32,13 +32,14 @@ struct NanosMetadata { struct LedgerMetadata { curve: Vec, path: Vec, - flags: String, + flags: Option, name: Option, } #[derive(Debug, Deserialize)] struct DeviceMetadata { icon: String, + flags: Option, } #[derive(Parser, Debug)] @@ -167,7 +168,7 @@ fn retrieve_metadata( let ledger_metadata = LedgerMetadata { curve: nanos_metadata.curve, path: nanos_metadata.path, - flags: nanos_metadata.flags, + flags: Some(nanos_metadata.flags), name: nanos_metadata.name, }; @@ -176,6 +177,7 @@ fn retrieve_metadata( Device::Nanos => nanos_metadata.icon, _ => nanos_metadata.icon_small, }, + flags: None, }; (this_pkg.clone(), ledger_metadata, device_metadata) @@ -291,14 +293,21 @@ fn build_app( // Retrieve real data size and SDK infos from ELF let infos = retrieve_infos(&exe_path).unwrap(); - // Modify flags to enable BLE if targeting Nano X - let flags = match device { - Device::Nanos | Device::Nanosplus => metadata_ledger.flags, - Device::Nanox | Device::Stax | Device::Flex => { - let base = u32::from_str_radix(metadata_ledger.flags.as_str(), 16) - .unwrap_or(0); - format!("0x{:x}", base | 0x200) - } + let flags = match metadata_device.flags { + Some(flags) => flags, + None => match metadata_ledger.flags { + Some(flags) => match device { + // Modify flags to enable BLE if targeting Nano X + Device::Nanos | Device::Nanosplus => flags, + Device::Nanox | Device::Stax | Device::Flex => { + let base = + u32::from_str_radix(flags.trim_start_matches("0x"), 16) + .unwrap_or(0); + format!("0x{:x}", base | 0x200) + } + }, + None => String::from("0x00"), + }, }; // Target ID according to target, in case it From c1fe1ee6a4f9302ab8f3231abf255ddc0fb97ce0 Mon Sep 17 00:00:00 2001 From: GroM Date: Fri, 20 Dec 2024 15:55:22 +0100 Subject: [PATCH 2/3] remove backward compatibility code --- cargo-ledger/src/main.rs | 44 +++++----------------------------------- 1 file changed, 5 insertions(+), 39 deletions(-) diff --git a/cargo-ledger/src/main.rs b/cargo-ledger/src/main.rs index 95b0cc02..723fae5f 100644 --- a/cargo-ledger/src/main.rs +++ b/cargo-ledger/src/main.rs @@ -16,18 +16,6 @@ use utils::*; mod setup; mod utils; -/// Structure for retrocompatibility, when the cargo manifest file -/// contains a single `[package.metadata.nanos]` section -#[derive(Debug, Deserialize)] -struct NanosMetadata { - curve: Vec, - path: Vec, - flags: String, - icon: String, - icon_small: String, - name: Option, -} - #[derive(Debug, Deserialize)] struct LedgerMetadata { curve: Vec, @@ -124,7 +112,7 @@ fn main() { fn retrieve_metadata( device: Device, manifest_path: Option<&str>, -) -> (Package, LedgerMetadata, DeviceMetadata) { +) -> Result<(Package, LedgerMetadata, DeviceMetadata), ()> { let mut cmd = cargo_metadata::MetadataCommand::new(); // Only used during tests @@ -155,32 +143,10 @@ fn retrieve_metadata( serde_json::from_value(metadata_device) .expect("Could not deserialize device medatada"); - (this_pkg.clone(), ledger_metadata, device_metadata) + Ok((this_pkg.clone(), ledger_metadata, device_metadata)) } else { - println!("WARNING: 'package.metadata.ledger' section is missing in Cargo.toml, trying 'package.metadata.nanos'"); - let nanos_section = this_pkg.metadata.get("nanos").expect( - "No appropriate [package.metadata.] section found.", - ); - - let nanos_metadata: NanosMetadata = - serde_json::from_value(nanos_section.clone()) - .expect("Could not deserialize medatada.nanos"); - let ledger_metadata = LedgerMetadata { - curve: nanos_metadata.curve, - path: nanos_metadata.path, - flags: Some(nanos_metadata.flags), - name: nanos_metadata.name, - }; - - let device_metadata = DeviceMetadata { - icon: match device { - Device::Nanos => nanos_metadata.icon, - _ => nanos_metadata.icon_small, - }, - flags: None, - }; - - (this_pkg.clone(), ledger_metadata, device_metadata) + println!("No metadata found for device: {}", device); + Err(()) } } @@ -265,7 +231,7 @@ fn build_app( }; let (this_pkg, metadata_ledger, metadata_device) = - retrieve_metadata(device, None); + retrieve_metadata(device, None).unwrap(); let package_path = this_pkg .manifest_path From 72c22a9c73edba8ce6106a3fefffcd22dbb5fdcb Mon Sep 17 00:00:00 2001 From: GroM Date: Fri, 20 Dec 2024 15:57:43 +0100 Subject: [PATCH 3/3] 0x000 is default appflags --- cargo-ledger/src/main.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cargo-ledger/src/main.rs b/cargo-ledger/src/main.rs index 723fae5f..061319fd 100644 --- a/cargo-ledger/src/main.rs +++ b/cargo-ledger/src/main.rs @@ -272,7 +272,7 @@ fn build_app( format!("0x{:x}", base | 0x200) } }, - None => String::from("0x00"), + None => String::from("0x000"), }, };