mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 02:22:29 +00:00 
			
		
		
		
	This reverts r155000.
The cdp2 instruction should have the same restrictions as cdp on the co-processor registers. VFP instructions on v8/AArch32 share the same encoding space as cdp2. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184445 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -1007,11 +1007,6 @@ def p_imm : Operand<i32> { | |||||||
|   let DecoderMethod = "DecodeCoprocessor"; |   let DecoderMethod = "DecodeCoprocessor"; | ||||||
| } | } | ||||||
|  |  | ||||||
| def pf_imm : Operand<i32> { |  | ||||||
|   let PrintMethod = "printPImmediate"; |  | ||||||
|   let ParserMatchClass = CoprocNumAsmOperand; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| def CoprocRegAsmOperand : AsmOperandClass { | def CoprocRegAsmOperand : AsmOperandClass { | ||||||
|   let Name = "CoprocReg"; |   let Name = "CoprocReg"; | ||||||
|   let ParserMethod = "parseCoprocRegOperand"; |   let ParserMethod = "parseCoprocRegOperand"; | ||||||
| @@ -4447,7 +4442,7 @@ def CDP : ABI<0b1110, (outs), (ins p_imm:$cop, imm0_15:$opc1, | |||||||
|   let Inst{23-20} = opc1; |   let Inst{23-20} = opc1; | ||||||
| } | } | ||||||
|  |  | ||||||
| def CDP2 : ABXI<0b1110, (outs), (ins pf_imm:$cop, imm0_15:$opc1, | def CDP2 : ABXI<0b1110, (outs), (ins p_imm:$cop, imm0_15:$opc1, | ||||||
|                c_imm:$CRd, c_imm:$CRn, c_imm:$CRm, imm0_7:$opc2), |                c_imm:$CRd, c_imm:$CRn, c_imm:$CRm, imm0_7:$opc2), | ||||||
|                NoItinerary, "cdp2\t$cop, $opc1, $CRd, $CRn, $CRm, $opc2", |                NoItinerary, "cdp2\t$cop, $opc1, $CRd, $CRn, $CRm, $opc2", | ||||||
|                [(int_arm_cdp2 imm:$cop, imm:$opc1, imm:$CRd, imm:$CRn, |                [(int_arm_cdp2 imm:$cop, imm:$opc1, imm:$CRd, imm:$CRn, | ||||||
|   | |||||||
| @@ -459,9 +459,11 @@ Lforward: | |||||||
| @------------------------------------------------------------------------------ | @------------------------------------------------------------------------------ | ||||||
|         cdp  p7, #1, c1, c1, c1, #4 |         cdp  p7, #1, c1, c1, c1, #4 | ||||||
|         cdp2  p7, #1, c1, c1, c1, #4 |         cdp2  p7, #1, c1, c1, c1, #4 | ||||||
|  |         cdp2   p10, #0, c6, c12, c0, #7 | ||||||
|  |  | ||||||
| @ CHECK: cdp  p7, #1, c1, c1, c1, #4     @ encoding: [0x81,0x17,0x11,0xee] | @ CHECK: cdp  p7, #1, c1, c1, c1, #4     @ encoding: [0x81,0x17,0x11,0xee] | ||||||
| @ CHECK: cdp2  p7, #1, c1, c1, c1, #4    @ encoding: [0x81,0x17,0x11,0xfe] | @ CHECK: cdp2  p7, #1, c1, c1, c1, #4    @ encoding: [0x81,0x17,0x11,0xfe] | ||||||
|  | @ CHECK: cdp2  p10, #0, c6, c12, c0, #7   @ encoding: [0xe0,0x6a,0x0c,0xfe] | ||||||
|  |  | ||||||
|  |  | ||||||
| @------------------------------------------------------------------------------ | @------------------------------------------------------------------------------ | ||||||
|   | |||||||
| @@ -362,7 +362,3 @@ | |||||||
|  |  | ||||||
| # CHECK: ldmgt	sp!, {r9} | # CHECK: ldmgt	sp!, {r9} | ||||||
| 0x00 0x02 0xbd 0xc8 | 0x00 0x02 0xbd 0xc8 | ||||||
|  |  | ||||||
| # CHECK: cdp2	p10, #0, c6, c12, c0, #7 |  | ||||||
| 0xe0 0x6a 0x0c 0xfe |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								test/MC/Disassembler/ARM/invalid-CDP2-arm.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								test/MC/Disassembler/ARM/invalid-CDP2-arm.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | # RUN: llvm-mc --disassemble %s -triple=arm 2>&1 | FileCheck %s | ||||||
|  |  | ||||||
|  | # CHECK: invalid instruction encoding | ||||||
|  | 0xe0 0x6a 0x0c 0xfe | ||||||
		Reference in New Issue
	
	Block a user