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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user