From d682769b2e223070ff194d6c62f0c4f37f42437e Mon Sep 17 00:00:00 2001 From: Hamy Ratoanina Date: Fri, 1 Dec 2023 19:12:59 -0500 Subject: [PATCH] Fix set_context constraints (#1401) * Fix set_context constraints * Apply comment --- evm/src/cpu/contextops.rs | 48 +++++++++++++++++++++++++-------------- 1 file changed, 31 insertions(+), 17 deletions(-) diff --git a/evm/src/cpu/contextops.rs b/evm/src/cpu/contextops.rs index bdcd77fc50..9f62ade0c7 100644 --- a/evm/src/cpu/contextops.rs +++ b/evm/src/cpu/contextops.rs @@ -163,11 +163,14 @@ fn eval_packed_set( // The next row's context is read from stack_top. yield_constr.constraint(filter * (stack_top[0] - nv.context)); + for &limb in &stack_top[1..] { + yield_constr.constraint(filter * limb); + } // The old SP is decremented (since the new context was popped) and written to memory. yield_constr.constraint(filter * (write_old_sp_channel.value[0] - local_sp_dec)); - for limb in &write_old_sp_channel.value[1..] { - yield_constr.constraint(filter * *limb); + for &limb in &write_old_sp_channel.value[1..] { + yield_constr.constraint(filter * limb); } yield_constr.constraint(filter * (write_old_sp_channel.used - P::ONES)); yield_constr.constraint(filter * write_old_sp_channel.is_read); @@ -177,6 +180,9 @@ fn eval_packed_set( // The new SP is loaded from memory. yield_constr.constraint(filter * (read_new_sp_channel.value[0] - nv.stack_len)); + for &limb in &read_new_sp_channel.value[1..] { + yield_constr.constraint(filter * limb); + } yield_constr.constraint(filter * (read_new_sp_channel.used - P::ONES)); yield_constr.constraint(filter * (read_new_sp_channel.is_read - P::ONES)); yield_constr.constraint(filter * (read_new_sp_channel.addr_context - nv.context)); @@ -191,13 +197,14 @@ fn eval_packed_set( - lv.general.stack().stack_inv_aux_2), ); // The new top is loaded in memory channel 3, if the stack isn't empty (see eval_packed). - yield_constr.constraint( - lv.op.context_op - * lv.general.stack().stack_inv_aux_2 - * (lv.mem_channels[3].value[0] - new_top_channel.value[0]), - ); - for &limb in &new_top_channel.value[1..] { - yield_constr.constraint(lv.op.context_op * lv.general.stack().stack_inv_aux_2 * limb); + for (&limb_new_top, &limb_read_top) in new_top_channel + .value + .iter() + .zip(lv.mem_channels[3].value.iter()) + { + yield_constr.constraint( + lv.op.context_op * lv.general.stack().stack_inv_aux_2 * (limb_new_top - limb_read_top), + ); } yield_constr.constraint(filter * new_top_channel.used); @@ -230,6 +237,10 @@ fn eval_ext_circuit_set, const D: usize>( let constr = builder.mul_extension(filter, diff); yield_constr.constraint(builder, constr); } + for &limb in &stack_top[1..] { + let constr = builder.mul_extension(filter, limb); + yield_constr.constraint(builder, constr); + } // The old SP is decremented (since the new context was popped) and written to memory. { @@ -237,8 +248,8 @@ fn eval_ext_circuit_set, const D: usize>( let constr = builder.mul_extension(filter, diff); yield_constr.constraint(builder, constr); } - for limb in &write_old_sp_channel.value[1..] { - let constr = builder.mul_extension(filter, *limb); + for &limb in &write_old_sp_channel.value[1..] { + let constr = builder.mul_extension(filter, limb); yield_constr.constraint(builder, constr); } { @@ -271,6 +282,10 @@ fn eval_ext_circuit_set, const D: usize>( let constr = builder.mul_extension(filter, diff); yield_constr.constraint(builder, constr); } + for &limb in &read_new_sp_channel.value[1..] { + let constr = builder.mul_extension(filter, limb); + yield_constr.constraint(builder, constr); + } { let constr = builder.mul_sub_extension(filter, read_new_sp_channel.used, filter); yield_constr.constraint(builder, constr); @@ -307,17 +322,16 @@ fn eval_ext_circuit_set, const D: usize>( yield_constr.constraint(builder, constr); } // The new top is loaded in memory channel 3, if the stack isn't empty (see eval_packed). + for (&limb_new_top, &limb_read_top) in new_top_channel + .value + .iter() + .zip(lv.mem_channels[3].value.iter()) { - let diff = builder.sub_extension(lv.mem_channels[3].value[0], new_top_channel.value[0]); + let diff = builder.sub_extension(limb_new_top, limb_read_top); let prod = builder.mul_extension(lv.general.stack().stack_inv_aux_2, diff); let constr = builder.mul_extension(lv.op.context_op, prod); yield_constr.constraint(builder, constr); } - for &limb in &new_top_channel.value[1..] { - let prod = builder.mul_extension(lv.general.stack().stack_inv_aux_2, limb); - let constr = builder.mul_extension(lv.op.context_op, prod); - yield_constr.constraint(builder, constr); - } { let constr = builder.mul_extension(filter, new_top_channel.used);