Skip to content

Latest commit

 

History

History

op-program

op-program

Implements a fault proof program that runs through the rollup state-transition to verify an L2 output from L1 inputs. This verifiable output can then resolve a disputed output on L1.

The program is designed such that it can be run in a deterministic way such that two invocations with the same input data will result in not only the same output, but the same program execution trace. This allows it to be run in an on-chain VM as part of the dispute resolution process.

Compiling

To build op-program, from within the op-program directory run:

make op-program

This resulting executable will be in ./bin/op-program

Testing

To run op-program unit tests, from within the op-program directory run:

make test

Running

From within the op-program directory, options can be reviewed with:

./bin/op-program --help

Generating the Absolute Prestate

The absolute pre-state of the op-program can be generated by executing the makefile reproducible-prestate target. Effectively, this builds a docker image specified by Dockerfile.repro pinned with the following dependencies:

  • golang version 1.21.3
  • alpine 3.18

After running make reproducible-prestate, the following files can be found in ./bin/:

The prestate-proof.json file is what contains the absolute pre-state hash under the .pre key that is also used by the contracts deploy script.