<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/63884>63884</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Assertion `!Call.isInvalid() && "Call to __builtin_memcpy cannot fail!"' on code with __restrict
</td>
</tr>
<tr>
<th>Labels</th>
<td>
clang:frontend,
crash
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
wheatman
</td>
</tr>
</table>
<pre>
The following code triggers an assertion and dump
https://gcc.godbolt.org/z/s8qj851hE on post 16 trunk(ba7cc56782dbf4a26c0a043dd33c7949366e2b0d) when compiling in c++ mode
```
struct Obj { int * __restrict myPtr[2]; };
int main() {
Obj a, b;
a = b;
return 0;
}
```
the assertion is
```
clang++: /root/llvm-project/clang/lib/Sema/SemaDeclCXX.cpp:14315: clang::StmtResult
buildMemcpyForAssignmentOp(clang::Sema&, clang::SourceLocation, clang::QualType, const {anonymous}::ExprBuilder&, const {anonymous}::ExprBuilder&):
Assertion `!Call.isInvalid() && "Call to __builtin_memcpy cannot fail!"' failed.
```
I found this when looking at https://github.com/llvm/llvm-project/issues/37979 but made a new issue since that issue was more about supporting restrict generally, and not about a crash
The full dump is
```
<source>:1:8: error: cannot initialize a parameter of type 'void *' with an rvalue of type 'int *__restrict (*)[2]'
1 | struct Obj { int * __restrict myPtr[2]; };
| ^~~
<source>:5:7: note: in implicit copy assignment operator for 'Obj' first required here
5 | a = b;
| ^
clang++: /root/llvm-project/clang/lib/Sema/SemaDeclCXX.cpp:14315: clang::StmtResult buildMemcpyForAssignmentOp(clang::Sema&, clang::SourceLocation, clang::QualType, const {anonymous}::ExprBuilder&, const {anonymous}::ExprBuilder&): Assertion `!Call.isInvalid() && "Call to __builtin_memcpy cannot fail!"' failed.
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace, preprocessed source, and associated run script.
Stack dump:
0. Program arguments: /opt/compiler-explorer/clang-assertions-trunk/bin/clang++ -gdwarf-4 -g -o /app/output.s -mllvm --x86-asm-syntax=intel -S --gcc-toolchain=/opt/compiler-explorer/gcc-snapshot -fcolor-diagnostics -fno-crash-diagnostics <source>
1. <source>:5:10: current parser token ';'
2. <source>:3:12: parsing function body 'main'
3. <source>:3:12: in compound statement ('{}')
#0 0x0000564d7c89ac1a llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x3a9ac1a)
#1 0x0000564d7c89884c llvm::sys::CleanupOnSignal(unsigned long) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x3a9884c)
#2 0x0000564d7c7e7020 CrashRecoverySignalHandler(int) CrashRecoveryContext.cpp:0:0
#3 0x00007fc4d836a420 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x14420)
#4 0x00007fc4d7e3700b raise (/lib/x86_64-linux-gnu/libc.so.6+0x4300b)
#5 0x00007fc4d7e16859 abort (/lib/x86_64-linux-gnu/libc.so.6+0x22859)
#6 0x00007fc4d7e16729 (/lib/x86_64-linux-gnu/libc.so.6+0x22729)
#7 0x00007fc4d7e27fd6 (/lib/x86_64-linux-gnu/libc.so.6+0x33fd6)
#8 0x0000564d7ef7d7c6 (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x617d7c6)
#9 0x0000564d7ef7d8cb buildSingleCopyAssign(clang::Sema&, clang::SourceLocation, clang::QualType, (anonymous namespace)::ExprBuilder const&, (anonymous namespace)::ExprBuilder const&, bool, bool) SemaDeclCXX.cpp:0:0
#10 0x0000564d7efa51bc clang::Sema::DefineImplicitCopyAssignment(clang::SourceLocation, clang::CXXMethodDecl*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x61a51bc)
#11 0x0000564d7f092230 void llvm::function_ref<void ()>::callback_fn<clang::Sema::MarkFunctionReferenced(clang::SourceLocation, clang::FunctionDecl*, bool)::'lambda'()>(long) SemaExpr.cpp:0:0
#12 0x0000564d7ed616ff clang::Sema::runWithSufficientStackSpace(clang::SourceLocation, llvm::function_ref<void ()>) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5f616ff)
#13 0x0000564d7f08fc0b clang::Sema::MarkFunctionReferenced(clang::SourceLocation, clang::FunctionDecl*, bool) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x628fc0b)
#14 0x0000564d7f0968cd MarkExprReferenced(clang::Sema&, clang::SourceLocation, clang::Decl*, clang::Expr*, bool, llvm::DenseMap<clang::VarDecl const*, int, llvm::DenseMapInfo<clang::VarDecl const*, void>, llvm::detail::DenseMapPair<clang::VarDecl const*, int>>&) SemaExpr.cpp:0:0
#15 0x0000564d7f3b789b CreateFunctionRefExpr(clang::Sema&, clang::FunctionDecl*, clang::NamedDecl*, clang::Expr const*, bool, clang::SourceLocation, clang::DeclarationNameLoc const&) SemaOverload.cpp:0:0
#16 0x0000564d7f3ed371 clang::Sema::CreateOverloadedBinOp(clang::SourceLocation, clang::BinaryOperatorKind, clang::UnresolvedSetImpl const&, clang::Expr*, clang::Expr*, bool, bool, clang::FunctionDecl*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x65ed371)
#17 0x0000564d7f07e2fc BuildOverloadedBinOp(clang::Sema&, clang::Scope*, clang::SourceLocation, clang::BinaryOperatorKind, clang::Expr*, clang::Expr*) SemaExpr.cpp:0:0
#18 0x0000564d7f0e1620 clang::Sema::BuildBinOp(clang::Scope*, clang::SourceLocation, clang::BinaryOperatorKind, clang::Expr*, clang::Expr*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x62e1620)
#19 0x0000564d7f0e1a47 clang::Sema::ActOnBinOp(clang::Scope*, clang::SourceLocation, clang::tok::TokenKind, clang::Expr*, clang::Expr*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x62e1a47)
#20 0x0000564d7ec934f0 clang::Parser::ParseRHSOfBinaryExpression(clang::ActionResult<clang::Expr*, true>, clang::prec::Level) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e934f0)
#21 0x0000564d7ec92d49 clang::Parser::ParseExpression(clang::Parser::TypeCastState) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e92d49)
#22 0x0000564d7ecfe56d clang::Parser::ParseExprStatement(clang::Parser::ParsedStmtContext) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5efe56d)
#23 0x0000564d7ecf67df clang::Parser::ParseStatementOrDeclarationAfterAttributes(llvm::SmallVector<clang::Stmt*, 32u>&, clang::Parser::ParsedStmtContext, clang::SourceLocation*, clang::ParsedAttributes&, clang::ParsedAttributes&) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5ef67df)
#24 0x0000564d7ecf7597 clang::Parser::ParseStatementOrDeclaration(llvm::SmallVector<clang::Stmt*, 32u>&, clang::Parser::ParsedStmtContext, clang::SourceLocation*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5ef7597)
#25 0x0000564d7ecf84c9 clang::Parser::ParseCompoundStatementBody(bool) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5ef84c9)
#26 0x0000564d7ecf8a3b clang::Parser::ParseFunctionStatementBody(clang::Decl*, clang::Parser::ParseScope&) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5ef8a3b)
#27 0x0000564d7ec47ed8 clang::Parser::ParseFunctionDefinition(clang::ParsingDeclarator&, clang::Parser::ParsedTemplateInfo const&, clang::Parser::LateParsedAttrList*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e47ed8)
#28 0x0000564d7ec72d31 clang::Parser::ParseDeclGroup(clang::ParsingDeclSpec&, clang::DeclaratorContext, clang::ParsedAttributes&, clang::SourceLocation*, clang::Parser::ForRangeInit*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e72d31)
#29 0x0000564d7ec3e728 clang::Parser::ParseDeclOrFunctionDefInternal(clang::ParsedAttributes&, clang::ParsedAttributes&, clang::ParsingDeclSpec&, clang::AccessSpecifier) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e3e728)
#30 0x0000564d7ec3f0a6 clang::Parser::ParseDeclarationOrFunctionDefinition(clang::ParsedAttributes&, clang::ParsedAttributes&, clang::ParsingDeclSpec*, clang::AccessSpecifier) (.part.321) Parser.cpp:0:0
#31 0x0000564d7ec4394b clang::Parser::ParseExternalDeclaration(clang::ParsedAttributes&, clang::ParsedAttributes&, clang::ParsingDeclSpec*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e4394b)
#32 0x0000564d7ec45176 clang::Parser::ParseTopLevelDecl(clang::OpaquePtr<clang::DeclGroupRef>&, clang::Sema::ModuleImportState&) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e45176)
#33 0x0000564d7ec3a22b clang::ParseAST(clang::Sema&, bool, bool) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x5e3a22b)
#34 0x0000564d7d967560 clang::CodeGenAction::ExecuteAction() (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x4b67560)
#35 0x0000564d7d2892e9 clang::FrontendAction::Execute() (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x44892e9)
#36 0x0000564d7d21dc42 clang::CompilerInstance::ExecuteAction(clang::FrontendAction&) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x441dc42)
#37 0x0000564d7d360c9f clang::ExecuteCompilerInvocation(clang::CompilerInstance*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x4560c9f)
#38 0x0000564d7a022cc3 cc1_main(llvm::ArrayRef<char const*>, char const*, void*) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x1222cc3)
#39 0x0000564d7a01ade8 ExecuteCC1Tool(llvm::SmallVectorImpl<char const*>&, llvm::ToolContext const&) driver.cpp:0:0
#40 0x0000564d7d0912f9 void llvm::function_ref<void ()>::callback_fn<clang::driver::CC1Command::Execute(llvm::ArrayRef<std::optional<llvm::StringRef>>, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char>>*, bool*) const::'lambda'()>(long) Job.cpp:0:0
#41 0x0000564d7c7e74a5 llvm::CrashRecoveryContext::RunSafely(llvm::function_ref<void ()>) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x39e74a5)
#42 0x0000564d7d093eee clang::driver::CC1Command::Execute(llvm::ArrayRef<std::optional<llvm::StringRef>>, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char>>*, bool*) const (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x4293eee)
#43 0x0000564d7d06060b clang::driver::Compilation::ExecuteCommand(clang::driver::Command const&, clang::driver::Command const*&, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x426060b)
#44 0x0000564d7d0611e3 clang::driver::Compilation::ExecuteJobs(clang::driver::JobList const&, llvm::SmallVectorImpl<std::pair<int, clang::driver::Command const*>>&, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x42611e3)
#45 0x0000564d7d069fd6 clang::driver::Driver::ExecuteCompilation(clang::driver::Compilation&, llvm::SmallVectorImpl<std::pair<int, clang::driver::Command const*>>&) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x4269fd6)
#46 0x0000564d7a020a8e clang_main(int, char**, llvm::ToolContext const&) (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x1220a8e)
#47 0x0000564d79f51cb1 main (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x1151cb1)
#48 0x00007fc4d7e18083 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24083)
#49 0x0000564d7a01a4da _start (/opt/compiler-explorer/clang-assertions-trunk/bin/clang+++0x121a4da)
clang++: error: clang frontend command failed with exit code 134 (use -v to see invocation)
Compiler returned: 134
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzkW91y4zaWfhr6BiUXCf5f-EKW7RlnO-veVu9s7lQgeCghTQIMALrtuZhn3wJIyQRNy-5EyqR2U2lLIsGD833nFyBJlGJbDnDlxddefHNBOr0T8ur7DohuCL8oRPl89XUHqBJ1Lb4zvkVUlIC0ZNstSIUIR0QpkJoJjggvUdk1reffeP5yp3WrvHDp4TsP320pvdyKshC1vhRy6-G7f3r4TmW__ZrFwe4WCY5aoTQKEqRlx795OCtISmmcpBkuiyoiOKE-8aOwLMOQpnmUh0kCuPBLD-fo-w44oqJpWW2UZBxRD197-Bo1ooReoeFv4g__259Ky45q9FD8irz0GjGukYeXaLORoLRkVKPm-bOWXnyNvfjGC6-Rl5qP_mozvCGMezgzWnjpcBwhZEUSD69QcRhuDhPkhTeTYxJ0JznyDwfNHHPa9n_1DkasM4Vmx9Ka8G1PghcukYfvpBDaw3d1_dgsWil-BWp-DuPualZ4-G4NDRk-boDWq19-uaRt64XLIAqD2Ajqx4dLL1yudaO_gOpqPahQdKwuf4aGts93Qi6tdzXA9UPr4Wx8oZ0lMeyMj4pOUvgkKDHAJif_qyP11-cW7GHBlTZsEy74cyM6ZY1iht0-tfLaaAFyP8HHB-eWKItkeeDXEIqDFanrS6bu-SOpWbm3t7koQR7G5jTSAm02hgLN-KaxLCBKOBcaVYTVHg48jD2c2l9QXh4x8T2qRMdLpHdM9c5dC_HNuDbRaBJZTO-64pKKZrDtaxMzpTpQHr4L0zzNUdEZry0BEcThO7JnkWKcAtI7oocD34lCjZCASCE6jVTXtkJqo8IhNLbAQZK6fjY8m-g3UPvhBFFJ1G6MyeaRrq5tjnjTbb1wpawfeOGtcTsvXGbGLCClkNb_ekYZZ5qRmv3TwGiJJA1okEhUSD-3gDycPgpWmmA2jH9nemeSlXwkdQfjUUPEjwLeGndpvGEIepy-hGqAvHSF_ljWsCKG_7z49l__mkVugi01gLnQYD4ZR6xpa0aZRlS0z4gc4guJFiTRQqJKSIPqofjVOhqTSiMJv3VMQol2IOEFSnzQYy4nIXvWi2__Hdnk_0Ie-fMyyOdPt8v1LVJd0TATeUVnYtREqxH4-7OFDWnGad2Zkr-DPqRRQeg3LQm1FLYSWikoKAUlGtx3SAZEKUEZ0VAi2XGkqGStHlRea0K_9c1COKQH_9Lz889SbCVpEJHbzhhcDc4mWutctsCDXMBTWwtp2O4dbnEoh2oxtA93hSnLdyO_RYtt-Z3IahGhxRYthJFL2tZI73Tb6UuFFo3hAi0WT1myIKpZqGeuyZMX3jCuoUaLNVostpQutBA13ZnKH94cVc8MVpy0aic0WlRU1EIuSka2XCjNqEKLiouFJdY57CQDy09g-JnJEYFv46iT0iSClkgFEmnxDbhJBCam9_kLz0gIjQRsJJgrTXavOk6t25rmz4joG5xBRnhUBuubMFu6lCYabHKyvp6a5ii1yRTn-zyIQx_5T77v-3ESlSnNckIDgqxf2shSz6r_8lkyrq3XfO1dL3sZJMn3jVBaAmmGWGVc99GVnch3PHztP4XEqufoH0z0z7KIzum_qoHwrn3ga7blpPZw1nHbe5eoFmaWc2hrlHG0xY62KaQ-9tHKON8XoOIR5HOv3t8JL2szaTYw6YxZCa7hSQ-p3Lf_DlOEwxRpRaMyCxMSYX8ojELCRg7uMBSIpyzZJNGiZrx7Wmx5159o9U4CKS-VuPQtliCKsO8gicbTpBCmvl8gSZiCD8inRnJiJUeh7xeO5NiVHCRZnJum5kOajyRjnMW5IzmZSk4PVv-wzBS7MlNXJk6rMvkxmWFYlYkjMxt7CVRpmdLk1N6ZBFasM28-nTejRd8KrBnf1rAS7XPfC5y0C_BwdijpiJMGVGszTP6quPc9wDDV77ysEKJ--czR695oFFAmwfguKyQOCoqm6O23G6gYh_uhR3xhyyThCWPHuFn98svPoHeiNGr1nfDprW9hHKxvcDqZtPJzbIqD7eFf0um-Nm0kVF64Gjr8zJJ-2w-hpK5Nh7KpuBeuZnn6mchvd4OkL1CBBE6h_AGG9hcfCDqYsz_v4bQmTVESW-326uFsn-mNKsY_5g3uJGkokyCpqnmDy47_D9O7dVdVjDIYCuS698PjaD7K6eltH1cWkWP70LV9VlG_mId8Rtud3MmxxeEAjSZOnmS0RAaTcYc38fx4fhuhGx01kziYx35wA1zBz6R1o-YfRBpZ-xS2PHRXc5fe80q8f7nxMOtaYxElaLPAccR9Jkx-TBsT_Lf90uud4IodA4RFmuUFWkkgGkZu1RP1vg1mnGl09j9JA-XblnBQ7O3xIwYm0p4x03wSdFRlehIeHkHWgpTzRCQuEVCGaTAfcj07e2lQXjP-ah1-TNVrxol8fhh2KP6D8XIy4L-5BCXqRyjXoE35cgrmvP8e9-oZNl-Z6vTxHlsSnXhP3XhPAVcU2bbgOJ_zEU-F6Vim-P8Y-e9w-l48ZS5ACBLsz7uRRT2H9d-C6uS53iJ3bJ9PqSFROk_NkuoHfiJqtPjWf_kqvgH_i1BDonRMDXZ7WpqHUeV4zWe7izH6_uXv64eqt7rRFJSyyMdkLYfkrbpau1VjhFjLDobaMxrQSqD9t0_wCOfoBWKwGB0SggkJuIzyoyS8hXw80CxqVkSZTlDDeYAYPR0gbsNKK4iT8l0g6_320NtY7PdyrRs97DicBY9V18ETTvAkaVkdxXPA8iBHdXlZaZBLrSUrOg3K2bJaN6Su_wFUi0mHY9AOvhribt_VrI5O71J0NFVMw76_fqzk7GzTEecwg2HZMUM0MUMa5-nvMMNfhfdzcGYocTiLJ5xlET2eU1bDdu2Bu2tRPns4O9OaKAarkqNzMtWZhMVRnfet3FTnd9c_rz2mL7Bn8mgDxEGaukijFMrsQ0jtzg7Ts5mf8e3e24X8iNd-haatiQazWnur0x5f9YloeMkCn9iwZjkDY5YQhzF3K5KmuAyDo-gMFX-TomvfJGrdAn0N-IXC-YB-P1F-KNUOqt4J-YXwLdxzdjYyLVcOme7-Kg0hxcfdz5DyIEdOeM81yP72xR8vIq9GHDXQklJQypxjFTOMnIEyy8iYsnDSqIaVT5J3KRsKj8Pcm-F7cuKmfjdP3GVLpL4MsfEQ1KOYXeCFky41CvPoeHa-fep9xC3BfwLqcyQkg9ZxiEmvG8VBetwhvorWLir6ijTm4aElv3XwWU86kUMG-wLVbB8y2gwVZVfDfdMKuW_4z1PKLEyHh0mPHBKMX7vFcv31zX2N6X2Q0wezUcnR2WkoyzxJ48RZda5ECX8D3i8k90tHoJ2G4dD-mY2TahoVVhFHU6eNK3GWY3DauDtpihQvZ1Q9k5KR1cFRMnGVDEoaYZfOftp7rjThFOYZfRvVWXw5iqyeDhCnLSvDxKd55e6NWJVf8Dweinx2DO9ZklIUW_0cAE6XRHyMKQ0RpcFmeDb1Zf2zlJI828Syojsy2oIe9kScY_u9-rPgCLBV08GRuzgCUkKG9uyvgq82Vcyv5u6btp4Flbj3GYyMocNzNsxLyR7fKIGR0wSUfh7gKj_lncl-7sGJVsFKNA3h5TSqZ42o9DBOtGZ2YjgY8aMl49uhjvQWPlyw2dCnpyDofxREMbpRdvjAojPYHNhoSZhW-9MTcaSuTVD0y-rhvBky2pa3XtRzbi957y7pT6KYt0cwfYolIvHIFHPPqvRnvnR8TSqonx06_-wboGFuNR57foQnLhYCAPr_7CInT5vYcuqQHrqkJ37i3nV2SLcqkFfldm8JpxJMLjQD3lpoHxm6dDqls_FiYTu8RBNeggDCH-XlJ1Got0n5SRSfmNIOKcfS-sGH2v6W8HAH-qM8vtwePj-bhiyHzXjCZl6VyVua34y-O13HTLvxlhX-RDZP39xgS4_DXzJpbnySDalx397s9bcpaTkklPdL_ukbGqOao7vTWeZVHNAisC8MnXzywMp2Js8mjxtmfhaizaZmhcnjROrNSJOPPoAY-Znr3q96tqgkqJd_eoat9MP04_POGyLmOKqG1QSigwP3z8z3r4LAk32JogQUhJHRs1OAFo9IC6QAEBu1-MNk--5-eFkLTAiZi4-8xHNRXoVlHubkAq6CJMujKMJxdrG7qvI0xj5OiiDPszBOSEazLMQ4TJKsLKLkgl1hH4d-GsRB5kdBdhn5eQlxTmlkFuMZ9SIfGsLqS-Pml0JuL-xT-1dJmGXRRU0KqJV9qQ_jfVjv-bBvEKzMCfuCDsZefHMhr-xLAEW3VV7k10xp9SJaM13D1VnfZxC8t4Y1zstrNBedrK9-_wsMlo3_DQAA__9P3nrk">