Port SwiftShader to LLVM 7.0
Change-Id: I89601ef9e42e56cfaeb1cd5ece4daa3f32b39950
Reviewed-on: https://swiftshader-review.googlesource.com/20475
Tested-by: Logan Chien <loganchien@google.com>
Reviewed-by: Nicolas Capens <nicolascapens@google.com>
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 7a30cc1..bb9926b 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -65,6 +65,8 @@
set(REACTOR_BACKEND DEFAULT_REACTOR_BACKEND CACHE STRING "JIT compiler back-end used by Reactor")
set_property(CACHE REACTOR_BACKEND PROPERTY STRINGS LLVM Subzero)
+set(SWIFTSHADER_LLVM_VERSION "3" CACHE STRING "LLVM version used by Reactor")
+
# LLVM disallows calling cmake . from the main LLVM dir, the reason is that
# it builds header files that could overwrite the orignal ones. Here we
# want to include LLVM as a subdirectory and even though it wouldn't cause
@@ -152,7 +154,12 @@
set(SOURCE_DIR ${CMAKE_SOURCE_DIR}/src)
set(OPENGL_DIR ${SOURCE_DIR}/OpenGL)
set(OPENGL_COMPILER_DIR ${OPENGL_DIR}/compiler)
-set(LLVM_DIR ${CMAKE_SOURCE_DIR}/third_party/LLVM)
+if(SWIFTSHADER_LLVM_VERSION EQUAL 3)
+ set(LLVM_DIR ${CMAKE_SOURCE_DIR}/third_party/LLVM)
+else()
+ set(LLVM_DIR ${CMAKE_SOURCE_DIR}/third_party/llvm-7.0/llvm)
+ set(LLVM_CONFIG_DIR ${CMAKE_SOURCE_DIR}/third_party/llvm-7.0/configs)
+endif()
set(SUBZERO_DIR ${CMAKE_SOURCE_DIR}/third_party/subzero)
set(SUBZERO_LLVM_DIR ${CMAKE_SOURCE_DIR}/third_party/llvm-subzero)
set(TESTS_DIR ${CMAKE_SOURCE_DIR}/tests)
@@ -249,6 +256,10 @@
# LLVM
###########################################################
+add_definitions(-DSWIFTSHADER_LLVM_VERSION=${SWIFTSHADER_LLVM_VERSION})
+
+if(SWIFTSHADER_LLVM_VERSION EQUAL 3)
+
set(LLVM_LIST
${LLVM_DIR}/lib/Analysis/AliasAnalysis.cpp
${LLVM_DIR}/lib/Analysis/AliasSetTracker.cpp
@@ -612,6 +623,902 @@
${LLVM_DIR}/include
${LLVM_DIR}/lib/Target/X86
)
+
+elseif(SWIFTSHADER_LLVM_VERSION EQUAL 7)
+
+set(LLVM_LIST
+ ${LLVM_DIR}/lib/Analysis/AliasAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/AliasAnalysisEvaluator.cpp
+ ${LLVM_DIR}/lib/Analysis/AliasAnalysisSummary.cpp
+ ${LLVM_DIR}/lib/Analysis/AliasSetTracker.cpp
+ ${LLVM_DIR}/lib/Analysis/Analysis.cpp
+ ${LLVM_DIR}/lib/Analysis/AssumptionCache.cpp
+ ${LLVM_DIR}/lib/Analysis/BasicAliasAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/BlockFrequencyInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/BlockFrequencyInfoImpl.cpp
+ ${LLVM_DIR}/lib/Analysis/BranchProbabilityInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/CFG.cpp
+ ${LLVM_DIR}/lib/Analysis/CFGPrinter.cpp
+ ${LLVM_DIR}/lib/Analysis/CFLAndersAliasAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/CFLSteensAliasAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/CGSCCPassManager.cpp
+ ${LLVM_DIR}/lib/Analysis/CallGraph.cpp
+ ${LLVM_DIR}/lib/Analysis/CallGraphSCCPass.cpp
+ ${LLVM_DIR}/lib/Analysis/CallPrinter.cpp
+ ${LLVM_DIR}/lib/Analysis/CaptureTracking.cpp
+ ${LLVM_DIR}/lib/Analysis/CmpInstAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/CodeMetrics.cpp
+ ${LLVM_DIR}/lib/Analysis/ConstantFolding.cpp
+ ${LLVM_DIR}/lib/Analysis/CostModel.cpp
+ ${LLVM_DIR}/lib/Analysis/Delinearization.cpp
+ ${LLVM_DIR}/lib/Analysis/DemandedBits.cpp
+ ${LLVM_DIR}/lib/Analysis/DependenceAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/DivergenceAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/DomPrinter.cpp
+ ${LLVM_DIR}/lib/Analysis/DominanceFrontier.cpp
+ ${LLVM_DIR}/lib/Analysis/EHPersonalities.cpp
+ ${LLVM_DIR}/lib/Analysis/GlobalsModRef.cpp
+ ${LLVM_DIR}/lib/Analysis/IVUsers.cpp
+ ${LLVM_DIR}/lib/Analysis/IndirectCallPromotionAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/InlineCost.cpp
+ ${LLVM_DIR}/lib/Analysis/InstCount.cpp
+ ${LLVM_DIR}/lib/Analysis/InstructionSimplify.cpp
+ ${LLVM_DIR}/lib/Analysis/Interval.cpp
+ ${LLVM_DIR}/lib/Analysis/IntervalPartition.cpp
+ ${LLVM_DIR}/lib/Analysis/IteratedDominanceFrontier.cpp
+ ${LLVM_DIR}/lib/Analysis/LazyBlockFrequencyInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/LazyBranchProbabilityInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/LazyCallGraph.cpp
+ ${LLVM_DIR}/lib/Analysis/LazyValueInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/Lint.cpp
+ ${LLVM_DIR}/lib/Analysis/Loads.cpp
+ ${LLVM_DIR}/lib/Analysis/LoopAccessAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/LoopAnalysisManager.cpp
+ ${LLVM_DIR}/lib/Analysis/LoopInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/LoopPass.cpp
+ ${LLVM_DIR}/lib/Analysis/LoopUnrollAnalyzer.cpp
+ ${LLVM_DIR}/lib/Analysis/MemDepPrinter.cpp
+ ${LLVM_DIR}/lib/Analysis/MemDerefPrinter.cpp
+ ${LLVM_DIR}/lib/Analysis/MemoryBuiltins.cpp
+ ${LLVM_DIR}/lib/Analysis/MemoryDependenceAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/MemoryLocation.cpp
+ ${LLVM_DIR}/lib/Analysis/MemorySSA.cpp
+ ${LLVM_DIR}/lib/Analysis/MemorySSAUpdater.cpp
+ ${LLVM_DIR}/lib/Analysis/ModuleDebugInfoPrinter.cpp
+ ${LLVM_DIR}/lib/Analysis/ModuleSummaryAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/MustExecute.cpp
+ ${LLVM_DIR}/lib/Analysis/ObjCARCAliasAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/ObjCARCAnalysisUtils.cpp
+ ${LLVM_DIR}/lib/Analysis/ObjCARCInstKind.cpp
+ ${LLVM_DIR}/lib/Analysis/OptimizationRemarkEmitter.cpp
+ ${LLVM_DIR}/lib/Analysis/OrderedBasicBlock.cpp
+ ${LLVM_DIR}/lib/Analysis/PHITransAddr.cpp
+ ${LLVM_DIR}/lib/Analysis/PhiValues.cpp
+ ${LLVM_DIR}/lib/Analysis/PostDominators.cpp
+ ${LLVM_DIR}/lib/Analysis/ProfileSummaryInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/PtrUseVisitor.cpp
+ ${LLVM_DIR}/lib/Analysis/RegionInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/RegionPass.cpp
+ ${LLVM_DIR}/lib/Analysis/RegionPrinter.cpp
+ ${LLVM_DIR}/lib/Analysis/ScalarEvolution.cpp
+ ${LLVM_DIR}/lib/Analysis/ScalarEvolutionAliasAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/ScalarEvolutionExpander.cpp
+ ${LLVM_DIR}/lib/Analysis/ScalarEvolutionNormalization.cpp
+ ${LLVM_DIR}/lib/Analysis/ScopedNoAliasAA.cpp
+ ${LLVM_DIR}/lib/Analysis/SyntheticCountsUtils.cpp
+ ${LLVM_DIR}/lib/Analysis/TargetLibraryInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/TargetTransformInfo.cpp
+ ${LLVM_DIR}/lib/Analysis/Trace.cpp
+ ${LLVM_DIR}/lib/Analysis/TypeBasedAliasAnalysis.cpp
+ ${LLVM_DIR}/lib/Analysis/TypeMetadataUtils.cpp
+ ${LLVM_DIR}/lib/Analysis/ValueLattice.cpp
+ ${LLVM_DIR}/lib/Analysis/ValueLatticeUtils.cpp
+ ${LLVM_DIR}/lib/Analysis/ValueTracking.cpp
+ ${LLVM_DIR}/lib/Analysis/VectorUtils.cpp
+ ${LLVM_DIR}/lib/BinaryFormat/Dwarf.cpp
+ ${LLVM_DIR}/lib/BinaryFormat/Magic.cpp
+ ${LLVM_DIR}/lib/BinaryFormat/Wasm.cpp
+ ${LLVM_DIR}/lib/Bitcode/Reader/BitReader.cpp
+ ${LLVM_DIR}/lib/Bitcode/Reader/BitcodeReader.cpp
+ ${LLVM_DIR}/lib/Bitcode/Reader/BitstreamReader.cpp
+ ${LLVM_DIR}/lib/Bitcode/Reader/MetadataLoader.cpp
+ ${LLVM_DIR}/lib/Bitcode/Reader/ValueList.cpp
+ ${LLVM_DIR}/lib/Bitcode/Writer/BitWriter.cpp
+ ${LLVM_DIR}/lib/Bitcode/Writer/BitcodeWriter.cpp
+ ${LLVM_DIR}/lib/Bitcode/Writer/BitcodeWriterPass.cpp
+ ${LLVM_DIR}/lib/Bitcode/Writer/ValueEnumerator.cpp
+ ${LLVM_DIR}/lib/CodeGen/AggressiveAntiDepBreaker.cpp
+ ${LLVM_DIR}/lib/CodeGen/AllocationOrder.cpp
+ ${LLVM_DIR}/lib/CodeGen/Analysis.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/ARMException.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AccelTable.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AddressPool.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AsmPrinterDwarf.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AsmPrinterInlineAsm.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DIE.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DIEHash.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DbgValueHistoryCalculator.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DebugHandlerBase.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DebugLocStream.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfCFIException.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfDebug.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfExpression.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfFile.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfUnit.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/EHStreamer.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/ErlangGCPrinter.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/OcamlGCPrinter.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/WinCFGuard.cpp
+ ${LLVM_DIR}/lib/CodeGen/AsmPrinter/WinException.cpp
+ ${LLVM_DIR}/lib/CodeGen/AtomicExpandPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/BasicTargetTransformInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/BranchFolding.cpp
+ ${LLVM_DIR}/lib/CodeGen/BranchRelaxation.cpp
+ ${LLVM_DIR}/lib/CodeGen/BreakFalseDeps.cpp
+ ${LLVM_DIR}/lib/CodeGen/BuiltinGCs.cpp
+ ${LLVM_DIR}/lib/CodeGen/CFIInstrInserter.cpp
+ ${LLVM_DIR}/lib/CodeGen/CalcSpillWeights.cpp
+ ${LLVM_DIR}/lib/CodeGen/CallingConvLower.cpp
+ ${LLVM_DIR}/lib/CodeGen/CodeGen.cpp
+ ${LLVM_DIR}/lib/CodeGen/CodeGenPrepare.cpp
+ ${LLVM_DIR}/lib/CodeGen/CriticalAntiDepBreaker.cpp
+ ${LLVM_DIR}/lib/CodeGen/DFAPacketizer.cpp
+ ${LLVM_DIR}/lib/CodeGen/DeadMachineInstructionElim.cpp
+ ${LLVM_DIR}/lib/CodeGen/DetectDeadLanes.cpp
+ ${LLVM_DIR}/lib/CodeGen/DwarfEHPrepare.cpp
+ ${LLVM_DIR}/lib/CodeGen/EarlyIfConversion.cpp
+ ${LLVM_DIR}/lib/CodeGen/EdgeBundles.cpp
+ ${LLVM_DIR}/lib/CodeGen/ExecutionDomainFix.cpp
+ ${LLVM_DIR}/lib/CodeGen/ExpandISelPseudos.cpp
+ ${LLVM_DIR}/lib/CodeGen/ExpandMemCmp.cpp
+ ${LLVM_DIR}/lib/CodeGen/ExpandPostRAPseudos.cpp
+ ${LLVM_DIR}/lib/CodeGen/ExpandReductions.cpp
+ ${LLVM_DIR}/lib/CodeGen/FEntryInserter.cpp
+ ${LLVM_DIR}/lib/CodeGen/FaultMaps.cpp
+ ${LLVM_DIR}/lib/CodeGen/FuncletLayout.cpp
+ ${LLVM_DIR}/lib/CodeGen/GCMetadata.cpp
+ ${LLVM_DIR}/lib/CodeGen/GCMetadataPrinter.cpp
+ ${LLVM_DIR}/lib/CodeGen/GCRootLowering.cpp
+ ${LLVM_DIR}/lib/CodeGen/GCStrategy.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/CallLowering.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/Combiner.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/CombinerHelper.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/GlobalISel.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/IRTranslator.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/InstructionSelect.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/InstructionSelector.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalityPredicates.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalizeMutations.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/Legalizer.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalizerHelper.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalizerInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/Localizer.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/MachineIRBuilder.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/RegBankSelect.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/RegisterBank.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalISel/Utils.cpp
+ ${LLVM_DIR}/lib/CodeGen/GlobalMerge.cpp
+ ${LLVM_DIR}/lib/CodeGen/IfConversion.cpp
+ ${LLVM_DIR}/lib/CodeGen/ImplicitNullChecks.cpp
+ ${LLVM_DIR}/lib/CodeGen/IndirectBrExpandPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/InlineSpiller.cpp
+ ${LLVM_DIR}/lib/CodeGen/InterferenceCache.cpp
+ ${LLVM_DIR}/lib/CodeGen/InterleavedAccessPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/IntrinsicLowering.cpp
+ ${LLVM_DIR}/lib/CodeGen/LLVMTargetMachine.cpp
+ ${LLVM_DIR}/lib/CodeGen/LatencyPriorityQueue.cpp
+ ${LLVM_DIR}/lib/CodeGen/LazyMachineBlockFrequencyInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/LexicalScopes.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveDebugValues.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveDebugVariables.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveInterval.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveIntervalUnion.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveIntervals.cpp
+ ${LLVM_DIR}/lib/CodeGen/LivePhysRegs.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveRangeCalc.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveRangeEdit.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveRangeShrink.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveRegMatrix.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveRegUnits.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveStacks.cpp
+ ${LLVM_DIR}/lib/CodeGen/LiveVariables.cpp
+ ${LLVM_DIR}/lib/CodeGen/LocalStackSlotAllocation.cpp
+ ${LLVM_DIR}/lib/CodeGen/LoopTraversal.cpp
+ ${LLVM_DIR}/lib/CodeGen/LowLevelType.cpp
+ ${LLVM_DIR}/lib/CodeGen/LowerEmuTLS.cpp
+ ${LLVM_DIR}/lib/CodeGen/MIRCanonicalizerPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/MIRPrinter.cpp
+ ${LLVM_DIR}/lib/CodeGen/MIRPrintingPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineBasicBlock.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineBlockFrequencyInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineBlockPlacement.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineBranchProbabilityInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineCSE.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineCombiner.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineCopyPropagation.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineDominanceFrontier.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineDominators.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineFrameInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineFunction.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineFunctionPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineFunctionPrinterPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineInstr.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineInstrBundle.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineLICM.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineLoopInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineModuleInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineModuleInfoImpls.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineOperand.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineOptimizationRemarkEmitter.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineOutliner.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachinePassRegistry.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachinePipeliner.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachinePostDominators.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineRegionInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineRegisterInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineSSAUpdater.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineScheduler.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineSink.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineTraceMetrics.cpp
+ ${LLVM_DIR}/lib/CodeGen/MachineVerifier.cpp
+ ${LLVM_DIR}/lib/CodeGen/MacroFusion.cpp
+ ${LLVM_DIR}/lib/CodeGen/OptimizePHIs.cpp
+ ${LLVM_DIR}/lib/CodeGen/PHIElimination.cpp
+ ${LLVM_DIR}/lib/CodeGen/PHIEliminationUtils.cpp
+ ${LLVM_DIR}/lib/CodeGen/ParallelCG.cpp
+ ${LLVM_DIR}/lib/CodeGen/PatchableFunction.cpp
+ ${LLVM_DIR}/lib/CodeGen/PeepholeOptimizer.cpp
+ ${LLVM_DIR}/lib/CodeGen/PostRAHazardRecognizer.cpp
+ ${LLVM_DIR}/lib/CodeGen/PostRASchedulerList.cpp
+ ${LLVM_DIR}/lib/CodeGen/PreISelIntrinsicLowering.cpp
+ ${LLVM_DIR}/lib/CodeGen/ProcessImplicitDefs.cpp
+ ${LLVM_DIR}/lib/CodeGen/PrologEpilogInserter.cpp
+ ${LLVM_DIR}/lib/CodeGen/PseudoSourceValue.cpp
+ ${LLVM_DIR}/lib/CodeGen/ReachingDefAnalysis.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegAllocBase.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegAllocBasic.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegAllocFast.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegAllocGreedy.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegAllocPBQP.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegUsageInfoCollector.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegUsageInfoPropagate.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegisterClassInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegisterCoalescer.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegisterPressure.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegisterScavenging.cpp
+ ${LLVM_DIR}/lib/CodeGen/RegisterUsageInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/RenameIndependentSubregs.cpp
+ ${LLVM_DIR}/lib/CodeGen/ResetMachineFunctionPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/SafeStack.cpp
+ ${LLVM_DIR}/lib/CodeGen/SafeStackColoring.cpp
+ ${LLVM_DIR}/lib/CodeGen/SafeStackLayout.cpp
+ ${LLVM_DIR}/lib/CodeGen/ScalarizeMaskedMemIntrin.cpp
+ ${LLVM_DIR}/lib/CodeGen/ScheduleDAG.cpp
+ ${LLVM_DIR}/lib/CodeGen/ScheduleDAGInstrs.cpp
+ ${LLVM_DIR}/lib/CodeGen/ScheduleDAGPrinter.cpp
+ ${LLVM_DIR}/lib/CodeGen/ScoreboardHazardRecognizer.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/FastISel.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/InstrEmitter.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeTypes.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeTypesGeneric.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ResourcePriorityQueue.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ScheduleDAGFast.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ScheduleDAGVLIW.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGAddressAnalysis.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGDumper.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGTargetInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/StatepointLowering.cpp
+ ${LLVM_DIR}/lib/CodeGen/SelectionDAG/TargetLowering.cpp
+ ${LLVM_DIR}/lib/CodeGen/ShadowStackGCLowering.cpp
+ ${LLVM_DIR}/lib/CodeGen/ShrinkWrap.cpp
+ ${LLVM_DIR}/lib/CodeGen/SjLjEHPrepare.cpp
+ ${LLVM_DIR}/lib/CodeGen/SlotIndexes.cpp
+ ${LLVM_DIR}/lib/CodeGen/SpillPlacement.cpp
+ ${LLVM_DIR}/lib/CodeGen/SplitKit.cpp
+ ${LLVM_DIR}/lib/CodeGen/StackColoring.cpp
+ ${LLVM_DIR}/lib/CodeGen/StackMapLivenessAnalysis.cpp
+ ${LLVM_DIR}/lib/CodeGen/StackMaps.cpp
+ ${LLVM_DIR}/lib/CodeGen/StackProtector.cpp
+ ${LLVM_DIR}/lib/CodeGen/StackSlotColoring.cpp
+ ${LLVM_DIR}/lib/CodeGen/TailDuplication.cpp
+ ${LLVM_DIR}/lib/CodeGen/TailDuplicator.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetFrameLoweringImpl.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetInstrInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetLoweringBase.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetOptionsImpl.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetPassConfig.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetRegisterInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetSchedule.cpp
+ ${LLVM_DIR}/lib/CodeGen/TargetSubtargetInfo.cpp
+ ${LLVM_DIR}/lib/CodeGen/TwoAddressInstructionPass.cpp
+ ${LLVM_DIR}/lib/CodeGen/UnreachableBlockElim.cpp
+ ${LLVM_DIR}/lib/CodeGen/ValueTypes.cpp
+ ${LLVM_DIR}/lib/CodeGen/VirtRegMap.cpp
+ ${LLVM_DIR}/lib/CodeGen/WasmEHPrepare.cpp
+ ${LLVM_DIR}/lib/CodeGen/WinEHPrepare.cpp
+ ${LLVM_DIR}/lib/CodeGen/XRayInstrumentation.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/AppendingTypeTableBuilder.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/CVSymbolVisitor.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/CVTypeVisitor.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/CodeViewError.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/CodeViewRecordIO.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/ContinuationRecordBuilder.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugChecksumsSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugCrossExSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugCrossImpSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugFrameDataSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugInlineeLinesSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugLinesSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugStringTableSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugSubsectionRecord.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugSubsectionVisitor.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugSymbolRVASubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/DebugSymbolsSubsection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/EnumTables.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/Formatters.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/GlobalTypeTableBuilder.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/LazyRandomTypeCollection.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/Line.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/MergingTypeTableBuilder.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/RecordName.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/RecordSerialization.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/SimpleTypeSerializer.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/StringsAndChecksums.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/SymbolDumper.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/SymbolRecordMapping.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/SymbolSerializer.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeDumpVisitor.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeHashing.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeIndex.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeIndexDiscovery.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeRecordMapping.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeStreamMerger.cpp
+ ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeTableCollection.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/ExecutionEngine.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/ExecutionEngineBindings.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/GDBRegistrationListener.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/CompileOnDemandLayer.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/Core.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/ExecutionUtils.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/IRCompileLayer.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/IRTransformLayer.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/IndirectionUtils.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/LLJIT.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/Layer.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/Legacy.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/NullResolver.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/ObjectTransformLayer.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/OrcABISupport.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/OrcCBindings.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/OrcError.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/OrcMCJITReplacement.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/RPCUtils.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/Orc/RTDyldObjectLinkingLayer.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/JITSymbol.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RTDyldMemoryManager.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyld.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldCOFF.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldChecker.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldELF.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldMachO.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/Targets/RuntimeDyldELFMips.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/SectionMemoryManager.cpp
+ ${LLVM_DIR}/lib/ExecutionEngine/TargetSelect.cpp
+ ${LLVM_DIR}/lib/IR/AsmWriter.cpp
+ ${LLVM_DIR}/lib/IR/Attributes.cpp
+ ${LLVM_DIR}/lib/IR/AutoUpgrade.cpp
+ ${LLVM_DIR}/lib/IR/BasicBlock.cpp
+ ${LLVM_DIR}/lib/IR/Comdat.cpp
+ ${LLVM_DIR}/lib/IR/ConstantFold.cpp
+ ${LLVM_DIR}/lib/IR/ConstantRange.cpp
+ ${LLVM_DIR}/lib/IR/Constants.cpp
+ ${LLVM_DIR}/lib/IR/Core.cpp
+ ${LLVM_DIR}/lib/IR/DIBuilder.cpp
+ ${LLVM_DIR}/lib/IR/DataLayout.cpp
+ ${LLVM_DIR}/lib/IR/DebugInfo.cpp
+ ${LLVM_DIR}/lib/IR/DebugInfoMetadata.cpp
+ ${LLVM_DIR}/lib/IR/DebugLoc.cpp
+ ${LLVM_DIR}/lib/IR/DiagnosticHandler.cpp
+ ${LLVM_DIR}/lib/IR/DiagnosticInfo.cpp
+ ${LLVM_DIR}/lib/IR/DiagnosticPrinter.cpp
+ ${LLVM_DIR}/lib/IR/DomTreeUpdater.cpp
+ ${LLVM_DIR}/lib/IR/Dominators.cpp
+ ${LLVM_DIR}/lib/IR/Function.cpp
+ ${LLVM_DIR}/lib/IR/GVMaterializer.cpp
+ ${LLVM_DIR}/lib/IR/Globals.cpp
+ ${LLVM_DIR}/lib/IR/IRBuilder.cpp
+ ${LLVM_DIR}/lib/IR/IRPrintingPasses.cpp
+ ${LLVM_DIR}/lib/IR/InlineAsm.cpp
+ ${LLVM_DIR}/lib/IR/Instruction.cpp
+ ${LLVM_DIR}/lib/IR/Instructions.cpp
+ ${LLVM_DIR}/lib/IR/IntrinsicInst.cpp
+ ${LLVM_DIR}/lib/IR/LLVMContext.cpp
+ ${LLVM_DIR}/lib/IR/LLVMContextImpl.cpp
+ ${LLVM_DIR}/lib/IR/LegacyPassManager.cpp
+ ${LLVM_DIR}/lib/IR/MDBuilder.cpp
+ ${LLVM_DIR}/lib/IR/Mangler.cpp
+ ${LLVM_DIR}/lib/IR/Metadata.cpp
+ ${LLVM_DIR}/lib/IR/Module.cpp
+ ${LLVM_DIR}/lib/IR/ModuleSummaryIndex.cpp
+ ${LLVM_DIR}/lib/IR/Operator.cpp
+ ${LLVM_DIR}/lib/IR/OptBisect.cpp
+ ${LLVM_DIR}/lib/IR/Pass.cpp
+ ${LLVM_DIR}/lib/IR/PassManager.cpp
+ ${LLVM_DIR}/lib/IR/PassRegistry.cpp
+ ${LLVM_DIR}/lib/IR/ProfileSummary.cpp
+ ${LLVM_DIR}/lib/IR/SafepointIRVerifier.cpp
+ ${LLVM_DIR}/lib/IR/Statepoint.cpp
+ ${LLVM_DIR}/lib/IR/Type.cpp
+ ${LLVM_DIR}/lib/IR/TypeFinder.cpp
+ ${LLVM_DIR}/lib/IR/Use.cpp
+ ${LLVM_DIR}/lib/IR/User.cpp
+ ${LLVM_DIR}/lib/IR/Value.cpp
+ ${LLVM_DIR}/lib/IR/ValueSymbolTable.cpp
+ ${LLVM_DIR}/lib/IR/Verifier.cpp
+ ${LLVM_DIR}/lib/IRReader/IRReader.cpp
+ ${LLVM_DIR}/lib/MC/ConstantPools.cpp
+ ${LLVM_DIR}/lib/MC/ELFObjectWriter.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmBackend.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmInfo.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmInfoCOFF.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmInfoDarwin.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmInfoELF.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmInfoWasm.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmMacro.cpp
+ ${LLVM_DIR}/lib/MC/MCAsmStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCAssembler.cpp
+ ${LLVM_DIR}/lib/MC/MCCodeEmitter.cpp
+ ${LLVM_DIR}/lib/MC/MCCodePadder.cpp
+ ${LLVM_DIR}/lib/MC/MCCodeView.cpp
+ ${LLVM_DIR}/lib/MC/MCContext.cpp
+ ${LLVM_DIR}/lib/MC/MCDisassembler/Disassembler.cpp
+ ${LLVM_DIR}/lib/MC/MCDisassembler/MCDisassembler.cpp
+ ${LLVM_DIR}/lib/MC/MCDisassembler/MCExternalSymbolizer.cpp
+ ${LLVM_DIR}/lib/MC/MCDisassembler/MCRelocationInfo.cpp
+ ${LLVM_DIR}/lib/MC/MCDisassembler/MCSymbolizer.cpp
+ ${LLVM_DIR}/lib/MC/MCDwarf.cpp
+ ${LLVM_DIR}/lib/MC/MCELFObjectTargetWriter.cpp
+ ${LLVM_DIR}/lib/MC/MCELFStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCExpr.cpp
+ ${LLVM_DIR}/lib/MC/MCFragment.cpp
+ ${LLVM_DIR}/lib/MC/MCInst.cpp
+ ${LLVM_DIR}/lib/MC/MCInstPrinter.cpp
+ ${LLVM_DIR}/lib/MC/MCInstrAnalysis.cpp
+ ${LLVM_DIR}/lib/MC/MCInstrDesc.cpp
+ ${LLVM_DIR}/lib/MC/MCLabel.cpp
+ ${LLVM_DIR}/lib/MC/MCLinkerOptimizationHint.cpp
+ ${LLVM_DIR}/lib/MC/MCMachOStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCMachObjectTargetWriter.cpp
+ ${LLVM_DIR}/lib/MC/MCNullStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCObjectFileInfo.cpp
+ ${LLVM_DIR}/lib/MC/MCObjectStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCObjectWriter.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/AsmLexer.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/AsmParser.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/COFFAsmParser.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/DarwinAsmParser.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/ELFAsmParser.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/MCAsmLexer.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/MCAsmParser.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/MCAsmParserExtension.cpp
+ ${LLVM_DIR}/lib/MC/MCParser/MCTargetAsmParser.cpp
+ ${LLVM_DIR}/lib/MC/MCRegisterInfo.cpp
+ ${LLVM_DIR}/lib/MC/MCSchedule.cpp
+ ${LLVM_DIR}/lib/MC/MCSection.cpp
+ ${LLVM_DIR}/lib/MC/MCSectionCOFF.cpp
+ ${LLVM_DIR}/lib/MC/MCSectionELF.cpp
+ ${LLVM_DIR}/lib/MC/MCSectionMachO.cpp
+ ${LLVM_DIR}/lib/MC/MCSectionWasm.cpp
+ ${LLVM_DIR}/lib/MC/MCStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCSubtargetInfo.cpp
+ ${LLVM_DIR}/lib/MC/MCSymbol.cpp
+ ${LLVM_DIR}/lib/MC/MCSymbolELF.cpp
+ ${LLVM_DIR}/lib/MC/MCTargetOptions.cpp
+ ${LLVM_DIR}/lib/MC/MCValue.cpp
+ ${LLVM_DIR}/lib/MC/MCWasmObjectTargetWriter.cpp
+ ${LLVM_DIR}/lib/MC/MCWasmStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCWin64EH.cpp
+ ${LLVM_DIR}/lib/MC/MCWinCOFFStreamer.cpp
+ ${LLVM_DIR}/lib/MC/MCWinEH.cpp
+ ${LLVM_DIR}/lib/MC/MachObjectWriter.cpp
+ ${LLVM_DIR}/lib/MC/StringTableBuilder.cpp
+ ${LLVM_DIR}/lib/MC/SubtargetFeature.cpp
+ ${LLVM_DIR}/lib/MC/WasmObjectWriter.cpp
+ ${LLVM_DIR}/lib/MC/WinCOFFObjectWriter.cpp
+ ${LLVM_DIR}/lib/Object/Archive.cpp
+ ${LLVM_DIR}/lib/Object/ArchiveWriter.cpp
+ ${LLVM_DIR}/lib/Object/Binary.cpp
+ ${LLVM_DIR}/lib/Object/COFFImportFile.cpp
+ ${LLVM_DIR}/lib/Object/COFFModuleDefinition.cpp
+ ${LLVM_DIR}/lib/Object/COFFObjectFile.cpp
+ ${LLVM_DIR}/lib/Object/Decompressor.cpp
+ ${LLVM_DIR}/lib/Object/ELF.cpp
+ ${LLVM_DIR}/lib/Object/ELFObjectFile.cpp
+ ${LLVM_DIR}/lib/Object/Error.cpp
+ ${LLVM_DIR}/lib/Object/IRObjectFile.cpp
+ ${LLVM_DIR}/lib/Object/IRSymtab.cpp
+ ${LLVM_DIR}/lib/Object/MachOObjectFile.cpp
+ ${LLVM_DIR}/lib/Object/MachOUniversal.cpp
+ ${LLVM_DIR}/lib/Object/ModuleSymbolTable.cpp
+ ${LLVM_DIR}/lib/Object/Object.cpp
+ ${LLVM_DIR}/lib/Object/ObjectFile.cpp
+ ${LLVM_DIR}/lib/Object/RecordStreamer.cpp
+ ${LLVM_DIR}/lib/Object/SymbolSize.cpp
+ ${LLVM_DIR}/lib/Object/SymbolicFile.cpp
+ ${LLVM_DIR}/lib/Object/WasmObjectFile.cpp
+ ${LLVM_DIR}/lib/Object/WindowsResource.cpp
+ ${LLVM_DIR}/lib/ProfileData/GCOV.cpp
+ ${LLVM_DIR}/lib/ProfileData/InstrProf.cpp
+ ${LLVM_DIR}/lib/ProfileData/InstrProfReader.cpp
+ ${LLVM_DIR}/lib/ProfileData/InstrProfWriter.cpp
+ ${LLVM_DIR}/lib/ProfileData/ProfileSummaryBuilder.cpp
+ ${LLVM_DIR}/lib/ProfileData/SampleProf.cpp
+ ${LLVM_DIR}/lib/ProfileData/SampleProfReader.cpp
+ ${LLVM_DIR}/lib/ProfileData/SampleProfWriter.cpp
+ ${LLVM_DIR}/lib/Support/AMDGPUMetadata.cpp
+ ${LLVM_DIR}/lib/Support/APFloat.cpp
+ ${LLVM_DIR}/lib/Support/APInt.cpp
+ ${LLVM_DIR}/lib/Support/APSInt.cpp
+ ${LLVM_DIR}/lib/Support/ARMAttributeParser.cpp
+ ${LLVM_DIR}/lib/Support/ARMBuildAttrs.cpp
+ ${LLVM_DIR}/lib/Support/ARMWinEH.cpp
+ ${LLVM_DIR}/lib/Support/Allocator.cpp
+ ${LLVM_DIR}/lib/Support/Atomic.cpp
+ ${LLVM_DIR}/lib/Support/BinaryStreamError.cpp
+ ${LLVM_DIR}/lib/Support/BinaryStreamReader.cpp
+ ${LLVM_DIR}/lib/Support/BinaryStreamRef.cpp
+ ${LLVM_DIR}/lib/Support/BinaryStreamWriter.cpp
+ ${LLVM_DIR}/lib/Support/BlockFrequency.cpp
+ ${LLVM_DIR}/lib/Support/BranchProbability.cpp
+ ${LLVM_DIR}/lib/Support/COM.cpp
+ ${LLVM_DIR}/lib/Support/CachePruning.cpp
+ ${LLVM_DIR}/lib/Support/Chrono.cpp
+ ${LLVM_DIR}/lib/Support/CodeGenCoverage.cpp
+ ${LLVM_DIR}/lib/Support/CommandLine.cpp
+ ${LLVM_DIR}/lib/Support/Compression.cpp
+ ${LLVM_DIR}/lib/Support/ConvertUTF.cpp
+ ${LLVM_DIR}/lib/Support/ConvertUTFWrapper.cpp
+ ${LLVM_DIR}/lib/Support/CrashRecoveryContext.cpp
+ ${LLVM_DIR}/lib/Support/DAGDeltaAlgorithm.cpp
+ ${LLVM_DIR}/lib/Support/DJB.cpp
+ ${LLVM_DIR}/lib/Support/DataExtractor.cpp
+ ${LLVM_DIR}/lib/Support/Debug.cpp
+ ${LLVM_DIR}/lib/Support/DebugCounter.cpp
+ ${LLVM_DIR}/lib/Support/DeltaAlgorithm.cpp
+ ${LLVM_DIR}/lib/Support/DynamicLibrary.cpp
+ ${LLVM_DIR}/lib/Support/Errno.cpp
+ ${LLVM_DIR}/lib/Support/Error.cpp
+ ${LLVM_DIR}/lib/Support/ErrorHandling.cpp
+ ${LLVM_DIR}/lib/Support/FileOutputBuffer.cpp
+ ${LLVM_DIR}/lib/Support/FileUtilities.cpp
+ ${LLVM_DIR}/lib/Support/FoldingSet.cpp
+ ${LLVM_DIR}/lib/Support/FormatVariadic.cpp
+ ${LLVM_DIR}/lib/Support/FormattedStream.cpp
+ ${LLVM_DIR}/lib/Support/GlobPattern.cpp
+ ${LLVM_DIR}/lib/Support/GraphWriter.cpp
+ ${LLVM_DIR}/lib/Support/Hashing.cpp
+ ${LLVM_DIR}/lib/Support/Host.cpp
+ ${LLVM_DIR}/lib/Support/InitLLVM.cpp
+ ${LLVM_DIR}/lib/Support/IntEqClasses.cpp
+ ${LLVM_DIR}/lib/Support/IntervalMap.cpp
+ ${LLVM_DIR}/lib/Support/JSON.cpp
+ ${LLVM_DIR}/lib/Support/JamCRC.cpp
+ ${LLVM_DIR}/lib/Support/KnownBits.cpp
+ ${LLVM_DIR}/lib/Support/LEB128.cpp
+ ${LLVM_DIR}/lib/Support/LineIterator.cpp
+ ${LLVM_DIR}/lib/Support/Locale.cpp
+ ${LLVM_DIR}/lib/Support/LockFileManager.cpp
+ ${LLVM_DIR}/lib/Support/LowLevelType.cpp
+ ${LLVM_DIR}/lib/Support/MD5.cpp
+ ${LLVM_DIR}/lib/Support/ManagedStatic.cpp
+ ${LLVM_DIR}/lib/Support/MathExtras.cpp
+ ${LLVM_DIR}/lib/Support/Memory.cpp
+ ${LLVM_DIR}/lib/Support/MemoryBuffer.cpp
+ ${LLVM_DIR}/lib/Support/Mutex.cpp
+ ${LLVM_DIR}/lib/Support/NativeFormatting.cpp
+ ${LLVM_DIR}/lib/Support/Options.cpp
+ ${LLVM_DIR}/lib/Support/Parallel.cpp
+ ${LLVM_DIR}/lib/Support/Path.cpp
+ ${LLVM_DIR}/lib/Support/PluginLoader.cpp
+ ${LLVM_DIR}/lib/Support/PrettyStackTrace.cpp
+ ${LLVM_DIR}/lib/Support/Process.cpp
+ ${LLVM_DIR}/lib/Support/Program.cpp
+ ${LLVM_DIR}/lib/Support/RWMutex.cpp
+ ${LLVM_DIR}/lib/Support/RandomNumberGenerator.cpp
+ ${LLVM_DIR}/lib/Support/Regex.cpp
+ ${LLVM_DIR}/lib/Support/SHA1.cpp
+ ${LLVM_DIR}/lib/Support/ScaledNumber.cpp
+ ${LLVM_DIR}/lib/Support/ScopedPrinter.cpp
+ ${LLVM_DIR}/lib/Support/Signals.cpp
+ ${LLVM_DIR}/lib/Support/SmallPtrSet.cpp
+ ${LLVM_DIR}/lib/Support/SmallVector.cpp
+ ${LLVM_DIR}/lib/Support/SourceMgr.cpp
+ ${LLVM_DIR}/lib/Support/SpecialCaseList.cpp
+ ${LLVM_DIR}/lib/Support/Statistic.cpp
+ ${LLVM_DIR}/lib/Support/StringExtras.cpp
+ ${LLVM_DIR}/lib/Support/StringMap.cpp
+ ${LLVM_DIR}/lib/Support/StringPool.cpp
+ ${LLVM_DIR}/lib/Support/StringRef.cpp
+ ${LLVM_DIR}/lib/Support/StringSaver.cpp
+ ${LLVM_DIR}/lib/Support/SystemUtils.cpp
+ ${LLVM_DIR}/lib/Support/TarWriter.cpp
+ ${LLVM_DIR}/lib/Support/TargetParser.cpp
+ ${LLVM_DIR}/lib/Support/TargetRegistry.cpp
+ ${LLVM_DIR}/lib/Support/ThreadLocal.cpp
+ ${LLVM_DIR}/lib/Support/ThreadPool.cpp
+ ${LLVM_DIR}/lib/Support/Threading.cpp
+ ${LLVM_DIR}/lib/Support/Timer.cpp
+ ${LLVM_DIR}/lib/Support/ToolOutputFile.cpp
+ ${LLVM_DIR}/lib/Support/TrigramIndex.cpp
+ ${LLVM_DIR}/lib/Support/Triple.cpp
+ ${LLVM_DIR}/lib/Support/Twine.cpp
+ ${LLVM_DIR}/lib/Support/Unicode.cpp
+ ${LLVM_DIR}/lib/Support/UnicodeCaseFold.cpp
+ ${LLVM_DIR}/lib/Support/Valgrind.cpp
+ ${LLVM_DIR}/lib/Support/VersionTuple.cpp
+ ${LLVM_DIR}/lib/Support/Watchdog.cpp
+ ${LLVM_DIR}/lib/Support/WithColor.cpp
+ ${LLVM_DIR}/lib/Support/YAMLParser.cpp
+ ${LLVM_DIR}/lib/Support/YAMLTraits.cpp
+ ${LLVM_DIR}/lib/Support/circular_raw_ostream.cpp
+ ${LLVM_DIR}/lib/Support/raw_os_ostream.cpp
+ ${LLVM_DIR}/lib/Support/raw_ostream.cpp
+ ${LLVM_DIR}/lib/Support/regcomp.c
+ ${LLVM_DIR}/lib/Support/regerror.c
+ ${LLVM_DIR}/lib/Support/regerror.c
+ ${LLVM_DIR}/lib/Support/regexec.c
+ ${LLVM_DIR}/lib/Support/regfree.c
+ ${LLVM_DIR}/lib/Support/regstrlcpy.c
+ ${LLVM_DIR}/lib/Support/xxhash.cpp
+ ${LLVM_DIR}/lib/Target/Target.cpp
+ ${LLVM_DIR}/lib/Target/TargetIntrinsicInfo.cpp
+ ${LLVM_DIR}/lib/Target/TargetLoweringObjectFile.cpp
+ ${LLVM_DIR}/lib/Target/TargetMachine.cpp
+ ${LLVM_DIR}/lib/Target/TargetMachineC.cpp
+ ${LLVM_DIR}/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp
+ ${LLVM_DIR}/lib/Target/X86/AsmParser/X86AsmParser.cpp
+ ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86ATTInstPrinter.cpp
+ ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86InstComments.cpp
+ ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86InstPrinterCommon.cpp
+ ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86IntelInstPrinter.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86AsmBackend.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MCAsmInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MCTargetDesc.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MachObjectWriter.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86WinCOFFObjectWriter.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86WinCOFFStreamer.cpp
+ ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86WinCOFFTargetStreamer.cpp
+ ${LLVM_DIR}/lib/Target/X86/ShadowCallStack.cpp
+ ${LLVM_DIR}/lib/Target/X86/TargetInfo/X86TargetInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/Utils/X86ShuffleDecode.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86AsmPrinter.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86AvoidStoreForwardingBlocks.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86CallFrameOptimization.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86CallLowering.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86CallingConv.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86CmovConversion.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86DomainReassignment.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86EvexToVex.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86ExpandPseudo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86FastISel.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86FixupBWInsts.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86FixupLEAs.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86FixupSetCC.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86FlagsCopyLowering.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86FloatingPoint.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86FrameLowering.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86ISelDAGToDAG.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86ISelLowering.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86IndirectBranchTracking.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86InstrFMA3Info.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86InstrFoldTables.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86InstrInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86InstructionSelector.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86InterleavedAccess.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86LegalizerInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86MCInstLower.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86MachineFunctionInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86MacroFusion.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86OptimizeLEAs.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86PadShortFunction.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86RegisterBankInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86RegisterInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86RetpolineThunks.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86SelectionDAGInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86ShuffleDecodeConstantPool.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86SpeculativeLoadHardening.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86Subtarget.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86TargetMachine.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86TargetObjectFile.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86TargetTransformInfo.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86VZeroUpper.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86WinAllocaExpander.cpp
+ ${LLVM_DIR}/lib/Target/X86/X86WinEHState.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineAddSub.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineCalls.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineCasts.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineCompares.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineLoadStoreAlloca.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineMulDivRem.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombinePHI.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineSelect.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineShifts.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineVectorOps.cpp
+ ${LLVM_DIR}/lib/Transforms/InstCombine/InstructionCombining.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/ADCE.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/AlignmentFromAssumptions.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/BDCE.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/CallSiteSplitting.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/ConstantHoisting.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/ConstantProp.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/DCE.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/DeadStoreElimination.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/DivRemPairs.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/EarlyCSE.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/FlattenCFGPass.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/Float2Int.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/GVN.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/GVNHoist.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/GVNSink.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/GuardWidening.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/IVUsersPrinter.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/IndVarSimplify.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/InductiveRangeCheckElimination.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/InferAddressSpaces.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/InstSimplifyPass.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/JumpThreading.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LICM.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopAccessAnalysisPrinter.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopDataPrefetch.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopDeletion.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopDistribute.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopIdiomRecognize.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopInstSimplify.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopInterchange.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopLoadElimination.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopPassManager.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopPredication.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopRerollPass.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopRotation.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopSimplifyCFG.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopSink.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopStrengthReduce.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopUnrollAndJamPass.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopUnrollPass.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopUnswitch.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LoopVersioningLICM.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LowerAtomic.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LowerExpectIntrinsic.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/LowerGuardIntrinsic.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/MemCpyOptimizer.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/MergeICmps.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/MergedLoadStoreMotion.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/NaryReassociate.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/NewGVN.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/PartiallyInlineLibCalls.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/PlaceSafepoints.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/Reassociate.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/Reg2Mem.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/RewriteStatepointsForGC.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/SCCP.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/SROA.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/Scalar.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/Scalarizer.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/SeparateConstOffsetFromGEP.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/SimpleLoopUnswitch.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/SimplifyCFGPass.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/Sink.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/SpeculateAroundPHIs.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/SpeculativeExecution.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/StraightLineStrengthReduce.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/StructurizeCFG.cpp
+ ${LLVM_DIR}/lib/Transforms/Scalar/TailRecursionElimination.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/ASanStackFrameLayout.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/AddDiscriminators.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/BasicBlockUtils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/BreakCriticalEdges.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/BuildLibCalls.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/BypassSlowDivision.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/CallPromotionUtils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/CloneFunction.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/CloneModule.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/CodeExtractor.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/CtorUtils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/DemoteRegToStack.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/EntryExitInstrumenter.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/EscapeEnumerator.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/Evaluator.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/FlattenCFG.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/FunctionComparator.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/FunctionImportUtils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/GlobalStatus.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/ImportedFunctionsInliningStatistics.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/InlineFunction.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/InstructionNamer.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/IntegerDivision.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LCSSA.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LibCallsShrinkWrap.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/Local.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopRotationUtils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopSimplify.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopUnroll.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopUnrollAndJam.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopUnrollPeel.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopUnrollRuntime.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopUtils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LoopVersioning.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LowerInvoke.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LowerMemIntrinsics.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/LowerSwitch.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/Mem2Reg.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/MetaRenamer.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/ModuleUtils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/NameAnonGlobals.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/OrderedInstructions.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/PredicateInfo.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/PromoteMemoryToRegister.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SSAUpdater.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SSAUpdaterBulk.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SanitizerStats.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SimplifyCFG.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SimplifyIndVar.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SimplifyLibCalls.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SplitModule.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/StripGCRelocates.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/StripNonLineTableDebugInfo.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/SymbolRewriter.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/UnifyFunctionExitNodes.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/Utils.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/VNCoercion.cpp
+ ${LLVM_DIR}/lib/Transforms/Utils/ValueMapper.cpp
+)
+
+set(LLVM_INCLUDE_DIR "")
+
+if(WIN32)
+ # list(APPEND LLVM_INCLUDE_DIR ${LLVM_CONFIG_DIR}/include)
+elseif(LINUX)
+ list(APPEND LLVM_INCLUDE_DIR ${LLVM_CONFIG_DIR}/linux/include)
+elseif(APPLE)
+ # list(APPEND LLVM_INCLUDE_DIR ${LLVM_CONFIG_DIR}/include-osx)
+endif()
+
+list(APPEND LLVM_INCLUDE_DIR
+ ${LLVM_DIR}/include
+ ${LLVM_DIR}/lib/Target/X86
+ ${LLVM_CONFIG_DIR}/common/include
+ ${LLVM_CONFIG_DIR}/common/lib/IR
+ ${LLVM_CONFIG_DIR}/common/lib/Target/X86
+ ${LLVM_CONFIG_DIR}/common/lib/Transforms/InstCombine
+)
+
+endif() # SWIFTSHADER_LLVM_VERSION
+
add_library(llvm STATIC ${LLVM_LIST})
set_target_properties(llvm PROPERTIES
POSITION_INDEPENDENT_CODE 1
diff --git a/src/Reactor/LLVMReactor.cpp b/src/Reactor/LLVMReactor.cpp
index 801aef3..ff290c2 100644
--- a/src/Reactor/LLVMReactor.cpp
+++ b/src/Reactor/LLVMReactor.cpp
@@ -14,37 +14,72 @@
#include "Reactor.hpp"
-#include "llvm/Support/IRBuilder.h"
-#include "llvm/Function.h"
-#include "llvm/GlobalVariable.h"
-#include "llvm/Module.h"
-#include "llvm/LLVMContext.h"
-#include "llvm/Constants.h"
-#include "llvm/Intrinsics.h"
-#include "llvm/PassManager.h"
-#include "llvm/Analysis/LoopPass.h"
-#include "llvm/Transforms/Scalar.h"
-#include "llvm/Target/TargetData.h"
-#include "llvm/Target/TargetOptions.h"
-#include "llvm/Support/TargetSelect.h"
-#include "../lib/ExecutionEngine/JIT/JIT.h"
+#if SWIFTSHADER_LLVM_VERSION < 7
+ #include "llvm/Analysis/LoopPass.h"
+ #include "llvm/Constants.h"
+ #include "llvm/Function.h"
+ #include "llvm/GlobalVariable.h"
+ #include "llvm/Intrinsics.h"
+ #include "llvm/LLVMContext.h"
+ #include "llvm/Module.h"
+ #include "llvm/PassManager.h"
+ #include "llvm/Support/IRBuilder.h"
+ #include "llvm/Support/TargetSelect.h"
+ #include "llvm/Target/TargetData.h"
+ #include "llvm/Target/TargetOptions.h"
+ #include "llvm/Transforms/Scalar.h"
+ #include "../lib/ExecutionEngine/JIT/JIT.h"
-#include "LLVMRoutine.hpp"
-#include "LLVMRoutineManager.hpp"
+ #include "LLVMRoutine.hpp"
+ #include "LLVMRoutineManager.hpp"
+
+ #define ARGS(...) __VA_ARGS__
+#else
+ #include "llvm/Analysis/LoopPass.h"
+ #include "llvm/ExecutionEngine/ExecutionEngine.h"
+ #include "llvm/ExecutionEngine/JITSymbol.h"
+ #include "llvm/ExecutionEngine/Orc/CompileUtils.h"
+ #include "llvm/ExecutionEngine/Orc/IRCompileLayer.h"
+ #include "llvm/ExecutionEngine/Orc/LambdaResolver.h"
+ #include "llvm/ExecutionEngine/Orc/RTDyldObjectLinkingLayer.h"
+ #include "llvm/ExecutionEngine/RTDyldMemoryManager.h"
+ #include "llvm/ExecutionEngine/SectionMemoryManager.h"
+ #include "llvm/IR/Constants.h"
+ #include "llvm/IR/DataLayout.h"
+ #include "llvm/IR/Function.h"
+ #include "llvm/IR/GlobalVariable.h"
+ #include "llvm/IR/IRBuilder.h"
+ #include "llvm/IR/Intrinsics.h"
+ #include "llvm/IR/LLVMContext.h"
+ #include "llvm/IR/LegacyPassManager.h"
+ #include "llvm/IR/Module.h"
+ #include "llvm/Support/Error.h"
+ #include "llvm/Support/TargetSelect.h"
+ #include "llvm/Target/TargetOptions.h"
+ #include "llvm/Transforms/InstCombine/InstCombine.h"
+ #include "llvm/Transforms/Scalar.h"
+ #include "llvm/Transforms/Scalar/GVN.h"
+
+ #include "LLVMRoutine.hpp"
+
+ #define ARGS(...) {__VA_ARGS__}
+ #define CreateCall2 CreateCall
+ #define CreateCall3 CreateCall
+#endif
+
#include "x86.hpp"
#include "Common/CPUID.hpp"
#include "Common/Thread.hpp"
#include "Common/Memory.hpp"
#include "Common/MutexLock.hpp"
+#include <numeric>
#include <fstream>
#if defined(__i386__) || defined(__x86_64__)
#include <xmmintrin.h>
#endif
-#define ARGS(...) __VA_ARGS__
-
#if defined(__x86_64__) && defined(_WIN32)
extern "C" void X86CompilationCallback()
{
@@ -52,17 +87,21 @@
}
#endif
+#if defined(_WIN32)
extern "C"
{
bool (*CodeAnalystInitialize)() = 0;
void (*CodeAnalystCompleteJITLog)() = 0;
bool (*CodeAnalystLogJITCode)(const void *jitCodeStartAddr, unsigned int jitCodeSize, const wchar_t *functionName) = 0;
}
+#endif
+#if SWIFTSHADER_LLVM_VERSION < 7
namespace llvm
{
extern bool JITEmitDebugInfo;
}
+#endif
namespace sw
{
@@ -78,10 +117,66 @@
llvm::Function *function = nullptr;
sw::MutexLock codegenMutex;
+
+#if SWIFTSHADER_LLVM_VERSION >= 7
+#if defined(__i386__) || defined(__x86_64__)
+ llvm::Value *lowerPAVG(llvm::Value *x, llvm::Value *y)
+ {
+ llvm::VectorType *ty = llvm::cast<llvm::VectorType>(x->getType());
+
+ llvm::VectorType *extTy =
+ llvm::VectorType::getExtendedElementVectorType(ty);
+ x = ::builder->CreateZExt(x, extTy);
+ y = ::builder->CreateZExt(y, extTy);
+
+ // (x + y + 1) >> 1
+ llvm::Constant *one = llvm::ConstantInt::get(extTy, 1);
+ llvm::Value *res = ::builder->CreateAdd(x, y);
+ res = ::builder->CreateAdd(res, one);
+ res = ::builder->CreateLShr(res, one);
+ return ::builder->CreateTrunc(res, ty);
+ }
+
+ llvm::Value *lowerPMINMAX(llvm::Value *x, llvm::Value *y,
+ llvm::ICmpInst::Predicate pred)
+ {
+ return ::builder->CreateSelect(::builder->CreateICmp(pred, x, y), x, y);
+ }
+
+ llvm::Value *lowerPCMP(llvm::ICmpInst::Predicate pred, llvm::Value *x,
+ llvm::Value *y, llvm::Type *dstTy)
+ {
+ return ::builder->CreateSExt(::builder->CreateICmp(pred, x, y), dstTy, "");
+ }
+
+ llvm::Value *lowerPMOV(llvm::Value *op, llvm::Type *dstType, bool sext)
+ {
+ llvm::VectorType *srcTy = llvm::cast<llvm::VectorType>(op->getType());
+ llvm::VectorType *dstTy = llvm::cast<llvm::VectorType>(dstType);
+
+ llvm::Value *undef = llvm::UndefValue::get(srcTy);
+ llvm::SmallVector<uint32_t, 16> mask(dstTy->getNumElements());
+ std::iota(mask.begin(), mask.end(), 0);
+ llvm::Value *v = ::builder->CreateShuffleVector(op, undef, mask);
+
+ return sext ? ::builder->CreateSExt(v, dstTy)
+ : ::builder->CreateZExt(v, dstTy);
+ }
+
+ llvm::Value *lowerPABS(llvm::Value *v)
+ {
+ llvm::Value *zero = llvm::Constant::getNullValue(v->getType());
+ llvm::Value *cmp = ::builder->CreateICmp(llvm::ICmpInst::ICMP_SGT, v, zero);
+ llvm::Value *neg = ::builder->CreateNeg(v);
+ return ::builder->CreateSelect(cmp, v, neg);
+ }
+#endif // defined(__i386__) || defined(__x86_64__)
+#endif // SWIFTSHADER_LLVM_VERSION >= 7
}
namespace sw
{
+#if SWIFTSHADER_LLVM_VERSION < 7
class LLVMReactorJIT
{
private:
@@ -168,6 +263,132 @@
passManager->run(*::module);
}
};
+#else
+ class LLVMReactorJIT
+ {
+ private:
+ using ObjLayer = llvm::orc::RTDyldObjectLinkingLayer;
+ using CompileLayer = llvm::orc::IRCompileLayer<ObjLayer, llvm::orc::SimpleCompiler>;
+
+ llvm::orc::ExecutionSession session;
+ std::shared_ptr<llvm::orc::SymbolResolver> resolver;
+ std::unique_ptr<llvm::TargetMachine> targetMachine;
+ const llvm::DataLayout dataLayout;
+ ObjLayer objLayer;
+ CompileLayer compileLayer;
+ size_t emittedFunctionsNum;
+
+ public:
+ LLVMReactorJIT(const char *arch, const llvm::SmallVectorImpl<std::string>& mattrs,
+ const llvm::TargetOptions &targetOpts):
+ resolver(createLegacyLookupResolver(
+ session,
+ [this](const std::string &name) {
+ return objLayer.findSymbol(name, true);
+ },
+ [](llvm::Error err) {
+ if (err)
+ {
+ // TODO: Log the symbol resolution errors.
+ return;
+ }
+ })),
+ targetMachine(llvm::EngineBuilder()
+ .setMArch(arch)
+ .setMAttrs(mattrs)
+ .setTargetOptions(targetOpts)
+ .selectTarget()),
+ dataLayout(targetMachine->createDataLayout()),
+ objLayer(
+ session,
+ [this](llvm::orc::VModuleKey) {
+ return ObjLayer::Resources{
+ std::make_shared<llvm::SectionMemoryManager>(),
+ resolver};
+ }),
+ compileLayer(objLayer, llvm::orc::SimpleCompiler(*targetMachine)),
+ emittedFunctionsNum(0)
+ {
+ }
+
+ void startSession()
+ {
+ ::module = new llvm::Module("", *::context);
+ }
+
+ void endSession()
+ {
+ ::function = nullptr;
+ ::module = nullptr;
+ }
+
+ LLVMRoutine *acquireRoutine(llvm::Function *func)
+ {
+ std::string name = "f" + llvm::Twine(emittedFunctionsNum++).str();
+ func->setName(name);
+ func->setLinkage(llvm::GlobalValue::ExternalLinkage);
+ func->setDoesNotThrow();
+
+ std::unique_ptr<llvm::Module> mod(::module);
+ ::module = nullptr;
+ mod->setDataLayout(dataLayout);
+
+ auto moduleKey = session.allocateVModule();
+ llvm::cantFail(compileLayer.addModule(moduleKey, std::move(mod)));
+
+ llvm::JITSymbol symbol = compileLayer.findSymbolIn(moduleKey, name, false);
+
+ llvm::Expected<llvm::JITTargetAddress> expectAddr = symbol.getAddress();
+ if (!expectAddr)
+ {
+ return nullptr;
+ }
+
+ void *addr = reinterpret_cast<void *>(static_cast<intptr_t>(expectAddr.get()));
+ return new LLVMRoutine(addr, releaseRoutineCallback, this, moduleKey);
+ }
+
+ void optimize(llvm::Module *module)
+ {
+ std::unique_ptr<llvm::legacy::PassManager> passManager(
+ new llvm::legacy::PassManager());
+
+ passManager->add(llvm::createSROAPass());
+
+ for(int pass = 0; pass < 10 && optimization[pass] != Disabled; pass++)
+ {
+ switch(optimization[pass])
+ {
+ case Disabled: break;
+ case CFGSimplification: passManager->add(llvm::createCFGSimplificationPass()); break;
+ case LICM: passManager->add(llvm::createLICMPass()); break;
+ case AggressiveDCE: passManager->add(llvm::createAggressiveDCEPass()); break;
+ case GVN: passManager->add(llvm::createGVNPass()); break;
+ case InstructionCombining: passManager->add(llvm::createInstructionCombiningPass()); break;
+ case Reassociate: passManager->add(llvm::createReassociatePass()); break;
+ case DeadStoreElimination: passManager->add(llvm::createDeadStoreEliminationPass()); break;
+ case SCCP: passManager->add(llvm::createSCCPPass()); break;
+ case ScalarReplAggregates: passManager->add(llvm::createSROAPass()); break;
+ default:
+ assert(false);
+ }
+ }
+
+ passManager->run(*::module);
+ }
+
+ private:
+ void releaseRoutineModule(llvm::orc::VModuleKey moduleKey)
+ {
+ llvm::cantFail(compileLayer.removeModule(moduleKey));
+ }
+
+ static void releaseRoutineCallback(LLVMReactorJIT *jit, uint64_t moduleKey)
+ {
+ jit->releaseRoutineModule(moduleKey);
+ }
+ };
+#endif
Optimization optimization[10] = {InstructionCombining, Disabled};
@@ -284,6 +505,11 @@
llvm::InitializeNativeTarget();
+#if SWIFTSHADER_LLVM_VERSION >= 7
+ llvm::InitializeNativeTargetAsmPrinter();
+ llvm::InitializeNativeTargetAsmParser();
+#endif
+
if(!::context)
{
::context = new llvm::LLVMContext();
@@ -296,22 +522,37 @@
#endif
llvm::SmallVector<std::string, 1> mattrs;
- mattrs.push_back(CPUID::supportsMMX() ? "+mmx" : "-mmx");
- mattrs.push_back(CPUID::supportsCMOV() ? "+cmov" : "-cmov");
- mattrs.push_back(CPUID::supportsSSE() ? "+sse" : "-sse");
- mattrs.push_back(CPUID::supportsSSE2() ? "+sse2" : "-sse2");
- mattrs.push_back(CPUID::supportsSSE3() ? "+sse3" : "-sse3");
- mattrs.push_back(CPUID::supportsSSSE3() ? "+ssse3" : "-ssse3");
- mattrs.push_back(CPUID::supportsSSE4_1() ? "+sse41" : "-sse41");
+ mattrs.push_back(CPUID::supportsMMX() ? "+mmx" : "-mmx");
+ mattrs.push_back(CPUID::supportsCMOV() ? "+cmov" : "-cmov");
+ mattrs.push_back(CPUID::supportsSSE() ? "+sse" : "-sse");
+ mattrs.push_back(CPUID::supportsSSE2() ? "+sse2" : "-sse2");
+ mattrs.push_back(CPUID::supportsSSE3() ? "+sse3" : "-sse3");
+ mattrs.push_back(CPUID::supportsSSSE3() ? "+ssse3" : "-ssse3");
+#if SWIFTSHADER_LLVM_VERSION < 7
+ mattrs.push_back(CPUID::supportsSSE4_1() ? "+sse41" : "-sse41");
+#else
+ mattrs.push_back(CPUID::supportsSSE4_1() ? "+sse4.1" : "-sse4.1");
+#endif
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::JITEmitDebugInfo = false;
llvm::UnsafeFPMath = true;
// llvm::NoInfsFPMath = true;
// llvm::NoNaNsFPMath = true;
+#else
+ llvm::TargetOptions targetOpts;
+ targetOpts.UnsafeFPMath = true;
+ // targetOpts.NoInfsFPMath = true;
+ // targetOpts.NoNaNsFPMath = true;
+#endif
if(!::reactorJIT)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
::reactorJIT = new LLVMReactorJIT(arch, mattrs);
+#else
+ ::reactorJIT = new LLVMReactorJIT(arch, mattrs, targetOpts);
+#endif
}
::reactorJIT->startSession();
@@ -320,7 +561,7 @@
{
::builder = new llvm::IRBuilder<>(*::context);
- #if defined(_WIN32)
+ #if defined(_WIN32) && SWIFTSHADER_LLVM_VERSION < 7
HMODULE CodeAnalyst = LoadLibrary("CAJitNtfyLib.dll");
if(CodeAnalyst)
{
@@ -359,7 +600,11 @@
if(false)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
std::string error;
+#else
+ std::error_code error;
+#endif
llvm::raw_fd_ostream file("llvm-dump-unopt.txt", error);
::module->print(file, 0);
}
@@ -371,17 +616,23 @@
if(false)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
std::string error;
+#else
+ std::error_code error;
+#endif
llvm::raw_fd_ostream file("llvm-dump-opt.txt", error);
::module->print(file, 0);
}
LLVMRoutine *routine = ::reactorJIT->acquireRoutine(::function);
+#if defined(_WIN32) && SWIFTSHADER_LLVM_VERSION < 7
if(CodeAnalystLogJITCode)
{
CodeAnalystLogJITCode(routine->getEntry(), routine->getCodeSize(), name);
}
+#endif
return routine;
}
@@ -400,11 +651,19 @@
if(arraySize)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
declaration = new llvm::AllocaInst(T(type), V(Nucleus::createConstantInt(arraySize)));
+#else
+ declaration = new llvm::AllocaInst(T(type), 0, V(Nucleus::createConstantInt(arraySize)));
+#endif
}
else
{
+#if SWIFTSHADER_LLVM_VERSION < 7
declaration = new llvm::AllocaInst(T(type), (llvm::Value*)nullptr);
+#else
+ declaration = new llvm::AllocaInst(T(type), 0, (llvm::Value*)nullptr);
+#endif
}
entryBlock.getInstList().push_front(declaration);
@@ -6082,11 +6341,15 @@
RValue<Float> sqrtss(RValue<Float> val)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *sqrtss = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse_sqrt_ss);
-
Value *vector = Nucleus::createInsertElement(V(llvm::UndefValue::get(T(Float4::getType()))), val.value, 0);
return RValue<Float>(Nucleus::createExtractElement(V(::builder->CreateCall(sqrtss, ARGS(V(vector)))), Float::getType(), 0));
+#else
+ llvm::Function *sqrt = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::sqrt, {V(val.value)->getType()});
+ return RValue<Float>(V(::builder->CreateCall(sqrt, ARGS(V(val.value)))));
+#endif
}
RValue<Float> rsqrtss(RValue<Float> val)
@@ -6107,7 +6370,11 @@
RValue<Float4> sqrtps(RValue<Float4> val)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *sqrtps = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse_sqrt_ps);
+#else
+ llvm::Function *sqrtps = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::sqrt, {V(val.value)->getType()});
+#endif
return RValue<Float4>(V(::builder->CreateCall(sqrtps, ARGS(V(val.value)))));
}
@@ -6172,9 +6439,13 @@
RValue<Int4> pabsd(RValue<Int4> x)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pabsd = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_ssse3_pabs_d_128);
return RValue<Int4>(V(::builder->CreateCall(pabsd, ARGS(V(x.value)))));
+#else
+ return RValue<Int4>(V(lowerPABS(V(x.value))));
+#endif
}
RValue<Short4> paddsw(RValue<Short4> x, RValue<Short4> y)
@@ -6235,51 +6506,79 @@
RValue<UShort4> pavgw(RValue<UShort4> x, RValue<UShort4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pavgw = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse2_pavg_w);
return As<UShort4>(V(::builder->CreateCall2(pavgw, ARGS(V(x.value), V(y.value)))));
+#else
+ return As<UShort4>(V(lowerPAVG(V(x.value), V(y.value))));
+#endif
}
RValue<Short4> pmaxsw(RValue<Short4> x, RValue<Short4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pmaxsw = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse2_pmaxs_w);
return As<Short4>(V(::builder->CreateCall2(pmaxsw, ARGS(V(x.value), V(y.value)))));
+#else
+ return As<Short4>(V(lowerPMINMAX(V(x.value), V(y.value), llvm::ICmpInst::ICMP_SGT)));
+#endif
}
RValue<Short4> pminsw(RValue<Short4> x, RValue<Short4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pminsw = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse2_pmins_w);
return As<Short4>(V(::builder->CreateCall2(pminsw, ARGS(V(x.value), V(y.value)))));
+#else
+ return As<Short4>(V(lowerPMINMAX(V(x.value), V(y.value), llvm::ICmpInst::ICMP_SLT)));
+#endif
}
RValue<Short4> pcmpgtw(RValue<Short4> x, RValue<Short4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pcmpgtw = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse2_pcmpgt_w);
return As<Short4>(V(::builder->CreateCall2(pcmpgtw, ARGS(V(x.value), V(y.value)))));
+#else
+ return As<Short4>(V(lowerPCMP(llvm::ICmpInst::ICMP_SGT, V(x.value), V(y.value), T(Short4::getType()))));
+#endif
}
RValue<Short4> pcmpeqw(RValue<Short4> x, RValue<Short4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pcmpeqw = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse2_pcmpeq_w);
return As<Short4>(V(::builder->CreateCall2(pcmpeqw, ARGS(V(x.value), V(y.value)))));
+#else
+ return As<Short4>(V(lowerPCMP(llvm::ICmpInst::ICMP_EQ, V(x.value), V(y.value), T(Short4::getType()))));
+#endif
}
RValue<Byte8> pcmpgtb(RValue<SByte8> x, RValue<SByte8> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pcmpgtb = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse2_pcmpgt_b);
return As<Byte8>(V(::builder->CreateCall2(pcmpgtb, ARGS(V(x.value), V(y.value)))));
+#else
+ return As<Byte8>(V(lowerPCMP(llvm::ICmpInst::ICMP_SGT, V(x.value), V(y.value), T(Byte8::getType()))));
+#endif
}
RValue<Byte8> pcmpeqb(RValue<Byte8> x, RValue<Byte8> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pcmpeqb = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse2_pcmpeq_b);
return As<Byte8>(V(::builder->CreateCall2(pcmpeqb, ARGS(V(x.value), V(y.value)))));
+#else
+ return As<Byte8>(V(lowerPCMP(llvm::ICmpInst::ICMP_EQ, V(x.value), V(y.value), T(Byte8::getType()))));
+#endif
}
RValue<Short4> packssdw(RValue<Int2> x, RValue<Int2> y)
@@ -6413,30 +6712,46 @@
RValue<Int4> pmaxsd(RValue<Int4> x, RValue<Int4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pmaxsd = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pmaxsd);
return RValue<Int4>(V(::builder->CreateCall2(pmaxsd, ARGS(V(x.value), V(y.value)))));
+#else
+ return RValue<Int4>(V(lowerPMINMAX(V(x.value), V(y.value), llvm::ICmpInst::ICMP_SGT)));
+#endif
}
RValue<Int4> pminsd(RValue<Int4> x, RValue<Int4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pminsd = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pminsd);
return RValue<Int4>(V(::builder->CreateCall2(pminsd, ARGS(V(x.value), V(y.value)))));
+#else
+ return RValue<Int4>(V(lowerPMINMAX(V(x.value), V(y.value), llvm::ICmpInst::ICMP_SLT)));
+#endif
}
RValue<UInt4> pmaxud(RValue<UInt4> x, RValue<UInt4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pmaxud = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pmaxud);
return RValue<UInt4>(V(::builder->CreateCall2(pmaxud, ARGS(V(x.value), V(y.value)))));
+#else
+ return RValue<UInt4>(V(lowerPMINMAX(V(x.value), V(y.value), llvm::ICmpInst::ICMP_UGT)));
+#endif
}
RValue<UInt4> pminud(RValue<UInt4> x, RValue<UInt4> y)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pminud = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pminud);
return RValue<UInt4>(V(::builder->CreateCall2(pminud, ARGS(V(x.value), V(y.value)))));
+#else
+ return RValue<UInt4>(V(lowerPMINMAX(V(x.value), V(y.value), llvm::ICmpInst::ICMP_ULT)));
+#endif
}
RValue<Short4> pmulhw(RValue<Short4> x, RValue<Short4> y)
@@ -6497,30 +6812,46 @@
RValue<Int4> pmovzxbd(RValue<Byte16> x)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pmovzxbd = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pmovzxbd);
return RValue<Int4>(V(::builder->CreateCall(pmovzxbd, ARGS(V(x.value)))));
+#else
+ return RValue<Int4>(V(lowerPMOV(V(x.value), T(Int4::getType()), false)));
+#endif
}
RValue<Int4> pmovsxbd(RValue<SByte16> x)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pmovsxbd = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pmovsxbd);
return RValue<Int4>(V(::builder->CreateCall(pmovsxbd, ARGS(V(x.value)))));
+#else
+ return RValue<Int4>(V(lowerPMOV(V(x.value), T(Int4::getType()), true)));
+#endif
}
RValue<Int4> pmovzxwd(RValue<UShort8> x)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pmovzxwd = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pmovzxwd);
return RValue<Int4>(V(::builder->CreateCall(pmovzxwd, ARGS(V(x.value)))));
+#else
+ return RValue<Int4>(V(lowerPMOV(V(x.value), T(Int4::getType()), false)));
+#endif
}
RValue<Int4> pmovsxwd(RValue<Short8> x)
{
+#if SWIFTSHADER_LLVM_VERSION < 7
llvm::Function *pmovsxwd = llvm::Intrinsic::getDeclaration(::module, llvm::Intrinsic::x86_sse41_pmovsxwd);
return RValue<Int4>(V(::builder->CreateCall(pmovsxwd, ARGS(V(x.value)))));
+#else
+ return RValue<Int4>(V(lowerPMOV(V(x.value), T(Int4::getType()), true)));
+#endif
}
}
}
diff --git a/src/Reactor/LLVMRoutine.cpp b/src/Reactor/LLVMRoutine.cpp
index df12337..3deb7b4 100644
--- a/src/Reactor/LLVMRoutine.cpp
+++ b/src/Reactor/LLVMRoutine.cpp
@@ -20,6 +20,7 @@
namespace sw
{
+#if SWIFTSHADER_LLVM_VERSION < 7
LLVMRoutine::LLVMRoutine(int bufferSize) : bufferSize(bufferSize)
{
void *memory = allocateExecutable(bufferSize);
@@ -43,4 +44,10 @@
{
return functionSize - static_cast<int>((uintptr_t)entry - (uintptr_t)buffer);
}
+#else
+ LLVMRoutine::~LLVMRoutine()
+ {
+ dtor(reactorJIT, moduleKey);
+ }
+#endif
}
diff --git a/src/Reactor/LLVMRoutine.hpp b/src/Reactor/LLVMRoutine.hpp
index 264990f..0e70245 100644
--- a/src/Reactor/LLVMRoutine.hpp
+++ b/src/Reactor/LLVMRoutine.hpp
@@ -17,8 +17,11 @@
#include "Routine.hpp"
+#include <cstdint>
+
namespace sw
{
+#if SWIFTSHADER_LLVM_VERSION < 7
class LLVMRoutineManager;
class LLVMRoutine : public Routine
@@ -48,6 +51,32 @@
//const bool dynamic; // Generated or precompiled
};
+#else
+ class LLVMReactorJIT;
+
+ class LLVMRoutine : public Routine
+ {
+ public:
+ LLVMRoutine(void *ent, void (*callback)(LLVMReactorJIT *, uint64_t),
+ LLVMReactorJIT *jit, uint64_t key)
+ : entry(ent), dtor(callback), reactorJIT(jit), moduleKey(key)
+ { }
+
+ virtual ~LLVMRoutine();
+
+ const void *getEntry()
+ {
+ return entry;
+ }
+
+ private:
+ const void *entry;
+
+ void (*dtor)(LLVMReactorJIT *, uint64_t);
+ LLVMReactorJIT *reactorJIT;
+ uint64_t moduleKey;
+ };
+#endif // SWIFTSHADER_LLVM_VERSION < 7
}
#endif // sw_LLVMRoutine_hpp
diff --git a/src/Reactor/LLVMRoutineManager.cpp b/src/Reactor/LLVMRoutineManager.cpp
index 99a8e9d..3b73799 100644
--- a/src/Reactor/LLVMRoutineManager.cpp
+++ b/src/Reactor/LLVMRoutineManager.cpp
@@ -14,6 +14,8 @@
#include "LLVMRoutineManager.hpp"
+#if SWIFTSHADER_LLVM_VERSION < 7
+
#include "LLVMRoutine.hpp"
#include "llvm/Function.h"
#include "../Common/Memory.hpp"
@@ -146,3 +148,5 @@
return result;
}
}
+
+#endif // SWIFTSHADER_LLVM_VERSION < 7
diff --git a/src/Reactor/LLVMRoutineManager.hpp b/src/Reactor/LLVMRoutineManager.hpp
index b235923..28c51c5 100644
--- a/src/Reactor/LLVMRoutineManager.hpp
+++ b/src/Reactor/LLVMRoutineManager.hpp
@@ -15,8 +15,10 @@
#ifndef sw_LLVMRoutineManager_hpp
#define sw_LLVMRoutineManager_hpp
-#include "llvm/GlobalValue.h"
+#if SWIFTSHADER_LLVM_VERSION < 7
+
#include "llvm/ExecutionEngine/JITMemoryManager.h"
+#include "llvm/GlobalValue.h"
namespace sw
{
@@ -54,4 +56,6 @@
};
}
+#endif // SWIFTSHADER_LLVM_VERSION < 7
+
#endif // sw_LLVMRoutineManager_hpp