# Precompiles

Precompiles are highly optimized SNARK gadgets which can be invoked from the high-level programming language of the VM user. These gadgets can be much more efficient for the prover than compiling down to the underlying ISA by exploiting the structure of the workload. In practice zkVMs use these for heavy cryptographic operations such as hash functions, signatures and other elliptic curve arithmetic.

By popular demand, Jolt will support these gadgets as well. The short term plan is to optimize for minimizing Jolt-core development resources rather than optimal prover speed.

Precompile support plan:

- RV32 library wrapping syscalls of supported libraries
- Tracer picks up syscalls, sets relevant flag bits and loads memory accordingly
- Individual (uniform) Spartan instance for each precompile, repeated over
`trace_length`

steps - Jolt config includes which precompiles are supported (there is some non-zero prover / verifier cost to including an unused precompile)
- Survey existing hash / elliptic curve arithmetic R1CS arithmetizations. Prioritize efficiency and audits.
- Use circom-scotia to convert $A,B,C$ matrices into static files in the Jolt codebase
- Write a converter to uniformly repeat the constraints
`trace_length`

steps

*TODO(sragss): How do we deal with memory and loading more than 64-bits of inputs to precompiles.*