mirror of
https://github.com/logos-storage/plonky2.git
synced 2026-01-11 18:23:09 +00:00
39 lines
1.2 KiB
Rust
39 lines
1.2 KiB
Rust
mod eq_iszero;
|
|
mod not;
|
|
|
|
use plonky2::field::extension::Extendable;
|
|
use plonky2::field::packed::PackedField;
|
|
use plonky2::hash::hash_types::RichField;
|
|
use plonky2::iop::ext_target::ExtensionTarget;
|
|
|
|
use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer};
|
|
use crate::cpu::registers;
|
|
|
|
pub fn generate<F: RichField>(lv: &mut [F; registers::NUM_CPU_COLUMNS]) {
|
|
let cycle_filter = lv[registers::IS_CPU_CYCLE].to_canonical_u64();
|
|
if cycle_filter == 0 {
|
|
return;
|
|
}
|
|
assert_eq!(cycle_filter, 1);
|
|
|
|
not::generate(lv);
|
|
eq_iszero::generate(lv);
|
|
}
|
|
|
|
pub fn eval_packed<P: PackedField>(
|
|
lv: &[P; registers::NUM_CPU_COLUMNS],
|
|
yield_constr: &mut ConstraintConsumer<P>,
|
|
) {
|
|
not::eval_packed(lv, yield_constr);
|
|
eq_iszero::eval_packed(lv, yield_constr);
|
|
}
|
|
|
|
pub fn eval_ext_circuit<F: RichField + Extendable<D>, const D: usize>(
|
|
builder: &mut plonky2::plonk::circuit_builder::CircuitBuilder<F, D>,
|
|
lv: &[ExtensionTarget<D>; registers::NUM_CPU_COLUMNS],
|
|
yield_constr: &mut RecursiveConstraintConsumer<F, D>,
|
|
) {
|
|
not::eval_ext_circuit(builder, lv, yield_constr);
|
|
eq_iszero::eval_ext_circuit(builder, lv, yield_constr);
|
|
}
|