From 76a30b8b5b5e765a14fe7d896d8890897cad7756 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Mon, 28 Aug 2023 12:20:54 +0100 Subject: [PATCH] chore: compile minimal WASM binary needed for blackbox functions (#1824) resolves #1823 # Checklist: Remove the checklist to signal you've completed it. Enable auto-merge if the PR is ready to merge. - [ ] If the pull request requires a cryptography review (e.g. cryptographic algorithm implementations) I have added the 'crypto' tag. - [ ] I have reviewed my diff in github, line by line and removed unexpected formatting changes, testing logs, or commented-out code. - [ ] Every change is related to the PR description. - [ ] I have [linked](https://docs.github.com/en/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue) this pull request to relevant issues (if any exist). --- .../cpp/barretenberg/cpp/CMakePresets.json | 2 +- .../cpp/barretenberg/cpp/src/CMakeLists.txt | 41 ++++++++++++------- 2 files changed, 27 insertions(+), 16 deletions(-) diff --git a/circuits/cpp/barretenberg/cpp/CMakePresets.json b/circuits/cpp/barretenberg/cpp/CMakePresets.json index 310dd897b19..1d20bec7719 100644 --- a/circuits/cpp/barretenberg/cpp/CMakePresets.json +++ b/circuits/cpp/barretenberg/cpp/CMakePresets.json @@ -200,7 +200,7 @@ "configurePreset": "wasm", "inheritConfigureEnvironment": true, "jobs": 0, - "targets": ["barretenberg.wasm"] + "targets": ["barretenberg.wasm", "acvm_backend.wasm"] }, { "name": "wasm-dbg", diff --git a/circuits/cpp/barretenberg/cpp/src/CMakeLists.txt b/circuits/cpp/barretenberg/cpp/src/CMakeLists.txt index e76e775d656..e9ffeb97e39 100644 --- a/circuits/cpp/barretenberg/cpp/src/CMakeLists.txt +++ b/circuits/cpp/barretenberg/cpp/src/CMakeLists.txt @@ -116,21 +116,6 @@ add_library( $ ) -# Small library to provide necessary primitives for rust crate. -add_library( - acvm_backend - $ - $ - $ - $ - $ - $ - $ - $ - $ - $ -) - if(WASM) # With binaryen installed, it seems its wasm backend optimiser gets invoked automatically. # Due to either a bug in the optimiser, or non-standards compliant c++ in crypto/aes, tests start failing with @@ -178,26 +163,52 @@ if(WASM) $ ) + add_executable( + acvm_backend.wasm + $ + $ + $ + $ + $ + $ + $ + $ + $ + $ + $ + ) + target_link_options( barretenberg.wasm PRIVATE -nostartfiles -Wl,--no-entry,--export-dynamic,--allow-undefined ) + target_link_options( + acvm_backend.wasm + PRIVATE + -nostartfiles -Wl,--no-entry,--export-dynamic,--allow-undefined + ) if(INSTALL_BARRETENBERG) install(TARGETS barretenberg.wasm DESTINATION ${CMAKE_INSTALL_BINDIR}) + install(TARGETS acvm_backend.wasm DESTINATION ${CMAKE_INSTALL_BINDIR}) endif() + else() if(INSTALL_BARRETENBERG) # The `install` function takes targets to install in different destinations on the system. install( + # TODO(dbanks12): should only need to install API headers TARGETS barretenberg barretenberg_headers + # We also give it an optional export name in case something wants to target the install. EXPORT barretenbergTargets + # The ARCHIVE output signifies static libraries that should be installed # and we use the GNUInstallDirs location to install into the standard system library location ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} + # The FILE_SET output is used instead of PUBLIC_HEADER & PRIVATE_HEADER outputs because # our headers don't have a clear delineation between public & private, but we still use # the GNUInstallDirs location to install into the standard system header location