|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Creates a configurable regalloc pipeline.
Ensure specific llc options do what they say and nothing more: -reglloc=... has no effect other than selecting the allocator pass itself. This patch introduces a new umbrella flag, "-optimize-regalloc", to enable/disable the optimizing regalloc "superpass". This allows for example testing coalscing and scheduling under -O0 or vice-versa.
When a CodeGen pass requires the MachineFunction to have a particular property, we need to explicitly define that property so it can be directly queried rather than naming a specific Pass. For example, to check for SSA, use MRI->isSSA, not addRequired<PHIElimination>.
CodeGen transformation passes are never "required" as an analysis
ProcessImplicitDefs does not require LiveVariables.
We have a plan to massively simplify some of the early passes within the regalloc superpass.
llvm-svn: 150226 | 
| | 
| 
| 
| | llvm-svn: 149671 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | A REG_SEQUENCE instruction is lowered into a sequence of partial defs:
  %vreg7:ssub_0<def,undef> = COPY %vreg20:ssub_0
  %vreg7:ssub_1<def> = COPY %vreg2
  %vreg7:ssub_2<def> = COPY %vreg2
  %vreg7:ssub_3<def> = COPY %vreg2
The first def needs an <undef> flag to indicate it is the beginning of
the live range, while the other defs are read-modify-write.  Previously,
we depended on LiveIntervalAnalysis to notice and fix the missing
<def,undef>, but that solution was never robust, it was causing problems
with ProcessImplicitDefs and the lowering of chained REG_SEQUENCE
instructions.
This fixes PR11841.
llvm-svn: 148879 | 
| | 
| 
| 
| 
| 
| 
| | This won't have an effect until EliminateRegSequences() starts setting
the undef flags.
llvm-svn: 148779 | 
| | 
| 
| 
| 
| 
| | TwoAddressInstructionPass to insert copies for any physical reg operands of the REG_SEQUENCE
llvm-svn: 148377 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | generator to it. For non-bundle instructions, these behave exactly the same
as the MC layer API.
For properties like mayLoad / mayStore, look into the bundle and if any of the
bundled instructions has the property it would return true.
For properties like isPredicable, only return true if *all* of the bundled
instructions have the property.
For properties like canFoldAsLoad, isCompare, conservatively return false for
bundles.
llvm-svn: 146026 | 
| | 
| 
| 
| 
| 
| | -3% on ARMDissasembler.cpp.
llvm-svn: 145773 | 
| | 
| 
| 
| | llvm-svn: 144806 | 
| | 
| 
| 
| 
| 
| | kill markers.
llvm-svn: 144804 | 
| | 
| 
| 
| | llvm-svn: 144776 | 
| | 
| 
| 
| 
| 
| | since we don't want to extend other live ranges.
llvm-svn: 144772 | 
| | 
| 
| 
| 
| 
| | instructions. rdar://10451185
llvm-svn: 144771 | 
| | 
| 
| 
| 
| 
| | rdar://10449480
llvm-svn: 144770 | 
| | 
| 
| 
| 
| 
| | non-deterministic behavior.
llvm-svn: 144628 | 
| | 
| 
| 
| | llvm-svn: 144569 | 
| | 
| 
| 
| 
| 
| 
| 
| | "kill". This looks like a bug upstream. Since that's going to take some time
to understand, loosen the assertion and disable the optimization when
multiple kills are seen.
llvm-svn: 144568 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | instructions of the two-address operands) in order to avoid inserting copies.
This fixes the few regressions introduced when the two-address hack was
disabled (without regressing the improvements).
rdar://10422688
llvm-svn: 144559 | 
| | 
| 
| 
| 
| 
| | block; make sure we don't do that.
llvm-svn: 140428 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This flag is true from isel to register allocation when the machine
function is required to be in SSA form.  The TwoAddressInstructionPass
and PHIElimination passes clear the flag.
The SSA flag wil be used by the machine code verifier to check for SSA
form, and eventually an assertion can enforce it in +Asserts builds.
This will catch the common target error of creating machine code with
multiple defs of a virtual register.
llvm-svn: 136532 | 
| | 
| 
| 
| 
| 
| 
| 
| | sink them into MC layer.
- Added MCInstrInfo, which captures the tablegen generated static data. Chang
TargetInstrInfo so it's based off MCInstrInfo.
llvm-svn: 134021 | 
| | 
| 
| 
| | llvm-svn: 133944 | 
| | 
| 
| 
| | llvm-svn: 133350 | 
| | 
| 
| 
| 
| 
| | operands to an early clobber register. This fixes <rdar://problem/9566076>.
llvm-svn: 132738 | 
| | 
| 
| 
| 
| 
| | rdar://9002648.
llvm-svn: 126811 | 
| | 
| 
| 
| 
| 
| | add a missing check when considering whether it's profitable to commute. rdar://8977508.
llvm-svn: 125259 | 
| | 
| 
| 
| 
| 
| 
| 
| | These functions not longer assert when passed 0, but simply return false instead.
No functional change intended.
llvm-svn: 123155 | 
| | 
| 
| 
| | llvm-svn: 123108 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Instead encode llvm IR level property "HasSideEffects" in an operand (shared
with IsAlignStack). Added MachineInstrs::hasUnmodeledSideEffects() to check
the operand when the instruction is an INLINEASM.
This allows memory instructions to be moved around INLINEASM instructions.
llvm-svn: 123044 | 
| | 
| 
| 
| | llvm-svn: 122197 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | alternative register allocator that does not require LiveIntervals by specifying
it on the command-line for a target that has StrongPHIElimination enabled by
default.
These checks are pretty meaningless anyways, since StrongPHIElimination and
PHIElimination are never used at the same time.
llvm-svn: 122176 | 
| | 
| 
| 
| 
| 
| | Radar 8776599
llvm-svn: 122018 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | regB = move RCX
regA = op regB, regC
RAX  = move regA
where both regB and regC are killed. If regB is constrainted to non-compatible
physical registers but regC is not constrainted at all, then it's better to
commute the instruction.
       movl    %edi, %eax
       shlq    $32, %rcx
       leaq    (%rcx,%rax), %rax
=>
       movl    %edi, %eax
       shlq    $32, %rcx
       orq     %rcx, %rax
rdar://8762995
llvm-svn: 121793 | 
| | 
| 
| 
| 
| 
| | (gcc-4.6 warns about these).
llvm-svn: 117021 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | exposes an initializeMyPassFunction(), which
must be called in the pass's constructor.  This function uses static dependency declarations to recursively initialize
the pass's dependencies.
Clients that only create passes through the createFooPass() APIs will require no changes.  Clients that want to use the
CommandLine options for passes will need to manually call the appropriate initialization functions in PassInitialization.h
before parsing commandline arguments.
I have tested this with all standard configurations of clang and llvm-gcc on Darwin.  It is possible that there are problems
with the static dependencies that will only be visible with non-standard options.  If you encounter any crash in pass
registration/creation, please send the testcase to me directly.
llvm-svn: 116820 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | perform initialization without static constructors AND without explicit initialization
by the client.  For the moment, passes are required to initialize both their
(potential) dependencies and any passes they preserve.  I hope to be able to relax
the latter requirement in the future.
llvm-svn: 116334 | 
| | 
| 
| 
| | llvm-svn: 115996 | 
| | 
| 
| 
| 
| 
| | passes over to the new registration API.
llvm-svn: 111815 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | If we are emitting COPY instructions for the REG_SEQUENCE, make sure the kill
flag goes on the last COPY. Otherwise we may be using a killed register.
<rdar://problem/8287792>
llvm-svn: 110589 | 
| | 
| 
| 
| | llvm-svn: 110460 | 
| | 
| 
| 
| | llvm-svn: 110410 | 
| | 
| 
| 
| 
| 
| 
| 
| | address of the static
ID member as the sole unique type identifier.  Clean up APIs related to this change.
llvm-svn: 110396 | 
| | 
| 
| 
| 
| 
| | TII::isMoveInstr is going tobe completely removed.
llvm-svn: 108507 | 
| | 
| 
| 
| | llvm-svn: 108062 | 
| | 
| 
| 
| 
| 
| | This also avoids fatal copies from physregs.
llvm-svn: 108061 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | ScheduleDAGEmit, TwoAddressLowering, and PHIElimination.
This switches the bulk of register copies to using COPY, but many less used
copyRegToReg calls remain.
llvm-svn: 108050 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | EXTRACT_SUBREG no longer appears as a machine instruction. Use COPY instead.
Add isCopy() checks in many places using isMoveInstr() and isExtractSubreg().
The isMoveInstr hook will be removed later.
llvm-svn: 107879 | 
| | 
| 
| 
| 
| 
| 
| | Fix X86InstrInfo::convertToThreeAddressWithLEA to generate COPY instead of
INSERT_SUBREG.
llvm-svn: 107878 | 
| | 
| 
| 
| 
| 
| | Buildbot breakage.
llvm-svn: 107744 | 
| | 
| 
| 
| | llvm-svn: 107732 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | INSERT_SUBREG will now only appear in SSA machine instructions.
Fix the handling of partial redefs in ProcessImplicitDefs. This is now relevant
since partial redef COPY instructions appear.
llvm-svn: 107726 |