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

panic! on recursive tabled relation #2701

Open
jasagredo opened this issue Dec 11, 2024 · 4 comments
Open

panic! on recursive tabled relation #2701

jasagredo opened this issue Dec 11, 2024 · 4 comments

Comments

@jasagredo
Copy link
Contributor

jasagredo commented Dec 11, 2024

I experienced this error when solving today's Advent of Code, and I seem to be able to hit it consistently. I thought I might report it for future investigation.

The source file is here, only the second part is relevant. It basically is a recursive function that splits numbers and counts how many of those are when N reaches 0.

In order to reproduce the panic I have to use my input file, yours will probably also trigger it, the sample doesn't trigger it. It is triggered every single time I run this query.

➜ RUST_BACKTRACE=1 scryer-prolog 11.pl
?- solve_tabled(7, "11.txt", Sol).
thread 'main' panicked at src\machine\machine_state_impl.rs:70:26:
index out of bounds: the len is 841960 but the index is 841972
stack backtrace:
   0: rust_begin_unwind
   1: core::panicking::panic_fmt
   2: core::panicking::panic_bounds_check
   3: core::ops::function::impls::<impl core::ops::function::FnMut<A> for &mut F>::call_mut
   4: scryer_prolog::machine::attributed_variables::<impl scryer_prolog::machine::machine_state::MachineState>::gather_attr_vars_created_since
   5: scryer_prolog::machine::Machine::run_module_predicate
   6: scryer_prolog::run_binary
note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace.
@haijinSk
Copy link

haijinSk commented Dec 12, 2024

Maybe related: Rust thread panics on certain input #2423

@adri326
Copy link
Contributor

adri326 commented Dec 28, 2024

Here's a minimal reproduction:

:- use_module(library(tabling)).
:- use_module(library(lists)).

:- table blink_tabled/3.

blink_tabled(0, _, 1).
blink_tabled(N, X, Xs) :-
    N > 0,
    N1 is N - 1,
    blink_tabled(N1, X, Xs).

bug(Xs) :-
    member(X, [1, 2, 3, 4, 5]),
    blink_tabled(7, X, Xs).

The bug triggers when one types ; three times when querying bug(Y).

@triska
Copy link
Contributor

triska commented Dec 28, 2024

@adri326: Awesome test case, thank you a lot!

It is not yet minimal (i.e., shortest possible) though, since using the following version of bug/1 in your code also triggers the issue and is even shorter:

bug(Xs) :-
    member(X, [1, 2, 3, 4]),
    blink_tabled(7, X, Xs).

@adri326
Copy link
Contributor

adri326 commented Dec 28, 2024

You're right, I think one could also remove an argument or two to blink_tabled and still trigger the bug.

I've been investigating more, and I keep circling back on AttrVarInitializer::attr_var_queue: I have no idea what its values mean, as CopyTermState::copy_attr_val_lists treats them as pointers to within Balls for global variables, whereas other parts of the code treat them as pointers to the heap, which become invalidated whenever the pointee gets placed within a separate heap in a Ball.

I'm stuck trying to figure out a fix to the issue, given that I couldn't find much documentation around the semantics of AttrVarInitializer :/

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

No branches or pull requests

4 participants