When passing a parameter using the 'byval' mechanism, inline code needs to be used
authorDuncan Sands <baldrick@free.fr>
Fri, 5 Nov 2010 15:20:29 +0000 (15:20 +0000)
committerDuncan Sands <baldrick@free.fr>
Fri, 5 Nov 2010 15:20:29 +0000 (15:20 +0000)
to perform the copy, which may be of lots of memory [*].  It would be good if the
fall-back code generated something reasonable, i.e. did the copy in a loop, rather
than vast numbers of loads and stores.  Add a note about this.  Currently target
specific code seems to always kick in so this is more of a theoretical issue rather
than a practical one now that X86 has been fixed.
[*] It's amazing how often people pass mega-byte long arrays by copy...

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@118275 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/SelectionDAG.cpp

index 0840bd740be154f201cdab8eaba9a2c5d2942bb3..5477e7bf60d49c00819cb5208b3a442d0987c154 100644 (file)
@@ -3283,6 +3283,8 @@ static SDValue getMemcpyLoadsAndStores(SelectionDAG &DAG, DebugLoc dl,
 
   // Expand memcpy to a series of load and store ops if the size operand falls
   // below a certain threshold.
+  // TODO: In the AlwaysInline case, if the size is big then generate a loop
+  // rather than maybe a humongous number of loads and stores.
   const TargetLowering &TLI = DAG.getTargetLoweringInfo();
   std::vector<EVT> MemOps;
   bool DstAlignCanChange = false;