Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #603 from devrandom/no_std_devrandom
no_std support, keeping MSRV
- Loading branch information
Showing
48 changed files
with
588 additions
and
185 deletions.
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
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,24 @@ | ||
[package] | ||
authors = ["Riccardo Casatta <riccardo@casatta.it>", "Dev Random <c1.devrandom@niftybox.net>"] | ||
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"] } | ||
|
||
[[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,25 @@ | ||
# Running | ||
|
||
To run the embedded test, first prepare your environment: | ||
|
||
```shell | ||
sudo ./scripts/install-deps | ||
rustup target add thumbv7m-none-eabi | ||
``` | ||
|
||
Then: | ||
|
||
```shell | ||
source ./scripts/env.sh && cargo run --target thumbv7m-none-eabi | ||
``` | ||
|
||
Output should be something like: | ||
|
||
```text | ||
heap size 524288 | ||
secp buf size 66240 | ||
Seed WIF: L1HKVVLHXiUhecWnwFYF6L3shkf1E12HUmuZTESvBXUdx3yqVP1D | ||
Address: bc1qpx9t9pzzl4qsydmhyt6ctrxxjd4ep549np9993 | ||
``` | ||
|
||
Note that this heap size is required because of the amount of stack used by libsecp256k1 when initializing a context. |
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; // 512 KB | ||
|
||
#[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 {} | ||
} |
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
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
Oops, something went wrong.