Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[DNM] Execution trace dumping with contract support. #775

Draft
wants to merge 28 commits into
base: main
Choose a base branch
from

Conversation

azteca1998
Copy link
Collaborator

Checklist

  • Linked to Github Issue
  • Unit tests added
  • Integration tests added.
  • This change requires new documentation.
    • Documentation has been added/updated.

Copy link

github-actions bot commented Aug 28, 2024

Benchmarking results

Benchmark for program dict_insert

Open benchmarks
Command Mean [s] Min [s] Max [s] Relative
Cairo-vm (Rust, Cairo 1) 21.195 ± 0.154 21.036 21.575 100.81 ± 1.39
cairo-native (embedded AOT) 3.985 ± 0.017 3.949 4.010 18.95 ± 0.24
cairo-native (embedded JIT using LLVM's ORC Engine) 3.827 ± 0.023 3.788 3.871 18.20 ± 0.24
cairo-native (standalone AOT with -march=native) 0.210 ± 0.002 0.206 0.215 1.00

Benchmark for program dict_snapshot

Open benchmarks
Command Mean [s] Min [s] Max [s] Relative
Cairo-vm (Rust, Cairo 1) 5.739 ± 0.036 5.693 5.808 18.21 ± 0.13
cairo-native (embedded AOT) 4.156 ± 0.038 4.113 4.232 13.19 ± 0.13
cairo-native (embedded JIT using LLVM's ORC Engine) 4.005 ± 0.020 3.978 4.037 12.71 ± 0.08
cairo-native (standalone AOT with -march=native) 0.315 ± 0.001 0.314 0.316 1.00

Benchmark for program factorial_2M

Open benchmarks
Command Mean [s] Min [s] Max [s] Relative
Cairo-vm (Rust, Cairo 1) 14.283 ± 0.033 14.234 14.329 10.58 ± 0.03
cairo-native (embedded AOT) 4.215 ± 0.025 4.183 4.253 3.12 ± 0.02
cairo-native (embedded JIT using LLVM's ORC Engine) 4.031 ± 0.027 3.996 4.079 2.99 ± 0.02
cairo-native (standalone AOT with -march=native) 1.350 ± 0.002 1.348 1.353 1.00

Benchmark for program fib_2M

Open benchmarks
Command Mean [s] Min [s] Max [s] Relative
Cairo-vm (Rust, Cairo 1) 14.679 ± 0.105 14.578 14.892 188.63 ± 1.85
cairo-native (embedded AOT) 3.762 ± 0.021 3.734 3.790 48.34 ± 0.42
cairo-native (embedded JIT using LLVM's ORC Engine) 3.555 ± 0.019 3.533 3.585 45.69 ± 0.39
cairo-native (standalone AOT with -march=native) 0.078 ± 0.001 0.077 0.081 1.00

Benchmark for program linear_search

Open benchmarks
Command Mean [s] Min [s] Max [s] Relative
Cairo-vm (Rust, Cairo 1) 5.744 ± 0.035 5.688 5.799 2902.76 ± 66.70
cairo-native (embedded AOT) 3.860 ± 0.013 3.846 3.888 1950.84 ± 43.69
cairo-native (embedded JIT using LLVM's ORC Engine) 3.752 ± 0.014 3.736 3.778 1896.06 ± 42.55
cairo-native (standalone AOT with -march=native) 0.002 ± 0.000 0.002 0.002 1.00

Benchmark for program logistic_map

Open benchmarks
Command Mean [s] Min [s] Max [s] Relative
Cairo-vm (Rust, Cairo 1) 5.663 ± 0.035 5.630 5.740 23.31 ± 0.27
cairo-native (embedded AOT) 3.957 ± 0.021 3.933 3.994 16.29 ± 0.18
cairo-native (embedded JIT using LLVM's ORC Engine) 3.857 ± 0.021 3.827 3.904 15.88 ± 0.18
cairo-native (standalone AOT with -march=native) 0.243 ± 0.002 0.242 0.250 1.00

Copy link

github-actions bot commented Sep 10, 2024

❌ Code is not formatted! Please run cargo format and push the changes.

azteca1998 and others added 3 commits September 10, 2024 19:16
* Impl ClassHash and SegmentArena

* Add trace dump support to compiler

* Reset workflows

* Update lock

* Implement BoundedInt

* Fix Enum trace dump

* Make gas_metadata public

* Update deps

* Fix bug

* Move deps to optional (trace dump featire)
@igaray igaray changed the title Execution trace dumping with contract support. [DNM] Execution trace dumping with contract support. Sep 12, 2024
Copy link

github-actions bot commented Oct 8, 2024

Benchmark results Main vs HEAD.

Command Mean [s] Min [s] Max [s] Relative
base dict_insert.cairo (JIT) 3.779 ± 0.023 3.748 3.819 1.00
base dict_insert.cairo (AOT) 3.939 ± 0.036 3.894 3.994 1.04 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
:--- ---: ---: ---: ---:
head dict_insert.cairo (JIT) 3.933 ± 0.052 3.870 4.015 1.00
head dict_insert.cairo (AOT) 4.099 ± 0.038 4.026 4.147 1.04 ± 0.02
Command Mean [s] Min [s] Max [s] Relative
base dict_snapshot.cairo (JIT) 3.968 ± 0.023 3.934 4.008 1.00
base dict_snapshot.cairo (AOT) 4.139 ± 0.036 4.093 4.205 1.04 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
:--- ---: ---: ---: ---:
head dict_snapshot.cairo (JIT) 4.117 ± 0.036 4.064 4.189 1.00
head dict_snapshot.cairo (AOT) 4.239 ± 0.029 4.207 4.280 1.03 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
base factorial_2M.cairo (JIT) 3.997 ± 0.027 3.953 4.050 1.00
base factorial_2M.cairo (AOT) 4.191 ± 0.038 4.150 4.288 1.05 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
:--- ---: ---: ---: ---:
head factorial_2M.cairo (JIT) 4.125 ± 0.031 4.079 4.171 1.00
head factorial_2M.cairo (AOT) 4.331 ± 0.043 4.268 4.419 1.05 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
base fib_2M.cairo (JIT) 3.553 ± 0.023 3.520 3.590 1.00
base fib_2M.cairo (AOT) 3.726 ± 0.021 3.680 3.756 1.05 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
:--- ---: ---: ---: ---:
head fib_2M.cairo (JIT) 3.681 ± 0.033 3.628 3.729 1.00
head fib_2M.cairo (AOT) 3.915 ± 0.043 3.858 3.961 1.06 ± 0.02
Command Mean [s] Min [s] Max [s] Relative
base linear_search.cairo (JIT) 3.739 ± 0.027 3.683 3.780 1.00
base linear_search.cairo (AOT) 3.828 ± 0.019 3.808 3.854 1.02 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
:--- ---: ---: ---: ---:
head linear_search.cairo (JIT) 3.891 ± 0.032 3.848 3.940 1.00
head linear_search.cairo (AOT) 4.000 ± 0.040 3.935 4.049 1.03 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
base logistic_map.cairo (JIT) 3.847 ± 0.016 3.828 3.880 1.00
base logistic_map.cairo (AOT) 3.948 ± 0.040 3.886 4.038 1.03 ± 0.01
Command Mean [s] Min [s] Max [s] Relative
:--- ---: ---: ---: ---:
head logistic_map.cairo (JIT) 3.981 ± 0.031 3.914 4.034 1.00
head logistic_map.cairo (AOT) 4.051 ± 0.029 4.002 4.091 1.02 ± 0.01

JulianGCalderon and others added 7 commits October 21, 2024 09:38
* Add logs

* Implement Felt252Dict trace dump

* Implement nullabel for trace dump

* Print type id

* Remove print

* add convertion for Sints

* fix mispelled types

* forgot to add feature

* change Sints value to correspond to sierra-emu

* Readd feature

* Add is_infinity field to secp256 point struct (#828)

* add is_infinity to secp point

* clean

* fix

* use same deps as blockifier

* fix

* fix layout

* fix test

* remove some brittle asserts due to random initial data when adding and muling points at infinity

* fix

* remove unused dep

* fixes, missed the value entry/output

* Reset src

* Fix warnings

* Make library public

* Use debug runtime for trace dump

* fix storage's values truncations (#839)

* fix storage's values truncations

* change implementation for i8 i16 i32 i64 too

* format

* Add ptr check to felt dict entry

* Add malloc tracing and fix more memory leaks. (#833)

* Add memory tracing.

* Partial memory fixes.

* Fix arrays.

* Simplify dictionaries. Fix false positive memory leak in dictionary drops.

* Fix zero-sized allocation. Fix warnings. More mem tracing checks.

* Fix mem tracing.

* Fix memory leak in `print` libfunc.

* Fix array slice libfunc.

* Fix starknet memory leaks.

* Fix keccak syscall.

* Fix dict get double free bug.

* Lots of memory fixes.

* More fixes.

* Fix CI.

* Remove old TODOs.

* Fix CI (again).

* Remove TODOs.

* Fix test.

* Maybe fix

* Maybe fix

* Maybe fix

* Dont panic when building circuit partial outputs

* trace dump for Sha256StateHandler

* Builtin costs rework (#837)

* Update to 2.8.4, release docs, alpha

This PR updates cairo to 2.8.4, adds some release docs and updates the
version to alpha.3 to prepare for another release.

* try fix

* cleanup ci, remove panic in link

* rename from jit to from ptr, etc

* crates.io badge

* progress

* progress

* fmt2

* progress

* progress

* fix

* fix bench

* use struct

* Fix felt252 and enum deserialization bugs. (#844)

* Fix felt252 and enum deserialization bugs.

* Fix formatting.

* Also fix the runtime.

* Fix errors.

* try to fix ci

* remove unused deps

---------

Co-authored-by: Edgar Luque <[email protected]>

* Fix trace dump type conv

* fix aot contract executor not passing builtinstats (#849)

* Fix felt252 and enum deserialization bugs.

* Fix formatting.

* Also fix the runtime.

* Fix errors.

* try to fix ci

* remove unused deps

* fix aot contract executor not passing builtinstats

---------

Co-authored-by: Esteve Soler Arderiu <[email protected]>
Co-authored-by: Esteve Soler Arderiu <[email protected]>

* Fix bug (#851)

* Also fix felt bits in starknet syscall wrappers (#853)

* Also fix felt bits in starknet syscall wrappers

* style

* missed

* fix aot contract executor not passing builtinstats (#849)

* Fix felt252 and enum deserialization bugs.

* Fix formatting.

* Also fix the runtime.

* Fix errors.

* try to fix ci

* remove unused deps

* fix aot contract executor not passing builtinstats

---------

Co-authored-by: Esteve Soler Arderiu <[email protected]>
Co-authored-by: Esteve Soler Arderiu <[email protected]>

* Fix bug (#851)

* Also fix felt bits in starknet syscall wrappers (#853)

* Also fix felt bits in starknet syscall wrappers

* style

* missed

* update version to alpha 4 (#854)

* bytes31

* Better function attributes and re-enable >O1 opt (#843)

* Fix felt252 and enum deserialization bugs.

* Fix formatting.

* Also fix the runtime.

* Fix errors.

* try to fix ci

* remove unused deps

* proper function attributes

* add proper function attrs to optimize better, add some passes, run tests with atleast some opts

* dont use remi

* oops

* maybe with opt level 3 now it works

* test

* works

* readd deleted bench

* remove dbg

* Update bench-hyperfine.sh

* fixci

* comment

* Update src/ffi.rs

Co-authored-by: MrAzteca <[email protected]>

---------

Co-authored-by: Esteve Soler Arderiu <[email protected]>
Co-authored-by: Esteve Soler Arderiu <[email protected]>
Co-authored-by: MrAzteca <[email protected]>

* Resolve `CAIRO_NATIVE_RUNTIME_LIBRARY` relative path (#841)

* feat(ffi): resolve runtime relative path using current dir

* chore: remove mentions to old runtime variable

* fix: typo

---------

Co-authored-by: Bohdan Ohorodnii <[email protected]>

* Implement secp

* Fix bytes31

* try to fix ci (#858)

* update implementing libfuncs doc (#856)

* Fix bytes31 bug

* Remove unused dep

---------

Co-authored-by: FrancoGiachetta <[email protected]>
Co-authored-by: Edgar <[email protected]>
Co-authored-by: MrAzteca <[email protected]>
Co-authored-by: Esteve Soler Arderiu <[email protected]>
Co-authored-by: Esteve Soler Arderiu <[email protected]>
Co-authored-by: Rodrigo <[email protected]>
Co-authored-by: Bohdan Ohorodnii <[email protected]>
@JulianGCalderon JulianGCalderon force-pushed the add-trace-dump-contracts branch from ae6784e to 05b9971 Compare November 19, 2024 16:45
@JulianGCalderon JulianGCalderon force-pushed the add-trace-dump-contracts branch from 05b9971 to 7f37246 Compare November 19, 2024 16:47
@codecov-commenter
Copy link

codecov-commenter commented Nov 19, 2024

Codecov Report

Attention: Patch coverage is 82.45614% with 10 lines in your changes missing coverage. Please review.

Project coverage is 80.72%. Comparing base (e41f7b1) to head (8411019).
Report is 1 commits behind head on main.

Files with missing lines Patch % Lines
src/compiler.rs 82.45% 10 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main     #775      +/-   ##
==========================================
- Coverage   80.76%   80.72%   -0.04%     
==========================================
  Files         107      107              
  Lines       29256    29290      +34     
==========================================
+ Hits        23628    23644      +16     
- Misses       5628     5646      +18     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@JulianGCalderon JulianGCalderon force-pushed the add-trace-dump-contracts branch from d9a22a9 to c9787a4 Compare January 23, 2025 13:19
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants