Skip to content

Commit

Permalink
merge with master
Browse files Browse the repository at this point in the history
  • Loading branch information
hero78119 committed Oct 28, 2024
2 parents f98ca7e + 47f5572 commit c64e2d2
Show file tree
Hide file tree
Showing 33 changed files with 526 additions and 441 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,4 @@ target
log.txt
logs/
table_cache_dev_*
.DS_Store
36 changes: 6 additions & 30 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 1 addition & 5 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,11 +26,10 @@ version = "0.1.0"
[workspace.dependencies]
ark-std = "0.4"
cfg-if = "1.0"
const_env = "0.1"
criterion = { version = "0.5", features = ["html_reports"] }
crossbeam-channel = "0.5"
ff = "0.13"
goldilocks = { git = "https://github.com/zhenfeizhang/Goldilocks" }
goldilocks = { git = "https://github.com/hero78119/Goldilocks" }
itertools = "0.13"
paste = "1"
plonky2 = "0.2"
Expand All @@ -52,8 +51,5 @@ tracing = { version = "0.1", features = [
tracing-flame = "0.2"
tracing-subscriber = { version = "0.3", features = ["env-filter"] }

[patch."https://github.com/zhenfeizhang/Goldilocks"]
goldilocks = { git = "https://github.com/hero78119/Goldilocks" }

[profile.release]
lto = "thin"
3 changes: 0 additions & 3 deletions build.rs

This file was deleted.

22 changes: 0 additions & 22 deletions ceno_emul/src/rv32im.rs
Original file line number Diff line number Diff line change
Expand Up @@ -218,28 +218,6 @@ impl DecodedInstruction {
}
}

#[allow(dead_code)]
pub fn from_raw(kind: InsnKind, rs1: u32, rs2: u32, rd: u32) -> Self {
// limit the range of inputs
let rs2 = rs2 & 0x1f; // 5bits mask
let rs1 = rs1 & 0x1f;
let rd = rd & 0x1f;
let func7 = kind.codes().func7;
let func3 = kind.codes().func3;
let opcode = kind.codes().opcode;
let insn = func7 << 25 | rs2 << 20 | rs1 << 15 | func3 << 12 | rd << 7 | opcode;
Self {
insn,
top_bit: func7 | 0x80,
func7,
rs2,
rs1,
func3,
rd,
opcode,
}
}

pub fn encoded(&self) -> u32 {
self.insn
}
Expand Down
1 change: 0 additions & 1 deletion ceno_zkvm/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@ thread_local = "1.1"
[dev-dependencies]
base64 = "0.22"
cfg-if.workspace = true
const_env.workspace = true
criterion.workspace = true
pprof.workspace = true
serde_json.workspace = true
Expand Down
24 changes: 0 additions & 24 deletions ceno_zkvm/benches/riscv_add.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ use ceno_zkvm::{
scheme::prover::ZKVMProver,
structs::{ZKVMConstraintSystem, ZKVMFixedTraces},
};
use const_env::from_env;
use criterion::*;

use ceno_zkvm::scheme::constants::MAX_NUM_VARIABLES;
Expand Down Expand Up @@ -37,31 +36,9 @@ cfg_if::cfg_if! {
criterion_main!(op_add);

const NUM_SAMPLES: usize = 10;
#[from_env]
const RAYON_NUM_THREADS: usize = 8;

fn bench_add(c: &mut Criterion) {
type Pcs = BasefoldDefault<E>;
let max_threads = {
if !RAYON_NUM_THREADS.is_power_of_two() {
#[cfg(not(feature = "non_pow2_rayon_thread"))]
{
panic!(
"add --features non_pow2_rayon_thread to enable unsafe feature which support non pow of 2 rayon thread pool"
);
}

#[cfg(feature = "non_pow2_rayon_thread")]
{
use sumcheck::{local_thread_pool::create_local_pool_once, util::ceil_log2};
let max_thread_id = 1 << ceil_log2(RAYON_NUM_THREADS);
create_local_pool_once(1 << ceil_log2(RAYON_NUM_THREADS), true);
max_thread_id
}
} else {
RAYON_NUM_THREADS
}
};
let mut zkvm_cs = ZKVMConstraintSystem::default();
let _ = zkvm_cs.register_opcode_circuit::<AddInstruction<E>>();
let mut zkvm_fixed_traces = ZKVMFixedTraces::default();
Expand Down Expand Up @@ -128,7 +105,6 @@ fn bench_add(c: &mut Criterion) {
commit,
&[],
num_instances,
max_threads,
&mut transcript,
&challenges,
)
Expand Down
27 changes: 1 addition & 26 deletions ceno_zkvm/examples/riscv_opcodes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ use ceno_zkvm::{
},
};
use clap::Parser;
use const_env::from_env;

use ceno_emul::{
ByteAddr, CENO_PLATFORM, EmuContext,
Expand All @@ -31,9 +30,6 @@ use tracing_flame::FlameLayer;
use tracing_subscriber::{EnvFilter, Registry, fmt, layer::SubscriberExt};
use transcript::Transcript;

#[from_env]
const RAYON_NUM_THREADS: usize = 8;

const PROGRAM_SIZE: usize = 512;
// For now, we assume registers
// - x0 is not touched,
Expand Down Expand Up @@ -82,27 +78,6 @@ fn main() {
type E = GoldilocksExt2;
type Pcs = Basefold<GoldilocksExt2, BasefoldRSParams, ChaCha8Rng>;

let max_threads = {
if !RAYON_NUM_THREADS.is_power_of_two() {
#[cfg(not(feature = "non_pow2_rayon_thread"))]
{
panic!(
"add --features non_pow2_rayon_thread to enable unsafe feature which support non pow of 2 rayon thread pool"
);
}

#[cfg(feature = "non_pow2_rayon_thread")]
{
use sumcheck::{local_thread_pool::create_local_pool_once, util::ceil_log2};
let max_thread_id = 1 << ceil_log2(RAYON_NUM_THREADS);
create_local_pool_once(1 << ceil_log2(RAYON_NUM_THREADS), true);
max_thread_id
}
} else {
RAYON_NUM_THREADS
}
};

let (flame_layer, _guard) = FlameLayer::with_file("./tracing.folded").unwrap();
let subscriber = Registry::default()
.with(
Expand Down Expand Up @@ -287,7 +262,7 @@ fn main() {

let transcript = Transcript::new(b"riscv");
let mut zkvm_proof = prover
.create_proof(zkvm_witness, pi, max_threads, transcript)
.create_proof(zkvm_witness, pi, transcript)
.expect("create_proof failed");

println!(
Expand Down
8 changes: 7 additions & 1 deletion ceno_zkvm/src/chip_handler/general.rs
Original file line number Diff line number Diff line change
Expand Up @@ -173,7 +173,13 @@ impl<'a, E: ExtensionField> CircuitBuilder<'a, E> {
NR: Into<String>,
N: FnOnce() -> NR,
{
self.namespace(|| "require_equal", |cb| cb.cs.require_zero(name_fn, a - b))
self.namespace(
|| "require_equal",
|cb| {
cb.cs
.require_zero(name_fn, a.to_monomial_form() - b.to_monomial_form())
},
)
}

pub fn require_one<NR, N>(&mut self, name_fn: N, expr: Expression<E>) -> Result<(), ZKVMError>
Expand Down
20 changes: 3 additions & 17 deletions ceno_zkvm/src/expression.rs
Original file line number Diff line number Diff line change
Expand Up @@ -639,22 +639,6 @@ impl WitIn {
}
}

#[macro_export]
/// this is to avoid non-monomial expression
macro_rules! create_witin_from_expr {
// Handle the case for a single expression
($name:expr, $builder:expr, $debug:expr, $e:expr) => {
WitIn::from_expr($name, $builder, $e, $debug)
};
// Recursively handle multiple expressions and create a flat tuple with error handling
($name:expr, $builder:expr, $debug:expr, $e:expr, $($rest:expr),+) => {
{
// Return a Result tuple, handling errors
Ok::<_, ZKVMError>((WitIn::from_expr($name, $builder, $e, $debug)?, $(WitIn::from_expr($name, $builder, $rest)?),*))
}
};
}

pub trait ToExpr<E: ExtensionField> {
type Output;
fn expr(&self) -> Self::Output;
Expand Down Expand Up @@ -757,7 +741,9 @@ pub mod fmt {
) -> String {
match expression {
Expression::WitIn(wit_in) => {
wtns.push(*wit_in);
if !wtns.contains(wit_in) {
wtns.push(*wit_in);
}
format!("WitIn({})", wit_in)
}
Expression::Challenge(id, pow, scaler, offset) => {
Expand Down
25 changes: 17 additions & 8 deletions ceno_zkvm/src/gadgets/is_lt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -109,11 +109,23 @@ impl IsLtConfig {
lhs: u64,
rhs: u64,
) -> Result<(), ZKVMError> {
let is_lt = lhs < rhs;
set_val!(instance, self.is_lt, is_lt as u64);
set_val!(instance, self.is_lt, (lhs < rhs) as u64);
self.config.assign_instance(instance, lkm, lhs, rhs)?;
Ok(())
}

pub fn assign_instance_signed<F: SmallField>(
&self,
instance: &mut [MaybeUninit<F>],
lkm: &mut LkMultiplicity,
lhs: SWord,
rhs: SWord,
) -> Result<(), ZKVMError> {
set_val!(instance, self.is_lt, (lhs < rhs) as u64);
self.config
.assign_instance_signed(instance, lkm, lhs, rhs)?;
Ok(())
}
}

#[derive(Debug, Clone)]
Expand Down Expand Up @@ -337,12 +349,9 @@ impl InnerSignedLtConfig {
1,
)?;

// Convert two's complement representation into field arithmetic.
// Example: 0xFFFF_FFFF = 2^32 - 1 --> shift --> -1
let neg_shift = -Expression::Constant((1_u64 << 32).into());
let lhs_value = lhs.value() + is_lhs_neg.expr() * neg_shift.clone();
let rhs_value = rhs.value() + is_rhs_neg.expr() * neg_shift;

// Convert to field arithmetic.
let lhs_value = lhs.to_field_expr(is_lhs_neg.expr());
let rhs_value = rhs.to_field_expr(is_rhs_neg.expr());
let config = InnerLtConfig::construct_circuit(
cb,
format!("{name} (lhs < rhs)"),
Expand Down
3 changes: 3 additions & 0 deletions ceno_zkvm/src/instructions/riscv.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ pub mod mulh;
pub mod shift;
pub mod shift_imm;
pub mod slt;
pub mod slti;
pub mod sltu;

mod b_insn;
Expand All @@ -33,6 +34,8 @@ mod memory;
mod s_insn;
#[cfg(test)]
mod test;
#[cfg(test)]
mod test_utils;

pub trait RIVInstruction {
const INST_KIND: InsnKind;
Expand Down
Loading

0 comments on commit c64e2d2

Please sign in to comment.