<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/129043>129043</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[MLIR]`--pass-pipeline="builtin.module(func.func(test-match-reduction))"` triggers Assertion `Index < this->size() && "Invalid index!"' failed.
</td>
</tr>
<tr>
<th>Labels</th>
<td>
mlir
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
xisang0
</td>
</tr>
</table>
<pre>
Test on commit: https://github.com/llvm/llvm-project/commit/01cc1d13cd0c54bd4c29185b052fa5c16285dca7
steps to reproduce:
```
./mlir-opt test.mlir --pass-pipeline="builtin.module(func.func(test-match-reduction))"
```
test case:
```
func.func @pooling_ncw_sum_tensor(%input: tensor<1x3x10xf32>,
%kernel: tensor<3xf32>,
%output: tensor<1x3x8xf32>) {
%result = linalg.pooling_ncw_sum
{strides = dense<[1]> : tensor<1xi64>,
dilations = dense<[1]> : tensor<1xi64>}
ins(%input, %kernel : tensor<1x3x10xf32>, tensor<3xf32>)
outs(%output : tensor<1x3x8xf32>) -> tensor<1x3x8xf32>
return
}
```
crash trace:
```
mlir-opt: /home/llvm-project/llvm/include/llvm/ADT/ArrayRef.h:446: T &llvm::MutableArrayRef<mlir::OpOperand>::operator[](size_t) const [T = mlir::OpOperand]: Assertion `Index < this->size() && "Invalid index!"' failed.
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0. Program arguments: build/bin/mlir-opt test.mlir --pass-pipeline=builtin.module(func.func(test-match-reduction))
#0 0x00005648b7c8bdd8 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (build/bin/mlir-opt+0x10c8dd8)
#1 0x00005648b7c898fe llvm::sys::RunSignalHandlers() (build/bin/mlir-opt+0x10c68fe)
#2 0x00005648b7c8c7e1 SignalHandler(int, siginfo_t*, void*) Signals.cpp:0:0
#3 0x00007fcbbaac0520 (/lib/x86_64-linux-gnu/libc.so.6+0x42520)
#4 0x00007fcbbab149fc pthread_kill (/lib/x86_64-linux-gnu/libc.so.6+0x969fc)
#5 0x00007fcbbaac0476 gsignal (/lib/x86_64-linux-gnu/libc.so.6+0x42476)
#6 0x00007fcbbaaa67f3 abort (/lib/x86_64-linux-gnu/libc.so.6+0x287f3)
#7 0x00007fcbbaaa671b (/lib/x86_64-linux-gnu/libc.so.6+0x2871b)
#8 0x00007fcbbaab7e96 (/lib/x86_64-linux-gnu/libc.so.6+0x39e96)
#9 0x00005648b80add1b (build/bin/mlir-opt+0x14ead1b)
#10 0x00005648bac9e4da mlir::matchReduction(llvm::ArrayRef<mlir::BlockArgument>, unsigned int, llvm::SmallVectorImpl<mlir::Operation*>&) (build/bin/mlir-opt+0x40db4da)
#11 0x00005648baec2ff5 void llvm::function_ref<void (mlir::Operation*)>::callback_fn<(anonymous namespace)::TestMatchReductionPass::runOnOperation()::'lambda'(mlir::Operation*)>(long, mlir::Operation*) TestMatchReduction.cpp:0:0
#12 0x00005648b7d9de86 void mlir::detail::walk<mlir::ForwardIterator>(mlir::Operation*, llvm::function_ref<void (mlir::Operation*)>, mlir::WalkOrder) (build/bin/mlir-opt+0x11dae86)
#13 0x00005648b7d9df1e void mlir::detail::walk<mlir::ForwardIterator>(mlir::Operation*, llvm::function_ref<void (mlir::Operation*)>, mlir::WalkOrder) (build/bin/mlir-opt+0x11daf1e)
#14 0x00005648baec2de9 (anonymous namespace)::TestMatchReductionPass::runOnOperation() TestMatchReduction.cpp:0:0
#15 0x00005648bacc1373 mlir::detail::OpToOpPassAdaptor::run(mlir::Pass*, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int) (build/bin/mlir-opt+0x40fe373)
#16 0x00005648bacc1c12 mlir::detail::OpToOpPassAdaptor::runPipeline(mlir::OpPassManager&, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int, mlir::PassInstrumentor*, mlir::PassInstrumentation::PipelineParentInfo const*) (build/bin/mlir-opt+0x40fec12)
#17 0x00005648bacc718e auto void mlir::parallelForEach<__gnu_cxx::__normal_iterator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo*, std::vector<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo, std::allocator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo>>>, mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::$_0>(mlir::MLIRContext*, __gnu_cxx::__normal_iterator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo*, std::vector<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo, std::allocator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo>>>, __gnu_cxx::__normal_iterator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo*, std::vector<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo, std::allocator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo>>>, mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::$_0&&)::'lambda'(__gnu_cxx::__normal_iterator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo*, std::vector<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo, std::allocator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo>>>&&)::operator()<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo&>(__gnu_cxx::__normal_iterator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo*, std::vector<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo, std::allocator<mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool)::OpPMInfo>>>&&) const Pass.cpp:0:0
#18 0x00005648bacc346b mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool) (build/bin/mlir-opt+0x410046b)
#19 0x00005648bacc14cc mlir::detail::OpToOpPassAdaptor::run(mlir::Pass*, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int) (build/bin/mlir-opt+0x40fe4cc)
#20 0x00005648bacc1c12 mlir::detail::OpToOpPassAdaptor::runPipeline(mlir::OpPassManager&, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int, mlir::PassInstrumentor*, mlir::PassInstrumentation::PipelineParentInfo const*) (build/bin/mlir-opt+0x40fec12)
#21 0x00005648bacc43ee mlir::PassManager::run(mlir::Operation*) (build/bin/mlir-opt+0x41013ee)
#22 0x00005648bacbc9ab performActions(llvm::raw_ostream&, std::shared_ptr<llvm::SourceMgr> const&, mlir::MLIRContext*, mlir::MlirOptMainConfig const&) MlirOptMain.cpp:0:0
#23 0x00005648bacbc603 llvm::LogicalResult llvm::function_ref<llvm::LogicalResult (std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::raw_ostream&)>::callback_fn<mlir::MlirOptMain(llvm::raw_ostream&, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, mlir::DialectRegistry&, mlir::MlirOptMainConfig const&)::$_0>(long, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::raw_ostream&) MlirOptMain.cpp:0:0
#24 0x00005648bad66415 mlir::splitAndProcessBuffer(std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::function_ref<llvm::LogicalResult (std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::raw_ostream&)>, llvm::raw_ostream&, llvm::StringRef, llvm::StringRef) (build/bin/mlir-opt+0x41a3415)
#25 0x00005648bacb6262 mlir::MlirOptMain(llvm::raw_ostream&, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, mlir::DialectRegistry&, mlir::MlirOptMainConfig const&) (build/bin/mlir-opt+0x40f3262)
#26 0x00005648bacb6513 mlir::MlirOptMain(int, char**, llvm::StringRef, llvm::StringRef, mlir::DialectRegistry&) (build/bin/mlir-opt+0x40f3513)
#27 0x00005648bacb6722 mlir::MlirOptMain(int, char**, llvm::StringRef, mlir::DialectRegistry&) (build/bin/mlir-opt+0x40f3722)
#28 0x00005648b7c694f7 main (build/bin/mlir-opt+0x10a64f7)
#29 0x00007fcbbaaa7d90 (/lib/x86_64-linux-gnu/libc.so.6+0x29d90)
#30 0x00007fcbbaaa7e40 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x29e40)
#31 0x00005648b7c69055 _start (build/bin/mlir-opt+0x10a6055)
Aborted (core dumped)
```
</pre>
<img width="1" height="1" alt="" src="http://email.email.llvm.org/o/eJzsWt1u2zgWfhrmhohBUf8XuVCcGBtgggRpsXtpUCQlc0OTWpJqk336BSXbkmW7rmfSmZ2iQZraEnl-vnPOxyOKxFpRK85vQHwL4rsr0rqVNjdvwhJVo6tSs_ebz9w6qBWker0WDoQFXDnXWBAWAC8AXtTCrdpyRvUa4IWUX7b_XTdG_5tTB_BiMxUvUEBpwIKQMkTjqGQRxXmQxSWKcUViGiQ4ixklKUCFdbyx0GloeGM0ayn3GlEBErT5RcUM4MVaCnOtGwcdt27mv8Hr64ZYe92IhkuhOAjvAMZlK6QTarbWrJUc4KxqFZ35PwBnfu71mji6ujactdQJrQDOu188UerHQkrsEXt2IiGIUKO1FKpeKvp1adv10nFltQE4AzgWqmk7KDcXw3nwFr4F6K0KMQjvAZ5DgAoIcPzKjeJyb2h4OEq37pjAbDcyhyC99YP9aMNtKx0E4R2UQhFZzya2dmJHPyC9tc4Ixm03iXHlvZ-D-DYA8R0I7-FEtUiikYF7P0xI4uG9UFR65yUJZccAevlbiKbzJnAeQS_vjNOt28jsQTyUM0bx2lt4_C4qoOGuNconRWfuODWoIXYFnSHH8nibw141wIuVXvPDItqUllBUtowPF4q7z_6vMeT9hVezFQiLKEq8qM8Q4KQbFRYgLB5bR0rJtyNBOPd6-3tPzVPDDVHMe9Jd0f6706ZnBoAzK_7Ll86DQLWyDoL49nMXw2NSfCgLWFjLjQ82BAl6UIy_QRDOoVsJ64H0Ejvoc28owAkEGD-oL0QKBoUfDnDgCxCnsCJCcjYDqHj-7b74dA9tW66FgwSWbe05Qhvn2eJibhLWttwCvIBEea0dutCtOOxDVhL62oXN6_7kCH2FrF03fRDRrE_qZ6NrQ9aQmLpdc-W8BdAzDgN4UQr1vTz1e0mqY4EQQfSGEEJxEmVlSrOSsQwO8bfvtv_wbIRynSufu3zE2TDIkK9LbZ3hZN3FZA6Fcn2EsuMOAXyL3gJEM8aywZZgYkueVfyYLS-t-iRqReQ_iGKSG7tLiDPqkqzigzo8UUdTHsA9wQBnnSdzaEUtVKV9Lhf--xctWPcx38ywM9r4AKPuX68g3ChIK1qWhFAUYwQ7WxdSlAAv3rJkmUTXUqj27bpWbX-DzqyeJZ3NEY4xGiyO9gSWQZRXFDZuZThhy1ch5WXS8ySv6CA9npobpQmsbefepWZHaTIITvYFkyStQkhKX30XicVZWoWD2PRAbFBeLDAoB4HZvsAy5XlymcAw5_nI8XycYRkijPUWfitLI07Y1ihfE3sFSmjOI0ZG9NnV9stQ2qOyPErat1LT12JDOZt1rlVdR8fgJtkHEZ_WRMp_cuq0eVg3ckL_nuw7pUUnKDlfgxFiZcTI4N1eyRNOcVXFXXGNjPBU5vUsTedLdxfg7IQlON8tR5RI6al4WSnfLuCMKK3e17q1UJE1t01HZHk_2Lesj3tgPhO7IRzTqic10pLtZgGcSrIuvUvpOZtwJrWqPcAnh8FDKya84kHbJy6WM54lPWiDYMYdEbL__JXI173QLbT5Sgx7cJvlujPulFHzPxiKPX__ReTrk2GeWs_ydcAIz5IhV8Kp21XAf063q4APbkfTEmG8k_GRyfx9eRfvUxENwjQ8gf1T81k_NV5pwUjTgb3RvYdbZ1WP9uk4DHcKReS7FfaRKFJ7MOew1Foecth5Hqp4mIYDyMnUNRrgi1173jZl-6nhh-4sTj7c1_Ekr-pBWWc6evdPjsW3BvSa-xsb25-J4co9qEr3LfuGl87DSQM8wJlO4EyDjEPSOj2t14YYIiWXC23uCV2BcL5c1qpd0re3fsByqbRZE7kUu6qdXxqXUboX9l3RbinDWQ9nvgvTo_d6g5h1rL_-pVv8frjSkUYipaZ_hqd-mbw_oKqPUwRwtERTkn387eFlrpXjb9tW-lfA_4qA_0L95yqzbi_kVFv6K9h_frD34rHbGNs8Ovxgz5OedX-F_S8L-2a_0ws-0khnk_YojJLyg7nhXMcWIBQlo22GfNoAR5T-fXv7iNKdaxj96u0_sLfHwQTOKOR8YsXWr6N5Md3yOJuoQciHx2GM99WXNCclbLiptFkX3ZOrPbM5vaMHuyKGs2XjPD-MNr10ayh_rA0I77dATUJ72MWO7klhnhr3SISaa1WJeiQjh6O7h8SAw6lzCQpH-xC_6VpQIl_6d3En9ydOTQA42_neKvGflh_4_sjX2rzftlXVp-VuPOMVaaVbMi6546fn7Fqd0xE4tUF3FMLvjeUP92ew7k4Qyal74bWwzrwfJse3EuDg0Wi7J_h_EZkz6bm_FcWSJArikeO2kcIVij0bTbm1W1v_kqT7G5bEN0fs7co7I1T9wquTl8-zKgmjIB5YdbK1VyY4wcdT-mcryPPLX4iT0fKXTJGKg_AkUptFnK5Iv1wXlwbynJvfY34cDBudOJ2an-LTgb7E_D9uZ4pHMGf7L2eTPKpSuCZCnX3LS5KoSgdB-eQtYcryC1_C4pzlaCdw98Z8J5BHCC6Xfs7SOmLccmvmJSp4NFIRTJ1HcQx74d_hPoo3hV2U2jjevaqg2vDuDAJnGzXboyRX7CZkeZiTK34TpBFK4izP0qvVDUtDioIoDHOcZQlJooTEmOI8ZCiqMlpdiRuMcIwwTgOMQ5TOwjKPGSVRmPnGJSMgQnxNhJz5lJlpU191ByduApyjKLySpOTSdsfIMO7SB2MQ312Zm-64RdnWFkRICuvsIMEJJ7ujZ74FA_EdSNBHH91KEHRG1DU39gecRrlqjbz5_SdONth9ucH_CwAA___hdjEV">