|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| | This saves a small amount of code size, and is a first small step toward
passing values on the stack across block boundaries.
Differential Review: http://reviews.llvm.org/D20450
llvm-svn: 270294 | 
| | 
| 
| 
| | llvm-svn: 270137 | 
| | 
| 
| 
| | llvm-svn: 269862 | 
| | 
| 
| 
| | llvm-svn: 261465 | 
| | 
| 
| 
| 
| 
| | Differential Revision: http://reviews.llvm.org/D16554
llvm-svn: 258872 | 
| | 
| 
| 
| 
| 
| 
| | This pass runs after FrameIndex elimination, so it should never see FI
operands. NFC
llvm-svn: 258860 | 
| | 
| 
| 
| 
| 
| | I forgot to update this one in my previous patch.
llvm-svn: 258853 | 
| | 
| 
| 
| 
| 
| | r258781 optimized memcpy/memmove/memcpy so the intrinsic call can return its first argument, but missed the frame index case. Teach it to ignore that case so C code doesn't assert out in these cases.
llvm-svn: 258851 | 
| | 
| 
| 
| 
| 
| 
| 
| | These calls return their first argument, but because LLVM uses an intrinsic
with a void return type, they can't use the returned attribute. Generalize
the store results pass to optimize these calls too.
llvm-svn: 258781 | 
| | 
| 
| 
| 
| 
| | Differential Revision: http://reviews.llvm.org/D16534
llvm-svn: 258779 | 
| | 
| 
| 
| | llvm-svn: 258294 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Use the SP32 physical register as the base for FrameIndex
lowering. Update it and the __stack_pointer global var in the prolog and
epilog. Extend the mapping of virtual registers to wasm locals to
include the physical registers.
Rather than modify the target-independent PrologEpilogInserter (which
asserts that there are no virtual registers left) include a
slightly-modified copy for Wasm that does not have this assertion and
only clears the virtual registers if scavenging was needed (which of
course it isn't for wasm).
Differential Revision: http://reviews.llvm.org/D15344
llvm-svn: 255392 | 
| | 
| 
| 
| 
| 
| | changes.
llvm-svn: 255252 | 
| | 
| 
| 
| | llvm-svn: 255251 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | MachineBlockPlacement
This patch introduces a codegen-only instruction currently named br_unless,
which makes it convenient to implement ReverseBranchCondition and re-enable
the MachineBlockPlacement pass. Then in a late pass, it lowers br_unless
back into br_if.
Differential Revision: http://reviews.llvm.org/D14995
llvm-svn: 254826 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | If virtual registers are created late, mappings to WebAssembly
registers need to be added explicitly. This patch adds a function
to do so and teaches WebAssemblyPeephole to use it. This fixes
an out-of-bounds access on the WARegs vector.
llvm-svn: 254094 | 
|  | llvm-svn: 254076 |