-
Notifications
You must be signed in to change notification settings - Fork 622
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
7 changed files
with
133 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
[package] | ||
authors = ["Riccardo Casatta <riccardo@casatta.it>"] | ||
edition = "2018" | ||
readme = "README.md" | ||
name = "embedded" | ||
version = "0.1.0" | ||
|
||
[dependencies] | ||
cortex-m = "0.6.0" | ||
cortex-m-rt = "0.6.10" | ||
cortex-m-semihosting = "0.3.3" | ||
panic-halt = "0.2.0" | ||
alloc-cortex-m = "0.4.1" | ||
bitcoin = { path="../", default-features = false, features = ["no-std", "secp-lowmemory"] } | ||
bitcoin_hashes = { version = "0.9.6", default-features = false } | ||
|
||
[[bin]] | ||
name = "embedded" | ||
test = false | ||
bench = false | ||
|
||
[profile.release] | ||
codegen-units = 1 # better optimizations | ||
debug = true # symbols are nice and they don't increase the size on Flash | ||
lto = true # better optimizations |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
MEMORY | ||
{ | ||
FLASH : ORIGIN = 0x00000000, LENGTH = 512K | ||
RAM : ORIGIN = 0x20000000, LENGTH = 512K | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
export RUSTFLAGS="-C link-arg=-Tlink.x" | ||
export CARGO_TARGET_THUMBV7M_NONE_EABI_RUNNER="qemu-system-arm -cpu cortex-m3 -machine mps2-an385 -m 1G -nographic -semihosting-config enable=on,target=native -kernel" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
#!/bin/sh | ||
|
||
apt install gcc-arm-none-eabi qemu-system-arm gdb-multiarch |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
#![feature(alloc_error_handler)] | ||
#![feature(panic_info_message)] | ||
#![no_std] | ||
#![no_main] | ||
|
||
extern crate alloc; | ||
extern crate bitcoin; | ||
|
||
use alloc::string::ToString; | ||
use alloc::vec; | ||
use core::alloc::Layout; | ||
use core::panic::PanicInfo; | ||
|
||
use alloc_cortex_m::CortexMHeap; | ||
// use panic_halt as _; | ||
use bitcoin::{Address, Network, PrivateKey}; | ||
use bitcoin::secp256k1::ffi::types::AlignedType; | ||
use bitcoin::secp256k1::Secp256k1; | ||
|
||
use cortex_m::asm; | ||
use cortex_m_rt::entry; | ||
use cortex_m_semihosting::{debug, hprintln}; | ||
|
||
// this is the allocator the application will use | ||
#[global_allocator] | ||
static ALLOCATOR: CortexMHeap = CortexMHeap::empty(); | ||
|
||
const HEAP_SIZE: usize = 1024 * 512; // in bytes | ||
|
||
#[entry] | ||
fn main() -> ! { | ||
hprintln!("heap size {}", HEAP_SIZE).unwrap(); | ||
|
||
unsafe { ALLOCATOR.init(cortex_m_rt::heap_start() as usize, HEAP_SIZE) } | ||
|
||
let size = Secp256k1::preallocate_size(); | ||
hprintln!("secp buf size {}", size*16).unwrap(); | ||
|
||
// Load a private key | ||
let raw = "L1HKVVLHXiUhecWnwFYF6L3shkf1E12HUmuZTESvBXUdx3yqVP1D"; | ||
let pk = PrivateKey::from_wif(raw).unwrap(); | ||
hprintln!("Seed WIF: {}", pk).unwrap(); | ||
|
||
let mut buf_ful = vec![AlignedType::zeroed(); size]; | ||
let secp = Secp256k1::preallocated_new(&mut buf_ful).unwrap(); | ||
|
||
// Derive address | ||
let pubkey = pk.public_key(&secp); | ||
let address = Address::p2wpkh(&pubkey, Network::Bitcoin).unwrap(); | ||
hprintln!("Address: {}", address).unwrap(); | ||
|
||
assert_eq!(address.to_string(), "bc1qpx9t9pzzl4qsydmhyt6ctrxxjd4ep549np9993".to_string()); | ||
// exit QEMU | ||
// NOTE do not run this on hardware; it can corrupt OpenOCD state | ||
debug::exit(debug::EXIT_SUCCESS); | ||
|
||
loop {} | ||
} | ||
|
||
// define what happens in an Out Of Memory (OOM) condition | ||
#[alloc_error_handler] | ||
fn alloc_error(_layout: Layout) -> ! { | ||
hprintln!("alloc error").unwrap(); | ||
debug::exit(debug::EXIT_FAILURE); | ||
asm::bkpt(); | ||
|
||
loop {} | ||
} | ||
|
||
#[inline(never)] | ||
#[panic_handler] | ||
fn panic(info: &PanicInfo) -> ! { | ||
hprintln!("panic {:?}", info.message()).unwrap(); | ||
debug::exit(debug::EXIT_FAILURE); | ||
loop {} | ||
} |