- Apr 21, 2014
-
-
Reid Kleckner authored
The -tailcallelim pass should be checking if byval or inalloca args can be captured before marking calls as tail calls. This was the real root cause of PR7272. With a better fix in place, revert the inliner change from r105255. The test case it introduced still passes and has been moved to test/Transforms/Inline/byval-tail-call.ll. Reviewers: chandlerc Differential Revision: http://reviews.llvm.org/D3403 llvm-svn: 206789
-
David Blaikie authored
llvm-svn: 206788
-
David Blaikie authored
llvm-svn: 206786
-
David Blaikie authored
llvm-svn: 206785
-
David Blaikie authored
llvm-svn: 206784
-
David Blaikie authored
Requires switching some vectors to lists to maintain pointer validity. These could be changed to forward_lists (singly linked) with a bit more work - I've left comments to that effect. llvm-svn: 206780
-
Filipe Cabecinhas authored
Summary: The INSERTPS pattern fragment was called insrtps (mising 'e'), which would make it harder to grep for the patterns related to this instruction. Renaming it to use the proper instruction name. Reviewers: nadav CC: llvm-commits Differential Revision: http://reviews.llvm.org/D3443 llvm-svn: 206779
-
Chandler Carruth authored
cpp file rather than in the header and then again in the cpp file. llvm-svn: 206778
-
Chandler Carruth authored
header files and into the cpp files. These files will require more touches as the header files actually use DEBUG(). Eventually, I'll have to introduce a matched #define and #undef of DEBUG_TYPE for the header files, but that comes as step N of many to clean all of this up. llvm-svn: 206777
-
Chandler Carruth authored
various .cpp files. This macro is inherently non-modular, and it wasn't even needed in this header file. llvm-svn: 206775
-
Yi Jiang authored
llvm-svn: 206774
-
Jim Grosbach authored
Tentative revert for http://lab.llvm.org:8011/builders/llvm-mips-linux/builds/8305. This reverts commit c2a58efff07294fca724f89500538f2ddbcd12ff. llvm-svn: 206773
-
Matt Arsenault authored
llvm-svn: 206772
-
Duncan P. N. Exon Smith authored
Change `PositiveFloat` to `UnsignedFloat`, and fix some of the comments to indicate that it's disappearing eventually. llvm-svn: 206771
-
Jim Grosbach authored
llvm-svn: 206769
-
Duncan P. N. Exon Smith authored
This reverts commit r206707, reapplying r206704. The preceding commit to CalcSpillWeights should have sorted out the failing buildbots. <rdar://problem/14292693> llvm-svn: 206766
-
Duncan P. N. Exon Smith authored
This gross hack forces `hweight` into memory, preventing hidden precision from making `1 > 1` occasionally equal `true`. <rdar://problem/14292693> llvm-svn: 206765
-
Evgeniy Stepanov authored
llvm-svn: 206759
-
NAKAMURA Takumi authored
It can be reverted a few days later, after X86Disassembler.d is updated not to contain "X86Disassembler.c". llvm-svn: 206758
-
Kostya Serebryany authored
llvm-svn: 206756
-
Rafael Espindola authored
We normally don't drop functions from the C API's, but in this case I think we can: * The old implementation of getFileOffset was fairly broken * The introduction of LLVMGetSymbolFileOffset was itself a C api breaking change as it removed LLVMGetSymbolOffset. * It is an incredibly specialized use case. The only reason MCJIT needs it is because of its odd position of being a dynamic linker of .o files. llvm-svn: 206750
-
Michael Zolotukhin authored
llvm-svn: 206749
-
Kostya Serebryany authored
[asan] instead of inserting inline instrumentation around memset/memcpy/memmove, replace the intrinsic with __asan_memset/etc. This makes the memset/etc handling more complete and consistent with what we do in msan. It may slowdown some cases (when the intrinsic was actually inlined) and speedup other cases (when it was not inlined) llvm-svn: 206746
-
Chandler Carruth authored
LazyCallGraph analysis framework. Wire it up all the way through the opt driver and add some very basic testing that we can build pass pipelines including these components. Still a lot more to do in terms of testing that all of this works, but the basic pieces are here. There is a *lot* of boiler plate here. It's something I'm going to actively look at reducing, but I don't have any immediate ideas that don't end up making the code terribly complex in order to fold away the boilerplate. Until I figure out something to minimize the boilerplate, almost all of this is based on the code for the existing pass managers, copied and heavily adjusted to suit the needs of the CGSCC pass management layer. The actual CG management still has a bunch of FIXMEs in it. Notably, we don't do *any* updating of the CG as it is potentially invalidated. I wanted to get this in place to motivate the new analysis, and add update APIs to the analysis and the pass management layers in concert to make sure that the *right* APIs are present. llvm-svn: 206745
-
Chandler Carruth authored
became empty. This would manifest later as an assert failure due to a non-empty list map but an empty result map. This doesn't easily manifest with just the module pass manager and the function pass manager, but the next commit will add the CGSCC pass manager that hits this assert immediately. llvm-svn: 206744
-
Kostya Serebryany authored
llvm-svn: 206741
-
Benjamin Kramer authored
No functionality change. llvm-svn: 206740
-
Lang Hames authored
Generating BZHI in the variable mask case, i.e. (and X, (sub (shl 1, N), 1)), was already supported, but we were missing the constant-mask case. This patch fixes that. <rdar://problem/15480077> llvm-svn: 206738
-
Chandler Carruth authored
Original commit message: Implement builtins for safe division: safe.sdiv.iN, safe.udiv.iN, safe.srem.iN, safe.urem.iN (iN = i8, i61, i32, or i64). llvm-svn: 206735
-
Kostya Serebryany authored
llvm-svn: 206734
-
Michael Zolotukhin authored
safe.urem.iN (iN = i8, i16, i32, or i64). llvm-svn: 206732
-
Chandler Carruth authored
llvm-svn: 206730
-
David Blaikie authored
It could even be made non-virtual if it weren't for bad compiler warnings. This demonstrates that ArgList objects aren't destroyed polymorphically and possibly that they aren't even used polymorphically. If that's the case, it might be possible to refactor the two ArgList types more separately and simplify the Arg ownership model. *continues experimenting* llvm-svn: 206727
-
David Blaikie authored
This might be able to be simplified further by using Arg as a value type in a linked list (to maintain pointer validity), but here's something simple to start with. llvm-svn: 206724
-
Richard Smith authored
llvm-svn: 206723
-
Richard Smith authored
llvm-svn: 206722
-
- Apr 20, 2014
-
-
Richard Smith authored
llvm-svn: 206721
-
Richard Smith authored
Don't provide two different definitions of ModRMDecision, OpcodeDecision, and ContextDecision in different source files (depending on #define magic). llvm-svn: 206720
-
Richard Smith authored
different source files. llvm-svn: 206719
-
Richard Smith authored
llvm-svn: 206718
-