Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
bytecode_hashing.cpp
Go to the documentation of this file.
2
6
7namespace bb::avm2::simulation {
8
10 const std::vector<uint8_t>& bytecode,
11 const FF& public_bytecode_commitment)
12{
13 BB_BENCH_NAME("BytecodeHasher::assert_public_bytecode_commitment");
14 auto bytecode_length_in_bytes = static_cast<uint32_t>(bytecode.size());
15
16 std::vector<FF> inputs = { compute_public_bytecode_first_field(bytecode_length_in_bytes) };
17 auto bytecode_as_fields = encode_bytecode(bytecode);
18 inputs.insert(inputs.end(), bytecode_as_fields.begin(), bytecode_as_fields.end());
19
20 FF hash = hasher.hash(inputs);
21 // This will throw an unexpected exception if it fails.
22 BB_ASSERT_EQ(hash, public_bytecode_commitment, "Public bytecode commitment hash mismatch");
23
24 events.emit({ .bytecode_id = bytecode_id,
25 .bytecode_length = bytecode_length_in_bytes,
26 .bytecode_fields = std::move(bytecode_as_fields) });
27}
28
29} // namespace bb::avm2::simulation
#define BB_ASSERT_EQ(actual, expected,...)
Definition assert.hpp:83
std::shared_ptr< Napi::ThreadSafeFunction > bytecode
#define BB_BENCH_NAME(name)
Definition bb_bench.hpp:225
void assert_public_bytecode_commitment(const BytecodeId &bytecode_id, const std::vector< uint8_t > &bytecode, const FF &public_bytecode_commitment) override
EventEmitterInterface< BytecodeHashingEvent > & events
virtual FF hash(const std::vector< FF > &input)=0
AvmProvingInputs inputs
AVM range check gadget for witness generation.
std::vector< FF > encode_bytecode(std::span< const uint8_t > bytecode)
FF compute_public_bytecode_first_field(size_t bytecode_size)
AvmFlavorSettings::FF FF
Definition field.hpp:10
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13