Prevent stub inclusion when building shared objects (#10875)
This commit is contained in:
parent
2669ccb864
commit
52526a9bc2
|
@ -53,7 +53,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> u64 {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -85,7 +85,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> u64 {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -20,7 +20,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> u64 {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -201,4 +201,5 @@ fn process_instruction(
|
|||
Ok(())
|
||||
}
|
||||
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
|
|
@ -195,4 +195,5 @@ fn process_instruction(
|
|||
Ok(())
|
||||
}
|
||||
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
|
|
@ -21,7 +21,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> u64 {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -29,7 +29,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> u64 {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -51,7 +51,7 @@ pub fn many_args_sret(
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -67,7 +67,7 @@ fn process_instruction(
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -26,7 +26,7 @@ pub extern "C" fn entrypoint(_input: *mut u8) -> u64 {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -27,7 +27,7 @@ impl<'a> TestDep {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
// Pulls in the stubs required for `info!()`
|
||||
// Pull in syscall stubs when building for non-BPF targets
|
||||
solana_sdk::program_stubs!();
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
//! @brief Stubs for syscalls when building tests for x86
|
||||
//! @brief Syscall stubs when building for non-BPF targets
|
||||
|
||||
#[cfg(not(target_arch = "bpf"))]
|
||||
fn print_line_to_stdout(_message: &str) {
|
||||
#[cfg(not(feature = "program"))]
|
||||
{
|
||||
|
@ -11,6 +12,7 @@ fn print_line_to_stdout(_message: &str) {
|
|||
}
|
||||
}
|
||||
|
||||
#[cfg(not(target_arch = "bpf"))]
|
||||
#[no_mangle]
|
||||
/// # Safety
|
||||
pub unsafe fn sol_log_(message: *const u8, length: u64) {
|
||||
|
@ -19,11 +21,13 @@ pub unsafe fn sol_log_(message: *const u8, length: u64) {
|
|||
print_line_to_stdout(string);
|
||||
}
|
||||
|
||||
#[cfg(not(target_arch = "bpf"))]
|
||||
#[no_mangle]
|
||||
pub fn sol_log_64_(arg1: u64, arg2: u64, arg3: u64, arg4: u64, arg5: u64) {
|
||||
print_line_to_stdout(&format!("{} {} {} {} {}", arg1, arg2, arg3, arg4, arg5));
|
||||
}
|
||||
|
||||
#[cfg(not(target_arch = "bpf"))]
|
||||
#[no_mangle]
|
||||
pub fn sol_invoke_signed_rust() {
|
||||
print_line_to_stdout("sol_invoke_signed_rust()");
|
||||
|
@ -32,6 +36,7 @@ pub fn sol_invoke_signed_rust() {
|
|||
#[macro_export]
|
||||
macro_rules! program_stubs {
|
||||
() => {
|
||||
#[cfg(not(target_arch = "bpf"))]
|
||||
#[test]
|
||||
fn pull_in_externs() {
|
||||
use solana_sdk::program_stubs::{sol_invoke_signed_rust, sol_log_, sol_log_64_};
|
||||
|
|
Loading…
Reference in New Issue