llvm-6502/lib/Target/Mips
Jack Carter a0f14afee1 Mips specific inline asm operand modifier 'M':
Print the high order register of a double word register operand.

In 32 bit mode, a 64 bit double word integer will be represented
by 2 32 bit registers. This modifier causes the high order register
to be used in the asm expression. It is useful if you are using 
doubles in assembler and continue to control register to variable
relationships.

This patch also fixes a related bug in a previous patch:

    case 'D': // Second part of a double word register operand
    case 'L': // Low order register of a double word register operand
    case 'M': // High order register of a double word register operand

I got 'D' and 'M' confused. The second part of a double word operand
will only match 'M' for one of the endianesses. I had 'L' and 'D'
be the opposite twins when 'L' and 'M' are.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@160429 91177308-0d34-0410-b5e6-96231b3b80d8
2012-07-18 06:41:36 +00:00
..
AsmParser Mips/AsmParser/CMakeLists.txt: Fix dependency. 2012-06-16 15:33:52 +00:00
Disassembler Reapply r158846. 2012-07-09 18:46:47 +00:00
InstPrinter Enclose instruction rdhwr with directives, which are needed when target is 2012-07-05 19:26:38 +00:00
MCTargetDesc The Mips specific relocation R_MIPS_GOT_DISP 2012-07-13 19:15:47 +00:00
TargetInfo remove Emacs-tag form .cpp files in Mips Backend, and fix some typo. 2012-02-17 08:55:11 +00:00
CMakeLists.txt llvm/lib: [CMake] Add explicit dependency to intrinsics_gen. 2012-06-24 13:32:01 +00:00
LLVMBuild.txt Add disassembler to MIPS. 2012-04-17 18:03:21 +00:00
Makefile Add disassembler to MIPS. 2012-04-17 18:03:21 +00:00
Mips16InstrFormats.td Clean up Mips16InstrFormats.td and Mips16InstrInfo.td. 2012-07-17 22:55:34 +00:00
Mips16InstrInfo.td Clean up Mips16InstrFormats.td and Mips16InstrInfo.td. 2012-07-17 22:55:34 +00:00
Mips64InstrInfo.td Doubleword Shift Left Logical Plus 32 2012-07-16 15:14:51 +00:00
Mips.h Add long branch expansion pass for MIPS. 2012-06-14 01:19:35 +00:00
Mips.td This patch adds the register class for MIPS16 as well as the ability for 2012-05-16 22:19:56 +00:00
MipsAnalyzeImmediate.cpp Fix undefined behavior in the Mips backend. 2012-03-09 06:36:45 +00:00
MipsAnalyzeImmediate.h Fix undefined behavior in the Mips backend. 2012-03-09 06:36:45 +00:00
MipsAsmPrinter.cpp Mips specific inline asm operand modifier 'M': 2012-07-18 06:41:36 +00:00
MipsAsmPrinter.h Emit all directives except for ".cprestore" during asm printing rather than emit 2012-03-28 00:22:50 +00:00
MipsCallingConv.td Implement fastcc calling convention for MIPS. 2012-06-13 18:06:00 +00:00
MipsCodeEmitter.cpp Use MachineBasicBlock::instr_iterator instead of MachineBasicBlock::iterator in 2012-06-19 03:39:45 +00:00
MipsCondMov.td 1. introduce MipsPat in place of Pat in order to exclude those from 2012-06-14 21:03:23 +00:00
MipsDelaySlotFiller.cpp Fix coding style violations. Remove white spaces and tabs. 2012-06-14 21:10:56 +00:00
MipsFrameLowering.cpp Lower RETURNADDR node in Mips backend. 2012-07-11 00:53:32 +00:00
MipsFrameLowering.h Make register Mips::RA allocatable if not in mips16 mode. 2012-07-10 00:19:06 +00:00
MipsInstrFormats.td This patch adds a predicate to existing mips32 and mips64 so that those 2012-05-22 03:10:09 +00:00
MipsInstrFPU.td 1. introduce MipsPat in place of Pat in order to exclude those from 2012-06-14 21:03:23 +00:00
MipsInstrInfo.cpp Make register Mips::RA allocatable if not in mips16 mode. 2012-07-10 00:19:06 +00:00
MipsInstrInfo.h Make register Mips::RA allocatable if not in mips16 mode. 2012-07-10 00:19:06 +00:00
MipsInstrInfo.td Remove variable_ops from call instructions in most targets. 2012-07-13 20:44:29 +00:00
MipsISelDAGToDAG.cpp Silence uninitialized variable warning in MipsISelDAGToDAG.cpp. 2012-06-27 00:49:46 +00:00
MipsISelLowering.cpp Implement MipsTargetLowering::LowerSELECT_CC to custom lower SELECT_CC. 2012-07-11 19:32:27 +00:00
MipsISelLowering.h Implement MipsTargetLowering::LowerSELECT_CC to custom lower SELECT_CC. 2012-07-11 19:32:27 +00:00
MipsJITInfo.cpp Fix coding style violations. Remove white spaces and tabs. 2012-06-14 21:10:56 +00:00
MipsJITInfo.h Fix coding style violations. Remove white spaces and tabs. 2012-06-14 21:10:56 +00:00
MipsLongBranch.cpp Make MipsLongBranch::runOnMachineFunction return true. 2012-06-19 03:45:29 +00:00
MipsMachineFunction.cpp Delete all functions that are no longer needed in MipsFunctionInfo, including 2012-05-12 03:22:13 +00:00
MipsMachineFunction.h Add methods to MipsFunctionInfo for initializing and accessing the stack frame 2012-06-14 01:15:36 +00:00
MipsMCInstLower.cpp Doubleword Shift Left Logical Plus 32 2012-07-16 15:14:51 +00:00
MipsMCInstLower.h Doubleword Shift Left Logical Plus 32 2012-07-16 15:14:51 +00:00
MipsRegisterInfo.cpp Make register Mips::RA allocatable if not in mips16 mode. 2012-07-10 00:19:06 +00:00
MipsRegisterInfo.h Fix coding style violations. Remove white spaces and tabs. 2012-06-14 21:10:56 +00:00
MipsRegisterInfo.td In register classes in MipsRegisterInfo.td, list the registers in ascending 2012-07-11 20:51:50 +00:00
MipsRelocations.h remove blanks, and some code format 2012-02-28 07:46:26 +00:00
MipsSchedule.td remove blanks, and some code format 2012-02-28 07:46:26 +00:00
MipsSelectionDAGInfo.cpp remove Emacs-tag form .cpp files in Mips Backend, and fix some typo. 2012-02-17 08:55:11 +00:00
MipsSelectionDAGInfo.h
MipsSubtarget.cpp Fix coding style violations. Remove white spaces and tabs. 2012-06-14 21:10:56 +00:00
MipsSubtarget.h This patch adds a predicate to existing mips32 and mips64 so that those 2012-05-22 03:10:09 +00:00
MipsTargetMachine.cpp Add all codegen passes to the PassManager via TargetPassConfig. 2012-07-02 19:48:31 +00:00
MipsTargetMachine.h Fix coding style violations. Remove white spaces and tabs. 2012-06-14 21:10:56 +00:00
MipsTargetObjectFile.cpp remove Emacs-tag form .cpp files in Mips Backend, and fix some typo. 2012-02-17 08:55:11 +00:00
MipsTargetObjectFile.h