llvm-project/llvm/lib/CodeGen
Vladislav Dzhidzhoev 6cf11f4462 [GlobalISel][DebugInfo] Salvage trivially dead instructions
Use salvageDebugInfo for instructions erased as trivially dead in
GlobalISel.

It would be helpful to implement support of G_PTR_ADD and G_FRAME_INDEX
in salvageDebugInfo in future in order to preserve more variable
location.

Reviewed by: arsenm

Differential Revision: https://reviews.llvm.org/D133986
2022-09-17 03:54:55 +03:00
..
AsmPrinter Revert "Revert "[clang, llvm] Add __declspec(safebuffers), support it in CodeView"" 2022-09-16 19:39:48 +00:00
GlobalISel [GlobalISel][DebugInfo] Salvage trivially dead instructions 2022-09-17 03:54:55 +03:00
LiveDebugValues Use llvm::lower_bound (NFC) 2022-09-03 11:17:37 -07:00
MIRParser [MIR] Support printing and parsing pcsections 2022-09-14 10:30:25 +02:00
SelectionDAG [VP][VE] Default VP_SREM/UREM to Expand and add generic expansion using VP_SDIV/UDIV+VP_MUL+VP_SUB. 2022-09-16 13:19:02 -07:00
AggressiveAntiDepBreaker.cpp
AggressiveAntiDepBreaker.h
AllocationOrder.cpp
AllocationOrder.h
Analysis.cpp
AtomicExpandPass.cpp [AtomicExpandPass] Always copy pcsections Metadata to expanded atomics 2022-09-07 11:36:01 +02:00
BasicBlockSections.cpp Add a nop instruction if a section starts with landing pad for function splitter 2022-07-22 15:20:10 -07:00
BasicBlockSectionsProfileReader.cpp Reland "[Propeller] Promote functions with propeller profiles to .text.hot." 2022-05-26 19:53:14 -07:00
BasicTargetTransformInfo.cpp
BranchFolding.cpp BranchFolder: Require NoPHIs 2022-06-01 21:14:49 -04:00
BranchFolding.h
BranchRelaxation.cpp
BreakFalseDeps.cpp
CFGuardLongjmp.cpp
CFIFixup.cpp [CodeGen] Async unwind - add a pass to fix CFI information 2022-04-11 13:27:26 +01:00
CFIInstrInserter.cpp
CMakeLists.txt [llvm/CodeGen] Add ExpandLargeDivRem pass 2022-08-26 11:55:15 +01:00
CalcSpillWeights.cpp RegAlloc: Use SmallSet instead of std::set 2022-09-12 07:55:10 -04:00
CallingConvLower.cpp
CodeGen.cpp [llvm/CodeGen] Add ExpandLargeDivRem pass 2022-08-26 11:55:15 +01:00
CodeGenCommonISel.cpp [GlobalISel][DebugInfo] salvageDebugInfo analogue for gMIR 2022-08-01 11:14:53 +02:00
CodeGenPassBuilder.cpp
CodeGenPrepare.cpp [AArch64] Use tbl for truncating vector FPtoUI conversions. 2022-09-16 14:57:43 +01:00
CommandFlags.cpp [llvm] Use value_or instead of getValueOr (NFC) 2022-06-18 23:07:11 -07:00
CriticalAntiDepBreaker.cpp
CriticalAntiDepBreaker.h
DFAPacketizer.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
DeadMachineInstructionElim.cpp DeadMachineInstructionElim: Don't repeat per-function init 2022-09-13 08:19:54 -04:00
DetectDeadLanes.cpp
DwarfEHPrepare.cpp [DwarfEhPrepare] Assign dummy debug location for inserted _Unwind_Resume calls (PR57469) 2022-09-01 16:35:49 +02:00
EHContGuardCatchret.cpp
EarlyIfConversion.cpp CodeGen: Remove AliasAnalysis from regalloc 2022-07-18 17:23:41 -04:00
EdgeBundles.cpp
ExecutionDomainFix.cpp
ExpandLargeDivRem.cpp Move TargetTransformInfo::maxLegalDivRemBitWidth -> TargetLowering::maxSupportedDivRemBitWidth 2022-09-12 17:06:16 +01:00
ExpandMemCmp.cpp Don't use Optional::hasValue (NFC) 2022-06-20 20:17:57 -07:00
ExpandPostRAPseudos.cpp
ExpandReductions.cpp
ExpandVectorPredication.cpp [llvm] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 11:24:15 -07:00
FEntryInserter.cpp
FaultMaps.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
FinalizeISel.cpp
FixupStatepointCallerSaved.cpp [Statepoints] FixupStatepoint: Clear isKill flag if COPY is not deleted. 2022-06-14 10:52:32 +03:00
FuncletLayout.cpp
GCMetadata.cpp
GCMetadataPrinter.cpp
GCRootLowering.cpp
GlobalMerge.cpp [llvm] Use range-based for loops (NFC) 2022-09-03 11:17:40 -07:00
HardwareLoops.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
IfConversion.cpp
ImplicitNullChecks.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
IndirectBrExpandPass.cpp
InlineSpiller.cpp [llvm] Fix comment typos (NFC) 2022-08-07 00:16:14 -07:00
InterferenceCache.cpp
InterferenceCache.h
InterleavedAccessPass.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
InterleavedLoadCombinePass.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
IntrinsicLowering.cpp
JMCInstrumenter.cpp [CodeGen] Use StringRef::contains (NFC) 2022-06-04 20:58:58 -07:00
LLVMTargetMachine.cpp [MC][re-land] Omit DWARF unwind info if compact unwind is present where eligible 2022-06-12 17:24:19 -04:00
LatencyPriorityQueue.cpp
LazyMachineBlockFrequencyInfo.cpp
LexicalScopes.cpp
LiveDebugVariables.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
LiveDebugVariables.h
LiveInterval.cpp [LiveInterval] Simplify with partition_point. NFC 2022-06-27 19:25:26 -07:00
LiveIntervalCalc.cpp
LiveIntervalUnion.cpp
LiveIntervals.cpp [LiveIntervals] Split live intervals on any dead def 2022-09-02 20:00:22 +03:00
LivePhysRegs.cpp
LiveRangeCalc.cpp
LiveRangeEdit.cpp Fix subrange liveness checking at rematerialization 2022-08-16 10:50:09 -07:00
LiveRangeShrink.cpp
LiveRangeUtils.h
LiveRegMatrix.cpp
LiveRegUnits.cpp LiveRegUnits: Break register loop when a clobber is encountered 2022-09-13 10:15:08 -04:00
LiveStacks.cpp
LiveVariables.cpp [CodeGen] Use range-based for loops (NFC) 2022-07-23 16:10:46 -07:00
LocalStackSlotAllocation.cpp [iwyu] Handle regressions in libLLVM header include 2022-05-04 08:32:38 +02:00
LoopTraversal.cpp
LowLevelType.cpp
LowerEmuTLS.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
MBFIWrapper.cpp
MIRCanonicalizerPass.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
MIRFSDiscriminator.cpp Fix warnings about variables that are set but only used in debug mode 2022-04-06 10:01:46 +03:00
MIRNamerPass.cpp
MIRPrinter.cpp [MIR] Support printing and parsing pcsections 2022-09-14 10:30:25 +02:00
MIRPrintingPass.cpp
MIRSampleProfile.cpp
MIRVRegNamerUtils.cpp
MIRVRegNamerUtils.h
MIRYamlMapping.cpp
MLRegallocEvictAdvisor.cpp [mlgo] Add ability to create feature-gated development features in regalloc advisor 2022-08-15 16:01:37 -07:00
MachineBasicBlock.cpp Untangle the mess which is MachineBasicBlock::hasAddressTaken(). 2022-08-16 16:15:44 -07:00
MachineBlockFrequencyInfo.cpp
MachineBlockPlacement.cpp extending code layout alg 2022-08-24 09:40:25 -07:00
MachineBranchProbabilityInfo.cpp
MachineCSE.cpp [MachineCSE] Add a threshold to avoid spending too much time in isProfitableToCSE 2022-09-16 13:35:17 -07:00
MachineCheckDebugify.cpp
MachineCombiner.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
MachineCopyPropagation.cpp [MachineCopyPropagation][RISCV] Fix D125335 accidentally change control flow. 2022-06-17 21:40:08 -07:00
MachineCycleAnalysis.cpp [MachineSink] replace MachineLoop with MachineCycle 2022-05-26 06:45:23 -04:00
MachineDebugify.cpp
MachineDominanceFrontier.cpp
MachineDominators.cpp
MachineFrameInfo.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
MachineFunction.cpp [MachineInstr] Allow setting PCSections in ExtraInfo 2022-09-06 15:52:44 +02:00
MachineFunctionPass.cpp [NFC][MachineFunctionPass] Only lookup pass name if we request printing 2022-09-07 21:38:00 -07:00
MachineFunctionPrinterPass.cpp
MachineFunctionSplitter.cpp Split EH code by default 2022-08-17 12:40:31 -07:00
MachineInstr.cpp [MachineInstr] Allow setting PCSections in ExtraInfo 2022-09-06 15:52:44 +02:00
MachineInstrBundle.cpp
MachineLICM.cpp CodeGen: Remove AliasAnalysis from regalloc 2022-07-18 17:23:41 -04:00
MachineLoopInfo.cpp
MachineLoopUtils.cpp Fix an unused-variable warning in release build, NFC. 2022-06-19 20:52:00 +02:00
MachineModuleInfo.cpp [MC][re-land] Omit DWARF unwind info if compact unwind is present where eligible 2022-06-12 17:24:19 -04:00
MachineModuleInfoImpls.cpp
MachineModuleSlotTracker.cpp
MachineOperand.cpp Fix crash while printing MMO target flags 2022-09-14 17:29:48 -07:00
MachineOptimizationRemarkEmitter.cpp [llvm] Use value_or instead of getValueOr (NFC) 2022-06-18 23:07:11 -07:00
MachineOutliner.cpp Fix interaction of CFI instructions with MachineOutliner. 2022-06-10 13:37:49 -07:00
MachinePassManager.cpp
MachinePipeliner.cpp [MachinePipeliner] Fix the interpretation of the scheduling model 2022-09-16 09:51:48 +09:00
MachinePostDominators.cpp
MachineRegionInfo.cpp
MachineRegisterInfo.cpp [AMDGPU] Always select s_cselect_b32 for uniform 'select' SDNode 2022-09-15 22:03:56 +02:00
MachineSSAContext.cpp
MachineSSAUpdater.cpp Revert "[MachineSSAUpdater] compile time improvement in GetValueInMiddleOfBlock" 2022-06-14 20:27:21 +07:00
MachineScheduler.cpp [CodeGen] Fixed undeclared MISchedCutoff in case of NDEBUG and LLVM_ENABLE_ABI_BREAKING_CHECKS 2022-07-30 18:24:50 +02:00
MachineSink.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
MachineSizeOpts.cpp
MachineStableHash.cpp Address feedback in https://reviews.llvm.org/D133637 2022-09-13 16:12:41 -07:00
MachineStripDebug.cpp
MachineTraceMetrics.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
MachineVerifier.cpp [MachineVerifier] Fix crash on early clobbered subreg operands. 2022-09-05 17:08:21 +03:00
MacroFusion.cpp
ModuloSchedule.cpp [MachinePipeliner] Fix Phi generation failure for large stages 2022-08-09 13:14:26 +09:00
MultiHazardRecognizer.cpp
NonRelocatableStringpool.cpp [Debuginfo][DWARF][NFC] Refactor DwarfStringPoolEntryRef - remove isIndexed(). 2022-06-05 21:18:31 +03:00
OptimizePHIs.cpp
PHIElimination.cpp
PHIEliminationUtils.cpp
PHIEliminationUtils.h
ParallelCG.cpp
PatchableFunction.cpp
PeepholeOptimizer.cpp Teach PeepholeOpt to eliminate redundant copy from constant physreg (e.g VLENB on RISCV) 2022-05-16 16:38:30 -07:00
PostRAHazardRecognizer.cpp
PostRASchedulerList.cpp
PreISelIntrinsicLowering.cpp [WinEH] Apply funclet operand bundles to nounwind intrinsics that lower to function calls in the course of IR transforms 2022-07-26 17:52:43 +02:00
ProcessImplicitDefs.cpp [llvm] Remove redundaunt virtual specifiers (NFC) 2022-07-24 21:50:35 -07:00
PrologEpilogInserter.cpp [CodeGen] Don't zero callee-save registers with zero-call-used-regs (PR57692) 2022-09-16 11:52:29 +02:00
PseudoProbeInserter.cpp
PseudoSourceValue.cpp CodeGen: Move getAddressSpaceForPseudoSourceKind into TargetMachine 2022-06-01 09:45:40 -04:00
RDFGraph.cpp Recommit [RDF] Remove explicit template arguments from Print 2022-08-08 07:28:45 -07:00
RDFLiveness.cpp Recommit [RDF] Remove explicit template arguments from Print 2022-08-08 07:28:45 -07:00
RDFRegisters.cpp
README.txt
ReachingDefAnalysis.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
RegAllocBase.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
RegAllocBase.h
RegAllocBasic.cpp CodeGen: Remove AliasAnalysis from regalloc 2022-07-18 17:23:41 -04:00
RegAllocEvictionAdvisor.cpp [llvm] Remove unneeded cl::ZeroOrMore for cl::opt options. NFC 2022-06-03 21:59:05 -07:00
RegAllocEvictionAdvisor.h [CodeGen] Remove unused member variable NextCascade (NFC) 2022-07-10 18:57:40 -07:00
RegAllocFast.cpp (Reland) [fastalloc] Support allocating specific register class in fastalloc 2022-08-20 13:25:34 +08:00
RegAllocGreedy.cpp RegAllocGreedy: Avoid overflowing priority bitfields 2022-09-15 10:38:40 -04:00
RegAllocGreedy.h [NFC][Regalloc] Introduce the RegAllocPriorityAdvisorAnalysis 2022-09-08 07:50:03 -07:00
RegAllocPBQP.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
RegAllocPriorityAdvisor.cpp [NFC][Regalloc] Introduce the RegAllocPriorityAdvisorAnalysis 2022-09-08 07:50:03 -07:00
RegAllocPriorityAdvisor.h [NFC][Regalloc] Introduce the RegAllocPriorityAdvisorAnalysis 2022-09-08 07:50:03 -07:00
RegAllocScore.cpp CodeGen: Remove AliasAnalysis from regalloc 2022-07-18 17:23:41 -04:00
RegAllocScore.h CodeGen: Remove AliasAnalysis from regalloc 2022-07-18 17:23:41 -04:00
RegUsageInfoCollector.cpp
RegUsageInfoPropagate.cpp
RegisterBank.cpp
RegisterBankInfo.cpp [globalisel] Select register bank for DBG_VALUE 2022-08-09 13:11:51 +08:00
RegisterClassInfo.cpp Fix CSR update check 2022-08-24 18:09:49 -07:00
RegisterCoalescer.cpp RegisterCoalescer: Fix verifier error when merging copy of undef 2022-09-13 18:40:28 -04:00
RegisterCoalescer.h
RegisterPressure.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
RegisterScavenging.cpp
RegisterUsageInfo.cpp
RemoveRedundantDebugValues.cpp
RenameIndependentSubregs.cpp
ReplaceWithVeclib.cpp [LV][SLP] Mark fptosi_sat as vectorizable 2022-05-03 09:32:34 +01:00
ResetMachineFunctionPass.cpp
SafeStack.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
SafeStackLayout.cpp
SafeStackLayout.h [NFC][Alignment] Use Align in SafeStack 2022-06-14 10:56:36 +00:00
ScheduleDAG.cpp
ScheduleDAGInstrs.cpp [NFC][ScheduleDAGInstrs] Use structure bindings and emplace_back 2022-09-13 12:49:04 +03:00
ScheduleDAGPrinter.cpp
ScoreboardHazardRecognizer.cpp [llvm] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 11:24:15 -07:00
SelectOptimize.cpp [SelectOpti] Restrict load sinking 2022-09-16 20:50:46 +00:00
ShadowStackGCLowering.cpp Add helper func to get first non-alloca position 2022-09-09 15:39:53 +02:00
ShrinkWrap.cpp
SjLjEHPrepare.cpp [NFC] Rename Instrinsic to Intrinsic 2022-04-25 18:13:23 +01:00
SlotIndexes.cpp [LiveIntervals] Find better anchoring end points when repairing ranges 2022-07-18 19:34:43 +01:00
SpillPlacement.cpp
SpillPlacement.h
SplitKit.cpp CodeGen: Remove AliasAnalysis from regalloc 2022-07-18 17:23:41 -04:00
SplitKit.h CodeGen: Remove AliasAnalysis from regalloc 2022-07-18 17:23:41 -04:00
StackColoring.cpp [StackColoring] Don't merge slots with differing StackIDs 2022-05-17 08:28:49 +01:00
StackMapLivenessAnalysis.cpp
StackMaps.cpp [CodeGen] Qualify auto variables in for loops (NFC) 2022-07-17 01:33:28 -07:00
StackProtector.cpp StackProtector: ensure stack checks are inserted before the tail call 2022-09-16 22:24:46 +08:00
StackSlotColoring.cpp
SwiftErrorValueTracking.cpp Use any_of (NFC) 2022-07-30 10:35:56 -07:00
SwitchLoweringUtils.cpp
TailDuplication.cpp
TailDuplicator.cpp [llvm][TailDuplicator] don't taildup isInlineAsmBrIndirectTargets 2022-08-31 13:07:10 -07:00
TargetFrameLoweringImpl.cpp [iwyu] Handle regressions in libLLVM header include 2022-04-13 20:53:19 +02:00
TargetInstrInfo.cpp Outliner: add "target-cpu" feature from source function to outlined 2022-08-02 09:33:29 +01:00
TargetLoweringBase.cpp [VP][VE] Default VP_SREM/UREM to Expand and add generic expansion using VP_SDIV/UDIV+VP_MUL+VP_SUB. 2022-09-16 13:19:02 -07:00
TargetLoweringObjectFileImpl.cpp [Windows] Put init_seg(compiler/lib) in llvm.global_ctors 2022-08-16 08:16:18 -07:00
TargetOptionsImpl.cpp
TargetPassConfig.cpp [llvm/CodeGen] Enable the ExpandLargeDivRem pass for X86, Arm and AArch64 2022-09-06 15:32:04 +01:00
TargetRegisterInfo.cpp
TargetSchedule.cpp [CodeGen] Use std::lcm (NFC) 2022-09-03 11:17:33 -07:00
TargetSubtargetInfo.cpp
TwoAddressInstructionPass.cpp [TwoAddressInstruction] Handle pointer compare sunk past statepoint. 2022-08-23 12:34:11 +03:00
TypePromotion.cpp [TypePromotionPass] Don't treat phi's as ToPromote 2022-09-13 08:57:15 +01:00
UnreachableBlockElim.cpp
VLIWMachineScheduler.cpp [llvm] Fix comment typos (NFC) 2022-08-07 00:16:14 -07:00
ValueTypes.cpp [ValueTypes] Define MVTs for v256i2/v128i4. 2022-09-13 09:02:23 -07:00
VirtRegMap.cpp
WasmEHPrepare.cpp
WinEHPrepare.cpp Use PoisonValue instead of UndefValue when RAUWing unreachable code [NFC] 2022-09-10 14:28:01 +01:00
XRayInstrumentation.cpp

README.txt

//===---------------------------------------------------------------------===//

Common register allocation / spilling problem:

        mul lr, r4, lr
        str lr, [sp, #+52]
        ldr lr, [r1, #+32]
        sxth r3, r3
        ldr r4, [sp, #+52]
        mla r4, r3, lr, r4

can be:

        mul lr, r4, lr
        mov r4, lr
        str lr, [sp, #+52]
        ldr lr, [r1, #+32]
        sxth r3, r3
        mla r4, r3, lr, r4

and then "merge" mul and mov:

        mul r4, r4, lr
        str r4, [sp, #+52]
        ldr lr, [r1, #+32]
        sxth r3, r3
        mla r4, r3, lr, r4

It also increase the likelihood the store may become dead.

//===---------------------------------------------------------------------===//

bb27 ...
        ...
        %reg1037 = ADDri %reg1039, 1
        %reg1038 = ADDrs %reg1032, %reg1039, %noreg, 10
    Successors according to CFG: 0x8b03bf0 (#5)

bb76 (0x8b03bf0, LLVM BB @0x8b032d0, ID#5):
    Predecessors according to CFG: 0x8b0c5f0 (#3) 0x8b0a7c0 (#4)
        %reg1039 = PHI %reg1070, mbb<bb76.outer,0x8b0c5f0>, %reg1037, mbb<bb27,0x8b0a7c0>

Note ADDri is not a two-address instruction. However, its result %reg1037 is an
operand of the PHI node in bb76 and its operand %reg1039 is the result of the
PHI node. We should treat it as a two-address code and make sure the ADDri is
scheduled after any node that reads %reg1039.

//===---------------------------------------------------------------------===//

Use local info (i.e. register scavenger) to assign it a free register to allow
reuse:
        ldr r3, [sp, #+4]
        add r3, r3, #3
        ldr r2, [sp, #+8]
        add r2, r2, #2
        ldr r1, [sp, #+4]  <==
        add r1, r1, #1
        ldr r0, [sp, #+4]
        add r0, r0, #2

//===---------------------------------------------------------------------===//

LLVM aggressively lift CSE out of loop. Sometimes this can be negative side-
effects:

R1 = X + 4
R2 = X + 7
R3 = X + 15

loop:
load [i + R1]
...
load [i + R2]
...
load [i + R3]

Suppose there is high register pressure, R1, R2, R3, can be spilled. We need
to implement proper re-materialization to handle this:

R1 = X + 4
R2 = X + 7
R3 = X + 15

loop:
R1 = X + 4  @ re-materialized
load [i + R1]
...
R2 = X + 7 @ re-materialized
load [i + R2]
...
R3 = X + 15 @ re-materialized
load [i + R3]

Furthermore, with re-association, we can enable sharing:

R1 = X + 4
R2 = X + 7
R3 = X + 15

loop:
T = i + X
load [T + 4]
...
load [T + 7]
...
load [T + 15]
//===---------------------------------------------------------------------===//

It's not always a good idea to choose rematerialization over spilling. If all
the load / store instructions would be folded then spilling is cheaper because
it won't require new live intervals / registers. See 2003-05-31-LongShifts for
an example.

//===---------------------------------------------------------------------===//

With a copying garbage collector, derived pointers must not be retained across
collector safe points; the collector could move the objects and invalidate the
derived pointer. This is bad enough in the first place, but safe points can
crop up unpredictably. Consider:

        %array = load { i32, [0 x %obj] }** %array_addr
        %nth_el = getelementptr { i32, [0 x %obj] }* %array, i32 0, i32 %n
        %old = load %obj** %nth_el
        %z = div i64 %x, %y
        store %obj* %new, %obj** %nth_el

If the i64 division is lowered to a libcall, then a safe point will (must)
appear for the call site. If a collection occurs, %array and %nth_el no longer
point into the correct object.

The fix for this is to copy address calculations so that dependent pointers
are never live across safe point boundaries. But the loads cannot be copied
like this if there was an intervening store, so may be hard to get right.

Only a concurrent mutator can trigger a collection at the libcall safe point.
So single-threaded programs do not have this requirement, even with a copying
collector. Still, LLVM optimizations would probably undo a front-end's careful
work.

//===---------------------------------------------------------------------===//

The ocaml frametable structure supports liveness information. It would be good
to support it.

//===---------------------------------------------------------------------===//

The FIXME in ComputeCommonTailLength in BranchFolding.cpp needs to be
revisited. The check is there to work around a misuse of directives in inline
assembly.

//===---------------------------------------------------------------------===//

It would be good to detect collector/target compatibility instead of silently
doing the wrong thing.

//===---------------------------------------------------------------------===//

It would be really nice to be able to write patterns in .td files for copies,
which would eliminate a bunch of explicit predicates on them (e.g. no side
effects).  Once this is in place, it would be even better to have tblgen
synthesize the various copy insertion/inspection methods in TargetInstrInfo.

//===---------------------------------------------------------------------===//

Stack coloring improvements:

1. Do proper LiveStacks analysis on all stack objects including those which are
   not spill slots.
2. Reorder objects to fill in gaps between objects.
   e.g. 4, 1, <gap>, 4, 1, 1, 1, <gap>, 4 => 4, 1, 1, 1, 1, 4, 4

//===---------------------------------------------------------------------===//

The scheduler should be able to sort nearby instructions by their address. For
example, in an expanded memset sequence it's not uncommon to see code like this:

  movl $0, 4(%rdi)
  movl $0, 8(%rdi)
  movl $0, 12(%rdi)
  movl $0, 0(%rdi)

Each of the stores is independent, and the scheduler is currently making an
arbitrary decision about the order.

//===---------------------------------------------------------------------===//

Another opportunitiy in this code is that the $0 could be moved to a register:

  movl $0, 4(%rdi)
  movl $0, 8(%rdi)
  movl $0, 12(%rdi)
  movl $0, 0(%rdi)

This would save substantial code size, especially for longer sequences like
this. It would be easy to have a rule telling isel to avoid matching MOV32mi
if the immediate has more than some fixed number of uses. It's more involved
to teach the register allocator how to do late folding to recover from
excessive register pressure.