mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-31 04:06:46 +00:00 
			
		
		
		
	target-mips: Clean up microMIPS32 major opcode
I check MIPS microMIPS manual [1], and found the major opcode might be wrong. I add a comment to explicitly indicate what manual I am refering to, and according that manual I remove microMIPS32 major opcodes 0x1f. As for others, like 0x16, 0x17, 0x36 and 0x37, they are for higher-order MIPS ISA level or new revision of this microMIPS architecture. Quote from Johnson, they are belong MIPS64 [2]. [1] http://www.mips.com/products/architectures/micromips/#specifications MIPS Architecture for Programmers Volume II-B: The microMIPS32 Instruction Set (Revision 3.05) MD00582-2B-microMIPS-AFP-03.05.pdf [2] http://www.mips.com/products/architectures/mips64/ MIPS Architecture For Programmers Volume II-A: The MIPS64 Instruction Set MD00087-2B-MIPS64BIS-AFP-03.51.pdf Signed-off-by: Chen Wei-Ren <chenwj@iis.sinica.edu.tw> Reviewed-by: Eric Johnson <ericj@mips.com> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
This commit is contained in:
		
							parent
							
								
									d132c79f6b
								
							
						
					
					
						commit
						211da99290
					
				| @ -10239,9 +10239,19 @@ static int decode_mips16_opc (CPUMIPSState *env, DisasContext *ctx, | ||||
|     return n_bytes; | ||||
| } | ||||
| 
 | ||||
| /* microMIPS extension to MIPS32 */ | ||||
| /* microMIPS extension to MIPS32/MIPS64 */ | ||||
| 
 | ||||
| /* microMIPS32 major opcodes */ | ||||
| /*
 | ||||
|  * microMIPS32/microMIPS64 major opcodes | ||||
|  * | ||||
|  * 1. MIPS Architecture for Programmers Volume II-B: | ||||
|  *      The microMIPS32 Instruction Set (Revision 3.05) | ||||
|  * | ||||
|  *    Table 6.2 microMIPS32 Encoding of Major Opcode Field | ||||
|  * | ||||
|  * 2. MIPS Architecture For Programmers Volume II-A: | ||||
|  *      The MIPS64 Instruction Set (Revision 3.51) | ||||
|  */ | ||||
| 
 | ||||
| enum { | ||||
|     POOL32A = 0x00, | ||||
| @ -10268,9 +10278,10 @@ enum { | ||||
|     POOL16D = 0x13, | ||||
|     ORI32 = 0x14, | ||||
|     POOL32F = 0x15, | ||||
|     POOL32S = 0x16, | ||||
|     DADDIU32 = 0x17, | ||||
|     POOL32S = 0x16,  /* MIPS64 */ | ||||
|     DADDIU32 = 0x17, /* MIPS64 */ | ||||
| 
 | ||||
|     /* 0x1f is reserved */ | ||||
|     POOL32C = 0x18, | ||||
|     LWGP16 = 0x19, | ||||
|     LW16 = 0x1a, | ||||
| @ -10278,7 +10289,6 @@ enum { | ||||
|     XORI32 = 0x1c, | ||||
|     JALS32 = 0x1d, | ||||
|     ADDIUPC = 0x1e, | ||||
|     POOL48A = 0x1f, | ||||
| 
 | ||||
|     /* 0x20 is reserved */ | ||||
|     RES_20 = 0x20, | ||||
| @ -10307,8 +10317,8 @@ enum { | ||||
|     B16 = 0x33, | ||||
|     ANDI32 = 0x34, | ||||
|     J32 = 0x35, | ||||
|     SD32 = 0x36, | ||||
|     LD32 = 0x37, | ||||
|     SD32 = 0x36, /* MIPS64 */ | ||||
|     LD32 = 0x37, /* MIPS64 */ | ||||
| 
 | ||||
|     /* 0x38 and 0x39 are reserved */ | ||||
|     RES_38 = 0x38, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 陳韋任 (Wei-Ren Chen)
						陳韋任 (Wei-Ren Chen)