<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/128807>128807</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[MLIR] Assertion `*dim < shapedType.getRank() && "invalid dim value"' failed.
</td>
</tr>
<tr>
<th>Labels</th>
<td>
mlir
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
RiRi114
</td>
</tr>
</table>
<pre>
Test on commit : 0f9720a6
steps to reproduce:
`
mlir-opt temp.mlir -pass-pipeline='builtin.module(func.func(test-affine-reify-value-bounds))'
`
test case:
```mlir
func.func @test_reify_example(%size: index) -> (index, index) {
%zero = arith.constant 0 : index
%tensor_val = tensor.empty(%size) : tensor<?xf32>
%tensor_cast = tensor.cast %tensor_val : tensor<?xf32> to tensor<?xf32>
%element_zero = arith.constant 0.0 : f32
%inserted_tensor = tensor.insert %element_zero into %tensor_cast[%zero] : tensor<?xf32>
%dim_0 = tensor.dim %inserted_tensor, %zero : tensor<?xf32>
%dim_1 = "test.reify_bound"(%inserted_tensor) {dim = 0} : (tensor<?xf32>) -> (index)
%dim_2 = "test.reify_bound"(%inserted_tensor) {dim = 1 : i64} : (tensor<?xf32>) -> index
return %dim_1, %dim_2 : index, index
}
```
crash trace:
```
mlir-opt: /home/fuzzing/llvm-project/mlir/lib/Interfaces/ValueBoundsOpInterface.cpp:170: void assertValidValueDim(mlir::Value, std::optional<int64_t>): Assertion `*dim < shapedType.getRank() && "invalid dim value"' failed.
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0. Program arguments: /home/fuzzing/llvm-project/build/bin/mlir-opt temp.mlir -pass-pipeline=builtin.module(func.func(test-affine-reify-value-bounds))
#0 0x000000000113ce77 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x113ce77)
#1 0x000000000113aa0e llvm::sys::RunSignalHandlers() (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x113aa0e)
#2 0x000000000113d855 SignalHandler(int, siginfo_t*, void*) Signals.cpp:0:0
#3 0x00007cd102bec520 (/lib/x86_64-linux-gnu/libc.so.6+0x42520)
#4 0x00007cd102c409fc pthread_kill (/lib/x86_64-linux-gnu/libc.so.6+0x969fc)
#5 0x00007cd102bec476 gsignal (/lib/x86_64-linux-gnu/libc.so.6+0x42476)
#6 0x00007cd102bd27f3 abort (/lib/x86_64-linux-gnu/libc.so.6+0x287f3)
#7 0x00007cd102bd271b (/lib/x86_64-linux-gnu/libc.so.6+0x2871b)
#8 0x00007cd102be3e96 (/lib/x86_64-linux-gnu/libc.so.6+0x39e96)
#9 0x0000000006a101a2 (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x6a101a2)
#10 0x0000000006a0fb97 mlir::ValueBoundsConstraintSet::getExpr(mlir::Value, std::optional<long>) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x6a0fb97)
#11 0x0000000006a11052 llvm::SmallVector<std::remove_const<std::remove_reference<decltype(*(std::begin(std::declval<llvm::iterator_range<llvm::mapped_iterator<std::pair<mlir::Value, std::optional<long> > const*, mlir::ValueBoundsConstraintSet::insert(mlir::AffineMap, llvm::SmallVector<std::pair<mlir::Value, std::optional<long> >, 2u>, bool)::$_1, mlir::AffineExpr> >&>())))>::type>::type, CalculateSmallVectorDefaultInlinedElements<std::remove_const<std::remove_reference<decltype(*(std::begin(std::declval<llvm::iterator_range<llvm::mapped_iterator<std::pair<mlir::Value, std::optional<long> > const*, mlir::ValueBoundsConstraintSet::insert(mlir::AffineMap, llvm::SmallVector<std::pair<mlir::Value, std::optional<long> >, 2u>, bool)::$_1, mlir::AffineExpr> >&>())))>::type>::type>::value> llvm::to_vector<llvm::iterator_range<llvm::mapped_iterator<std::pair<mlir::Value, std::optional<long> > const*, mlir::ValueBoundsConstraintSet::insert(mlir::AffineMap, llvm::SmallVector<std::pair<mlir::Value, std::optional<long> >, 2u>, bool)::$_1, mlir::AffineExpr> > >(llvm::iterator_range<llvm::mapped_iterator<std::pair<mlir::Value, std::optional<long> > const*, mlir::ValueBoundsConstraintSet::insert(mlir::AffineMap, llvm::SmallVector<std::pair<mlir::Value, std::optional<long> >, 2u>, bool)::$_1, mlir::AffineExpr> >&&) ValueBoundsOpInterface.cpp:0:0
#12 0x0000000006a10ef4 mlir::ValueBoundsConstraintSet::insert(mlir::AffineMap, llvm::SmallVector<std::pair<mlir::Value, std::optional<long> >, 2u>, bool) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x6a10ef4)
#13 0x0000000006a12273 mlir::ValueBoundsConstraintSet::computeBound(mlir::AffineMap&, llvm::SmallVector<std::pair<mlir::Value, std::optional<long> >, 2u>&, mlir::presburger::BoundType, mlir::ValueBoundsConstraintSet::Variable const&, std::function<bool (mlir::Value, std::optional<long>, mlir::ValueBoundsConstraintSet&)>, bool) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x6a12273)
#14 0x0000000005f73977 mlir::affine::reifyValueBound(mlir::OpBuilder&, mlir::Location, mlir::presburger::BoundType, mlir::ValueBoundsConstraintSet::Variable const&, std::function<bool (mlir::Value, std::optional<long>, mlir::ValueBoundsConstraintSet&)>, bool) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x5f73977)
#15 0x0000000004415e3f mlir::WalkResult llvm::function_ref<mlir::WalkResult (mlir::Operation*)>::callback_fn<std::enable_if<(!(llvm::is_one_of<test::ReifyBoundOp, mlir::Operation*, mlir::Region*, mlir::Block*>::value)) && (std::is_same<mlir::WalkResult, mlir::WalkResult>::value), mlir::WalkResult>::type mlir::detail::walk<(mlir::WalkOrder)1, mlir::ForwardIterator, testReifyValueBounds(mlir::FunctionOpInterface, bool, bool)::$_1, test::ReifyBoundOp, mlir::WalkResult>(mlir::Operation*, testReifyValueBounds(mlir::FunctionOpInterface, bool, bool)::$_1&&)::'lambda'(mlir::Operation*)>(long, mlir::Operation*) TestReifyValueBounds.cpp:0:0
#16 0x00000000012714f7 mlir::WalkResult mlir::detail::walk<mlir::ForwardIterator>(mlir::Operation*, llvm::function_ref<mlir::WalkResult (mlir::Operation*)>, mlir::WalkOrder) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x12714f7)
#17 0x0000000004415641 (anonymous namespace)::TestReifyValueBounds::runOnOperation() TestReifyValueBounds.cpp:0:0
#18 0x00000000042452f7 mlir::detail::OpToOpPassAdaptor::run(mlir::Pass*, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x42452f7)
#19 0x0000000004245b61 mlir::detail::OpToOpPassAdaptor::runPipeline(mlir::OpPassManager&, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int, mlir::PassInstrumentor*, mlir::PassInstrumentation::PipelineParentInfo const*) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x4245b61)
#20 0x000000000424aede 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)::$_15>(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)::$_15&&)::'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
#21 0x000000000424735b mlir::detail::OpToOpPassAdaptor::runOnOperationAsyncImpl(bool) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x424735b)
#22 0x0000000004245450 mlir::detail::OpToOpPassAdaptor::run(mlir::Pass*, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x4245450)
#23 0x0000000004245b61 mlir::detail::OpToOpPassAdaptor::runPipeline(mlir::OpPassManager&, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int, mlir::PassInstrumentor*, mlir::PassInstrumentation::PipelineParentInfo const*) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x4245b61)
#24 0x000000000424825b mlir::PassManager::run(mlir::Operation*) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x424825b)
#25 0x00000000042408af performActions(llvm::raw_ostream&, std::shared_ptr<llvm::SourceMgr> const&, mlir::MLIRContext*, mlir::MlirOptMainConfig const&) MlirOptMain.cpp:0:0
#26 0x0000000004240503 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&)::$_3>(long, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer> >, llvm::raw_ostream&) MlirOptMain.cpp:0:0
#27 0x00000000042ec4e8 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) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x42ec4e8)
#28 0x000000000423a151 mlir::MlirOptMain(llvm::raw_ostream&, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer> >, mlir::DialectRegistry&, mlir::MlirOptMainConfig const&) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x423a151)
#29 0x000000000423a403 mlir::MlirOptMain(int, char**, llvm::StringRef, llvm::StringRef, mlir::DialectRegistry&) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x423a403)
#30 0x000000000423a612 mlir::MlirOptMain(int, char**, llvm::StringRef, mlir::DialectRegistry&) (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x423a612)
#31 0x000000000111a8d7 main (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x111a8d7)
#32 0x00007cd102bd3d90 (/lib/x86_64-linux-gnu/libc.so.6+0x29d90)
#33 0x00007cd102bd3e40 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x29e40)
#34 0x000000000111a435 _start (/home/fuzzing/llvm-project/build/bin/mlir-opt+0x111a435)
Aborted (core dumped)
```
</pre>
<img width="1" height="1" alt="" src="http://email.email.llvm.org/o/eJzsW1tP47zW_jXmxqJKnPMFF6WAPqRBIGY032XkJE7xxrGzbYcX5tdv2U6bQ8tppszs992gAk1ir8PzrGUvOwlWiq45IScgOgXR2RHu9J2QJ7f0lvp-eFSI6unkG1EaCg5L0TRUQxAsoVdnCfJwDLwl8JZKk1ZBLaAkrRRVVxIQmPMg9oC3bBiVx6LVEGrStAtzCI9brNRxS1vCKCcgOAMoKTrKNOWLRlQdIwCldcfLhfkDUKqJ0se4riknx5LQ-un4AbOOHBei45UCKLOfZKvUtIclViNL7MdoB95yKxqC0DNtcys0J4-4aa1ygCJFf5jukPKKPAKUwWMQnEOA0v7EargCklPgLSGEEKDoB5ECguAMYkn13aIUXGnMNfTgIG3bWBOuhMwfMLNd3OGCNK1-GllhVATL_ioIViC4eKwDBILzHUklVnosyh3PFO0VZRjcr2FQQhhpCNf5sz4unJem67YT5YpITarcSR9b5y7tSKZci5lPJkAdtiA6ewGNQW1Fm9wbK6tos8ccQ-TA2isgG5m-lQkQMoGzcIFj4xAg5Djb0WAjxKoPzqAHEueAjetdZbuRlk0NQL9ogO8CMQ7faMgmZHsrJNGd5Fs0evw2hm3zZTX0S87GOegklRKrO6glLuc5OhoznHEXd6IhAF3U3Y8flK8BumDsoTlupfgXKTVAFzar0QWjBUAXl1wTWeOSKIAuvptR4tQOEtft9sqibFsQLP3EMwoeBK0gVgax75jRyvY5ow1AqRUcLEGwtCeNU0pX7oxoNRUcMxCsKNdxmGuHmRG5tNKo4ND4g5YO-RVUd7gl1benlizWRN9ifm_5yiBAMUCx4ZTyB2MENF0enFIEUAJrTBmpFsBb3nw5X349h6orzHCMYdGtzcgrpDYZfKd1q4yF6AKgizXVd12xKEXTo7YLHlWqs1hBzCtIecm6ikB9R6CjqMDlvaXJ6P6qcXkPq65pHWneAtqfGynWEjcQy3Vn0li9kTkz6FfmP-U9j3aqeGGm-PVpwjOWBR70Hr3Nj-8HJUkSaBGy7Kon5b7cSMq1dfubjVWUDo0k_isXSkuCG0ugCXnt6Ex_2nmATr3H3qDBXH9mLsYe2Wfubce_0jXH7P8wrxiRahtgv26R0TlYhGYWVWkUwYluO4BpmzR0TXktcg3Q0hyblLNfs76H6lPSs79OQdArSMrK91BBygh5vR8u0x_TOI_DY0Z593i85p27UC6UWMTW5hBFyBssDicCy9DL6hK2-k4SXOX3lLH3Sc_irC4H6dHc3DCJ4VpZ995rdpjEg-B4KrhCSR1AXAg7b75DLEqTOhjEJjti_eLdAv1iEJjOAAhIFr9PYJCRbOR4No6wGPuej9GvB3IvyKkxmeVN1Xh1kSVwNvK7KWRlyhyJzYBAtLu6Jvr8sZVvnyuY4Ot-cj2AK9bYwRV_hpjvRWg0SnxtMGPfSantTL-1TpJGPJDcFnF7zktSE0m4madXFSmZfmpdhbwEKN02LsjaGDicME0fnMtbA6gmEmshc4n5mkwuNbhtSZVvWoztaLFBdvU-gKH5dS65MeetjLraaULo0s4oV7g1cl6F86fNNU1Q138phGCumrCTeegKrblNNvY2vWP7N92shuwnOHfNLWmTA7SCK8zKjmFNRp6ckRp3TF9yM99W564qV5_h8r8eLpsDV5MG5yPHtMgfNm59kvc7yHMS0k-wf1emmE8GX1xNbkpXMw-jeeVC6vBvitNhCi5Sh0OVEszQQSgJ3oxOKZq20-76cxjFvw2meBo7rSSq6OSa9MfWym_9bPtWD79jSXHByCbJ4olJZqVrjALByjAEf6LyfJMpNuI_IBQM2UMohONQiOokyJJx7e2W8pvygtZPg7kTv6_bU6PULDlnjHwRJbZwffL0Dp56JgaeojFPYehHJKhH1v0_Zve3RHVMj9Jug4CpCCd5Nmo9Y9FMUZas5bgYKTFjBS7v85qP85dwg35OjXDrsT-dElUuOMmFuayJ6km7NVFkcbxupwhPtY-v3JL1vtOnTJT35uy0NLKF1LChN1S4VOUKN-QZKKayR-d3pb_S0JRroxYV0Zgy9_0vzO4dWlMJ19LmTjabCi-E_AvL6nJTOqAVNEjeTjNRTcRd9KyPJsghNJ-bfd_Cz9TT5-PmY2yMN4nmziUMN0WFAUpei2CU2nx-IdQy-G2PwXuqiniy44YSP6yT_Un4IvvP8_sKrodN7R1yN0F4gL1Kh80wfCXz4SsOfaMGc8GfGtEpyHFDVGsDoSd5Hyn9TNTxaz7yKH0Hh-nEEhRGaMLhmK7r9pu4bm-wUssKt5afXvsEWtNgZ2x6fjBbcsyeFFVXmGMz_43ivuP2ZnB1sF3s3r-Bh2zufRH77_b-ZnMzYBpgpunWqfjgcIw7GVWXZhK29zrMwLh8qYHT7C70tt9gSbi-5LUYLaUOhHgR-1vEkTdDHJOKQNxp4W57jUoiLDFjhF0IeY7LOxCs8nzNu7x8fHQN8pwL2WA2Xkm-l7pR2izVEy8vm5YBlE4G3Ov25soA04O6nT63Wwwfq3SkETNmqsePVzpe1K_enQ9vUWVnsWg-wF99ubxdCa7J42Yt_8n5n-H8E_d_XK69WDJ-8v0n-J4wItrNqsZugX-07_1u-yfxf5B4V2tBI3q3NEf-rFRKgqg48ABxkALP2DUUeGheUoeR949eUISRN3gffC4ofvOCIpwhnqJJloxB2xtd872PQ1hobBgsjGYWeimuYUtkLWSztNsW6pWnuLaDlbrDklR5q6e3Nr-KTpbkai1Ht8JmAbJbWo-uMSqvW32FKV8JXtP1SEYGR1f3DFLx3LnIC0YbM1_EmpaYvbYX-1yH8XZlx-m_O7Lj-xVphHw67eraBffoBr59cCCvCCOaPN9nKL6ep-C5vd-9GL6VzI93aDDvjGJGSn1L1lRp-bQbHi-FwFBGBtMdxP8Obl6J0OleGyJlSNKR56plVC95dSNFSZTaGPtn4u7vmBYvtpjc9tSS8vUtqZ89fZDR1xI8jL6zDc4A-5G_P_D_cXl7CDQtXgOa2RzN0AueRbMvK8o77AqI5Xvj4TUkDuRh6A13gANv7mHso4N4-Ftcif3hQdL5M9o-TqsENpjyQzx9baUNutDs6d2gyt75cDTKqmyopOdPW1cBCT2Y56ZPrjSWOh958mYVJBypCOf4hEEEnfDDIBQGkdO2LITUpDJSSyGJfWGBVL0lm_dMjqqToMqCDB-REz8JvSj04sw_ujupwzDBJPCiuEhQVVVRFQYky6IyLNPMR8kRPUEeijyEYi8I_MBfpGWQZh6O0iLERZYEIPRIgylbGPsXQq6P7FsWJz5KUy85YrggTNl37hCycYoQiM6O5In1t-jWCoQeo0qrQYKmmtn39ExpCaKzD3zJ5KiT7OTnXyTpvXw4Qf8JAAD___wvZYM">