mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-07 11:33:44 +00:00
4e933df738
The changes to InstCombine (& SCEV) do seem a bit silly - it doesn't make anything obviously better to have the caller access the pointers element type (the thing I'm trying to remove) than the GEP itself, but it's a helpful migration step. This will allow me to more obviously lock down GEP (& Load, etc) API usage, then fix all the code that accesses pointer element types except the places that need to be removed (most of the InstCombines) anyway - at which point I'll need to just remove all that code because it won't be meaningful anymore (there will be no pointer types, so no bitcasts to combine) SCEV looks like it'll need some restructuring - we'll have to do a bit more work for GEP canonicalization, since it'll depend on how it's used if we can even manage to canonicalize it to a non-ugly GEP. I guess we can do some fun stuff like voting (do 2 out of 3 load from the GEP with a certain type that gives a pretty GEP? Does every typed use of the GEP use either a specific type or a generic type (i8*, etc)?) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@233131 91177308-0d34-0410-b5e6-96231b3b80d8 |
||
---|---|---|
.. | ||
AsmParser | ||
InstPrinter | ||
MCTargetDesc | ||
TargetInfo | ||
AMDGPU.h | ||
AMDGPU.td | ||
AMDGPUAlwaysInlinePass.cpp | ||
AMDGPUAsmPrinter.cpp | ||
AMDGPUAsmPrinter.h | ||
AMDGPUCallingConv.td | ||
AMDGPUFrameLowering.cpp | ||
AMDGPUFrameLowering.h | ||
AMDGPUInstrInfo.cpp | ||
AMDGPUInstrInfo.h | ||
AMDGPUInstrInfo.td | ||
AMDGPUInstructions.td | ||
AMDGPUIntrinsicInfo.cpp | ||
AMDGPUIntrinsicInfo.h | ||
AMDGPUIntrinsics.td | ||
AMDGPUISelDAGToDAG.cpp | ||
AMDGPUISelLowering.cpp | ||
AMDGPUISelLowering.h | ||
AMDGPUMachineFunction.cpp | ||
AMDGPUMachineFunction.h | ||
AMDGPUMCInstLower.cpp | ||
AMDGPUMCInstLower.h | ||
AMDGPUPromoteAlloca.cpp | ||
AMDGPURegisterInfo.cpp | ||
AMDGPURegisterInfo.h | ||
AMDGPURegisterInfo.td | ||
AMDGPUSubtarget.cpp | ||
AMDGPUSubtarget.h | ||
AMDGPUTargetMachine.cpp | ||
AMDGPUTargetMachine.h | ||
AMDGPUTargetTransformInfo.cpp | ||
AMDGPUTargetTransformInfo.h | ||
AMDILCFGStructurizer.cpp | ||
AMDKernelCodeT.h | ||
CaymanInstructions.td | ||
CIInstructions.td | ||
CMakeLists.txt | ||
EvergreenInstructions.td | ||
LLVMBuild.txt | ||
Makefile | ||
Processors.td | ||
R600ClauseMergePass.cpp | ||
R600ControlFlowFinalizer.cpp | ||
R600Defines.h | ||
R600EmitClauseMarkers.cpp | ||
R600ExpandSpecialInstrs.cpp | ||
R600InstrFormats.td | ||
R600InstrInfo.cpp | ||
R600InstrInfo.h | ||
R600Instructions.td | ||
R600Intrinsics.td | ||
R600ISelLowering.cpp | ||
R600ISelLowering.h | ||
R600MachineFunctionInfo.cpp | ||
R600MachineFunctionInfo.h | ||
R600MachineScheduler.cpp | ||
R600MachineScheduler.h | ||
R600OptimizeVectorRegisters.cpp | ||
R600Packetizer.cpp | ||
R600RegisterInfo.cpp | ||
R600RegisterInfo.h | ||
R600RegisterInfo.td | ||
R600Schedule.td | ||
R600TextureIntrinsicsReplacer.cpp | ||
R700Instructions.td | ||
SIAnnotateControlFlow.cpp | ||
SIDefines.h | ||
SIFixSGPRCopies.cpp | ||
SIFixSGPRLiveRanges.cpp | ||
SIFoldOperands.cpp | ||
SIInsertWaits.cpp | ||
SIInstrFormats.td | ||
SIInstrInfo.cpp | ||
SIInstrInfo.h | ||
SIInstrInfo.td | ||
SIInstructions.td | ||
SIIntrinsics.td | ||
SIISelLowering.cpp | ||
SIISelLowering.h | ||
SILoadStoreOptimizer.cpp | ||
SILowerControlFlow.cpp | ||
SILowerI1Copies.cpp | ||
SIMachineFunctionInfo.cpp | ||
SIMachineFunctionInfo.h | ||
SIPrepareScratchRegs.cpp | ||
SIRegisterInfo.cpp | ||
SIRegisterInfo.h | ||
SIRegisterInfo.td | ||
SISchedule.td | ||
SIShrinkInstructions.cpp | ||
SITypeRewriter.cpp | ||
VIInstrFormats.td | ||
VIInstructions.td |