mirror of
https://github.com/RPCSX/llvm.git
synced 2025-04-03 16:51:42 +00:00
Adding working version of assembly parser for the MBlaze backend
Major cleanup of whitespace and formatting issues in MBlaze backend git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@118434 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
554375b707
commit
0a67d92938
@ -2,10 +2,10 @@ set(MSVC_LIB_DEPS_LLVMARMAsmParser LLVMARMInfo LLVMMC LLVMMCParser LLVMSupport L
|
|||||||
set(MSVC_LIB_DEPS_LLVMARMAsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMARMAsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMARMCodeGen LLVMARMAsmPrinter LLVMARMInfo LLVMAnalysis LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMARMCodeGen LLVMARMAsmPrinter LLVMARMInfo LLVMAnalysis LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMARMDisassembler LLVMARMCodeGen LLVMARMInfo LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMARMDisassembler LLVMARMCodeGen LLVMARMInfo LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMARMInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMARMInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMAlphaAsmPrinter LLVMAlphaInfo LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMAlphaAsmPrinter LLVMAlphaInfo LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMAlphaCodeGen LLVMAlphaInfo LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMAlphaCodeGen LLVMAlphaInfo LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMAlphaInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMAlphaInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMArchive LLVMBitReader LLVMCore LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMArchive LLVMBitReader LLVMCore LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMAsmParser LLVMCore LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMAsmParser LLVMCore LLVMSupport LLVMSystem)
|
||||||
@ -14,16 +14,16 @@ set(MSVC_LIB_DEPS_LLVMBitReader LLVMCore LLVMSupport LLVMSystem)
|
|||||||
set(MSVC_LIB_DEPS_LLVMBitWriter LLVMCore LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMBitWriter LLVMCore LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMBlackfinAsmPrinter LLVMAsmPrinter LLVMBlackfinInfo LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMBlackfinAsmPrinter LLVMAsmPrinter LLVMBlackfinInfo LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMBlackfinCodeGen LLVMBlackfinInfo LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMBlackfinCodeGen LLVMBlackfinInfo LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMBlackfinInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMBlackfinInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMCBackend LLVMAnalysis LLVMCBackendInfo LLVMCodeGen LLVMCore LLVMMC LLVMScalarOpts LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils LLVMipa)
|
set(MSVC_LIB_DEPS_LLVMCBackend LLVMAnalysis LLVMCBackendInfo LLVMCodeGen LLVMCore LLVMMC LLVMScalarOpts LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils LLVMipa)
|
||||||
set(MSVC_LIB_DEPS_LLVMCBackendInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMCBackendInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMCellSPUAsmPrinter LLVMAsmPrinter LLVMCellSPUInfo LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMCellSPUAsmPrinter LLVMAsmPrinter LLVMCellSPUInfo LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMCellSPUCodeGen LLVMCellSPUInfo LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMCellSPUCodeGen LLVMCellSPUInfo LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMCellSPUInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMCellSPUInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMCodeGen LLVMAnalysis LLVMCore LLVMMC LLVMScalarOpts LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils)
|
set(MSVC_LIB_DEPS_LLVMCodeGen LLVMAnalysis LLVMCore LLVMMC LLVMScalarOpts LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils)
|
||||||
set(MSVC_LIB_DEPS_LLVMCore LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMCore LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMCppBackend LLVMCore LLVMCppBackendInfo LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMCppBackend LLVMCore LLVMCppBackendInfo LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMCppBackendInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMCppBackendInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMExecutionEngine LLVMCore LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMExecutionEngine LLVMCore LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMInstCombine LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils)
|
set(MSVC_LIB_DEPS_LLVMInstCombine LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils)
|
||||||
set(MSVC_LIB_DEPS_LLVMInstrumentation LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTransformUtils)
|
set(MSVC_LIB_DEPS_LLVMInstrumentation LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTransformUtils)
|
||||||
@ -34,41 +34,41 @@ set(MSVC_LIB_DEPS_LLVMMBlazeAsmParser LLVMMBlazeInfo LLVMMC LLVMMCParser LLVMSup
|
|||||||
set(MSVC_LIB_DEPS_LLVMMBlazeAsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMMBlazeAsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMMBlazeCodeGen LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMBlazeAsmPrinter LLVMMBlazeInfo LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMMBlazeCodeGen LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMBlazeAsmPrinter LLVMMBlazeInfo LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMMBlazeDisassembler LLVMMBlazeCodeGen LLVMMBlazeInfo LLVMMC LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMMBlazeDisassembler LLVMMBlazeCodeGen LLVMMBlazeInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMMBlazeInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMMBlazeInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMMCDisassembler LLVMARMAsmParser LLVMARMCodeGen LLVMARMDisassembler LLVMARMInfo LLVMAlphaAsmPrinter LLVMAlphaCodeGen LLVMAlphaInfo LLVMBlackfinAsmPrinter LLVMBlackfinCodeGen LLVMBlackfinInfo LLVMCBackend LLVMCBackendInfo LLVMCellSPUAsmPrinter LLVMCellSPUCodeGen LLVMCellSPUInfo LLVMCppBackend LLVMCppBackendInfo LLVMMBlazeAsmParser LLVMMBlazeCodeGen LLVMMBlazeDisassembler LLVMMBlazeInfo LLVMMC LLVMMCParser LLVMMSP430CodeGen LLVMMSP430Info LLVMMipsAsmPrinter LLVMMipsCodeGen LLVMMipsInfo LLVMPTXAsmPrinter LLVMPTXCodeGen LLVMPTXInfo LLVMPowerPCAsmPrinter LLVMPowerPCCodeGen LLVMPowerPCInfo LLVMSparcAsmPrinter LLVMSparcCodeGen LLVMSparcInfo LLVMSupport LLVMSystem LLVMSystemZAsmPrinter LLVMSystemZCodeGen LLVMSystemZInfo LLVMX86AsmParser LLVMX86CodeGen LLVMX86Disassembler LLVMX86Info LLVMXCoreAsmPrinter LLVMXCoreCodeGen LLVMXCoreInfo)
|
set(MSVC_LIB_DEPS_LLVMMCDisassembler LLVMARMAsmParser LLVMARMCodeGen LLVMARMDisassembler LLVMARMInfo LLVMAlphaAsmPrinter LLVMAlphaCodeGen LLVMAlphaInfo LLVMBlackfinAsmPrinter LLVMBlackfinCodeGen LLVMBlackfinInfo LLVMCBackend LLVMCBackendInfo LLVMCellSPUAsmPrinter LLVMCellSPUCodeGen LLVMCellSPUInfo LLVMCppBackend LLVMCppBackendInfo LLVMMBlazeAsmParser LLVMMBlazeCodeGen LLVMMBlazeDisassembler LLVMMBlazeInfo LLVMMC LLVMMCParser LLVMMSP430CodeGen LLVMMSP430Info LLVMMipsAsmPrinter LLVMMipsCodeGen LLVMMipsInfo LLVMPTXAsmPrinter LLVMPTXCodeGen LLVMPTXInfo LLVMPowerPCAsmPrinter LLVMPowerPCCodeGen LLVMPowerPCInfo LLVMSparcAsmPrinter LLVMSparcCodeGen LLVMSparcInfo LLVMSupport LLVMSystem LLVMSystemZAsmPrinter LLVMSystemZCodeGen LLVMSystemZInfo LLVMX86AsmParser LLVMX86CodeGen LLVMX86Disassembler LLVMX86Info LLVMXCoreAsmPrinter LLVMXCoreCodeGen LLVMXCoreInfo)
|
||||||
set(MSVC_LIB_DEPS_LLVMMCParser LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMMCParser LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMMSP430AsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMMSP430AsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMMSP430CodeGen LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMMSP430AsmPrinter LLVMMSP430Info LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMMSP430CodeGen LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMMSP430AsmPrinter LLVMMSP430Info LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMMSP430Info LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMMSP430Info LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMMipsAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMMipsCodeGen LLVMMipsInfo LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMMipsAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMMipsCodeGen LLVMMipsInfo LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMMipsCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMMipsInfo LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMMipsCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMMipsInfo LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMMipsInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMMipsInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMPTXAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMPTXInfo LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMPTXAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMPTXCodeGen LLVMPTXInfo LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMPTXCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMPTXInfo LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMPTXCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMPTXInfo LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMPTXInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMPTXInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMPowerPCAsmPrinter LLVMAnalysis LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMPowerPCInfo LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMPowerPCAsmPrinter LLVMAnalysis LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMPowerPCInfo LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMPowerPCCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMPowerPCInfo LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMPowerPCCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMPowerPCInfo LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMPowerPCInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMPowerPCInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMScalarOpts LLVMAnalysis LLVMCore LLVMInstCombine LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils)
|
set(MSVC_LIB_DEPS_LLVMScalarOpts LLVMAnalysis LLVMCore LLVMInstCombine LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils)
|
||||||
set(MSVC_LIB_DEPS_LLVMSelectionDAG LLVMAnalysis LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMSelectionDAG LLVMAnalysis LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMSparcAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSparcInfo LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMSparcAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSparcInfo LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMSparcCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSparcInfo LLVMSupport LLVMSystem LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMSparcCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSparcInfo LLVMSupport LLVMSystem LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMSparcInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMSparcInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMSystem )
|
set(MSVC_LIB_DEPS_LLVMSystem )
|
||||||
set(MSVC_LIB_DEPS_LLVMSystemZAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMSystemZInfo LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMSystemZAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMSystemZInfo LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMSystemZCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMSystemZInfo LLVMTarget)
|
set(MSVC_LIB_DEPS_LLVMSystemZCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMSystemZInfo LLVMTarget)
|
||||||
set(MSVC_LIB_DEPS_LLVMSystemZInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMSystemZInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMTarget LLVMCore LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMTarget LLVMCore LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMTransformUtils LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTarget LLVMipa)
|
set(MSVC_LIB_DEPS_LLVMTransformUtils LLVMAnalysis LLVMCore LLVMSupport LLVMSystem LLVMTarget LLVMipa)
|
||||||
set(MSVC_LIB_DEPS_LLVMX86AsmParser LLVMMC LLVMMCParser LLVMSupport LLVMSystem LLVMTarget LLVMX86Info)
|
set(MSVC_LIB_DEPS_LLVMX86AsmParser LLVMMC LLVMMCParser LLVMSupport LLVMSystem LLVMTarget LLVMX86Info)
|
||||||
set(MSVC_LIB_DEPS_LLVMX86AsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMX86AsmPrinter LLVMMC LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMX86CodeGen LLVMAnalysis LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget LLVMX86AsmPrinter LLVMX86Info)
|
set(MSVC_LIB_DEPS_LLVMX86CodeGen LLVMAnalysis LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget LLVMX86AsmPrinter LLVMX86Info)
|
||||||
set(MSVC_LIB_DEPS_LLVMX86Disassembler LLVMMC LLVMSupport LLVMX86Info)
|
set(MSVC_LIB_DEPS_LLVMX86Disassembler LLVMMC LLVMSupport LLVMX86Info)
|
||||||
set(MSVC_LIB_DEPS_LLVMX86Info LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMX86Info LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMXCoreAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget LLVMXCoreInfo)
|
set(MSVC_LIB_DEPS_LLVMXCoreAsmPrinter LLVMAsmPrinter LLVMCodeGen LLVMCore LLVMMC LLVMSupport LLVMSystem LLVMTarget LLVMXCoreInfo)
|
||||||
set(MSVC_LIB_DEPS_LLVMXCoreCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget LLVMXCoreInfo)
|
set(MSVC_LIB_DEPS_LLVMXCoreCodeGen LLVMCodeGen LLVMCore LLVMMC LLVMSelectionDAG LLVMSupport LLVMSystem LLVMTarget LLVMXCoreInfo)
|
||||||
set(MSVC_LIB_DEPS_LLVMXCoreInfo LLVMSupport)
|
set(MSVC_LIB_DEPS_LLVMXCoreInfo LLVMMC LLVMSupport)
|
||||||
set(MSVC_LIB_DEPS_LLVMipa LLVMAnalysis LLVMCore LLVMSupport LLVMSystem)
|
set(MSVC_LIB_DEPS_LLVMipa LLVMAnalysis LLVMCore LLVMSupport LLVMSystem)
|
||||||
set(MSVC_LIB_DEPS_LLVMipo LLVMAnalysis LLVMCore LLVMScalarOpts LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils LLVMipa)
|
set(MSVC_LIB_DEPS_LLVMipo LLVMAnalysis LLVMCore LLVMScalarOpts LLVMSupport LLVMSystem LLVMTarget LLVMTransformUtils LLVMipa)
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -56,38 +56,38 @@ static unsigned mblazeBinary2Opcode[] = {
|
|||||||
MBlaze::SBI, MBlaze::SHI, MBlaze::SWI, UNSUPPORTED, //3C,3D,3E,3F
|
MBlaze::SBI, MBlaze::SHI, MBlaze::SWI, UNSUPPORTED, //3C,3D,3E,3F
|
||||||
};
|
};
|
||||||
|
|
||||||
static unsigned getRD( uint32_t insn ) {
|
static unsigned getRD(uint32_t insn) {
|
||||||
return MBlazeRegisterInfo::getRegisterFromNumbering( (insn>>21)&0x1F );
|
return MBlazeRegisterInfo::getRegisterFromNumbering((insn>>21)&0x1F);
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned getRA( uint32_t insn ) {
|
static unsigned getRA(uint32_t insn) {
|
||||||
return MBlazeRegisterInfo::getRegisterFromNumbering( (insn>>16)&0x1F );
|
return MBlazeRegisterInfo::getRegisterFromNumbering((insn>>16)&0x1F);
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned getRB( uint32_t insn ) {
|
static unsigned getRB(uint32_t insn) {
|
||||||
return MBlazeRegisterInfo::getRegisterFromNumbering( (insn>>11)&0x1F );
|
return MBlazeRegisterInfo::getRegisterFromNumbering((insn>>11)&0x1F);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int64_t getRS( uint32_t insn ) {
|
static int64_t getRS(uint32_t insn) {
|
||||||
int16_t val = (insn & 0x3FFF);
|
int16_t val = (insn & 0x3FFF);
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int64_t getIMM( uint32_t insn ) {
|
static int64_t getIMM(uint32_t insn) {
|
||||||
int16_t val = (insn & 0xFFFF);
|
int16_t val = (insn & 0xFFFF);
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int64_t getSHT( uint32_t insn ) {
|
static int64_t getSHT(uint32_t insn) {
|
||||||
int16_t val = (insn & 0x1F);
|
int16_t val = (insn & 0x1F);
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned getFLAGS( int32_t insn ) {
|
static unsigned getFLAGS(int32_t insn) {
|
||||||
return (insn & 0x7FF);
|
return (insn & 0x7FF);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int64_t getFSL( uint32_t insn ) {
|
static int64_t getFSL(uint32_t insn) {
|
||||||
int16_t val = (insn & 0xF);
|
int16_t val = (insn & 0xF);
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
@ -412,7 +412,7 @@ static unsigned decodeRTSD(uint32_t insn) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned getOPCODE( uint32_t insn ) {
|
static unsigned getOPCODE(uint32_t insn) {
|
||||||
unsigned opcode = mblazeBinary2Opcode[ (insn>>26)&0x3F ];
|
unsigned opcode = mblazeBinary2Opcode[ (insn>>26)&0x3F ];
|
||||||
switch (opcode) {
|
switch (opcode) {
|
||||||
case MBlaze::MUL: return decodeMUL(insn);
|
case MBlaze::MUL: return decodeMUL(insn);
|
||||||
@ -465,102 +465,99 @@ bool MBlazeDisassembler::getInstruction(MCInst &instr,
|
|||||||
|
|
||||||
// Get the MCInst opcode from the binary instruction and make sure
|
// Get the MCInst opcode from the binary instruction and make sure
|
||||||
// that it is a valid instruction.
|
// that it is a valid instruction.
|
||||||
unsigned opcode = getOPCODE( insn );
|
unsigned opcode = getOPCODE(insn);
|
||||||
if( opcode == UNSUPPORTED )
|
if (opcode == UNSUPPORTED)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
instr.setOpcode(opcode);
|
instr.setOpcode(opcode);
|
||||||
|
|
||||||
uint64_t tsFlags = MBlazeInsts[opcode].TSFlags;
|
uint64_t tsFlags = MBlazeInsts[opcode].TSFlags;
|
||||||
switch( (tsFlags & MBlazeII::FormMask) ) {
|
switch ((tsFlags & MBlazeII::FormMask)) {
|
||||||
default:
|
default: llvm_unreachable("unknown instruction encoding");
|
||||||
errs() << "Opcode: " << MBlazeInsts[opcode].Name << "\n";
|
|
||||||
errs() << "Flags: "; errs().write_hex( tsFlags ); errs() << "\n";
|
|
||||||
return false;
|
|
||||||
|
|
||||||
case MBlazeII::FRRR:
|
case MBlazeII::FRRR:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRB(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRB(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRRI:
|
case MBlazeII::FRRI:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getIMM(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getIMM(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCRR:
|
case MBlazeII::FCRR:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRB(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRB(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCRI:
|
case MBlazeII::FCRI:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getIMM(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getIMM(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRCR:
|
case MBlazeII::FRCR:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRB(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRB(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRCI:
|
case MBlazeII::FRCI:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getIMM(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getIMM(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCCR:
|
case MBlazeII::FCCR:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRB(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRB(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCCI:
|
case MBlazeII::FCCI:
|
||||||
instr.addOperand( MCOperand::CreateImm( getIMM(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getIMM(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRRCI:
|
case MBlazeII::FRRCI:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getSHT(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getSHT(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRRC:
|
case MBlazeII::FRRC:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRCX:
|
case MBlazeII::FRCX:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getFSL(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getFSL(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRCS:
|
case MBlazeII::FRCS:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getRS(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getRS(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCRCS:
|
case MBlazeII::FCRCS:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getRS(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getRS(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCRCX:
|
case MBlazeII::FCRCX:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getFSL(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getFSL(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCX:
|
case MBlazeII::FCX:
|
||||||
instr.addOperand( MCOperand::CreateImm( getFSL(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getFSL(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCR:
|
case MBlazeII::FCR:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRB(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRB(insn)));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRIR:
|
case MBlazeII::FRIR:
|
||||||
instr.addOperand( MCOperand::CreateReg( getRD(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRD(insn)));
|
||||||
instr.addOperand( MCOperand::CreateImm( getIMM(insn) ) );
|
instr.addOperand(MCOperand::CreateImm(getIMM(insn)));
|
||||||
instr.addOperand( MCOperand::CreateReg( getRA(insn) ) );
|
instr.addOperand(MCOperand::CreateReg(getRA(insn)));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,7 +102,7 @@ void MBlazeInstPrinter::printUnsignedImm(const MCInst *MI, int OpNo,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void MBlazeInstPrinter::printMemOperand(const MCInst *MI, int OpNo,
|
void MBlazeInstPrinter::printMemOperand(const MCInst *MI, int OpNo,
|
||||||
raw_ostream &O, const char *Modifier ) {
|
raw_ostream &O, const char *Modifier) {
|
||||||
printOperand(MI, OpNo+1, O, NULL);
|
printOperand(MI, OpNo+1, O, NULL);
|
||||||
O << ", ";
|
O << ", ";
|
||||||
printOperand(MI, OpNo, O, NULL);
|
printOperand(MI, OpNo, O, NULL);
|
||||||
|
@ -70,8 +70,8 @@ bool MBlazeAsmBackend::WriteNopData(uint64_t Count, MCObjectWriter *OW) const {
|
|||||||
if ((Count % 4) != 0)
|
if ((Count % 4) != 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
for (uint64_t i = 0; i < Count; i += 4 )
|
for (uint64_t i = 0; i < Count; i += 4)
|
||||||
OW->Write32( 0x00000000 );
|
OW->Write32(0x00000000);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -114,17 +114,17 @@ public:
|
|||||||
void ELFMBlazeAsmBackend::ApplyFixup(const MCFixup &Fixup, MCDataFragment &DF,
|
void ELFMBlazeAsmBackend::ApplyFixup(const MCFixup &Fixup, MCDataFragment &DF,
|
||||||
uint64_t Value) const {
|
uint64_t Value) const {
|
||||||
unsigned Size = getFixupKindSize(Fixup.getKind());
|
unsigned Size = getFixupKindSize(Fixup.getKind());
|
||||||
|
|
||||||
assert(Fixup.getOffset() + Size <= DF.getContents().size() &&
|
assert(Fixup.getOffset() + Size <= DF.getContents().size() &&
|
||||||
"Invalid fixup offset!");
|
"Invalid fixup offset!");
|
||||||
|
|
||||||
char *data = DF.getContents().data() + Fixup.getOffset();
|
char *data = DF.getContents().data() + Fixup.getOffset();
|
||||||
switch (Size) {
|
switch (Size) {
|
||||||
default: llvm_unreachable( "Cannot fixup unknown value." );
|
default: llvm_unreachable("Cannot fixup unknown value.");
|
||||||
case 1: llvm_unreachable( "Cannot fixup 1 byte value." );
|
case 1: llvm_unreachable("Cannot fixup 1 byte value.");
|
||||||
case 8: llvm_unreachable( "Cannot fixup 8 byte value." );
|
case 8: llvm_unreachable("Cannot fixup 8 byte value.");
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
*(data+7) = uint8_t(Value);
|
*(data+7) = uint8_t(Value);
|
||||||
*(data+6) = uint8_t(Value >> 8);
|
*(data+6) = uint8_t(Value >> 8);
|
||||||
*(data+3) = uint8_t(Value >> 16);
|
*(data+3) = uint8_t(Value >> 16);
|
||||||
|
@ -69,7 +69,7 @@ namespace {
|
|||||||
void printMemOperand(const MachineInstr *MI, int opNum, raw_ostream &O,
|
void printMemOperand(const MachineInstr *MI, int opNum, raw_ostream &O,
|
||||||
const char *Modifier = 0);
|
const char *Modifier = 0);
|
||||||
|
|
||||||
void EmitInstruction(const MachineInstr *MI);
|
void EmitInstruction(const MachineInstr *MI);
|
||||||
};
|
};
|
||||||
} // end of anonymous namespace
|
} // end of anonymous namespace
|
||||||
|
|
||||||
|
@ -1,16 +1,16 @@
|
|||||||
//===- MBlazeCallingConv.td - Calling Conventions for MBlaze -*- tablegen -*-=//
|
//===- MBlazeCallingConv.td - Calling Conventions for MBlaze -*- tablegen -*-=//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
// This file is distributed under the University of Illinois Open Source
|
// This file is distributed under the University of Illinois Open Source
|
||||||
// License. See LICENSE.TXT for details.
|
// License. See LICENSE.TXT for details.
|
||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// This describes the calling conventions for MBlaze architecture.
|
// This describes the calling conventions for MBlaze architecture.
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
/// CCIfSubtarget - Match if the current subtarget has a feature F.
|
||||||
class CCIfSubtarget<string F, CCAction A>:
|
class CCIfSubtarget<string F, CCAction A>:
|
||||||
CCIf<!strconcat("State.getTarget().getSubtarget<MBlazeSubtarget>().", F), A>;
|
CCIf<!strconcat("State.getTarget().getSubtarget<MBlazeSubtarget>().", F), A>;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
@ -36,7 +36,7 @@ namespace {
|
|||||||
const TargetInstrInfo *TII;
|
const TargetInstrInfo *TII;
|
||||||
|
|
||||||
static char ID;
|
static char ID;
|
||||||
Filler(TargetMachine &tm)
|
Filler(TargetMachine &tm)
|
||||||
: MachineFunctionPass(ID), TM(tm), TII(tm.getInstrInfo()) { }
|
: MachineFunctionPass(ID), TM(tm), TII(tm.getInstrInfo()) { }
|
||||||
|
|
||||||
virtual const char *getPassName() const {
|
virtual const char *getPassName() const {
|
||||||
@ -56,44 +56,44 @@ namespace {
|
|||||||
char Filler::ID = 0;
|
char Filler::ID = 0;
|
||||||
} // end of anonymous namespace
|
} // end of anonymous namespace
|
||||||
|
|
||||||
static bool hasImmInstruction( MachineBasicBlock::iterator &candidate ) {
|
static bool hasImmInstruction(MachineBasicBlock::iterator &candidate) {
|
||||||
// Any instruction with an immediate mode operand greater than
|
// Any instruction with an immediate mode operand greater than
|
||||||
// 16-bits requires an implicit IMM instruction.
|
// 16-bits requires an implicit IMM instruction.
|
||||||
unsigned numOper = candidate->getNumOperands();
|
unsigned numOper = candidate->getNumOperands();
|
||||||
for( unsigned op = 0; op < numOper; ++op ) {
|
for (unsigned op = 0; op < numOper; ++op) {
|
||||||
if( candidate->getOperand(op).isImm() &&
|
if (candidate->getOperand(op).isImm() &&
|
||||||
(candidate->getOperand(op).getImm() & 0xFFFFFFFFFFFF0000LL) != 0 )
|
(candidate->getOperand(op).getImm() & 0xFFFFFFFFFFFF0000LL) != 0)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// FIXME: we could probably check to see if the FP value happens
|
// FIXME: we could probably check to see if the FP value happens
|
||||||
// to not need an IMM instruction. For now we just always
|
// to not need an IMM instruction. For now we just always
|
||||||
// assume that FP values always do.
|
// assume that FP values always do.
|
||||||
if( candidate->getOperand(op).isFPImm() )
|
if (candidate->getOperand(op).isFPImm())
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool delayHasHazard( MachineBasicBlock::iterator &candidate,
|
static bool delayHasHazard(MachineBasicBlock::iterator &candidate,
|
||||||
MachineBasicBlock::iterator &slot ) {
|
MachineBasicBlock::iterator &slot) {
|
||||||
|
|
||||||
// Loop over all of the operands in the branch instruction
|
// Loop over all of the operands in the branch instruction
|
||||||
// and make sure that none of them are defined by the
|
// and make sure that none of them are defined by the
|
||||||
// candidate instruction.
|
// candidate instruction.
|
||||||
unsigned numOper = slot->getNumOperands();
|
unsigned numOper = slot->getNumOperands();
|
||||||
for( unsigned op = 0; op < numOper; ++op ) {
|
for (unsigned op = 0; op < numOper; ++op) {
|
||||||
if( !slot->getOperand(op).isReg() ||
|
if (!slot->getOperand(op).isReg() ||
|
||||||
!slot->getOperand(op).isUse() ||
|
!slot->getOperand(op).isUse() ||
|
||||||
slot->getOperand(op).isImplicit() )
|
slot->getOperand(op).isImplicit())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
unsigned cnumOper = candidate->getNumOperands();
|
unsigned cnumOper = candidate->getNumOperands();
|
||||||
for( unsigned cop = 0; cop < cnumOper; ++cop ) {
|
for (unsigned cop = 0; cop < cnumOper; ++cop) {
|
||||||
if( candidate->getOperand(cop).isReg() &&
|
if (candidate->getOperand(cop).isReg() &&
|
||||||
candidate->getOperand(cop).isDef() &&
|
candidate->getOperand(cop).isDef() &&
|
||||||
candidate->getOperand(cop).getReg() ==
|
candidate->getOperand(cop).getReg() ==
|
||||||
slot->getOperand(op).getReg() )
|
slot->getOperand(op).getReg())
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -102,20 +102,20 @@ static bool delayHasHazard( MachineBasicBlock::iterator &candidate,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool usedBeforeDelaySlot( MachineBasicBlock::iterator &candidate,
|
static bool usedBeforeDelaySlot(MachineBasicBlock::iterator &candidate,
|
||||||
MachineBasicBlock::iterator &slot ) {
|
MachineBasicBlock::iterator &slot) {
|
||||||
MachineBasicBlock::iterator I = candidate;
|
MachineBasicBlock::iterator I = candidate;
|
||||||
for (++I; I != slot; ++I) {
|
for (++I; I != slot; ++I) {
|
||||||
unsigned numOper = I->getNumOperands();
|
unsigned numOper = I->getNumOperands();
|
||||||
for( unsigned op = 0; op < numOper; ++op ) {
|
for (unsigned op = 0; op < numOper; ++op) {
|
||||||
if( I->getOperand(op).isReg() &&
|
if (I->getOperand(op).isReg() &&
|
||||||
I->getOperand(op).isUse() ) {
|
I->getOperand(op).isUse()) {
|
||||||
unsigned reg = I->getOperand(op).getReg();
|
unsigned reg = I->getOperand(op).getReg();
|
||||||
unsigned cops = candidate->getNumOperands();
|
unsigned cops = candidate->getNumOperands();
|
||||||
for( unsigned cop = 0; cop < cops; ++cop ) {
|
for (unsigned cop = 0; cop < cops; ++cop) {
|
||||||
if( candidate->getOperand(cop).isReg() &&
|
if (candidate->getOperand(cop).isReg() &&
|
||||||
candidate->getOperand(cop).isDef() &&
|
candidate->getOperand(cop).isDef() &&
|
||||||
candidate->getOperand(cop).getReg() == reg )
|
candidate->getOperand(cop).getReg() == reg)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -130,9 +130,9 @@ findDelayInstr(MachineBasicBlock &MBB,MachineBasicBlock::iterator &slot) {
|
|||||||
MachineBasicBlock::iterator found = MBB.end();
|
MachineBasicBlock::iterator found = MBB.end();
|
||||||
for (MachineBasicBlock::iterator I = MBB.begin(); I != slot; ++I) {
|
for (MachineBasicBlock::iterator I = MBB.begin(); I != slot; ++I) {
|
||||||
TargetInstrDesc desc = I->getDesc();
|
TargetInstrDesc desc = I->getDesc();
|
||||||
if( desc.hasDelaySlot() || desc.isBranch() ||
|
if (desc.hasDelaySlot() || desc.isBranch() ||
|
||||||
desc.mayLoad() || desc. mayStore() ||
|
desc.mayLoad() || desc. mayStore() ||
|
||||||
hasImmInstruction(I) || delayHasHazard(I,slot) ||
|
hasImmInstruction(I) || delayHasHazard(I,slot) ||
|
||||||
usedBeforeDelaySlot(I,slot)) continue;
|
usedBeforeDelaySlot(I,slot)) continue;
|
||||||
|
|
||||||
found = I;
|
found = I;
|
||||||
@ -155,10 +155,10 @@ bool Filler::runOnMachineBasicBlock(MachineBasicBlock &MBB) {
|
|||||||
++FilledSlots;
|
++FilledSlots;
|
||||||
Changed = true;
|
Changed = true;
|
||||||
|
|
||||||
if( D == MBB.end() )
|
if (D == MBB.end())
|
||||||
BuildMI(MBB, J, I->getDebugLoc(), TII->get(MBlaze::NOP));
|
BuildMI(MBB, J, I->getDebugLoc(), TII->get(MBlaze::NOP));
|
||||||
else
|
else
|
||||||
MBB.splice( J, &MBB, D );
|
MBB.splice(J, &MBB, D);
|
||||||
}
|
}
|
||||||
return Changed;
|
return Changed;
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,7 @@ MBlazeELFWriterInfo::MBlazeELFWriterInfo(TargetMachine &TM)
|
|||||||
MBlazeELFWriterInfo::~MBlazeELFWriterInfo() {}
|
MBlazeELFWriterInfo::~MBlazeELFWriterInfo() {}
|
||||||
|
|
||||||
unsigned MBlazeELFWriterInfo::getRelocationType(unsigned MachineRelTy) const {
|
unsigned MBlazeELFWriterInfo::getRelocationType(unsigned MachineRelTy) const {
|
||||||
switch(MachineRelTy) {
|
switch (MachineRelTy) {
|
||||||
case MBlaze::reloc_pcrel_word:
|
case MBlaze::reloc_pcrel_word:
|
||||||
return R_MICROBLAZE_64_PCREL;
|
return R_MICROBLAZE_64_PCREL;
|
||||||
case MBlaze::reloc_absolute_word:
|
case MBlaze::reloc_absolute_word:
|
||||||
@ -45,7 +45,7 @@ unsigned MBlazeELFWriterInfo::getRelocationType(unsigned MachineRelTy) const {
|
|||||||
|
|
||||||
long int MBlazeELFWriterInfo::getDefaultAddendForRelTy(unsigned RelTy,
|
long int MBlazeELFWriterInfo::getDefaultAddendForRelTy(unsigned RelTy,
|
||||||
long int Modifier) const {
|
long int Modifier) const {
|
||||||
switch(RelTy) {
|
switch (RelTy) {
|
||||||
case R_MICROBLAZE_32_PCREL:
|
case R_MICROBLAZE_32_PCREL:
|
||||||
return Modifier - 4;
|
return Modifier - 4;
|
||||||
case R_MICROBLAZE_32:
|
case R_MICROBLAZE_32:
|
||||||
@ -58,7 +58,7 @@ long int MBlazeELFWriterInfo::getDefaultAddendForRelTy(unsigned RelTy,
|
|||||||
|
|
||||||
unsigned MBlazeELFWriterInfo::getRelocationTySize(unsigned RelTy) const {
|
unsigned MBlazeELFWriterInfo::getRelocationTySize(unsigned RelTy) const {
|
||||||
// FIXME: Most of these sizes are guesses based on the name
|
// FIXME: Most of these sizes are guesses based on the name
|
||||||
switch(RelTy) {
|
switch (RelTy) {
|
||||||
case R_MICROBLAZE_32:
|
case R_MICROBLAZE_32:
|
||||||
case R_MICROBLAZE_32_PCREL:
|
case R_MICROBLAZE_32_PCREL:
|
||||||
case R_MICROBLAZE_32_PCREL_LO:
|
case R_MICROBLAZE_32_PCREL_LO:
|
||||||
@ -83,7 +83,7 @@ unsigned MBlazeELFWriterInfo::getRelocationTySize(unsigned RelTy) const {
|
|||||||
|
|
||||||
bool MBlazeELFWriterInfo::isPCRelativeRel(unsigned RelTy) const {
|
bool MBlazeELFWriterInfo::isPCRelativeRel(unsigned RelTy) const {
|
||||||
// FIXME: Most of these are guesses based on the name
|
// FIXME: Most of these are guesses based on the name
|
||||||
switch(RelTy) {
|
switch (RelTy) {
|
||||||
case R_MICROBLAZE_32_PCREL:
|
case R_MICROBLAZE_32_PCREL:
|
||||||
case R_MICROBLAZE_64_PCREL:
|
case R_MICROBLAZE_64_PCREL:
|
||||||
case R_MICROBLAZE_32_PCREL_LO:
|
case R_MICROBLAZE_32_PCREL_LO:
|
||||||
|
@ -31,7 +31,7 @@ namespace llvm {
|
|||||||
R_MICROBLAZE_32_LO = 6,
|
R_MICROBLAZE_32_LO = 6,
|
||||||
R_MICROBLAZE_SRO32 = 7,
|
R_MICROBLAZE_SRO32 = 7,
|
||||||
R_MICROBLAZE_SRW32 = 8,
|
R_MICROBLAZE_SRW32 = 8,
|
||||||
R_MICROBLAZE_64_NONE = 9,
|
R_MICROBLAZE_64_NONE = 9,
|
||||||
R_MICROBLAZE_32_SYM_OP_SYM = 10,
|
R_MICROBLAZE_32_SYM_OP_SYM = 10,
|
||||||
R_MICROBLAZE_GNU_VTINHERIT = 11,
|
R_MICROBLAZE_GNU_VTINHERIT = 11,
|
||||||
R_MICROBLAZE_GNU_VTENTRY = 12,
|
R_MICROBLAZE_GNU_VTENTRY = 12,
|
||||||
|
@ -159,7 +159,6 @@ SelectAddrRegImm(SDValue N, SDValue &Disp, SDValue &Base) {
|
|||||||
} else {
|
} else {
|
||||||
Base = N.getOperand(0);
|
Base = N.getOperand(0);
|
||||||
}
|
}
|
||||||
DEBUG( errs() << "WESLEY: Using Operand Immediate\n" );
|
|
||||||
return true; // [r+i]
|
return true; // [r+i]
|
||||||
}
|
}
|
||||||
} else if (ConstantSDNode *CN = dyn_cast<ConstantSDNode>(N)) {
|
} else if (ConstantSDNode *CN = dyn_cast<ConstantSDNode>(N)) {
|
||||||
@ -167,7 +166,6 @@ SelectAddrRegImm(SDValue N, SDValue &Disp, SDValue &Base) {
|
|||||||
uint32_t Imm = CN->getZExtValue();
|
uint32_t Imm = CN->getZExtValue();
|
||||||
Disp = CurDAG->getTargetConstant(Imm, CN->getValueType(0));
|
Disp = CurDAG->getTargetConstant(Imm, CN->getValueType(0));
|
||||||
Base = CurDAG->getRegister(MBlaze::R0, CN->getValueType(0));
|
Base = CurDAG->getRegister(MBlaze::R0, CN->getValueType(0));
|
||||||
DEBUG( errs() << "WESLEY: Using Constant Node\n" );
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -192,20 +190,15 @@ SDNode* MBlazeDAGToDAGISel::Select(SDNode *Node) {
|
|||||||
unsigned Opcode = Node->getOpcode();
|
unsigned Opcode = Node->getOpcode();
|
||||||
DebugLoc dl = Node->getDebugLoc();
|
DebugLoc dl = Node->getDebugLoc();
|
||||||
|
|
||||||
// Dump information about the Node being selected
|
|
||||||
DEBUG(errs() << "Selecting: "; Node->dump(CurDAG); errs() << "\n");
|
|
||||||
|
|
||||||
// If we have a custom node, we already have selected!
|
// If we have a custom node, we already have selected!
|
||||||
if (Node->isMachineOpcode()) {
|
if (Node->isMachineOpcode())
|
||||||
DEBUG(errs() << "== "; Node->dump(CurDAG); errs() << "\n");
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
|
||||||
|
|
||||||
///
|
///
|
||||||
// Instruction Selection not handled by the auto-generated
|
// Instruction Selection not handled by the auto-generated
|
||||||
// tablegen selection should be handled here.
|
// tablegen selection should be handled here.
|
||||||
///
|
///
|
||||||
switch(Opcode) {
|
switch (Opcode) {
|
||||||
default: break;
|
default: break;
|
||||||
|
|
||||||
// Get target GOT address.
|
// Get target GOT address.
|
||||||
@ -235,8 +228,8 @@ SDNode* MBlazeDAGToDAGISel::Select(SDNode *Node) {
|
|||||||
SDValue R20Reg = CurDAG->getRegister(MBlaze::R20, MVT::i32);
|
SDValue R20Reg = CurDAG->getRegister(MBlaze::R20, MVT::i32);
|
||||||
SDValue InFlag(0, 0);
|
SDValue InFlag(0, 0);
|
||||||
|
|
||||||
if ( (isa<GlobalAddressSDNode>(Callee)) ||
|
if ((isa<GlobalAddressSDNode>(Callee)) ||
|
||||||
(isa<ExternalSymbolSDNode>(Callee)) )
|
(isa<ExternalSymbolSDNode>(Callee)))
|
||||||
{
|
{
|
||||||
/// Direct call for global addresses and external symbols
|
/// Direct call for global addresses and external symbols
|
||||||
SDValue GPReg = CurDAG->getRegister(MBlaze::R15, MVT::i32);
|
SDValue GPReg = CurDAG->getRegister(MBlaze::R15, MVT::i32);
|
||||||
|
@ -290,7 +290,7 @@ MBlazeTargetLowering::EmitInstrWithCustomInserter(MachineInstr *MI,
|
|||||||
else if (MI->getOpcode() == MBlaze::ShiftRL)
|
else if (MI->getOpcode() == MBlaze::ShiftRL)
|
||||||
BuildMI(loop, dl, TII->get(MBlaze::SRL), NDST).addReg(DST);
|
BuildMI(loop, dl, TII->get(MBlaze::SRL), NDST).addReg(DST);
|
||||||
else
|
else
|
||||||
llvm_unreachable( "Cannot lower unknown shift instruction" );
|
llvm_unreachable("Cannot lower unknown shift instruction");
|
||||||
|
|
||||||
BuildMI(loop, dl, TII->get(MBlaze::ADDI), NAMT)
|
BuildMI(loop, dl, TII->get(MBlaze::ADDI), NAMT)
|
||||||
.addReg(SAMT)
|
.addReg(SAMT)
|
||||||
@ -332,7 +332,7 @@ MBlazeTargetLowering::EmitInstrWithCustomInserter(MachineInstr *MI,
|
|||||||
|
|
||||||
unsigned Opc;
|
unsigned Opc;
|
||||||
switch (MI->getOperand(4).getImm()) {
|
switch (MI->getOperand(4).getImm()) {
|
||||||
default: llvm_unreachable( "Unknown branch condition" );
|
default: llvm_unreachable("Unknown branch condition");
|
||||||
case MBlazeCC::EQ: Opc = MBlaze::BNEID; break;
|
case MBlazeCC::EQ: Opc = MBlaze::BNEID; break;
|
||||||
case MBlazeCC::NE: Opc = MBlaze::BEQID; break;
|
case MBlazeCC::NE: Opc = MBlaze::BEQID; break;
|
||||||
case MBlazeCC::GT: Opc = MBlaze::BLEID; break;
|
case MBlazeCC::GT: Opc = MBlaze::BLEID; break;
|
||||||
@ -396,9 +396,9 @@ SDValue MBlazeTargetLowering::LowerSELECT_CC(SDValue Op,
|
|||||||
CompareFlag = DAG.getNode(MBlazeISD::ICmp, dl, MVT::i32, LHS, RHS)
|
CompareFlag = DAG.getNode(MBlazeISD::ICmp, dl, MVT::i32, LHS, RHS)
|
||||||
.getValue(1);
|
.getValue(1);
|
||||||
} else {
|
} else {
|
||||||
llvm_unreachable( "Cannot lower select_cc with unknown type" );
|
llvm_unreachable("Cannot lower select_cc with unknown type");
|
||||||
}
|
}
|
||||||
|
|
||||||
return DAG.getNode(Opc, dl, TrueVal.getValueType(), TrueVal, FalseVal,
|
return DAG.getNode(Opc, dl, TrueVal.getValueType(), TrueVal, FalseVal,
|
||||||
CompareFlag);
|
CompareFlag);
|
||||||
}
|
}
|
||||||
@ -429,7 +429,7 @@ LowerJumpTable(SDValue Op, SelectionDAG &DAG) const {
|
|||||||
EVT PtrVT = Op.getValueType();
|
EVT PtrVT = Op.getValueType();
|
||||||
JumpTableSDNode *JT = cast<JumpTableSDNode>(Op);
|
JumpTableSDNode *JT = cast<JumpTableSDNode>(Op);
|
||||||
|
|
||||||
SDValue JTI = DAG.getTargetJumpTable(JT->getIndex(), PtrVT, 0 );
|
SDValue JTI = DAG.getTargetJumpTable(JT->getIndex(), PtrVT, 0);
|
||||||
return DAG.getNode(MBlazeISD::Wrap, dl, MVT::i32, JTI);
|
return DAG.getNode(MBlazeISD::Wrap, dl, MVT::i32, JTI);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -441,7 +441,7 @@ LowerConstantPool(SDValue Op, SelectionDAG &DAG) const {
|
|||||||
DebugLoc dl = Op.getDebugLoc();
|
DebugLoc dl = Op.getDebugLoc();
|
||||||
|
|
||||||
SDValue CP = DAG.getTargetConstantPool(C, MVT::i32, N->getAlignment(),
|
SDValue CP = DAG.getTargetConstantPool(C, MVT::i32, N->getAlignment(),
|
||||||
N->getOffset(), 0 );
|
N->getOffset(), 0);
|
||||||
return DAG.getNode(MBlazeISD::Wrap, dl, MVT::i32, CP);
|
return DAG.getNode(MBlazeISD::Wrap, dl, MVT::i32, CP);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -616,10 +616,10 @@ LowerCall(SDValue Chain, SDValue Callee, CallingConv::ID CallConv,
|
|||||||
// node so that legalize doesn't hack it.
|
// node so that legalize doesn't hack it.
|
||||||
if (GlobalAddressSDNode *G = dyn_cast<GlobalAddressSDNode>(Callee))
|
if (GlobalAddressSDNode *G = dyn_cast<GlobalAddressSDNode>(Callee))
|
||||||
Callee = DAG.getTargetGlobalAddress(G->getGlobal(), dl,
|
Callee = DAG.getTargetGlobalAddress(G->getGlobal(), dl,
|
||||||
getPointerTy(), 0, 0 );
|
getPointerTy(), 0, 0);
|
||||||
else if (ExternalSymbolSDNode *S = dyn_cast<ExternalSymbolSDNode>(Callee))
|
else if (ExternalSymbolSDNode *S = dyn_cast<ExternalSymbolSDNode>(Callee))
|
||||||
Callee = DAG.getTargetExternalSymbol(S->getSymbol(),
|
Callee = DAG.getTargetExternalSymbol(S->getSymbol(),
|
||||||
getPointerTy(), 0 );
|
getPointerTy(), 0);
|
||||||
|
|
||||||
// MBlazeJmpLink = #chain, #target_address, #opt_in_flags...
|
// MBlazeJmpLink = #chain, #target_address, #opt_in_flags...
|
||||||
// = Chain, Callee, Reg#1, Reg#2, ...
|
// = Chain, Callee, Reg#1, Reg#2, ...
|
||||||
@ -675,7 +675,7 @@ LowerCallResult(SDValue Chain, SDValue InFlag, CallingConv::ID CallConv,
|
|||||||
RVLocs[i].getValVT(), InFlag).getValue(1);
|
RVLocs[i].getValVT(), InFlag).getValue(1);
|
||||||
InFlag = Chain.getValue(2);
|
InFlag = Chain.getValue(2);
|
||||||
InVals.push_back(Chain.getValue(0));
|
InVals.push_back(Chain.getValue(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
return Chain;
|
return Chain;
|
||||||
}
|
}
|
||||||
@ -785,7 +785,7 @@ LowerFormalArguments(SDValue Chain, CallingConv::ID CallConv, bool isVarArg,
|
|||||||
|
|
||||||
// To meet ABI, when VARARGS are passed on registers, the registers
|
// To meet ABI, when VARARGS are passed on registers, the registers
|
||||||
// must have their values written to the caller stack frame. If the last
|
// must have their values written to the caller stack frame. If the last
|
||||||
// argument was placed in the stack, there's no need to save any register.
|
// argument was placed in the stack, there's no need to save any register.
|
||||||
if ((isVarArg) && ArgRegEnd) {
|
if ((isVarArg) && ArgRegEnd) {
|
||||||
if (StackPtr.getNode() == 0)
|
if (StackPtr.getNode() == 0)
|
||||||
StackPtr = DAG.getRegister(StackReg, getPointerTy());
|
StackPtr = DAG.getRegister(StackReg, getPointerTy());
|
||||||
@ -817,7 +817,7 @@ LowerFormalArguments(SDValue Chain, CallingConv::ID CallConv, bool isVarArg,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// All stores are grouped in one node to allow the matching between
|
// All stores are grouped in one node to allow the matching between
|
||||||
// the size of Ins and InVals. This only happens when on varg functions
|
// the size of Ins and InVals. This only happens when on varg functions
|
||||||
if (!OutChains.empty()) {
|
if (!OutChains.empty()) {
|
||||||
OutChains.push_back(Chain);
|
OutChains.push_back(Chain);
|
||||||
|
@ -100,11 +100,11 @@ let Predicates=[HasFPU] in {
|
|||||||
def FMUL : ArithF<0x16, 0x100, "fmul ", fmul, IIAlu>;
|
def FMUL : ArithF<0x16, 0x100, "fmul ", fmul, IIAlu>;
|
||||||
def FDIV : ArithF<0x16, 0x180, "fdiv ", fdiv, IIAlu>;
|
def FDIV : ArithF<0x16, 0x180, "fdiv ", fdiv, IIAlu>;
|
||||||
|
|
||||||
def LWF : LoadFM<0x32, "lw ", load>;
|
def LWF : LoadFM<0x32, "lw ", load>;
|
||||||
def LWFI : LoadFMI<0x32, "lwi ", load>;
|
def LWFI : LoadFMI<0x32, "lwi ", load>;
|
||||||
|
|
||||||
def SWF : StoreFM<0x32, "sw ", store>;
|
def SWF : StoreFM<0x32, "sw ", store>;
|
||||||
def SWFI : StoreFMI<0x32, "swi ", store>;
|
def SWFI : StoreFMI<0x32, "swi ", store>;
|
||||||
}
|
}
|
||||||
|
|
||||||
let Predicates=[HasFPU,HasSqrt] in {
|
let Predicates=[HasFPU,HasSqrt] in {
|
||||||
|
@ -58,8 +58,8 @@ class MBlazeInst<bits<6> op, Format form, dag outs, dag ins, string asmstr,
|
|||||||
bits<6> FormBits = Form.Value;
|
bits<6> FormBits = Form.Value;
|
||||||
|
|
||||||
// Top 6 bits are the 'opcode' field
|
// Top 6 bits are the 'opcode' field
|
||||||
let Inst{0-5} = opcode;
|
let Inst{0-5} = opcode;
|
||||||
|
|
||||||
// If the instruction is marked as a pseudo, set isCodeGenOnly so that the
|
// If the instruction is marked as a pseudo, set isCodeGenOnly so that the
|
||||||
// assembler and disassmbler ignore it.
|
// assembler and disassmbler ignore it.
|
||||||
let isCodeGenOnly = !eq(!cast<string>(form), "FPseudo");
|
let isCodeGenOnly = !eq(!cast<string>(form), "FPseudo");
|
||||||
@ -86,15 +86,15 @@ class MBlazePseudo<dag outs, dag ins, string asmstr, list<dag> pattern>:
|
|||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
class TA<bits<6> op, bits<11> flags, dag outs, dag ins, string asmstr,
|
class TA<bits<6> op, bits<11> flags, dag outs, dag ins, string asmstr,
|
||||||
list<dag> pattern, InstrItinClass itin> :
|
list<dag> pattern, InstrItinClass itin> :
|
||||||
MBlazeInst<op,FRRR,outs, ins, asmstr, pattern, itin>
|
MBlazeInst<op,FRRR,outs, ins, asmstr, pattern, itin>
|
||||||
{
|
{
|
||||||
bits<5> rd;
|
bits<5> rd;
|
||||||
bits<5> ra;
|
bits<5> ra;
|
||||||
bits<5> rb;
|
bits<5> rb;
|
||||||
|
|
||||||
let Inst{6-10} = rd;
|
let Inst{6-10} = rd;
|
||||||
let Inst{11-15} = ra;
|
let Inst{11-15} = ra;
|
||||||
let Inst{16-20} = rb;
|
let Inst{16-20} = rb;
|
||||||
let Inst{21-31} = flags;
|
let Inst{21-31} = flags;
|
||||||
}
|
}
|
||||||
@ -104,15 +104,15 @@ class TA<bits<6> op, bits<11> flags, dag outs, dag ins, string asmstr,
|
|||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
class TB<bits<6> op, dag outs, dag ins, string asmstr, list<dag> pattern,
|
class TB<bits<6> op, dag outs, dag ins, string asmstr, list<dag> pattern,
|
||||||
InstrItinClass itin> :
|
InstrItinClass itin> :
|
||||||
MBlazeInst<op, FRRI, outs, ins, asmstr, pattern, itin>
|
MBlazeInst<op, FRRI, outs, ins, asmstr, pattern, itin>
|
||||||
{
|
{
|
||||||
bits<5> rd;
|
bits<5> rd;
|
||||||
bits<5> ra;
|
bits<5> ra;
|
||||||
bits<16> imm16;
|
bits<16> imm16;
|
||||||
|
|
||||||
let Inst{6-10} = rd;
|
let Inst{6-10} = rd;
|
||||||
let Inst{11-15} = ra;
|
let Inst{11-15} = ra;
|
||||||
let Inst{16-31} = imm16;
|
let Inst{16-31} = imm16;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,7 +121,7 @@ class TB<bits<6> op, dag outs, dag ins, string asmstr, list<dag> pattern,
|
|||||||
// the LLVM DAG : <|opcode|rd|ra|immediate|>
|
// the LLVM DAG : <|opcode|rd|ra|immediate|>
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
class TBR<bits<6> op, dag outs, dag ins, string asmstr, list<dag> pattern,
|
class TBR<bits<6> op, dag outs, dag ins, string asmstr, list<dag> pattern,
|
||||||
InstrItinClass itin> :
|
InstrItinClass itin> :
|
||||||
TB<op, outs, ins, asmstr, pattern, itin> {
|
TB<op, outs, ins, asmstr, pattern, itin> {
|
||||||
bits<5> rrd;
|
bits<5> rrd;
|
||||||
bits<16> rimm16;
|
bits<16> rimm16;
|
||||||
|
@ -64,6 +64,16 @@ def HasMMU : Predicate<"Subtarget.hasMMU()">;
|
|||||||
// MBlaze Operand, Complex Patterns and Transformations Definitions.
|
// MBlaze Operand, Complex Patterns and Transformations Definitions.
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
def MBlazeMemAsmOperand : AsmOperandClass {
|
||||||
|
let Name = "Mem";
|
||||||
|
let SuperClasses = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
def MBlazeFslAsmOperand : AsmOperandClass {
|
||||||
|
let Name = "Fsl";
|
||||||
|
let SuperClasses = [];
|
||||||
|
}
|
||||||
|
|
||||||
// Instruction operand types
|
// Instruction operand types
|
||||||
def brtarget : Operand<OtherVT>;
|
def brtarget : Operand<OtherVT>;
|
||||||
def calltarget : Operand<i32>;
|
def calltarget : Operand<i32>;
|
||||||
@ -79,17 +89,20 @@ def uimm16 : Operand<i32> {
|
|||||||
// FSL Operand
|
// FSL Operand
|
||||||
def fslimm : Operand<i32> {
|
def fslimm : Operand<i32> {
|
||||||
let PrintMethod = "printFSLImm";
|
let PrintMethod = "printFSLImm";
|
||||||
|
let ParserMatchClass = MBlazeFslAsmOperand;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Address operand
|
// Address operand
|
||||||
def memri : Operand<i32> {
|
def memri : Operand<i32> {
|
||||||
let PrintMethod = "printMemOperand";
|
let PrintMethod = "printMemOperand";
|
||||||
let MIOperandInfo = (ops simm16, GPR);
|
let MIOperandInfo = (ops simm16, GPR);
|
||||||
|
let ParserMatchClass = MBlazeMemAsmOperand;
|
||||||
}
|
}
|
||||||
|
|
||||||
def memrr : Operand<i32> {
|
def memrr : Operand<i32> {
|
||||||
let PrintMethod = "printMemOperand";
|
let PrintMethod = "printMemOperand";
|
||||||
let MIOperandInfo = (ops GPR, GPR);
|
let MIOperandInfo = (ops GPR, GPR);
|
||||||
|
let ParserMatchClass = MBlazeMemAsmOperand;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Node immediate fits as 16-bit sign extended on target immediate.
|
// Node immediate fits as 16-bit sign extended on target immediate.
|
||||||
@ -490,31 +503,31 @@ let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1,
|
|||||||
hasCtrlDep=1, rd=0x10, Form=FCRI in {
|
hasCtrlDep=1, rd=0x10, Form=FCRI in {
|
||||||
def RTSD : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
def RTSD : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
||||||
"rtsd $target, $imm",
|
"rtsd $target, $imm",
|
||||||
[],
|
[],
|
||||||
IIBranch>;
|
IIBranch>;
|
||||||
}
|
}
|
||||||
|
|
||||||
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1,
|
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1,
|
||||||
hasCtrlDep=1, rd=0x11, Form=FCRI in {
|
hasCtrlDep=1, rd=0x11, Form=FCRI in {
|
||||||
def RTID : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
def RTID : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
||||||
"rtsd $target, $imm",
|
"rtid $target, $imm",
|
||||||
[],
|
[],
|
||||||
IIBranch>;
|
IIBranch>;
|
||||||
}
|
}
|
||||||
|
|
||||||
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1,
|
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1,
|
||||||
hasCtrlDep=1, rd=0x12, Form=FCRI in {
|
hasCtrlDep=1, rd=0x12, Form=FCRI in {
|
||||||
def RTBD : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
def RTBD : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
||||||
"rtsd $target, $imm",
|
"rtbd $target, $imm",
|
||||||
[],
|
[],
|
||||||
IIBranch>;
|
IIBranch>;
|
||||||
}
|
}
|
||||||
|
|
||||||
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1,
|
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1,
|
||||||
hasCtrlDep=1, rd=0x14, Form=FCRI in {
|
hasCtrlDep=1, rd=0x14, Form=FCRI in {
|
||||||
def RTED : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
def RTED : TB<0x2D, (outs), (ins GPR:$target, simm16:$imm),
|
||||||
"rtsd $target, $imm",
|
"rted $target, $imm",
|
||||||
[],
|
[],
|
||||||
IIBranch>;
|
IIBranch>;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -551,20 +564,20 @@ let usesCustomInserter = 1 in {
|
|||||||
|
|
||||||
let rb = 0 in {
|
let rb = 0 in {
|
||||||
def SEXT16 : TA<0x24, 0x061, (outs GPR:$dst), (ins GPR:$src),
|
def SEXT16 : TA<0x24, 0x061, (outs GPR:$dst), (ins GPR:$src),
|
||||||
"sext16 $dst, $src", [], IIAlu>;
|
"sext16 $dst, $src", [], IIAlu>;
|
||||||
def SEXT8 : TA<0x24, 0x060, (outs GPR:$dst), (ins GPR:$src),
|
def SEXT8 : TA<0x24, 0x060, (outs GPR:$dst), (ins GPR:$src),
|
||||||
"sext8 $dst, $src", [], IIAlu>;
|
"sext8 $dst, $src", [], IIAlu>;
|
||||||
def SRL : TA<0x24, 0x041, (outs GPR:$dst), (ins GPR:$src),
|
def SRL : TA<0x24, 0x041, (outs GPR:$dst), (ins GPR:$src),
|
||||||
"srl $dst, $src", [], IIAlu>;
|
"srl $dst, $src", [], IIAlu>;
|
||||||
def SRA : TA<0x24, 0x001, (outs GPR:$dst), (ins GPR:$src),
|
def SRA : TA<0x24, 0x001, (outs GPR:$dst), (ins GPR:$src),
|
||||||
"sra $dst, $src", [], IIAlu>;
|
"sra $dst, $src", [], IIAlu>;
|
||||||
def SRC : TA<0x24, 0x021, (outs GPR:$dst), (ins GPR:$src),
|
def SRC : TA<0x24, 0x021, (outs GPR:$dst), (ins GPR:$src),
|
||||||
"src $dst, $src", [], IIAlu>;
|
"src $dst, $src", [], IIAlu>;
|
||||||
}
|
}
|
||||||
|
|
||||||
let opcode=0x08, isCodeGenOnly=1 in {
|
let opcode=0x08, isCodeGenOnly=1 in {
|
||||||
def LEA_ADDI : TB<0x08, (outs GPR:$dst), (ins memri:$addr),
|
def LEA_ADDI : TB<0x08, (outs GPR:$dst), (ins memri:$addr),
|
||||||
"addi $dst, ${addr:stackloc}",
|
"addi $dst, ${addr:stackloc}",
|
||||||
[(set GPR:$dst, iaddr:$addr)], IIAlu>;
|
[(set GPR:$dst, iaddr:$addr)], IIAlu>;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -584,7 +597,7 @@ def MSRCLR : MBlazeInst<0x25, FPseudo, (outs), (ins), "msrclr", [], IIAlu> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let rd=0x0, Form=FCRR in {
|
let rd=0x0, Form=FCRR in {
|
||||||
def WDC : TA<0x24, 0x64, (outs), (ins GPR:$a, GPR:$b),
|
def WDC : TA<0x24, 0x64, (outs), (ins GPR:$a, GPR:$b),
|
||||||
"wdc $a, $b", [], IIAlu>;
|
"wdc $a, $b", [], IIAlu>;
|
||||||
def WDCF : TA<0x24, 0x74, (outs), (ins GPR:$a, GPR:$b),
|
def WDCF : TA<0x24, 0x74, (outs), (ins GPR:$a, GPR:$b),
|
||||||
"wdc.flush $a, $b", [], IIAlu>;
|
"wdc.flush $a, $b", [], IIAlu>;
|
||||||
@ -597,7 +610,7 @@ let rd=0x0, Form=FCRR in {
|
|||||||
def BRK : Branch<0x26, 0x0C, 0x000, "brk ">;
|
def BRK : Branch<0x26, 0x0C, 0x000, "brk ">;
|
||||||
def BRKI : BranchI<0x2E, 0x0C, "brki ">;
|
def BRKI : BranchI<0x2E, 0x0C, "brki ">;
|
||||||
|
|
||||||
def IMM : MBlazeInst<0x2C, FCCI, (outs), (ins simm16:$imm),
|
def IMM : MBlazeInst<0x2C, FCCI, (outs), (ins simm16:$imm),
|
||||||
"imm $imm", [], IIAlu>;
|
"imm $imm", [], IIAlu>;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
@ -633,42 +646,42 @@ def : Pat<(srl GPR:$L, GPR:$R), (ShiftRL GPR:$L, GPR:$R)>;
|
|||||||
|
|
||||||
// SET_CC operations
|
// SET_CC operations
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETEQ),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETEQ),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMP GPR:$L, GPR:$R), 1)>;
|
(CMP GPR:$L, GPR:$R), 1)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETNE),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETNE),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMP GPR:$L, GPR:$R), 2)>;
|
(CMP GPR:$L, GPR:$R), 2)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETGT),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETGT),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMP GPR:$L, GPR:$R), 3)>;
|
(CMP GPR:$L, GPR:$R), 3)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETLT),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETLT),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMP GPR:$L, GPR:$R), 4)>;
|
(CMP GPR:$L, GPR:$R), 4)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETGE),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETGE),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMP GPR:$L, GPR:$R), 5)>;
|
(CMP GPR:$L, GPR:$R), 5)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETLE),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETLE),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMP GPR:$L, GPR:$R), 6)>;
|
(CMP GPR:$L, GPR:$R), 6)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETUGT),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETUGT),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMPU GPR:$L, GPR:$R), 3)>;
|
(CMPU GPR:$L, GPR:$R), 3)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETULT),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETULT),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMPU GPR:$L, GPR:$R), 4)>;
|
(CMPU GPR:$L, GPR:$R), 4)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETUGE),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETUGE),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMPU GPR:$L, GPR:$R), 5)>;
|
(CMPU GPR:$L, GPR:$R), 5)>;
|
||||||
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETULE),
|
def : Pat<(setcc (i32 GPR:$L), (i32 GPR:$R), SETULE),
|
||||||
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
(Select_CC (ADDI (i32 R0), 1), (ADDI (i32 R0), 0),
|
||||||
(CMPU GPR:$L, GPR:$R), 6)>;
|
(CMPU GPR:$L, GPR:$R), 6)>;
|
||||||
|
|
||||||
// SELECT operations
|
// SELECT operations
|
||||||
def : Pat<(select (i32 GPR:$C), (i32 GPR:$T), (i32 GPR:$F)),
|
def : Pat<(select (i32 GPR:$C), (i32 GPR:$T), (i32 GPR:$F)),
|
||||||
(Select_CC GPR:$T, GPR:$F, GPR:$C, 2)>;
|
(Select_CC GPR:$T, GPR:$F, GPR:$C, 2)>;
|
||||||
|
|
||||||
// SELECT_CC
|
// SELECT_CC
|
||||||
def : Pat<(selectcc (i32 GPR:$L), (i32 GPR:$R),
|
def : Pat<(selectcc (i32 GPR:$L), (i32 GPR:$R),
|
||||||
(i32 GPR:$T), (i32 GPR:$F), SETEQ),
|
(i32 GPR:$T), (i32 GPR:$F), SETEQ),
|
||||||
(Select_CC GPR:$T, GPR:$F, (CMP GPR:$L, GPR:$R), 1)>;
|
(Select_CC GPR:$T, GPR:$F, (CMP GPR:$L, GPR:$R), 1)>;
|
||||||
def : Pat<(selectcc (i32 GPR:$L), (i32 GPR:$R),
|
def : Pat<(selectcc (i32 GPR:$L), (i32 GPR:$R),
|
||||||
|
@ -48,7 +48,7 @@ std::string MBlazeIntrinsicInfo::getName(unsigned IntrID, const Type **Tys,
|
|||||||
assert(!isOverloaded(IntrID) && "MBlaze intrinsics are not overloaded");
|
assert(!isOverloaded(IntrID) && "MBlaze intrinsics are not overloaded");
|
||||||
if (IntrID < Intrinsic::num_intrinsics)
|
if (IntrID < Intrinsic::num_intrinsics)
|
||||||
return 0;
|
return 0;
|
||||||
assert(IntrID < mblazeIntrinsic::num_mblaze_intrinsics &&
|
assert(IntrID < mblazeIntrinsic::num_mblaze_intrinsics &&
|
||||||
"Invalid intrinsic ID");
|
"Invalid intrinsic ID");
|
||||||
|
|
||||||
std::string Result(names[IntrID - Intrinsic::num_intrinsics]);
|
std::string Result(names[IntrID - Intrinsic::num_intrinsics]);
|
||||||
@ -94,12 +94,12 @@ static const FunctionType *getType(LLVMContext &Context, unsigned id) {
|
|||||||
const Type *ResultTy = NULL;
|
const Type *ResultTy = NULL;
|
||||||
std::vector<const Type*> ArgTys;
|
std::vector<const Type*> ArgTys;
|
||||||
bool IsVarArg = false;
|
bool IsVarArg = false;
|
||||||
|
|
||||||
#define GET_INTRINSIC_GENERATOR
|
#define GET_INTRINSIC_GENERATOR
|
||||||
#include "MBlazeGenIntrinsics.inc"
|
#include "MBlazeGenIntrinsics.inc"
|
||||||
#undef GET_INTRINSIC_GENERATOR
|
#undef GET_INTRINSIC_GENERATOR
|
||||||
|
|
||||||
return FunctionType::get(ResultTy, ArgTys, IsVarArg);
|
return FunctionType::get(ResultTy, ArgTys, IsVarArg);
|
||||||
}
|
}
|
||||||
|
|
||||||
Function *MBlazeIntrinsicInfo::getDeclaration(Module *M, unsigned IntrID,
|
Function *MBlazeIntrinsicInfo::getDeclaration(Module *M, unsigned IntrID,
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
//===- IntrinsicsMBlaze.td - Defines MBlaze intrinsics -----*- tablegen -*-===//
|
//===- IntrinsicsMBlaze.td - Defines MBlaze intrinsics -----*- tablegen -*-===//
|
||||||
//
|
//
|
||||||
// The LLVM Compiler Infrastructure
|
// The LLVM Compiler Infrastructure
|
||||||
//
|
//
|
||||||
// This file is distributed under the University of Illinois Open Source
|
// This file is distributed under the University of Illinois Open Source
|
||||||
// License. See LICENSE.TXT for details.
|
// License. See LICENSE.TXT for details.
|
||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
//
|
//
|
||||||
// This file defines all of the MicroBlaze-specific intrinsics.
|
// This file defines all of the MicroBlaze-specific intrinsics.
|
||||||
@ -16,7 +16,7 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
// MBlaze intrinsic classes.
|
// MBlaze intrinsic classes.
|
||||||
let TargetPrefix = "mblaze", isTarget = 1 in {
|
let TargetPrefix = "mblaze", isTarget = 1 in {
|
||||||
class MBFSL_Get_Intrinsic : Intrinsic<[llvm_i32_ty], [llvm_i32_ty], []>;
|
class MBFSL_Get_Intrinsic : Intrinsic<[llvm_i32_ty], [llvm_i32_ty], []>;
|
||||||
|
|
||||||
class MBFSL_Put_Intrinsic : Intrinsic<[], [llvm_i32_ty, llvm_i32_ty], []>;
|
class MBFSL_Put_Intrinsic : Intrinsic<[], [llvm_i32_ty, llvm_i32_ty], []>;
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
class Target;
|
class Target;
|
||||||
|
|
||||||
class MBlazeMCAsmInfo : public MCAsmInfo {
|
class MBlazeMCAsmInfo : public MCAsmInfo {
|
||||||
public:
|
public:
|
||||||
explicit MBlazeMCAsmInfo();
|
explicit MBlazeMCAsmInfo();
|
||||||
|
@ -94,7 +94,7 @@ public:
|
|||||||
|
|
||||||
void EmitConstant(uint64_t Val, unsigned Size, unsigned &CurByte,
|
void EmitConstant(uint64_t Val, unsigned Size, unsigned &CurByte,
|
||||||
raw_ostream &OS) const {
|
raw_ostream &OS) const {
|
||||||
assert(Size <= 8 && "size too big in emit constant" );
|
assert(Size <= 8 && "size too big in emit constant");
|
||||||
|
|
||||||
for (unsigned i = 0; i != Size; ++i) {
|
for (unsigned i = 0; i != Size; ++i) {
|
||||||
EmitByte(Val & 255, CurByte, OS);
|
EmitByte(Val & 255, CurByte, OS);
|
||||||
@ -103,7 +103,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
void EmitIMM(const MCOperand &imm, unsigned &CurByte, raw_ostream &OS) const;
|
void EmitIMM(const MCOperand &imm, unsigned &CurByte, raw_ostream &OS) const;
|
||||||
void EmitIMM(const MCInst &MI, unsigned op, unsigned &CurByte,
|
void EmitIMM(const MCInst &MI, unsigned op, unsigned &CurByte,
|
||||||
raw_ostream &OS) const;
|
raw_ostream &OS) const;
|
||||||
|
|
||||||
void EmitImmediate(const MCInst &MI,
|
void EmitImmediate(const MCInst &MI,
|
||||||
@ -132,7 +132,7 @@ unsigned MBlazeMCCodeEmitter::getMachineOpValue(const MCInst &MI,
|
|||||||
return MBlazeRegisterInfo::getRegisterNumbering(MO.getReg());
|
return MBlazeRegisterInfo::getRegisterNumbering(MO.getReg());
|
||||||
else if (MO.isImm())
|
else if (MO.isImm())
|
||||||
return static_cast<unsigned>(MO.getImm());
|
return static_cast<unsigned>(MO.getImm());
|
||||||
else if (MO.isExpr() )
|
else if (MO.isExpr())
|
||||||
return 0; // The relocation has already been recorded at this point.
|
return 0; // The relocation has already been recorded at this point.
|
||||||
else {
|
else {
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
@ -146,7 +146,7 @@ unsigned MBlazeMCCodeEmitter::getMachineOpValue(const MCInst &MI,
|
|||||||
void MBlazeMCCodeEmitter::
|
void MBlazeMCCodeEmitter::
|
||||||
EmitIMM(const MCOperand &imm, unsigned &CurByte, raw_ostream &OS) const {
|
EmitIMM(const MCOperand &imm, unsigned &CurByte, raw_ostream &OS) const {
|
||||||
int32_t val = (int32_t)imm.getImm();
|
int32_t val = (int32_t)imm.getImm();
|
||||||
if (val > 32767 || val < -32678 ) {
|
if (val > 32767 || val < -32678) {
|
||||||
EmitByte(0x0D, CurByte, OS);
|
EmitByte(0x0D, CurByte, OS);
|
||||||
EmitByte(0x00, CurByte, OS);
|
EmitByte(0x00, CurByte, OS);
|
||||||
EmitRawByte((val >> 24) & 0xFF, CurByte, OS);
|
EmitRawByte((val >> 24) & 0xFF, CurByte, OS);
|
||||||
@ -155,7 +155,7 @@ EmitIMM(const MCOperand &imm, unsigned &CurByte, raw_ostream &OS) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void MBlazeMCCodeEmitter::
|
void MBlazeMCCodeEmitter::
|
||||||
EmitIMM(const MCInst &MI, unsigned op, unsigned &CurByte,
|
EmitIMM(const MCInst &MI, unsigned op, unsigned &CurByte,
|
||||||
raw_ostream &OS) const {
|
raw_ostream &OS) const {
|
||||||
MCOperand mcop = MI.getOperand(op);
|
MCOperand mcop = MI.getOperand(op);
|
||||||
if (mcop.isExpr()) {
|
if (mcop.isExpr()) {
|
||||||
@ -170,11 +170,11 @@ void MBlazeMCCodeEmitter::
|
|||||||
EmitImmediate(const MCInst &MI, unsigned opNo, MCFixupKind FixupKind,
|
EmitImmediate(const MCInst &MI, unsigned opNo, MCFixupKind FixupKind,
|
||||||
unsigned &CurByte, raw_ostream &OS,
|
unsigned &CurByte, raw_ostream &OS,
|
||||||
SmallVectorImpl<MCFixup> &Fixups) const {
|
SmallVectorImpl<MCFixup> &Fixups) const {
|
||||||
assert( MI.getNumOperands()>opNo && "Not enought operands for instruction" );
|
assert(MI.getNumOperands()>opNo && "Not enought operands for instruction");
|
||||||
|
|
||||||
MCOperand oper = MI.getOperand(opNo);
|
MCOperand oper = MI.getOperand(opNo);
|
||||||
if (oper.isImm()) {
|
if (oper.isImm()) {
|
||||||
EmitIMM( oper, CurByte, OS );
|
EmitIMM(oper, CurByte, OS);
|
||||||
} else if (oper.isExpr()) {
|
} else if (oper.isExpr()) {
|
||||||
Fixups.push_back(MCFixup::Create(0,oper.getExpr(),FixupKind));
|
Fixups.push_back(MCFixup::Create(0,oper.getExpr(),FixupKind));
|
||||||
}
|
}
|
||||||
@ -198,25 +198,25 @@ EncodeInstruction(const MCInst &MI, raw_ostream &OS,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
case MBlazeII::FRRI:
|
case MBlazeII::FRRI:
|
||||||
EmitImmediate( MI, 2, FK_Data_4, CurByte, OS, Fixups );
|
EmitImmediate(MI, 2, FK_Data_4, CurByte, OS, Fixups);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRIR:
|
case MBlazeII::FRIR:
|
||||||
EmitImmediate( MI, 1, FK_Data_4, CurByte, OS, Fixups );
|
EmitImmediate(MI, 1, FK_Data_4, CurByte, OS, Fixups);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FCRI:
|
case MBlazeII::FCRI:
|
||||||
EmitImmediate( MI, 1, MCFixupKind(MBlaze::reloc_pcrel_2byte), CurByte, OS,
|
EmitImmediate(MI, 1, MCFixupKind(MBlaze::reloc_pcrel_2byte), CurByte, OS,
|
||||||
Fixups );
|
Fixups);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBlazeII::FRCI:
|
case MBlazeII::FRCI:
|
||||||
EmitImmediate( MI, 1, MCFixupKind(MBlaze::reloc_pcrel_4byte), CurByte, OS,
|
EmitImmediate(MI, 1, MCFixupKind(MBlaze::reloc_pcrel_4byte), CurByte, OS,
|
||||||
Fixups );
|
Fixups);
|
||||||
|
|
||||||
case MBlazeII::FCCI:
|
case MBlazeII::FCCI:
|
||||||
EmitImmediate( MI, 0, MCFixupKind(MBlaze::reloc_pcrel_4byte), CurByte, OS,
|
EmitImmediate(MI, 0, MCFixupKind(MBlaze::reloc_pcrel_4byte), CurByte, OS,
|
||||||
Fixups );
|
Fixups);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ using namespace llvm;
|
|||||||
MCSymbol *MBlazeMCInstLower::
|
MCSymbol *MBlazeMCInstLower::
|
||||||
GetGlobalAddressSymbol(const MachineOperand &MO) const {
|
GetGlobalAddressSymbol(const MachineOperand &MO) const {
|
||||||
switch (MO.getTargetFlags()) {
|
switch (MO.getTargetFlags()) {
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("Unknown target flag on GV operand");
|
llvm_unreachable("Unknown target flag on GV operand");
|
||||||
|
|
||||||
case 0: break;
|
case 0: break;
|
||||||
|
@ -26,11 +26,11 @@ namespace llvm {
|
|||||||
class MBlazeFunctionInfo : public MachineFunctionInfo {
|
class MBlazeFunctionInfo : public MachineFunctionInfo {
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/// Holds for each function where on the stack the Frame Pointer must be
|
/// Holds for each function where on the stack the Frame Pointer must be
|
||||||
/// saved. This is used on Prologue and Epilogue to emit FP save/restore
|
/// saved. This is used on Prologue and Epilogue to emit FP save/restore
|
||||||
int FPStackOffset;
|
int FPStackOffset;
|
||||||
|
|
||||||
/// Holds for each function where on the stack the Return Address must be
|
/// Holds for each function where on the stack the Return Address must be
|
||||||
/// saved. This is used on Prologue and Epilogue to emit RA save/restore
|
/// saved. This is used on Prologue and Epilogue to emit RA save/restore
|
||||||
int RAStackOffset;
|
int RAStackOffset;
|
||||||
|
|
||||||
@ -50,22 +50,22 @@ private:
|
|||||||
: FI(FrameIndex), SPOffset(StackPointerOffset) {}
|
: FI(FrameIndex), SPOffset(StackPointerOffset) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
/// When PIC is used the GP must be saved on the stack on the function
|
/// When PIC is used the GP must be saved on the stack on the function
|
||||||
/// prologue and must be reloaded from this stack location after every
|
/// prologue and must be reloaded from this stack location after every
|
||||||
/// call. A reference to its stack location and frame index must be kept
|
/// call. A reference to its stack location and frame index must be kept
|
||||||
/// to be used on emitPrologue and processFunctionBeforeFrameFinalized.
|
/// to be used on emitPrologue and processFunctionBeforeFrameFinalized.
|
||||||
MBlazeFIHolder GPHolder;
|
MBlazeFIHolder GPHolder;
|
||||||
|
|
||||||
/// On LowerFormalArguments the stack size is unknown, so the Stack
|
/// On LowerFormalArguments the stack size is unknown, so the Stack
|
||||||
/// Pointer Offset calculation of "not in register arguments" must be
|
/// Pointer Offset calculation of "not in register arguments" must be
|
||||||
/// postponed to emitPrologue.
|
/// postponed to emitPrologue.
|
||||||
SmallVector<MBlazeFIHolder, 16> FnLoadArgs;
|
SmallVector<MBlazeFIHolder, 16> FnLoadArgs;
|
||||||
bool HasLoadArgs;
|
bool HasLoadArgs;
|
||||||
|
|
||||||
// When VarArgs, we must write registers back to caller stack, preserving
|
// When VarArgs, we must write registers back to caller stack, preserving
|
||||||
// on register arguments. Since the stack size is unknown on
|
// on register arguments. Since the stack size is unknown on
|
||||||
// LowerFormalArguments, the Stack Pointer Offset calculation must be
|
// LowerFormalArguments, the Stack Pointer Offset calculation must be
|
||||||
// postponed to emitPrologue.
|
// postponed to emitPrologue.
|
||||||
SmallVector<MBlazeFIHolder, 4> FnStoreVarArgs;
|
SmallVector<MBlazeFIHolder, 4> FnStoreVarArgs;
|
||||||
bool HasStoreVarArgs;
|
bool HasStoreVarArgs;
|
||||||
|
|
||||||
@ -83,8 +83,8 @@ private:
|
|||||||
int VarArgsFrameIndex;
|
int VarArgsFrameIndex;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MBlazeFunctionInfo(MachineFunction& MF)
|
MBlazeFunctionInfo(MachineFunction& MF)
|
||||||
: FPStackOffset(0), RAStackOffset(0), CPUTopSavedRegOff(0),
|
: FPStackOffset(0), RAStackOffset(0), CPUTopSavedRegOff(0),
|
||||||
GPHolder(-1,-1), HasLoadArgs(false), HasStoreVarArgs(false),
|
GPHolder(-1,-1), HasLoadArgs(false), HasStoreVarArgs(false),
|
||||||
SRetReturnReg(0), GlobalBaseReg(0), VarArgsFrameIndex(0)
|
SRetReturnReg(0), GlobalBaseReg(0), VarArgsFrameIndex(0)
|
||||||
{}
|
{}
|
||||||
@ -105,7 +105,7 @@ public:
|
|||||||
bool needGPSaveRestore() const { return GPHolder.SPOffset != -1; }
|
bool needGPSaveRestore() const { return GPHolder.SPOffset != -1; }
|
||||||
|
|
||||||
bool hasLoadArgs() const { return HasLoadArgs; }
|
bool hasLoadArgs() const { return HasLoadArgs; }
|
||||||
bool hasStoreVarArgs() const { return HasStoreVarArgs; }
|
bool hasStoreVarArgs() const { return HasStoreVarArgs; }
|
||||||
|
|
||||||
void recordLoadArgsFI(int FI, int SPOffset) {
|
void recordLoadArgsFI(int FI, int SPOffset) {
|
||||||
if (!HasLoadArgs) HasLoadArgs=true;
|
if (!HasLoadArgs) HasLoadArgs=true;
|
||||||
@ -118,13 +118,13 @@ public:
|
|||||||
|
|
||||||
void adjustLoadArgsFI(MachineFrameInfo *MFI) const {
|
void adjustLoadArgsFI(MachineFrameInfo *MFI) const {
|
||||||
if (!hasLoadArgs()) return;
|
if (!hasLoadArgs()) return;
|
||||||
for (unsigned i = 0, e = FnLoadArgs.size(); i != e; ++i)
|
for (unsigned i = 0, e = FnLoadArgs.size(); i != e; ++i)
|
||||||
MFI->setObjectOffset( FnLoadArgs[i].FI, FnLoadArgs[i].SPOffset );
|
MFI->setObjectOffset(FnLoadArgs[i].FI, FnLoadArgs[i].SPOffset);
|
||||||
}
|
}
|
||||||
void adjustStoreVarArgsFI(MachineFrameInfo *MFI) const {
|
void adjustStoreVarArgsFI(MachineFrameInfo *MFI) const {
|
||||||
if (!hasStoreVarArgs()) return;
|
if (!hasStoreVarArgs()) return;
|
||||||
for (unsigned i = 0, e = FnStoreVarArgs.size(); i != e; ++i)
|
for (unsigned i = 0, e = FnStoreVarArgs.size(); i != e; ++i)
|
||||||
MFI->setObjectOffset( FnStoreVarArgs[i].FI, FnStoreVarArgs[i].SPOffset );
|
MFI->setObjectOffset(FnStoreVarArgs[i].FI, FnStoreVarArgs[i].SPOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned getSRetReturnReg() const { return SRetReturnReg; }
|
unsigned getSRetReturnReg() const { return SRetReturnReg; }
|
||||||
|
@ -25,8 +25,8 @@ class TargetInstrInfo;
|
|||||||
class Type;
|
class Type;
|
||||||
|
|
||||||
namespace MBlaze {
|
namespace MBlaze {
|
||||||
/// SubregIndex - The index of various sized subregister classes. Note that
|
/// SubregIndex - The index of various sized subregister classes. Note that
|
||||||
/// these indices must be kept in sync with the class indices in the
|
/// these indices must be kept in sync with the class indices in the
|
||||||
/// MBlazeRegisterInfo.td file.
|
/// MBlazeRegisterInfo.td file.
|
||||||
enum SubregIndex {
|
enum SubregIndex {
|
||||||
SUBREG_FPEVEN = 1, SUBREG_FPODD = 2
|
SUBREG_FPEVEN = 1, SUBREG_FPODD = 2
|
||||||
@ -36,7 +36,7 @@ namespace MBlaze {
|
|||||||
struct MBlazeRegisterInfo : public MBlazeGenRegisterInfo {
|
struct MBlazeRegisterInfo : public MBlazeGenRegisterInfo {
|
||||||
const MBlazeSubtarget &Subtarget;
|
const MBlazeSubtarget &Subtarget;
|
||||||
const TargetInstrInfo &TII;
|
const TargetInstrInfo &TII;
|
||||||
|
|
||||||
MBlazeRegisterInfo(const MBlazeSubtarget &Subtarget,
|
MBlazeRegisterInfo(const MBlazeSubtarget &Subtarget,
|
||||||
const TargetInstrInfo &tii);
|
const TargetInstrInfo &tii);
|
||||||
|
|
||||||
@ -70,7 +70,7 @@ struct MBlazeRegisterInfo : public MBlazeGenRegisterInfo {
|
|||||||
|
|
||||||
void emitPrologue(MachineFunction &MF) const;
|
void emitPrologue(MachineFunction &MF) const;
|
||||||
void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const;
|
void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const;
|
||||||
|
|
||||||
/// Debug information queries.
|
/// Debug information queries.
|
||||||
unsigned getRARegister() const;
|
unsigned getRARegister() const;
|
||||||
unsigned getFrameRegister(const MachineFunction &MF) const;
|
unsigned getFrameRegister(const MachineFunction &MF) const;
|
||||||
|
@ -14,7 +14,7 @@ def ALU : FuncUnit;
|
|||||||
def IMULDIV : FuncUnit;
|
def IMULDIV : FuncUnit;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Instruction Itinerary classes used for MBlaze
|
// Instruction Itinerary classes used for MBlaze
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
def IIAlu : InstrItinClass;
|
def IIAlu : InstrItinClass;
|
||||||
def IILoad : InstrItinClass;
|
def IILoad : InstrItinClass;
|
||||||
|
@ -61,7 +61,7 @@ extern "C" void LLVMInitializeMBlazeTarget() {
|
|||||||
// Register the MC code emitter
|
// Register the MC code emitter
|
||||||
TargetRegistry::RegisterCodeEmitter(TheMBlazeTarget,
|
TargetRegistry::RegisterCodeEmitter(TheMBlazeTarget,
|
||||||
llvm::createMBlazeMCCodeEmitter);
|
llvm::createMBlazeMCCodeEmitter);
|
||||||
|
|
||||||
// Register the asm backend
|
// Register the asm backend
|
||||||
TargetRegistry::RegisterAsmBackend(TheMBlazeTarget,
|
TargetRegistry::RegisterAsmBackend(TheMBlazeTarget,
|
||||||
createMBlazeAsmBackend);
|
createMBlazeAsmBackend);
|
||||||
|
@ -18,10 +18,9 @@ namespace llvm {
|
|||||||
const MCSection *SmallDataSection;
|
const MCSection *SmallDataSection;
|
||||||
const MCSection *SmallBSSSection;
|
const MCSection *SmallBSSSection;
|
||||||
public:
|
public:
|
||||||
|
|
||||||
void Initialize(MCContext &Ctx, const TargetMachine &TM);
|
void Initialize(MCContext &Ctx, const TargetMachine &TM);
|
||||||
|
|
||||||
|
|
||||||
/// IsGlobalInSmallSection - Return true if this global address should be
|
/// IsGlobalInSmallSection - Return true if this global address should be
|
||||||
/// placed into small data/bss section.
|
/// placed into small data/bss section.
|
||||||
bool IsGlobalInSmallSection(const GlobalValue *GV,
|
bool IsGlobalInSmallSection(const GlobalValue *GV,
|
||||||
@ -29,8 +28,8 @@ namespace llvm {
|
|||||||
SectionKind Kind) const;
|
SectionKind Kind) const;
|
||||||
|
|
||||||
bool IsGlobalInSmallSection(const GlobalValue *GV,
|
bool IsGlobalInSmallSection(const GlobalValue *GV,
|
||||||
const TargetMachine &TM) const;
|
const TargetMachine &TM) const;
|
||||||
|
|
||||||
const MCSection *SelectSectionForGlobal(const GlobalValue *GV,
|
const MCSection *SelectSectionForGlobal(const GlobalValue *GV,
|
||||||
SectionKind Kind,
|
SectionKind Kind,
|
||||||
Mangler *Mang,
|
Mangler *Mang,
|
||||||
|
@ -1,8 +1,5 @@
|
|||||||
* Writing out ELF files is close to working but the following needs to
|
* Writing out ELF files is close to working but the following needs to
|
||||||
be examined more closely:
|
be examined more closely:
|
||||||
- ELF files are written with the wrong E_MACHINE value because
|
|
||||||
ELFObjectWriter::WriteHeader function does not yet support
|
|
||||||
target specific E_MACHINE values.
|
|
||||||
- ELF relocation records are incorrect because the function
|
- ELF relocation records are incorrect because the function
|
||||||
ELFObjectWriter::RecordRelocation is hard coded for X86/X86-64.
|
ELFObjectWriter::RecordRelocation is hard coded for X86/X86-64.
|
||||||
- Relocations use 2-byte / 4-byte to terminology in reference to
|
- Relocations use 2-byte / 4-byte to terminology in reference to
|
||||||
@ -32,3 +29,11 @@
|
|||||||
and need to be updated to model the MicroBlaze correctly.
|
and need to be updated to model the MicroBlaze correctly.
|
||||||
- Look at the MBlazeGenFastISel.inc stuff and make use of it
|
- Look at the MBlazeGenFastISel.inc stuff and make use of it
|
||||||
if appropriate.
|
if appropriate.
|
||||||
|
|
||||||
|
* A basic assembly parser is present now and seems to parse most things.
|
||||||
|
There are a few things that need to be looked at:
|
||||||
|
- There are some instructions that are not generated by the backend
|
||||||
|
and have not been tested as far as the parser is concerned.
|
||||||
|
- The assembly parser does not use any MicroBlaze specific directives.
|
||||||
|
I should investigate if there are MicroBlaze specific directive and,
|
||||||
|
if there are, add them.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user