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

evaluate_function followed by Term.step causes segmentation fault #943

Open
tothtamas28 opened this issue Dec 20, 2023 · 2 comments
Open
Labels
bindings LLVM backend bindings to other languages bug Something isn't working

Comments

@tothtamas28
Copy link
Contributor

https://github.com/runtimeverification/pyk/actions/runs/7272674739/job/19815247058?pr=784

Reproduction script: test_evaluate.py.txt

Copy the file to the pyk repo root, then run

poetry run python3 test_evaluate.py

Output:

INFO:pyk.ktool.kompile:Running: kompile src/tests/integration/k-files/imp.k --emit-json --backend llvm --output-definition /tmp/tmp6hrgm03t/imp-kompiled
INFO:pyk.ktool.kompile:Completed in 5.169s with status 0: kompile src/tests/integration/k-files/imp.k --emit-json --backend llvm --output-definition /tmp/tmp6hrgm03t/imp-kompiled
INFO:pyk.kllvm.compiler:Compiling pythonast extension: _kllvm.cpython-310-x86_64-linux-gnu.so
INFO:pyk.kllvm.compiler:Running: llvm-kompile pythonast --python /home/ttoth/.cache/pypoetry/virtualenvs/pyk-YghnWhM2-py3.10/bin/python3 --python-output-dir /tmp/tmp6hrgm03t/imp-kompiled
INFO:pyk.kllvm.compiler:Completed in 4.834s with status 0: llvm-kompile pythonast --python /home/ttoth/.cache/pypoetry/virtualenvs/pyk-YghnWhM2-py3.10/bin/python3 --python-output-dir /tmp/tmp6hrgm03t/imp-kompiled
INFO:pyk.kllvm.compiler:Compiling python extension: _kllvm_runtime.cpython-310-x86_64-linux-gnu.so
INFO:pyk.kllvm.compiler:Running: llvm-kompile /tmp/tmp6hrgm03t/imp-kompiled/definition.kore /tmp/tmp6hrgm03t/imp-kompiled/dt python --python /home/ttoth/.cache/pypoetry/virtualenvs/pyk-YghnWhM2-py3.10/bin/python3
INFO:pyk.kllvm.compiler:Completed in 3.335s with status 0: llvm-kompile /tmp/tmp6hrgm03t/imp-kompiled/definition.kore /tmp/tmp6hrgm03t/imp-kompiled/dt python --python /home/ttoth/.cache/pypoetry/virtualenvs/pyk-YghnWhM2-py3.10/bin/python3
Fatal Python error: Segmentation fault

Current thread 0x00007fdbf640cb80 (most recent call first):
  File "/home/ttoth/git/pyk/test_evaluate.py", line 59 in <module>
[1]    300671 segmentation fault (core dumped)  poetry run python3 test_evaluate.py

On my machine, decreasing either of the two iteration bounds causes the issue to not surface. Accordingly, the bounds might require tweaking in other environments.

Additionally, evaluate_function, when run in an infinite loop, seems to exhibit the same monotonically increasing memory consumption as simplify_pattern (#922).

@tothtamas28 tothtamas28 added bug Something isn't working bindings LLVM backend bindings to other languages labels Dec 20, 2023
@Baltoli Baltoli self-assigned this Dec 20, 2023
@Baltoli
Copy link
Contributor

Baltoli commented Dec 21, 2023

First note is that the GC fix in #945 addresses the monotonic memory consumption issue when the function evaluator is run in an infinite loop (if a call to free_all_gc_memory is added after the function is evaluated, similarly to the simplification routines).

@Baltoli
Copy link
Contributor

Baltoli commented Dec 21, 2023

The second note is that I can reproduce the issue with the exact same depth bounds on my machine; this suggests there's something consistently odd going on in the backend that - fortunately - isn't architecture or OS-specific. I'm going to work on turning the Python example into a C++ one that can be more easily debugged.

rv-jenkins pushed a commit to runtimeverification/k that referenced this issue Jul 15, 2024
Transfer of:
* runtimeverification/pyk#784

Related:
* runtimeverification/llvm-backend#943

Co-authored-by: Tamás Tóth <tothtamas28@users.noreply.github.com>
Co-authored-by: Scott Guest <scott.guest@runtimeverification.com>
@Baltoli Baltoli removed their assignment Jul 26, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bindings LLVM backend bindings to other languages bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants