Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add versioning to mainnet update 2.5 #4711

Draft
wants to merge 86 commits into
base: mainnet_2_3
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
6c3858c
Asc message execution - requery message bytecode after each message e…
Leo-Besancon Jun 18, 2024
c316e44
Create MIP "MIP-0001-ASC-BugFix"
Leo-Besancon Jun 18, 2024
ab29c86
Add versioning to asc execution context
Leo-Besancon Jun 18, 2024
93b2b3b
Asc message execution - requery message bytecode after each message e…
Leo-Besancon Jun 18, 2024
ca5eaf2
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Jun 18, 2024
b5c548c
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Jul 17, 2024
a7cc744
Improve versioning
Leo-Besancon Jul 18, 2024
4f89e6a
fmt
Leo-Besancon Jul 18, 2024
f581540
Update ci.yml
Leo-Besancon Jul 18, 2024
72bd77c
Add ledger changes versioning
Leo-Besancon Jul 18, 2024
44a1874
Add runtime module versioning
Leo-Besancon Jul 18, 2024
59a5052
Add send_message versioning
Leo-Besancon Jul 18, 2024
361427f
Add address category versioning
Leo-Besancon Jul 18, 2024
99d8abe
Add Fix eliminated msg versioning
Leo-Besancon Jul 18, 2024
5df2700
add versioning test-exports mip
Leo-Besancon Jul 23, 2024
f848daa
fmt
Leo-Besancon Jul 23, 2024
9ea25d4
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Aug 1, 2024
5aa1fb8
Add ledger delete_entry versioning
Leo-Besancon Aug 1, 2024
0eb5ffc
Add versioning for Consistent expiry period
Leo-Besancon Aug 1, 2024
462caa7
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Aug 1, 2024
d1224b4
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Aug 1, 2024
6b19df6
Update speculative_async_pool.rs
Leo-Besancon Aug 1, 2024
8de2a7d
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Aug 1, 2024
f78ee71
Add versioning to fees fix
Leo-Besancon Aug 1, 2024
a4da3c5
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Aug 2, 2024
4ca00b0
Add versioning for Fix amount remaining to slash 2
Leo-Besancon Aug 2, 2024
133af5a
Fix conflict
Leo-Besancon Aug 2, 2024
de4bf07
Add versioning for LedgerChanges::Delete
Leo-Besancon Aug 2, 2024
15fe3ea
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Nov 7, 2024
f6d2f97
cargo fmt + check pass
Leo-Besancon Nov 7, 2024
641b99e
Add Condom Middleware versioning
Leo-Besancon Nov 7, 2024
9ddf5ae
fmt
Leo-Besancon Nov 7, 2024
d40efaa
Add versioning to max_recursive_calls_depth
Leo-Besancon Nov 7, 2024
7ed039a
Fix deadlock
Leo-Besancon Nov 7, 2024
84c0e4c
Add versioning to Fix potential ledger keys boundaries issue
Leo-Besancon Nov 8, 2024
fd98eda
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Nov 15, 2024
3f1262b
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Nov 15, 2024
1acd921
Add versioning to gas costs
Leo-Besancon Nov 15, 2024
a02f301
Add versioning to Add additional verification for v & s value in evm_…
Leo-Besancon Nov 15, 2024
8468653
Update runtime dep
Leo-Besancon Nov 15, 2024
56c53ad
Add comment relative to versioning of Update executed denunciations i…
Leo-Besancon Nov 15, 2024
a862f23
Add versioning to Limit event msg size & event number per operation
Leo-Besancon Nov 15, 2024
706d558
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Nov 15, 2024
d3c3bf0
Fix versioning for interface implementation tests
Leo-Besancon Nov 15, 2024
315b850
Fix test for max_event size
Leo-Besancon Nov 15, 2024
ce0e14b
Add versioning to Early set operation id
Leo-Besancon Nov 19, 2024
9e2d0e5
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Nov 22, 2024
82ed837
Review comment: propagate error message and better match
Leo-Besancon Nov 28, 2024
95b720d
Review comment: clean out match
Leo-Besancon Nov 28, 2024
fb37498
Review comment: Add helper function to query versioned condom_limits …
Leo-Besancon Nov 28, 2024
43d23d1
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Nov 28, 2024
b3e9ba5
Add comment
Leo-Besancon Nov 28, 2024
907b86f
Add dummy info for MIP_info
Leo-Besancon Nov 28, 2024
c46bf0c
Change .unwrap() to .expect() for get_block_timestamp
Leo-Besancon Dec 4, 2024
8b54a5e
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Dec 4, 2024
fa099d0
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
modship Dec 4, 2024
6b03ad8
Disable deferred calls abi if exec_comp = 0
modship Dec 5, 2024
2c38062
deferred calls const gas cost
modship Dec 9, 2024
cb30010
Add versioning for fix async message updates and add unit test
Leo-Besancon Dec 10, 2024
820ed1e
Api : deferred call endpoint versioning
modship Dec 11, 2024
fc07bc5
Metrics: add network version metrics
modship Dec 12, 2024
ef95780
fix empty help msg
modship Dec 12, 2024
37edce7
Rollback deferred calls abi bail
modship Dec 16, 2024
eeda2f5
update runtime
modship Dec 16, 2024
faa8521
Allow transfers to SC addresses (#4789)
Leo-Besancon Dec 16, 2024
09cda31
Add versioning to Allow transfers to SC addresses
Leo-Besancon Dec 16, 2024
c90ede1
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Dec 16, 2024
5ede1f1
Use coherent PublicKeyFormat in parse_slice (#4783)
sydhds Dec 16, 2024
8efc3fc
Fix incorrect address hashing + add TU for evm_get_address_from_pubke…
sydhds Dec 16, 2024
95eefb4
Add versioning to Use coherent PublicKeyFormat in parse_slice
Leo-Besancon Dec 16, 2024
5060ba4
Add versioning for Fix incorrect address hashing
Leo-Besancon Dec 16, 2024
47bfefd
cargo fmt + check
Leo-Besancon Dec 16, 2024
ee65688
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Dec 16, 2024
647f24b
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Dec 19, 2024
500a8e4
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Dec 19, 2024
47aee0c
Add versioning to massa event cache
Leo-Besancon Dec 19, 2024
27ca46c
Fix versioning of massa event cache
Leo-Besancon Dec 19, 2024
39698eb
Reset cache if version becomes active (#4791)
Leo-Besancon Dec 30, 2024
514ce26
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Dec 30, 2024
ce2b35d
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Dec 30, 2024
dee7e28
In HD DB reset(), Do not panic if fails to destroy HD cache
Leo-Besancon Dec 30, 2024
b2018c4
Fix async message execution order in slot with no active version (#4799)
Leo-Besancon Dec 31, 2024
582869d
current_mip_version to get_status (#4803)
modship Jan 3, 2025
f935f47
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Jan 6, 2025
fa9acda
Fix versioned TU
Leo-Besancon Jan 6, 2025
1e4b911
Merge branch 'mainnet_2_3' into mainnet_2_3_versioning_mip
Leo-Besancon Jan 10, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 19 additions & 1 deletion massa-execution-worker/src/context.rs
Original file line number Diff line number Diff line change
Expand Up @@ -360,10 +360,16 @@ impl ExecutionContext {
/// A vector of `(Option<Bytecode>, AsyncMessage)` pairs where:
/// * `Option<Bytecode>` is the bytecode to execute (or `None` if not found)
/// * `AsyncMessage` is the asynchronous message to execute
pub(crate) fn take_async_batch(
pub(crate) fn take_async_batch_v0(
&mut self,
max_gas: u64,
async_msg_cst_gas_cost: u64,
) -> Vec<(AsyncMessageId, AsyncMessage)> {
self.speculative_async_pool.take_batch_to_execute(
self.slot,
max_gas,
async_msg_cst_gas_cost,
)
) -> Vec<(Option<Bytecode>, AsyncMessage)> {
self.speculative_async_pool
.take_batch_to_execute(self.slot, max_gas, async_msg_cst_gas_cost)
Expand All @@ -372,6 +378,18 @@ impl ExecutionContext {
.collect()
}

pub(crate) fn take_async_batch_v1(
&mut self,
max_gas: u64,
async_msg_cst_gas_cost: u64
) -> Vec<(AsyncMessageId, AsyncMessage)> {
self.speculative_async_pool.take_batch_to_execute(
self.slot,
max_gas,
async_msg_cst_gas_cost,
)
}

/// Create a new `ExecutionContext` for executing an active slot.
/// This should be used before performing any executions at that slot.
///
Expand Down
109 changes: 82 additions & 27 deletions massa-execution-worker/src/execution.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ use massa_module_cache::config::ModuleCacheConfig;
use massa_module_cache::controller::ModuleCache;
use massa_pos_exports::SelectorController;
use massa_sc_runtime::{Interface, Response, VMError};
use massa_versioning::versioning::MipStore;
use massa_versioning::versioning::{MipComponent, MipStore};
use massa_wallet::Wallet;
use parking_lot::{Mutex, RwLock};
use std::collections::{BTreeMap, BTreeSet};
Expand Down Expand Up @@ -1104,7 +1104,9 @@ impl ExecutionState {
&self,
message: AsyncMessage,
bytecode: Option<Bytecode>,
asc_execution_version: u32
) -> Result<AsyncMessageExecutionResult, ExecutionError> {

let mut result = AsyncMessageExecutionResult::new();
#[cfg(feature = "execution-info")]
{
Expand All @@ -1123,7 +1125,10 @@ impl ExecutionState {
context.stack = vec![
ExecutionStackElement {
address: message.sender,
coins: message.coins,
coins: match asc_execution_version {
0 => message.coins,
_ => Default::default()
},
owned_addresses: vec![message.sender],
operation_datastore: None,
},
Expand Down Expand Up @@ -1260,35 +1265,85 @@ impl ExecutionState {
self.mip_store.clone(),
);

// Get asynchronous messages to execute
let messages = execution_context.take_async_batch(
self.config.max_async_gas,
self.config.async_msg_cst_gas_cost,
);
let ts = get_block_slot_timestamp(
self.config.thread_count,
self.config.t0,
self.config.genesis_timestamp,
self.final_cursor,
)
.unwrap();
Leo-Besancon marked this conversation as resolved.
Show resolved Hide resolved

let asc_execution_version = self.final_state.read().get_mip_store().get_latest_component_version_at(&MipComponent::AscExecution, ts);

match asc_execution_version {
0 => {
// Get asynchronous messages to execute
let messages = execution_context.take_async_batch_v0(
self.config.max_async_gas,
self.config.async_msg_cst_gas_cost
);

// Apply the created execution context for slot execution
*context_guard!(self) = execution_context;

// Try executing asynchronous messages.
// Effects are cancelled on failure and the sender is reimbursed.
for (opt_bytecode, message) in messages {
match self.execute_async_message(message, opt_bytecode) {
Ok(_message_return) => {
cfg_if::cfg_if! {
if #[cfg(feature = "execution-trace")] {
// Safe to unwrap
slot_trace.asc_call_stacks.push(_message_return.traces.unwrap().0);
} else if #[cfg(feature = "execution-info")] {
slot_trace.asc_call_stacks.push(_message_return.traces.clone().unwrap().0);
exec_info.async_messages.push(Ok(_message_return));
// Apply the created execution context for slot execution
*context_guard!(self) = execution_context;

// Try executing asynchronous messages.
// Effects are cancelled on failure and the sender is reimbursed.
for (opt_bytecode, message) in messages {
match self.execute_async_message(message, opt_bytecode, asc_execution_version) {
Ok(_message_return) => {
cfg_if::cfg_if! {
if #[cfg(feature = "execution-trace")] {
// Safe to unwrap
slot_trace.asc_call_stacks.push(_message_return.traces.unwrap().0);
} else if #[cfg(feature = "execution-info")] {
slot_trace.asc_call_stacks.push(_message_return.traces.clone().unwrap().0);
exec_info.async_messages.push(Ok(_message_return));
}
}
}
Err(err) => {
let msg = format!("failed executing async message: {}", err);
#[cfg(feature = "execution-info")]
exec_info.async_messages.push(Err(msg.clone()));
debug!(msg);
}
}
}
Err(err) => {
let msg = format!("failed executing async message: {}", err);
#[cfg(feature = "execution-info")]
exec_info.async_messages.push(Err(msg.clone()));
debug!(msg);
},
_ => {
// Get asynchronous messages to execute
let messages = execution_context.take_async_batch_v1(
self.config.max_async_gas,
self.config.async_msg_cst_gas_cost
);

// Apply the created execution context for slot execution
*context_guard!(self) = execution_context;

// Try executing asynchronous messages.
// Effects are cancelled on failure and the sender is reimbursed.
for (_message_id, message) in messages {
let opt_bytecode = context_guard!(self).get_bytecode(&message.destination);

match self.execute_async_message(message, opt_bytecode, asc_execution_version) {
Ok(_message_return) => {
cfg_if::cfg_if! {
if #[cfg(feature = "execution-trace")] {
// Safe to unwrap
slot_trace.asc_call_stacks.push(_message_return.traces.unwrap().0);
} else if #[cfg(feature = "execution-info")] {
slot_trace.asc_call_stacks.push(_message_return.traces.clone().unwrap().0);
exec_info.async_messages.push(Ok(_message_return));
}
}
}
Err(err) => {
let msg = format!("failed executing async message: {}", err);
#[cfg(feature = "execution-info")]
exec_info.async_messages.push(Err(msg.clone()));
debug!(msg);
}
}
}
}
}
Expand Down
28 changes: 12 additions & 16 deletions massa-versioning/src/mips.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,23 +7,19 @@ use massa_time::MassaTime;
#[allow(unused_imports)]
use crate::versioning::{MipComponent, MipInfo, MipState};

pub fn get_mip_list() -> [(MipInfo, MipState); 0] {
// placeholder
pub fn get_mip_list() -> [(MipInfo, MipState); 1] {
let mip_list = [
/*
(MipInfo {
name: "MIP-0000".to_string(),
version: 0,
components: BTreeMap::from([
(MipComponent::Address, 0),
(MipComponent::KeyPair, 0),
]),
start: MassaTime::from_millis(0),
timeout: MassaTime::from_millis(0),
activation_delay: MassaTime::from_millis(0),
},
MipState::new(MassaTime::from_millis(0)))
*/
(
MipInfo {
name: "MIP-0001-ASC-BugFix".to_string(),
version: 1,
components: BTreeMap::from([(MipComponent::AscExecution, 1)]),
start: MassaTime::from_millis(0), // TODO: set when known, ex: MassaTime::from_utc_ymd_hms(2024, 7, 10, 15, 0, 0).unwrap();
timeout: MassaTime::from_millis(0), // TODO: set when known
activation_delay: MassaTime::from_millis(3 * 24 * 60 * 60 * 1000), // TODO: set when known, 3 days as an example
},
MipState::new(MassaTime::from_millis(0)),
), // TODO: set when known, (when the MIP becomes defined, e.g. when merged to main branch)
];

// debug!("MIP list: {:?}", mip_list);
Expand Down
1 change: 1 addition & 0 deletions massa-versioning/src/versioning.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ pub enum MipComponent {
Block,
VM,
FinalStateHashKind,
AscExecution,
#[doc(hidden)]
#[num_enum(default)]
__Nonexhaustive,
Expand Down