Skip to content
This repository has been archived by the owner on Oct 31, 2023. It is now read-only.

feat!: Call backend via precompiled binaries #239

Merged
merged 91 commits into from
Aug 30, 2023
Merged
Changes from 1 commit
Commits
Show all changes
91 commits
Select commit Hold shift + click to select a range
10a90b6
wip
kevaundray Aug 17, 2023
1b8c9b0
modify comment
kevaundray Aug 18, 2023
01eede4
small cleanup of logic and more comments
kevaundray Aug 18, 2023
7caecec
chore: remove useless format
TomAFrench Aug 18, 2023
87a4091
chore: remove useless references
TomAFrench Aug 18, 2023
b137f07
chore: fix tests
TomAFrench Aug 18, 2023
b172a4d
change .json to .bytecode
kevaundray Aug 20, 2023
afcd80a
change path_to_json to `path_to_bytecode`
kevaundray Aug 20, 2023
652a091
modify interface implementation to accept the bytecode instead of the…
kevaundray Aug 20, 2023
08a2d24
cargo clippy
kevaundray Aug 20, 2023
a7ffab5
update cargo.toml
kevaundray Aug 20, 2023
c4741e9
return a u32 for gatesCommand
kevaundray Aug 20, 2023
e463e94
modify getCircuitSize
kevaundray Aug 20, 2023
97c5e77
make ContractCommand accessible
kevaundray Aug 20, 2023
a9a0ebf
make read_bytes and serialize_circuit pub(super)
kevaundray Aug 20, 2023
2c0c2f1
modify smart_contract trait impl
kevaundray Aug 20, 2023
a4fde90
small cleanup: add comments
kevaundray Aug 20, 2023
41981da
chore: prevent duplicate CRS
TomAFrench Aug 21, 2023
797cc46
chore: merge in master
TomAFrench Aug 21, 2023
2285e6a
Merge branch 'master' into kw/dyn-backends
TomAFrench Aug 21, 2023
72aca3f
chore: remove remainder of old `SmartContract` implementation
TomAFrench Aug 21, 2023
489b98f
fix: restore `contract.sol`
TomAFrench Aug 21, 2023
66b5ebc
chore: deal with clippy warnings
TomAFrench Aug 21, 2023
bc3681f
chore: download bb binary in `build.rs` script
TomAFrench Aug 21, 2023
e88c48c
chore: handle `is_recursive` better
TomAFrench Aug 21, 2023
033cd54
Update build.rs
kevaundray Aug 21, 2023
8f0014d
chore: remove preprocessing related code
TomAFrench Aug 22, 2023
65ef893
chore: stop tests from overwriting `contract.sol`
TomAFrench Aug 22, 2023
55a64e8
chore: remove unwanted printing to console
TomAFrench Aug 22, 2023
1ad7b73
chore: separate out different bb commands into files
TomAFrench Aug 22, 2023
23f14e7
chore: fix tests
TomAFrench Aug 22, 2023
9a32d70
chore: remove reliance on `NARGO_BINARIES_PATH` env var
TomAFrench Aug 22, 2023
f9b3404
chore: throw error if binary doesn't exist
TomAFrench Aug 22, 2023
c405e37
feat: download bb binaries at runtime
TomAFrench Aug 22, 2023
aea173d
chore: remove double-slash in url
TomAFrench Aug 22, 2023
27dd07d
chore: re-add test for `eth_contract_from_vk`
TomAFrench Aug 22, 2023
e77102e
chore: read verification library contract from stdout
TomAFrench Aug 22, 2023
238c8b8
chore: read proofs from stdout
TomAFrench Aug 22, 2023
5cac852
chore: push decision to read from stdout where possible down into `bb`
TomAFrench Aug 22, 2023
72ac103
chore: inline some functions
TomAFrench Aug 22, 2023
00c33ec
fix: re-add `Assignments` for wasm feature
TomAFrench Aug 23, 2023
d055b95
chore: remove dead-code
TomAFrench Aug 23, 2023
1e6be34
chore: make `barretenberg_structures` available to native
TomAFrench Aug 23, 2023
6050cdc
chore: fix compilation
TomAFrench Aug 23, 2023
054a789
fix: correctly ensure destination directory exists
TomAFrench Aug 23, 2023
e2fe3b3
chore: push temp nix debugging code
TomAFrench Aug 23, 2023
1b76110
chore: add extra inputs
TomAFrench Aug 23, 2023
f66c686
patch bb binary
kevaundray Aug 23, 2023
568692f
make patchelf only for linux
kevaundray Aug 23, 2023
48a53b4
add conditional statements for mac, so CI can show if there are any p…
kevaundray Aug 24, 2023
08c6c4e
chore: fix indentation
TomAFrench Aug 24, 2023
597ea71
chore: restore normal tests
TomAFrench Aug 24, 2023
a73a7e9
fix: include test inputs in sandbox
TomAFrench Aug 24, 2023
3caaeaa
fix: add necessary built inputs to wasm builds
TomAFrench Aug 24, 2023
c2f4204
chore: formatting changes
TomAFrench Aug 24, 2023
1d51b74
fix: revert to writing proofs to files
TomAFrench Aug 24, 2023
d76bc83
chore: use temp directories for test artifacts
TomAFrench Aug 25, 2023
d6cb1fe
chore: add test timeout
TomAFrench Aug 25, 2023
b56e6e3
chore: write contract to file
TomAFrench Aug 25, 2023
0e4b768
chore: be explicit about when to drop `temp_directory`
TomAFrench Aug 25, 2023
8d6d16f
chore: remove debugging code from `no_command_provided_works` test
TomAFrench Aug 25, 2023
0db655d
chore: maintain `temp_directory` when creating path
TomAFrench Aug 25, 2023
3c50783
chore: attach stderr to `CliShimError`
TomAFrench Aug 25, 2023
ab4af74
chore: be explicit about dropping the temp directory in `test_smart_c…
TomAFrench Aug 25, 2023
42d7bd7
chore: stop returning stdout output from `write_vk`
TomAFrench Aug 25, 2023
8131585
try large mac
kevaundray Aug 25, 2023
1f12c8a
Update .github/workflows/test.yml
kevaundray Aug 25, 2023
5e62425
sandbox issue?
kevaundray Aug 27, 2023
3bf6b82
use nix develop
kevaundray Aug 27, 2023
ddffd4d
chore: use WASM backend for blackbox functions exclusively and remove…
kevaundray Aug 28, 2023
2882490
Merge remote-tracking branch 'origin/master' into kw/dyn-backends
kevaundray Aug 28, 2023
1ec41f5
zipped path has been fixed
kevaundray Aug 28, 2023
fae8a73
now using version 0.4.4
kevaundray Aug 28, 2023
97a6518
unused import
kevaundray Aug 28, 2023
fcb80b8
add code to support arm64
kevaundray Aug 28, 2023
434c217
set env variables once all checks have passed
kevaundray Aug 28, 2023
4434996
Update src/bb/mod.rs
kevaundray Aug 28, 2023
74f6f37
update to 0.4.5
kevaundray Aug 29, 2023
c13223d
fix gates command
kevaundray Aug 29, 2023
f1e92d7
tmate debug
kevaundray Aug 29, 2023
86751bd
chore: remove unnecessary `match`
TomAFrench Aug 29, 2023
ab7808d
chore: remove unnecessary `return`
TomAFrench Aug 29, 2023
f55261e
Empty-Commit
kevaundray Aug 29, 2023
1771008
Empty-Commit
kevaundray Aug 29, 2023
1d5b4b9
remove tmate
kevaundray Aug 29, 2023
f47400a
0.4.6
kevaundray Aug 29, 2023
6d829f8
chore: use proper ci runner
TomAFrench Aug 29, 2023
3338cdf
chore: remove stale comment
TomAFrench Aug 29, 2023
a8fa9d6
chore!: Remove `BlackBoxFunctionSolver` implementation (#250)
TomAFrench Aug 30, 2023
8334a6c
Revert "chore: remove stale comment"
TomAFrench Aug 30, 2023
feeacfa
chore: switch to running cargo directly again
TomAFrench Aug 30, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
cargo clippy
  • Loading branch information
kevaundray committed Aug 20, 2023
commit 08a2d248dfd5bc74dbc666e8a6f87744553717c2
13 changes: 6 additions & 7 deletions src/acvm_interop/proof_system.rs
Original file line number Diff line number Diff line change
@@ -10,7 +10,7 @@ use tempfile::tempdir;

use crate::barretenberg_shim::WriteVkCommand;
use crate::FIELD_BYTES;
use crate::{barretenberg_structures::Assignments, composer::Composer, BackendError, Barretenberg};
use crate::{composer::Composer, BackendError, Barretenberg};

impl ProofSystemCompiler for Barretenberg {
type Error = BackendError;
@@ -87,7 +87,7 @@ impl ProofSystemCompiler for Barretenberg {
// Create a temporary file for the circuit
//
let circuit_path = temp_directory.join("circuit").with_extension("bytecode");
let serialized_circuit = serialize_circuit(&circuit);
let serialized_circuit = serialize_circuit(circuit);
write_to_file(serialized_circuit.as_bytes(), &circuit_path);

// Create proof and store it in the specified path
@@ -111,7 +111,7 @@ impl ProofSystemCompiler for Barretenberg {
// TODO: As noted in the verification procedure, this is an abstraction leak
// TODO: and will need modifications to barretenberg
let proof_with_public_inputs =
read_bytes_from_file(&proof_path.as_os_str().to_str().unwrap()).unwrap();
read_bytes_from_file(proof_path.as_os_str().to_str().unwrap()).unwrap();
let proof =
remove_public_inputs(circuit.public_inputs().0.len(), &proof_with_public_inputs);
Ok(proof)
@@ -148,7 +148,7 @@ impl ProofSystemCompiler for Barretenberg {

// Create a temporary file for the circuit
let circuit_path = temp_directory.join("circuit").with_extension("bytecode");
let serialized_circuit = serialize_circuit(&circuit);
let serialized_circuit = serialize_circuit(circuit);
write_to_file(serialized_circuit.as_bytes(), &circuit_path);

// Create the verification key and write it to the specified path
@@ -241,10 +241,9 @@ fn prepend_public_inputs(proof: Vec<u8>, public_inputs: Vec<FieldElement>) -> Ve

// TODO: See nargo/src/artifacts/mod.rs
// TODO: This method should live in ACVM and be the default method for serializing/deserializing circuits
use base64::Engine;
fn serialize_circuit(circuit: &Circuit) -> String {
use base64::Engine;
let mut circuit_bytes: Vec<u8> = Vec::new();
circuit.write(&mut circuit_bytes).unwrap();
let encoded_b64 = base64::engine::general_purpose::STANDARD.encode(circuit_bytes);
return encoded_b64;
base64::engine::general_purpose::STANDARD.encode(circuit_bytes)
}
2 changes: 1 addition & 1 deletion src/barretenberg_shim.rs
Original file line number Diff line number Diff line change
@@ -6,7 +6,7 @@ use std::env;
fn get_binary_path() -> String {
// Get the NARGO_BINARIES_PATH environment variable
if let Ok(bin_path) = env::var("NARGO_BINARIES_PATH") {
return bin_path;
bin_path
} else {
// TODO: This will be done once and for all in Nargo in the future; when Nargo gets installed
unreachable!("`NARGO_BINARIES_PATH` environment variable not set. Please run the bash script to download the binaries and set the path variable");