- 
                Notifications
    You must be signed in to change notification settings 
- Fork 33
Closed
Description
Reproducer
Reactant.compile(()) do
    x = [:a,:b,:c]
    unique(x)
endError
ERROR: StackOverflowError:
Stacktrace:
      [1] _unique_dims
        @ ./multidimensional.jl:1726 [inlined]
      [2] unique
        @ ./multidimensional.jl:1724 [inlined]
      [3] call_with_reactant(::typeof(unique), ::Vector{Symbol})
        @ Reactant ~/.julia/packages/Reactant/oG9qp/src/utils.jl:0
      [4] _unique_dims
        @ ./multidimensional.jl:1726 [inlined]
      [5] unique
        @ ./multidimensional.jl:1724 [inlined]
      [6] unique(none::Vector{Symbol})
        @ Reactant ./<missing>:0
--- the above 6 lines are repeated 19956 more times ---
 [119743] _unique_dims
        @ ./multidimensional.jl:1726 [inlined]
 [119744] unique
        @ ./multidimensional.jl:1724 [inlined]
 [119745] call_with_reactant(::typeof(unique), ::Vector{Symbol})
        @ Reactant ~/.julia/packages/Reactant/oG9qp/src/utils.jl:0
 [119746] _unique_dims
        @ ./multidimensional.jl:1726 [inlined]
 [119747] unique
        @ ./multidimensional.jl:1724 [inlined]
 [119748] #21
        @ ./REPL[20]:3 [inlined]
 [119749] (::var"#21#22")()
        @ Reactant ./<missing>:0
 [119750] GenericMemory
        @ ./boot.jl:516 [inlined]
 [119751] Array
        @ ./boot.jl:578 [inlined]
 [119752] vect
        @ ./array.jl:161 [inlined]
 [119753] #21
        @ ./REPL[20]:2 [inlined]
 [119754] call_with_reactant(redub_arguments#232::var"#21#22")
        @ Reactant ~/.julia/packages/Reactant/oG9qp/src/utils.jl:0
 [119755] make_mlir_fn(f::Function, args::Tuple{}, kwargs::Tuple{}, name::String, concretein::Bool; toscalar::Bool, return_dialect::Symbol, no_args_in_result::Bool, construct_function_without_args::Bool, do_transpose::Bool)
        @ Reactant.TracedUtils ~/.julia/packages/Reactant/oG9qp/src/TracedUtils.jl:184
 [119756] make_mlir_fn
        @ ~/.julia/packages/Reactant/oG9qp/src/TracedUtils.jl:86 [inlined]
 [119757] compile_mlir!(mod::Reactant.MLIR.IR.Module, f::Function, args::Tuple{}; optimize::Bool, no_nan::Bool)
        @ Reactant.Compiler ~/.julia/packages/Reactant/oG9qp/src/Compiler.jl:348
 [119758] compile_mlir!
        @ ~/.julia/packages/Reactant/oG9qp/src/Compiler.jl:339 [inlined]
 [119759] compile_xla(f::Function, args::Tuple{}; client::Nothing, optimize::Bool, no_nan::Bool)
        @ Reactant.Compiler ~/.julia/packages/Reactant/oG9qp/src/Compiler.jl:844
 [119760] compile_xla
        @ ~/.julia/packages/Reactant/oG9qp/src/Compiler.jl:835 [inlined]
 [119761] compile(f::Function, args::Tuple{}; client::Nothing, optimize::Bool, sync::Bool, no_nan::Bool)
        @ Reactant.Compiler ~/.julia/packages/Reactant/oG9qp/src/Compiler.jl:870Log from debug interpreter
"args (var\"#23#24\",)"
"ir 2 1 ─ %1  = \$(Expr(:foreigncall, :(:jl_alloc_genericmemory), Ref{Memory{Symbol}}, svec(Any, Int64), 0, :(:ccall), Memory{Symbol}, 3, 3))::Memory{Symbol}\n  │   %2  = Core.memoryrefnew(%1)::MemoryRef{Symbol}\n  └── %3  = %new(Vector{Symbol}, %2, (3,))::Vector{Symbol}\n  2 ┄ %4  = φ (#1 => 1, #6 => %15)::Int64\n  │   %5  = φ (#1 => 1, #6 => %16)::Int64\n  │   %6  = Base.getfield((:a, :b, :c), %4, false)::Symbol\n  │   %7  = Base.getfield(%3, :ref)::MemoryRef{Symbol}\n  │   %8  = Base.memoryrefnew(%7, %4, false)::MemoryRef{Symbol}\n  │         Base.memoryrefset!(%8, %6, :not_atomic, false)::Symbol\n  │   %10 = (%5 === 3)::Bool\n  └──       goto #4 if not %10\n  3 ─       goto #5\n  4 ─ %13 = Base.add_int(%5, 1)::Int64\n  └──       goto #5\n  5 ┄ %15 = φ (#4 => %13)::Int64\n  │   %16 = φ (#4 => %13)::Int64\n  │   %17 = φ (#3 => true, #4 => false)::Bool\n  │   %18 = Base.not_int(%17)::Bool\n  └──       goto #7 if not %18\n  6 ─       goto #2\n  7 ─       goto #8\n3 8 ─ %22 = invoke Base.unique(%3::Vector{Symbol})::Vector{Symbol}\n  └──       return %22\n  "
"src CodeInfo(\n    @ REPL[22]:2 within `#23`\n   ┌ @ array.jl:161 within `vect`\n   │┌ @ boot.jl:578 within `Array`\n   ││┌ @ boot.jl:516 within `GenericMemory`\n1 ─│││ %1  = \$(Expr(:foreigncall, :(:jl_alloc_genericmemory), Ref{Memory{Symbol}}, svec(Any, Int64), 0, :(:ccall), Memory{Symbol}, 3, 3))::Memory{Symbol}\n│  ││└\n│  ││ @ boot.jl:579 within `Array`\n│  ││┌ @ boot.jl:522 within `memoryref`\n│  │││ %2  = Core.memoryrefnew(%1)::MemoryRef{Symbol}\n│  ││└\n└──││ %3  = %new(Vector{Symbol}, %2, (3,))::Vector{Symbol}\n   │└\n   │ @ array.jl:162 within `vect`\n2 ┄│ %4  = φ (#1 => 1, #6 => %15)::Int64\n│  │ %5  = φ (#1 => 1, #6 => %16)::Int64\n│  │ @ array.jl:163 within `vect`\n│  │┌ @ tuple.jl:33 within `__safe_getindex`\n│  ││ %6  = Base.getfield((:a, :b, :c), %4, false)::Symbol\n│  │└\n│  │┌ @ array.jl:1001 within `__safe_setindex!`\n│  ││┌ @ Base.jl:49 within `getproperty`\n│  │││ %7  = Base.getfield(%3, :ref)::MemoryRef{Symbol}\n│  ││└\n│  ││ %8  = Base.memoryrefnew(%7, %4, false)::MemoryRef{Symbol}\n│  ││       Base.memoryrefset!(%8, %6, :not_atomic, false)::Symbol\n│  │└\n│  │ @ array.jl:164 within `vect`\n│  │┌ @ range.jl:908 within `iterate`\n│  ││┌ @ promotion.jl:639 within `==`\n│  │││ %10 = (%5 === 3)::Bool\n│  ││└\n└──││       goto #4 if not %10\n3 ─││       goto #5\n   ││ @ range.jl:909 within `iterate`\n   ││┌ @ int.jl:87 within `+`\n4 ─│││ %13 = Base.add_int(%5, 1)::Int64\n└──│││       goto #5\n   │└└\n5 ┄│ %15 = φ (#4 => %13)::Int64\n│  │ %16 = φ (#4 => %13)::Int64\n│  │ %17 = φ (#3 => true, #4 => false)::Bool\n│  │ %18 = Base.not_int(%17)::Bool\n└──│       goto #7 if not %18\n6 ─│       goto #2\n   │ @ array.jl:165 within `vect`\n7 ─│       goto #8\n   └\n    @ REPL[22]:3 within `#23`\n   ┌ @ multidimensional.jl:1724 within `unique`\n   │┌ @ multidimensional.jl:1724 within `#unique#715`\n   ││┌ @ multidimensional.jl:1726 within `_unique_dims`\n8 ─│││ %22 = invoke Reactant.call_with_reactant(Base.unique::typeof(unique), %3::Vector{Symbol})::Any\n└──│││       return %22\n   └└└\n)"
"code_info CodeInfo(\n    @ REPL[22]:2 within `#23`\n   ┌ @ array.jl:161 within `vect`\n   │┌ @ boot.jl:578 within `Array`\n   ││┌ @ boot.jl:516 within `GenericMemory`\n1 ─│││ %1 = Core.getfield(##redub_arguments#232, 1)\n│  │││      (Reactant.safe_print)(\"fn arg[1]\", %1)\n│  │││ %3 = (Reactant.make_oc_ref)(Base.RefValue{Core.OpaqueClosure}(#undef), Tuple{}, Vector{Symbol}, CodeInfo(\n    @ REPL[22]:2 within `#23`\n   ┌ @ array.jl:161 within `vect`\n   │┌ @ boot.jl:578 within `Array`\n   ││┌ @ boot.jl:516 within `GenericMemory`\n1 ─│││ %1  = \$(Expr(:foreigncall, :(:jl_alloc_genericmemory), Ref{Memory{Symbol}}, svec(Any, Int64), 0, :(:ccall), Memory{Symbol}, 3, 3))::Memory{Symbol}\n│  ││└\n│  ││ @ boot.jl:579 within `Array`\n│  ││┌ @ boot.jl:522 within `memoryref`\n│  │││ %2  = Core.memoryrefnew(%1)::MemoryRef{Symbol}\n│  ││└\n└──││ %3  = %new(Vector{Symbol}, %2, (3,))::Vector{Symbol}\n   │└\n   │ @ array.jl:162 within `vect`\n2 ┄│ %4  = φ (#1 => 1, #6 => %15)::Int64\n│  │ %5  = φ (#1 => 1, #6 => %16)::Int64\n│  │ @ array.jl:163 within `vect`\n│  │┌ @ tuple.jl:33 within `__safe_getindex`\n│  ││ %6  = Base.getfield((:a, :b, :c), %4, false)::Symbol\n│  │└\n│  │┌ @ array.jl:1001 within `__safe_setindex!`\n│  ││┌ @ Base.jl:49 within `getproperty`\n│  │││ %7  = Base.getfield(%3, :ref)::MemoryRef{Symbol}\n│  ││└\n│  ││ %8  = Base.memoryrefnew(%7, %4, false)::MemoryRef{Symbol}\n│  ││       Base.memoryrefset!(%8, %6, :not_atomic, false)::Symbol\n│  │└\n│  │ @ array.jl:164 within `vect`\n│  │┌ @ range.jl:908 within `iterate`\n│  ││┌ @ promotion.jl:639 within `==`\n│  │││ %10 = (%5 === 3)::Bool\n│  ││└\n└──││       goto #4 if not %10\n3 ─││       goto #5\n   ││ @ range.jl:909 within `iterate`\n   ││┌ @ int.jl:87 within `+`\n4 ─│││ %13 = Base.add_int(%5, 1)::Int64\n└──│││       goto #5\n   │└└\n5 ┄│ %15 = φ (#4 => %13)::Int64\n│  │ %16 = φ (#4 => %13)::Int64\n│  │ %17 = φ (#3 => true, #4 => false)::Bool\n│  │ %18 = Base.not_int(%17)::Bool\n└──│       goto #7 if not %18\n6 ─│       goto #2\n   │ @ array.jl:165 within `vect`\n7 ─│       goto #8\n   └\n    @ REPL[22]:3 within `#23`\n   ┌ @ multidimensional.jl:1724 within `unique`\n   │┌ @ multidimensional.jl:1724 within `#unique#715`\n   ││┌ @ multidimensional.jl:1726 within `_unique_dims`\n8 ─│││ %22 = invoke Reactant.call_with_reactant(Base.unique::typeof(unique), %3::Vector{Symbol})::Any\n└──│││       return %22\n   └└└\n), 0, false, %1)\n│  │││ %4 = (%3)()\n│  │││      (Reactant.safe_print)(\"ocres\", %4)\n└──│││      return %4\n   └└└\n)"
"fn arg[1] #23"
Metadata
Metadata
Assignees
Labels
No labels