From 38adfc994ab473bfb352f57680ee5917297f7ea1 Mon Sep 17 00:00:00 2001 From: crStiv Date: Sat, 11 Jan 2025 10:46:37 +0100 Subject: [PATCH 1/4] Update poseidon.rs --- crates/host/src/host/hash_helper/poseidon.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/host/src/host/hash_helper/poseidon.rs b/crates/host/src/host/hash_helper/poseidon.rs index e54532d2..53ae2458 100644 --- a/crates/host/src/host/hash_helper/poseidon.rs +++ b/crates/host/src/host/hash_helper/poseidon.rs @@ -19,7 +19,7 @@ use zkwasm_host_circuits::host::ForeignInst::PoseidonFinalize; use zkwasm_host_circuits::host::ForeignInst::PoseidonNew; use zkwasm_host_circuits::host::ForeignInst::PoseidonPush; -/// Foreign functions that supports the following C code library +/// Foreign functions that support the following C code library /// /// void poseidon(uint64_t* data, uint32_t size, uint64_t* r) /// { From 30fc5455e4db0ce768bc70ae40aed0400e5a1ac6 Mon Sep 17 00:00:00 2001 From: crStiv Date: Sat, 11 Jan 2025 10:46:59 +0100 Subject: [PATCH 2/4] Update sha256.rs --- crates/host/src/host/hash_helper/sha256.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/host/src/host/hash_helper/sha256.rs b/crates/host/src/host/hash_helper/sha256.rs index 9bba1cab..2a8d754f 100644 --- a/crates/host/src/host/hash_helper/sha256.rs +++ b/crates/host/src/host/hash_helper/sha256.rs @@ -9,7 +9,7 @@ use zkwasm_host_circuits::host::ForeignInst::SHA256Push; use sha2::Sha256; -/// Foreign functions that supports the following C code library +/// Foreign functions that support the following C code library /// /// void sha256(uint8_t* data, uint32_t size, uint64_t* r) /// { From 9346d9fda87de42f56bc86d919b53fd555c5420b Mon Sep 17 00:00:00 2001 From: crStiv Date: Sat, 11 Jan 2025 15:50:05 +0100 Subject: [PATCH 3/4] Update phantom.c --- crates/playground/c/phantom.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/crates/playground/c/phantom.c b/crates/playground/c/phantom.c index 6148bf88..015d6e4e 100644 --- a/crates/playground/c/phantom.c +++ b/crates/playground/c/phantom.c @@ -2,9 +2,9 @@ #include "foreign.h" /* - * An example of phantom function which will not generate any traces. + * An example of a phantom function that will not generate any traces. * - * To make the phantom function works, you should make sure the function + * To make the phantom function work, you should make sure the function * not to be inlined. * * Since the phantom function will not produce any traces, memory/global From 448298a758dbccfee8e5fbc263033e14a2edbf53 Mon Sep 17 00:00:00 2001 From: crStiv Date: Sat, 11 Jan 2025 16:05:09 +0100 Subject: [PATCH 4/4] Update README.md --- README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 054c1cef..eab7de37 100644 --- a/README.md +++ b/README.md @@ -10,7 +10,7 @@ The mission of DelphiusLab is to provide Web2 developers with a concise toolset to leverage the power of Web3 in their applications. The ZKWASM (ZKSNARK virtual machine that supports Web Assembly) serves as a trustless layer between rich applications running on WASM runtime and smart contracts on chain. -WASM (or WebAssembly) is an open standard binary code format similar to assembly. Its initial objective was to provide an alternative to java-script with improved performance for the current web ecosystem. Benefiting from its platform independence, front-end flexibility (can be compiled from the majority of languages including C, C++, assembly script, rust, etc.), good isolated runtime and speed comes closer to the speed of a native binary, its usage is arising in distributed cloud and edge computing. Recently it has become a popular binary format for users to run customized functions on AWS Lambda, Open Yurt, AZURE, etc. +WASM (or WebAssembly) is an open standard binary code format similar to assembly. Its initial objective was to provide an alternative to java-script with improved performance for the current web ecosystem. Benefiting from its platform independence, front-end flexibility (can be compiled from the majority of languages including C, C++, assembly script, rust, etc.), good isolated runtime and speed comes closer to the speed of a native binary, its usage is rising in distributed cloud and edge computing. Recently it has become a popular binary format for users to run customized functions on AWS Lambda, Open Yurt, AZURE, etc. The idea of ZKWASM is derived from ZKSNARK (Zero-Knowledge Succinct Non-Interactive Argument of Knowledge) which is a combination of SNARG (Succinct non-interactive arguments) and zero-knowledge proof. In general, the adoption of ZKSNARK usually requires implementing a program in arithmetic circuits or circuit-friendly languages (Pinocchio, TinyRAM, Buffet/Pequin, Geppetto, xJsnark framework, ZoKrates) that forms a barrier for existing programs to leverage its power. An alternative approach is, instead of applying ZKSNARK on the source code, applying it on the bytecode level of a virtual machine and implementing a zksnark-backed virtual machine. In this work, we take the approach of writing the whole WASM virtual machine in ZKSNARK circuits so that existing WASM applications can benefit from ZKSNARK by simply running on the ZKWASM, without any modification. Therefore, the cloud service provider can prove to any user that the computation result is computed honestly and no private information is leaked. @@ -132,7 +132,7 @@ We use z3 (https://github.com/Z3Prover/z3) to check that all operations are comp # Issue tracking: -- chore: non-feature requirements such as CI/CD, building script or work flow enhancement. +- chore: non-feature requirements such as CI/CD, building script or workflow enhancement. - feat: feature need, we could use feat(circuit), feat(lang), feat(CLI) to categorize features - bug: bug report, we also could use bug(circuit), bug(lang) to categorize bugs - doc: documents related issues. @@ -142,4 +142,4 @@ We use z3 (https://github.com/Z3Prover/z3) to check that all operations are comp - C project: There is a project template for compiling C to wasm with limited host functions (foreign circuits). (see https://github.com/DelphinusLab/zkWasm-C) - Rust project demo: https://github.com/xgaozoyoe/zkWasm-Rust-Demo - Assembly script demo: https://github.com/DelphinusLab/zkWasm-AssemblyScript-Demo -- Browser based project: See https://github.com/zkcrossteam/g1024/ for how to utilize zkWASM in javascript, how to generate proofs using PAAS service and verify it on chain (contact xgao@zoyoe.com for details about PAAS testnet). +- Browser-based project: See https://github.com/zkcrossteam/g1024/ for how to utilize zkWASM in javascript, how to generate proofs using PAAS service and verify it on chain (contact xgao@zoyoe.com for details about PAAS testnet).