Skip to content

Commit

Permalink
Merge branch 'new_spawn' into new_spawn_mohanson
Browse files Browse the repository at this point in the history
  • Loading branch information
mohanson authored Mar 12, 2024
2 parents 84d9b96 + 0481dec commit cfdf2bb
Show file tree
Hide file tree
Showing 6 changed files with 41 additions and 3 deletions.
14 changes: 13 additions & 1 deletion script/src/v2_scheduler.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ use std::{
};

const ROOT_VM_ID: VmId = FIRST_VM_ID;
const MAX_VMS_COUNT: u64 = 16;
const MAX_INSTANTIATED_VMS: usize = 4;

/// A single Scheduler instance is used to verify a single script
Expand All @@ -53,6 +54,7 @@ where
script_version: ScriptVersion,
syscalls_generator: TransactionScriptsSyscallsGenerator<DL>,

max_vms_count: u64,
total_cycles: Cycle,
next_vm_id: VmId,
next_pipe_slot: u64,
Expand Down Expand Up @@ -83,6 +85,7 @@ where
tx_data,
script_version,
syscalls_generator,
max_vms_count: MAX_VMS_COUNT,
total_cycles: 0,
next_vm_id: FIRST_VM_ID,
next_pipe_slot: FIRST_PIPE_SLOT,
Expand Down Expand Up @@ -112,6 +115,7 @@ where
tx_data,
script_version,
syscalls_generator,
max_vms_count: full.max_vms_count,
total_cycles: full.total_cycles,
next_vm_id: full.next_vm_id,
next_pipe_slot: full.next_pipe_slot,
Expand All @@ -135,6 +139,7 @@ where

/// Suspend current scheduler into a serializable full state
pub fn suspend(mut self) -> Result<FullSuspendedState, Error> {
assert!(self.message_box.lock().expect("lock").is_empty());
let mut vms = Vec::with_capacity(self.states.len());
let instantiated_ids: Vec<_> = self.instantiated.keys().cloned().collect();
for id in instantiated_ids {
Expand All @@ -145,6 +150,7 @@ where
vms.push((id, state, snapshot));
}
Ok(FullSuspendedState {
max_vms_count: self.max_vms_count,
total_cycles: self.total_cycles,
next_vm_id: self.next_vm_id,
next_pipe_slot: self.next_pipe_slot,
Expand Down Expand Up @@ -313,7 +319,13 @@ where
if !pipes_valid {
continue;
}
// TODO: spawn limits
if self.suspended.len() + self.instantiated.len() > self.max_vms_count as usize
{
self.ensure_vms_instantiated(&[vm_id])?;
let (_, machine) = self.instantiated.get_mut(&vm_id).unwrap();
machine.machine.set_register(A0, MAX_VMS_SPAWNED as u64);
continue;
}
let spawned_vm_id =
self.boot_vm(&args.data_piece_id, args.offset, args.length, &args.argv)?;
// Move passed pipes from spawner to spawnee
Expand Down
2 changes: 1 addition & 1 deletion script/src/v2_syscalls.rs
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,4 @@ where
pub fn set_base_cycles(&mut self, base_cycles: u64) {
*self.base_cycles.lock().expect("lock") = base_cycles;
}
}
}
1 change: 1 addition & 0 deletions script/src/v2_types.rs
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,7 @@ impl TryFrom<(u64, u64, u64)> for DataPieceId {
/// fully recover the running environment with the full transaction environment.
#[derive(Clone, Debug)]
pub struct FullSuspendedState {
pub max_vms_count: u64,
pub total_cycles: Cycle,
pub next_vm_id: VmId,
pub next_pipe_slot: u64,
Expand Down
8 changes: 7 additions & 1 deletion script/src/verify/tests/ckb_latest/features_since_v2023.rs
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,12 @@ fn check_spawn_read_then_close() {
assert_eq!(result.is_ok(), SCRIPT_VERSION == ScriptVersion::V2);
}

#[test]
fn check_spawn_max_vms_count() {
let result = simple_spawn_test("testdata/spawn_cases", &[10]);
assert_eq!(result.is_ok(), SCRIPT_VERSION == ScriptVersion::V2);
}

#[test]
fn check_vm_version() {
let script_version = SCRIPT_VERSION;
Expand Down Expand Up @@ -348,7 +354,7 @@ fn check_spawn_recursive() {
let result = verifier.verify(script_version, &rtx, 70_000_000);
if script_version >= ScriptVersion::V2 {
let msg = result.unwrap_err().to_string();
assert!(msg.contains("ExceededMaximumCycles"))
assert!(msg.contains("error code 8"))
} else {
assert!(result.is_err())
}
Expand Down
Binary file modified script/testdata/spawn_cases
Binary file not shown.
19 changes: 19 additions & 0 deletions script/testdata/spawn_cases.c
Original file line number Diff line number Diff line change
Expand Up @@ -320,6 +320,20 @@ int child_read_then_close() {
return err;
}

int parent_max_vms_count() {
const char* argv[2] = {"", 0};
return simple_spawn_args(0, 1, argv);
}

int child_max_vms_count() {
const char* argv[2] = {"", 0};
int err = simple_spawn_args(0, 1, argv);
CHECK2(err == 0 || err == CKB_MAX_VMS_SPAWNED, -2);
err = 0;
exit:
return err;
}

int parent_entry(int case_id) {
int err = 0;
uint64_t pid = 0;
Expand All @@ -341,6 +355,9 @@ int parent_entry(int case_id) {
err = parent_inherited_fds_without_owner(&pid);
} else if (case_id == 9) {
err = parent_read_then_close(&pid);
} else if (case_id == 10) {
err = parent_max_vms_count(&pid);
return err;
} else {
CHECK2(false, -2);
}
Expand Down Expand Up @@ -373,6 +390,8 @@ int child_entry(int case_id) {
return 0;
} else if (case_id == 9) {
return child_read_then_close();
} else if (case_id == 10) {
return child_max_vms_count();
} else {
return -1;
}
Expand Down

0 comments on commit cfdf2bb

Please sign in to comment.