Add libstd support to Rust BPF (#5788)
This commit is contained in:
parent
ceaf4781b0
commit
5fb2d7a98f
|
@ -24,7 +24,7 @@ _ ci/nits.sh
|
||||||
_ ci/order-crates-for-publishing.py
|
_ ci/order-crates-for-publishing.py
|
||||||
_ book/build.sh
|
_ book/build.sh
|
||||||
|
|
||||||
for project in sdk/bpf/rust/{rust-no-std,rust-utils,rust-test} programs/bpf/rust/*/ ; do
|
for project in sdk/bpf/rust/{rust-utils,rust-test} programs/bpf/rust/*/ ; do
|
||||||
echo "+++ do_bpf_check $project"
|
echo "+++ do_bpf_check $project"
|
||||||
(
|
(
|
||||||
cd "$project"
|
cd "$project"
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
solana-bpf-rust-128bit-dep = { path = "../128bit_dep", version = "0.19.0-pre0" }
|
solana-bpf-rust-128bit-dep = { path = "../128bit_dep", version = "0.19.0-pre0" }
|
||||||
|
|
||||||
[dev_dependencies]
|
[dev_dependencies]
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,12 +1,6 @@
|
||||||
//! @brief Example Rust-based BPF program tests loop iteration
|
//! @brief Example Rust-based BPF program tests loop iteration
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use solana_sdk_bpf_utils::info;
|
use solana_sdk_bpf_utils::info;
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,7 +1,5 @@
|
||||||
//! @brief Solana Rust-based BPF program utility functions and types
|
//! @brief Solana Rust-based BPF program utility functions and types
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
pub fn uadd(x: u128, y: u128) -> u128 {
|
pub fn uadd(x: u128, y: u128) -> u128 {
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = []
|
members = []
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,24 +1,18 @@
|
||||||
//! @brief Example Rust-based BPF program that test dynamic memory allocation
|
//! @brief Example Rust-based BPF program that test dynamic memory allocation
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate alloc;
|
extern crate alloc;
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use alloc::vec::Vec;
|
|
||||||
use core::alloc::Layout;
|
|
||||||
use core::mem;
|
|
||||||
use solana_sdk_bpf_utils::info;
|
use solana_sdk_bpf_utils::info;
|
||||||
|
use std::alloc::Layout;
|
||||||
|
use std::mem;
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn entrypoint(_input: *mut u8) -> bool {
|
pub extern "C" fn entrypoint(_input: *mut u8) -> bool {
|
||||||
unsafe {
|
unsafe {
|
||||||
// Confirm large allocation fails
|
// Confirm large allocation fails
|
||||||
|
|
||||||
let layout = Layout::from_size_align(core::usize::MAX, mem::align_of::<u8>()).unwrap();
|
let layout = Layout::from_size_align(std::usize::MAX, mem::align_of::<u8>()).unwrap();
|
||||||
let ptr = alloc::alloc::alloc(layout);
|
let ptr = alloc::alloc::alloc(layout);
|
||||||
if !ptr.is_null() {
|
if !ptr.is_null() {
|
||||||
info!("Error: Alloc of very larger buffer should fail");
|
info!("Error: Alloc of very larger buffer should fail");
|
||||||
|
@ -59,7 +53,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> bool {
|
||||||
alloc::alloc::dealloc(ptr, layout);
|
alloc::alloc::dealloc(ptr, layout);
|
||||||
}
|
}
|
||||||
|
|
||||||
// // TODO not supported for system or bump allocator
|
// TODO not supported bump allocator
|
||||||
// unsafe {
|
// unsafe {
|
||||||
// // Test alloc all bytes and one more (assumes heap size of 2048)
|
// // Test alloc all bytes and one more (assumes heap size of 2048)
|
||||||
|
|
||||||
|
@ -93,7 +87,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
// TODO test Vec::new()
|
// test Vec::new()
|
||||||
|
|
||||||
const ITERS: usize = 100;
|
const ITERS: usize = 100;
|
||||||
let mut v = Vec::new();
|
let mut v = Vec::new();
|
||||||
|
|
|
@ -14,7 +14,6 @@ edition = "2018"
|
||||||
[dependencies]
|
[dependencies]
|
||||||
byteorder = { version = "1", default-features = false }
|
byteorder = { version = "1", default-features = false }
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = []
|
members = []
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,12 +1,6 @@
|
||||||
//! @brief Example Rust-based BPF program tests dependent crates
|
//! @brief Example Rust-based BPF program tests dependent crates
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use byteorder::{ByteOrder, LittleEndian};
|
use byteorder::{ByteOrder, LittleEndian};
|
||||||
use solana_sdk_bpf_utils::info;
|
use solana_sdk_bpf_utils::info;
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = []
|
members = []
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,15 +1,8 @@
|
||||||
//! @brief Example Rust-based BPF program that moves a lamport from one account to another
|
//! @brief Example Rust-based BPF program that moves a lamport from one account to another
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unreachable_code)]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
use solana_sdk_bpf_utils::entrypoint;
|
||||||
use solana_sdk_bpf_utils::entrypoint::*;
|
use solana_sdk_bpf_utils::entrypoint::*;
|
||||||
use solana_sdk_bpf_utils::{entrypoint, info};
|
|
||||||
|
|
||||||
entrypoint!(process_instruction);
|
entrypoint!(process_instruction);
|
||||||
fn process_instruction(ka: &mut [SolKeyedAccount], _info: &SolClusterInfo, _data: &[u8]) -> bool {
|
fn process_instruction(ka: &mut [SolKeyedAccount], _info: &SolClusterInfo, _data: &[u8]) -> bool {
|
||||||
|
@ -18,6 +11,5 @@ fn process_instruction(ka: &mut [SolKeyedAccount], _info: &SolClusterInfo, _data
|
||||||
// is seen by the runtime and fails as expected
|
// is seen by the runtime and fails as expected
|
||||||
*ka[0].lamports -= 1;
|
*ka[0].lamports -= 1;
|
||||||
|
|
||||||
info!("Success");
|
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = []
|
members = []
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,12 +1,6 @@
|
||||||
//! @brief Example Rust-based BPF program tests loop iteration
|
//! @brief Example Rust-based BPF program tests loop iteration
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use solana_sdk_bpf_utils::info;
|
use solana_sdk_bpf_utils::info;
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
solana-bpf-rust-many-args-dep = { path = "../many_args_dep", version = "0.19.0-pre0" }
|
solana-bpf-rust-many-args-dep = { path = "../many_args_dep", version = "0.19.0-pre0" }
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,14 +1,7 @@
|
||||||
//! @brief Example Rust-based BPF program tests loop iteration
|
//! @brief Example Rust-based BPF program tests loop iteration
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
mod helper;
|
mod helper;
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use solana_sdk_bpf_utils::info;
|
use solana_sdk_bpf_utils::info;
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,9 +1,6 @@
|
||||||
//! @brief Solana Rust-based BPF program utility functions and types
|
//! @brief Solana Rust-based BPF program utility functions and types
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use solana_sdk_bpf_utils::info;
|
use solana_sdk_bpf_utils::info;
|
||||||
|
|
||||||
pub fn many_args(
|
pub fn many_args(
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = []
|
members = []
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,13 +1,8 @@
|
||||||
//! @brief Example Rust-based BPF program that prints out the parameters passed to it
|
//! @brief Example Rust-based BPF program that prints out the parameters passed to it
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unreachable_code)]
|
#![allow(unreachable_code)]
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use solana_sdk_bpf_utils::entrypoint::*;
|
use solana_sdk_bpf_utils::entrypoint::*;
|
||||||
use solana_sdk_bpf_utils::log::*;
|
use solana_sdk_bpf_utils::log::*;
|
||||||
use solana_sdk_bpf_utils::{entrypoint, info};
|
use solana_sdk_bpf_utils::{entrypoint, info};
|
||||||
|
@ -36,17 +31,11 @@ fn process_instruction(ka: &mut [SolKeyedAccount], info: &SolClusterInfo, data:
|
||||||
sol_log_params(ka, data);
|
sol_log_params(ka, data);
|
||||||
|
|
||||||
{
|
{
|
||||||
// Test - arch config
|
// Test - use std methods, unwrap
|
||||||
#[cfg(not(target_arch = "bpf"))]
|
|
||||||
panic!();
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
// Test - use core methods, unwrap
|
|
||||||
|
|
||||||
// valid bytes, in a stack-allocated array
|
// valid bytes, in a stack-allocated array
|
||||||
let sparkle_heart = [240, 159, 146, 150];
|
let sparkle_heart = [240, 159, 146, 150];
|
||||||
let result_str = core::str::from_utf8(&sparkle_heart).unwrap();
|
let result_str = std::str::from_utf8(&sparkle_heart).unwrap();
|
||||||
assert_eq!(4, result_str.len());
|
assert_eq!(4, result_str.len());
|
||||||
assert_eq!("💖", result_str);
|
assert_eq!("💖", result_str);
|
||||||
info!(result_str);
|
info!(result_str);
|
||||||
|
@ -59,6 +48,12 @@ fn process_instruction(ka: &mut [SolKeyedAccount], info: &SolClusterInfo, data:
|
||||||
assert_eq!(s.x + s.y + s.z, 6);
|
assert_eq!(s.x + s.y + s.z, 6);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
// Test - arch config
|
||||||
|
#[cfg(not(target_arch = "bpf"))]
|
||||||
|
panic!();
|
||||||
|
}
|
||||||
|
|
||||||
info!("Success");
|
info!("Success");
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = []
|
members = []
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,10 +1,5 @@
|
||||||
//! @brief Example Rust-based BPF program that panics
|
//! @brief Example Rust-based BPF program that panics
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
solana-bpf-rust-param-passing-dep = { path = "../param_passing_dep", version = "0.19.0-pre0" }
|
solana-bpf-rust-param-passing-dep = { path = "../param_passing_dep", version = "0.19.0-pre0" }
|
||||||
|
|
||||||
[dev_dependencies]
|
[dev_dependencies]
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,12 +1,6 @@
|
||||||
//! @brief Example Rust-based BPF program tests loop iteration
|
//! @brief Example Rust-based BPF program tests loop iteration
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use solana_bpf_rust_param_passing_dep::{Data, TestDep};
|
use solana_bpf_rust_param_passing_dep::{Data, TestDep};
|
||||||
use solana_sdk_bpf_utils::info;
|
use solana_sdk_bpf_utils::info;
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,6 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[dev_dependencies]
|
[dev_dependencies]
|
||||||
solana-sdk-bpf-test = { path = "../../../../sdk/bpf/rust/rust-test", version = "0.19.0-pre0" }
|
solana-sdk-bpf-test = { path = "../../../../sdk/bpf/rust/rust-test", version = "0.19.0-pre0" }
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,8 +1,5 @@
|
||||||
//! @brief Example Rust-based BPF program tests loop iteration
|
//! @brief Example Rust-based BPF program tests loop iteration
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unused_attributes)]
|
|
||||||
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
pub struct Data<'a> {
|
pub struct Data<'a> {
|
||||||
|
|
|
@ -14,7 +14,6 @@ edition = "2018"
|
||||||
[dependencies]
|
[dependencies]
|
||||||
byteorder = { version = "1", default-features = false }
|
byteorder = { version = "1", default-features = false }
|
||||||
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
solana-sdk-bpf-utils = { path = "../../../../sdk/bpf/rust/rust-utils", version = "0.19.0-pre0" }
|
||||||
solana-sdk-bpf-no-std = { path = "../../../../sdk/bpf/rust/rust-no-std", version = "0.19.0-pre0" }
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = []
|
members = []
|
||||||
|
|
|
@ -1,6 +1,2 @@
|
||||||
[dependencies.compiler_builtins]
|
[target.bpfel-unknown-unknown.dependencies.std]
|
||||||
path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/compiler-builtins"
|
features = []
|
||||||
features = ["c", "mem"]
|
|
||||||
|
|
||||||
[target.bpfel-unknown-unknown.dependencies]
|
|
||||||
alloc = { path = "../../../../sdk/bpf/dependencies/rust-bpf-sysroot/src/liballoc" }
|
|
|
@ -1,12 +1,6 @@
|
||||||
//! @brief Example Rust-based BPF program that prints out the parameters passed to it
|
//! @brief Example Rust-based BPF program that prints out the parameters passed to it
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![allow(unreachable_code)]
|
|
||||||
|
|
||||||
#[cfg(not(test))]
|
|
||||||
extern crate solana_sdk_bpf_no_std;
|
|
||||||
extern crate solana_sdk_bpf_utils;
|
extern crate solana_sdk_bpf_utils;
|
||||||
|
|
||||||
use byteorder::{ByteOrder, LittleEndian};
|
use byteorder::{ByteOrder, LittleEndian};
|
||||||
use solana_sdk_bpf_utils::entrypoint::*;
|
use solana_sdk_bpf_utils::entrypoint::*;
|
||||||
use solana_sdk_bpf_utils::{entrypoint, info};
|
use solana_sdk_bpf_utils::{entrypoint, info};
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
/dependencies/criterion*
|
/dependencies/criterion*
|
||||||
|
/dependencies/hashbrown*
|
||||||
/dependencies/llvm-native*
|
/dependencies/llvm-native*
|
||||||
/dependencies/rust-bpf*
|
/dependencies/rust-bpf*
|
||||||
/dependencies/xargo*
|
/dependencies/xargo*
|
||||||
|
|
|
@ -1,4 +0,0 @@
|
||||||
/target/
|
|
||||||
|
|
||||||
Cargo.lock
|
|
||||||
/farf/
|
|
|
@ -1,16 +0,0 @@
|
||||||
|
|
||||||
[package]
|
|
||||||
name = "solana-sdk-bpf-no-std"
|
|
||||||
version = "0.19.0-pre0"
|
|
||||||
description = "Solana BPF SDK Rust no_std support"
|
|
||||||
authors = ["Solana Maintainers <maintainers@solana.com>"]
|
|
||||||
repository = "https://github.com/solana-labs/solana"
|
|
||||||
license = "Apache-2.0"
|
|
||||||
homepage = "https://solana.com/"
|
|
||||||
edition = "2018"
|
|
||||||
|
|
||||||
[dependencies]
|
|
||||||
solana-sdk-bpf-utils = { path = "../rust-utils" }
|
|
||||||
|
|
||||||
[workspace]
|
|
||||||
members = []
|
|
|
@ -1,23 +0,0 @@
|
||||||
//! @brief Solana Rust-based BPF program memory allocator shim
|
|
||||||
|
|
||||||
use core::alloc::{GlobalAlloc, Layout};
|
|
||||||
use solana_sdk_bpf_utils::log::*;
|
|
||||||
|
|
||||||
pub struct Allocator;
|
|
||||||
unsafe impl GlobalAlloc for Allocator {
|
|
||||||
unsafe fn alloc(&self, layout: Layout) -> *mut u8 {
|
|
||||||
sol_alloc_free_(layout.size() as u64, 0)
|
|
||||||
}
|
|
||||||
unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout) {
|
|
||||||
sol_alloc_free_(layout.size() as u64, ptr as u64);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
extern "C" {
|
|
||||||
fn sol_alloc_free_(size: u64, ptr: u64) -> *mut u8;
|
|
||||||
}
|
|
||||||
|
|
||||||
#[alloc_error_handler]
|
|
||||||
fn my_alloc_error_handler(_: core::alloc::Layout) -> ! {
|
|
||||||
sol_log("alloc_error_handler");
|
|
||||||
panic!();
|
|
||||||
}
|
|
|
@ -1,20 +0,0 @@
|
||||||
//! @brief Solana Rust-based BPF program utility functions and types
|
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
#![feature(allocator_api)]
|
|
||||||
#![feature(alloc_error_handler)]
|
|
||||||
#![feature(panic_info_message)]
|
|
||||||
#![feature(compiler_builtins_lib)]
|
|
||||||
#![feature(lang_items)]
|
|
||||||
#![cfg(not(test))]
|
|
||||||
|
|
||||||
#[lang = "eh_personality"]
|
|
||||||
extern "C" fn eh_personality() {}
|
|
||||||
|
|
||||||
extern crate compiler_builtins;
|
|
||||||
|
|
||||||
pub mod allocator;
|
|
||||||
pub mod panic;
|
|
||||||
|
|
||||||
#[global_allocator]
|
|
||||||
static A: allocator::Allocator = allocator::Allocator;
|
|
|
@ -1,32 +0,0 @@
|
||||||
//! @brief Solana Rust-based BPF program panic handling
|
|
||||||
|
|
||||||
use core::panic::PanicInfo;
|
|
||||||
use core::ptr;
|
|
||||||
|
|
||||||
#[panic_handler]
|
|
||||||
fn panic(info: &PanicInfo) -> ! {
|
|
||||||
// Message is ignored for now to avoid incurring formatting overhead
|
|
||||||
match info.location() {
|
|
||||||
Some(location) => {
|
|
||||||
let mut file: [u8; 128] = [0; 128];
|
|
||||||
for (i, c) in location.file().as_bytes().iter().enumerate() {
|
|
||||||
if i > 127 {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
file[i] = *c;
|
|
||||||
}
|
|
||||||
unsafe {
|
|
||||||
sol_panic_(
|
|
||||||
file.as_ptr(),
|
|
||||||
file.len() as u64,
|
|
||||||
u64::from(location.line()),
|
|
||||||
u64::from(location.column()),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
None => unsafe { sol_panic_(ptr::null(), 0, 0, 0) },
|
|
||||||
}
|
|
||||||
}
|
|
||||||
extern "C" {
|
|
||||||
pub fn sol_panic_(file: *const u8, len: u64, line: u64, column: u64) -> !;
|
|
||||||
}
|
|
|
@ -1,6 +1,4 @@
|
||||||
//! @brief Solana Rust-based BPF program utility functions and types
|
//! @brief Solana Rust-based BPF program utility functions and types
|
||||||
|
|
||||||
#![no_std]
|
|
||||||
|
|
||||||
pub mod entrypoint;
|
pub mod entrypoint;
|
||||||
pub mod log;
|
pub mod log;
|
||||||
|
|
|
@ -116,7 +116,7 @@ if [[ ! -f rust-bpf-$machine-$version.md ]]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Install Rust-BPF Sysroot sources
|
# Install Rust-BPF Sysroot sources
|
||||||
version=v0.8
|
version=v0.9
|
||||||
if [[ ! -f rust-bpf-sysroot-$version.md ]]; then
|
if [[ ! -f rust-bpf-sysroot-$version.md ]]; then
|
||||||
(
|
(
|
||||||
set -ex
|
set -ex
|
||||||
|
@ -134,4 +134,23 @@ if [[ ! -f rust-bpf-sysroot-$version.md ]]; then
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Install custom Hashbrown crate needed by Rust-BPF Sysroot
|
||||||
|
version=v0.1
|
||||||
|
if [[ ! -f hashbrown-$version.md ]]; then
|
||||||
|
(
|
||||||
|
set -ex
|
||||||
|
rm -rf hashbrown*
|
||||||
|
rm -rf xargo
|
||||||
|
cmd="git clone --recursive --single-branch --branch $version https://github.com/solana-labs/hashbrown.git"
|
||||||
|
$cmd
|
||||||
|
|
||||||
|
echo "$cmd" > hashbrown-$version.md
|
||||||
|
)
|
||||||
|
exitcode=$?
|
||||||
|
if [[ $exitcode -ne 0 ]]; then
|
||||||
|
rm -rf hashbrown
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
|
Loading…
Reference in New Issue