Commit 0eedc8c6 by Logan Chien

Port SwiftShader to LLVM 7.0

Change-Id: I89601ef9e42e56cfaeb1cd5ece4daa3f32b39950 Reviewed-on: https://swiftshader-review.googlesource.com/20475Tested-by: 's avatarLogan Chien <loganchien@google.com> Reviewed-by: 's avatarNicolas Capens <nicolascapens@google.com>
parent 172f41b5
......@@ -65,6 +65,8 @@ endif()
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 @@ endif()
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 @@ endif()
# 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 @@ list(APPEND LLVM_INCLUDE_DIR
${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
......
......@@ -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"
#include "LLVMRoutine.hpp"
#include "LLVMRoutineManager.hpp"
#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"
#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 @@ extern "C" void X86CompilationCallback()
}
#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 @@ namespace
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 @@ namespace sw
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 @@ namespace sw
llvm::InitializeNativeTarget();
#if SWIFTSHADER_LLVM_VERSION >= 7
llvm::InitializeNativeTargetAsmPrinter();
llvm::InitializeNativeTargetAsmParser();
#endif
if(!::context)
{
::context = new llvm::LLVMContext();
......@@ -296,22 +522,37 @@ namespace sw
#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 @@ namespace sw
{
::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 @@ namespace sw
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 @@ namespace sw
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 @@ namespace sw
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 @@ namespace sw
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 @@ namespace sw
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 @@ namespace sw
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 @@ namespace sw
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 @@ namespace sw
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 @@ namespace sw
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
}
}
}
......@@ -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 @@ namespace sw
{
return functionSize - static_cast<int>((uintptr_t)entry - (uintptr_t)buffer);
}
#else
LLVMRoutine::~LLVMRoutine()
{
dtor(reactorJIT, moduleKey);
}
#endif
}
......@@ -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 @@ namespace sw
//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
......@@ -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 @@ namespace sw
return result;
}
}
#endif // SWIFTSHADER_LLVM_VERSION < 7
......@@ -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 @@ namespace sw
};
}
#endif // SWIFTSHADER_LLVM_VERSION < 7
#endif // sw_LLVMRoutineManager_hpp
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment