Skip to content

Commit

Permalink
Merge pull request #1557 from 0xPolygonMiden/plafer-fix-block-stack-t…
Browse files Browse the repository at this point in the history
…able

Fix block stack table
  • Loading branch information
plafer authored Oct 31, 2024
2 parents 34ea043 + a30bc62 commit 766292d
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 17 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@

- Fixed an issue with formatting of blocks in Miden Assembly syntax
- Fixed the construction of the block hash table (#1506)
- Fixed a bug in the block stack table (#1511) (#1512)
- Fixed a bug in the block stack table (#1511) (#1512) (#1557)
- Fixed the construction of the chiplets virtual table (#1514) (#1556)
- Fixed the construction of the chiplets bus (#1516) (#1525)
- Decorators are now allowed in empty basic blocks (#1466)
Expand Down
47 changes: 31 additions & 16 deletions processor/src/decoder/aux_trace/block_stack_table.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,8 @@ impl<E: FieldElement<BaseField = Felt>> AuxColumnBuilder<E> for BlockStackColumn
let op_code = op_code_felt.as_int() as u8;

match op_code {
OPCODE_RESPAN => {
get_block_stack_table_removal_multiplicand(main_trace, i, true, alphas)
},
OPCODE_END => get_block_stack_table_removal_multiplicand(main_trace, i, false, alphas),
OPCODE_RESPAN => get_block_stack_table_respan_multiplicand(main_trace, i, alphas),
OPCODE_END => get_block_stack_table_end_multiplicand(main_trace, i, alphas),
_ => E::ONE,
}
}
Expand All @@ -47,19 +45,37 @@ impl<E: FieldElement<BaseField = Felt>> AuxColumnBuilder<E> for BlockStackColumn
// HELPER FUNCTIONS
// ================================================================================================

/// Computes the multiplicand representing the removal of a row from the block stack table.
fn get_block_stack_table_removal_multiplicand<E: FieldElement<BaseField = Felt>>(
/// Computes the multiplicand representing the removal of a row from the block stack table when
/// encountering a RESPAN operation.
fn get_block_stack_table_respan_multiplicand<E: FieldElement<BaseField = Felt>>(
main_trace: &MainTrace,
i: RowIndex,
is_respan: bool,
alphas: &[E],
) -> E {
let block_id = main_trace.addr(i);
let (parent_id, is_loop) = if is_respan {
(main_trace.decoder_hasher_state_element(1, i + 1), ZERO)
} else {
(main_trace.addr(i + 1), main_trace.is_loop_flag(i))
};
let parent_id = main_trace.decoder_hasher_state_element(1, i + 1);
let is_loop = ZERO;

// Note: the last 8 elements are set to ZERO, so we omit them here.
let elements = [ONE, block_id, parent_id, is_loop];

let mut table_row = E::ZERO;
for (&alpha, &element) in alphas.iter().zip(elements.iter()) {
table_row += alpha.mul_base(element);
}
table_row
}

/// Computes the multiplicand representing the removal of a row from the block stack table when
/// encountering an END operation.
fn get_block_stack_table_end_multiplicand<E: FieldElement<BaseField = Felt>>(
main_trace: &MainTrace,
i: RowIndex,
alphas: &[E],
) -> E {
let block_id = main_trace.addr(i);
let parent_id = main_trace.addr(i + 1);
let is_loop = main_trace.is_loop_flag(i);

let elements = if main_trace.is_call_flag(i) == ONE || main_trace.is_syscall_flag(i) == ONE {
let parent_ctx = main_trace.ctx(i + 1);
Expand Down Expand Up @@ -91,12 +107,11 @@ fn get_block_stack_table_removal_multiplicand<E: FieldElement<BaseField = Felt>>
result
};

let mut value = E::ZERO;

let mut table_row = E::ZERO;
for (&alpha, &element) in alphas.iter().zip(elements.iter()) {
value += alpha.mul_base(element);
table_row += alpha.mul_base(element);
}
value
table_row
}

/// Computes the multiplicand representing the inclusion of a new row to the block stack table.
Expand Down
5 changes: 5 additions & 0 deletions processor/src/decoder/aux_trace/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,11 @@ impl AuxTraceBuilder {
let p2 = block_hash_column_builder.build_aux_column(main_trace, rand_elements);
let p3 = op_group_table_column_builder.build_aux_column(main_trace, rand_elements);

debug_assert_eq!(
*p1.last().unwrap(),
E::ONE,
"block stack table is not empty at the end of program execution"
);
debug_assert_eq!(
*p2.last().unwrap(),
E::ONE,
Expand Down

0 comments on commit 766292d

Please sign in to comment.