Specify loader when bootstrapping bpf programs (#11571)

This commit is contained in:
Jack May 2020-08-12 09:46:49 -07:00 committed by GitHub
parent f8221797c6
commit 0a94e7e7fa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 15 additions and 9 deletions

View File

@ -10,10 +10,11 @@ fetch_program() {
declare name=$1 declare name=$1
declare version=$2 declare version=$2
declare address=$3 declare address=$3
declare loader=$4
declare so=spl_$name-$version.so declare so=spl_$name-$version.so
genesis_args+=(--bpf-program "$address" "$so") genesis_args+=(--bpf-program "$address" "$loader" "$so")
if [[ -r $so ]]; then if [[ -r $so ]]; then
return return
@ -36,8 +37,8 @@ fetch_program() {
} }
fetch_program token 1.0.0 TokenSVp5gheXUvJ6jGWGeCsgPKgnE3YgdGKRVCMY9o fetch_program token 1.0.0 TokenSVp5gheXUvJ6jGWGeCsgPKgnE3YgdGKRVCMY9o BPFLoader1111111111111111111111111111111111
fetch_program memo 1.0.0 Memo1UhkJRfHyvLMcVucJwxXeuD728EqVDDwQDxFMNo fetch_program memo 1.0.0 Memo1UhkJRfHyvLMcVucJwxXeuD728EqVDDwQDxFMNo BPFLoader1111111111111111111111111111111111
echo "${genesis_args[@]}" > spl-genesis-args.sh echo "${genesis_args[@]}" > spl-genesis-args.sh

View File

@ -12,7 +12,7 @@ use solana_ledger::{
use solana_runtime::hardened_unpack::MAX_GENESIS_ARCHIVE_UNPACKED_SIZE; use solana_runtime::hardened_unpack::MAX_GENESIS_ARCHIVE_UNPACKED_SIZE;
use solana_sdk::{ use solana_sdk::{
account::Account, account::Account,
bpf_loader, clock, clock,
epoch_schedule::EpochSchedule, epoch_schedule::EpochSchedule,
fee_calculator::FeeRateGovernor, fee_calculator::FeeRateGovernor,
genesis_config::{GenesisConfig, OperatingMode}, genesis_config::{GenesisConfig, OperatingMode},
@ -353,7 +353,7 @@ fn main() -> Result<(), Box<dyn error::Error>> {
.long("bpf-program") .long("bpf-program")
.value_name("ADDRESS BPF_PROGRAM.SO") .value_name("ADDRESS BPF_PROGRAM.SO")
.takes_value(true) .takes_value(true)
.number_of_values(2) .number_of_values(3)
.multiple(true) .multiple(true)
.help("Install a BPF program at the given address"), .help("Install a BPF program at the given address"),
) )
@ -553,14 +553,19 @@ fn main() -> Result<(), Box<dyn error::Error>> {
if let Some(values) = matches.values_of("bpf_program") { if let Some(values) = matches.values_of("bpf_program") {
let values: Vec<&str> = values.collect::<Vec<_>>(); let values: Vec<&str> = values.collect::<Vec<_>>();
for address_program in values.chunks(2) { for address_loader_program in values.chunks(3) {
match address_program { match address_loader_program {
[address, program] => { [address, loader, program] => {
let address = address.parse::<Pubkey>().unwrap_or_else(|err| { let address = address.parse::<Pubkey>().unwrap_or_else(|err| {
eprintln!("Error: invalid address {}: {}", address, err); eprintln!("Error: invalid address {}: {}", address, err);
process::exit(1); process::exit(1);
}); });
let loader = loader.parse::<Pubkey>().unwrap_or_else(|err| {
eprintln!("Error: invalid loader {}: {}", loader, err);
process::exit(1);
});
let mut program_data = vec![]; let mut program_data = vec![];
File::open(program) File::open(program)
.and_then(|mut file| file.read_to_end(&mut program_data)) .and_then(|mut file| file.read_to_end(&mut program_data))
@ -574,7 +579,7 @@ fn main() -> Result<(), Box<dyn error::Error>> {
lamports: genesis_config.rent.minimum_balance(program_data.len()), lamports: genesis_config.rent.minimum_balance(program_data.len()),
data: program_data, data: program_data,
executable: true, executable: true,
owner: bpf_loader::id(), owner: loader,
rent_epoch: 0, rent_epoch: 0,
}, },
); );