1*9880d681SAndroid Build Coastguard Worker# RUN: llvm-mc %s -triple=mipsel -show-encoding -mcpu=mips32r2 -mattr=micromips \ 2*9880d681SAndroid Build Coastguard Worker# RUN: | FileCheck -check-prefix=CHECK-EL %s 3*9880d681SAndroid Build Coastguard Worker# RUN: llvm-mc %s -triple=mips -show-encoding -mcpu=mips32r2 -mattr=micromips \ 4*9880d681SAndroid Build Coastguard Worker# RUN: | FileCheck -check-prefix=CHECK-EB %s 5*9880d681SAndroid Build Coastguard Worker# Check that the assembler can handle the documented syntax 6*9880d681SAndroid Build Coastguard Worker# for control instructions. 7*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------ 8*9880d681SAndroid Build Coastguard Worker# microMIPS Control Instructions 9*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------ 10*9880d681SAndroid Build Coastguard Worker# Little endian 11*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------ 12*9880d681SAndroid Build Coastguard Worker# CHECK-EL: sdbbp # encoding: [0x00,0x00,0x7c,0xdb] 13*9880d681SAndroid Build Coastguard Worker# CHECK-EL: sdbbp 34 # encoding: [0x22,0x00,0x7c,0xdb] 14*9880d681SAndroid Build Coastguard Worker# CHECK-EL-NOT: .set push 15*9880d681SAndroid Build Coastguard Worker# CHECK-EL-NOT: .set mips32r2 16*9880d681SAndroid Build Coastguard Worker# CHECK-EL: rdhwr $5, $29 # encoding: [0xbd,0x00,0x3c,0x6b] 17*9880d681SAndroid Build Coastguard Worker# CHECK-EL-NOT: .set pop 18*9880d681SAndroid Build Coastguard Worker# CHECK-EL: cache 1, 8($5) # encoding: [0x25,0x20,0x08,0x60] 19*9880d681SAndroid Build Coastguard Worker# CHECK-EL: pref 1, 8($5) # encoding: [0x25,0x60,0x08,0x20] 20*9880d681SAndroid Build Coastguard Worker# CHECK-EL: ssnop # encoding: [0x00,0x00,0x00,0x08] 21*9880d681SAndroid Build Coastguard Worker# CHECK-EL: ehb # encoding: [0x00,0x00,0x00,0x18] 22*9880d681SAndroid Build Coastguard Worker# CHECK-EL: pause # encoding: [0x00,0x00,0x00,0x28] 23*9880d681SAndroid Build Coastguard Worker# CHECK-EL: break # encoding: [0x00,0x00,0x07,0x00] 24*9880d681SAndroid Build Coastguard Worker# CHECK-EL: break 7 # encoding: [0x07,0x00,0x07,0x00] 25*9880d681SAndroid Build Coastguard Worker# CHECK-EL: break 7, 5 # encoding: [0x07,0x00,0x47,0x01] 26*9880d681SAndroid Build Coastguard Worker# CHECK-EL: syscall # encoding: [0x00,0x00,0x7c,0x8b] 27*9880d681SAndroid Build Coastguard Worker# CHECK-EL: syscall 396 # encoding: [0x8c,0x01,0x7c,0x8b] 28*9880d681SAndroid Build Coastguard Worker# CHECK-EL: eret # encoding: [0x00,0x00,0x7c,0xf3] 29*9880d681SAndroid Build Coastguard Worker# CHECK-EL: deret # encoding: [0x00,0x00,0x7c,0xe3] 30*9880d681SAndroid Build Coastguard Worker# CHECK-EL: di # encoding: [0x00,0x00,0x7c,0x47] 31*9880d681SAndroid Build Coastguard Worker# CHECK-EL: di # encoding: [0x00,0x00,0x7c,0x47] 32*9880d681SAndroid Build Coastguard Worker# CHECK-EL: di $10 # encoding: [0x0a,0x00,0x7c,0x47] 33*9880d681SAndroid Build Coastguard Worker# CHECK-EL: ei # encoding: [0x00,0x00,0x7c,0x57] 34*9880d681SAndroid Build Coastguard Worker# CHECK-EL: ei # encoding: [0x00,0x00,0x7c,0x57] 35*9880d681SAndroid Build Coastguard Worker# CHECK-EL: ei $10 # encoding: [0x0a,0x00,0x7c,0x57] 36*9880d681SAndroid Build Coastguard Worker# CHECK-EL: wait # encoding: [0x00,0x00,0x7c,0x93] 37*9880d681SAndroid Build Coastguard Worker# CHECK-EL: wait 17 # encoding: [0x11,0x00,0x7c,0x93] 38*9880d681SAndroid Build Coastguard Worker# CHECK-EL: tlbp # encoding: [0x00,0x00,0x7c,0x03] 39*9880d681SAndroid Build Coastguard Worker# CHECK-EL: tlbr # encoding: [0x00,0x00,0x7c,0x13] 40*9880d681SAndroid Build Coastguard Worker# CHECK-EL: tlbwi # encoding: [0x00,0x00,0x7c,0x23] 41*9880d681SAndroid Build Coastguard Worker# CHECK-EL: tlbwr # encoding: [0x00,0x00,0x7c,0x33] 42*9880d681SAndroid Build Coastguard Worker# CHECK-EL: prefe 1, 8($5) # encoding: [0x25,0x60,0x08,0xa4] 43*9880d681SAndroid Build Coastguard Worker# CHECK-EL: cachee 1, 8($5) # encoding: [0x25,0x60,0x08,0xa6] 44*9880d681SAndroid Build Coastguard Worker# CHECK-EL: prefx 1, $3($5) # encoding: [0x65,0x54,0xa0,0x09] 45*9880d681SAndroid Build Coastguard Worker# CHECK-EL: swre $24, 5($3) # encoding: [0x03,0x63,0x05,0xa2] 46*9880d681SAndroid Build Coastguard Worker# CHECK-EL: swle $24, 5($3) # encoding: [0x03,0x63,0x05,0xa0] 47*9880d681SAndroid Build Coastguard Worker# CHECK-EL: lwre $24, 5($3) # encoding: [0x03,0x63,0x05,0x66] 48*9880d681SAndroid Build Coastguard Worker# CHECK-EL: lwle $24, 2($4) # encoding: [0x04,0x63,0x02,0x64] 49*9880d681SAndroid Build Coastguard Worker# CHECK-EL: lle $2, 8($4) # encoding: [0x44,0x60,0x08,0x6c] 50*9880d681SAndroid Build Coastguard Worker# CHECK-EL: sce $2, 8($4) # encoding: [0x44,0x60,0x08,0xac] 51*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------ 52*9880d681SAndroid Build Coastguard Worker# Big endian 53*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------ 54*9880d681SAndroid Build Coastguard Worker# CHECK-EB: sdbbp # encoding: [0x00,0x00,0xdb,0x7c] 55*9880d681SAndroid Build Coastguard Worker# CHECK-EB: sdbbp 34 # encoding: [0x00,0x22,0xdb,0x7c] 56*9880d681SAndroid Build Coastguard Worker# CHECK-EB-NOT: .set push 57*9880d681SAndroid Build Coastguard Worker# CHECK-EB-NOT: .set mips32r2 58*9880d681SAndroid Build Coastguard Worker# CHECK-EB: rdhwr $5, $29 # encoding: [0x00,0xbd,0x6b,0x3c] 59*9880d681SAndroid Build Coastguard Worker# CHECK-EB-NOT: .set pop 60*9880d681SAndroid Build Coastguard Worker# CHECK-EB: cache 1, 8($5) # encoding: [0x20,0x25,0x60,0x08] 61*9880d681SAndroid Build Coastguard Worker# CHECK-EB: pref 1, 8($5) # encoding: [0x60,0x25,0x20,0x08] 62*9880d681SAndroid Build Coastguard Worker# CHECK-EB: ssnop # encoding: [0x00,0x00,0x08,0x00] 63*9880d681SAndroid Build Coastguard Worker# CHECK-EB: ehb # encoding: [0x00,0x00,0x18,0x00] 64*9880d681SAndroid Build Coastguard Worker# CHECK-EB: pause # encoding: [0x00,0x00,0x28,0x00] 65*9880d681SAndroid Build Coastguard Worker# CHECK-EB: break # encoding: [0x00,0x00,0x00,0x07] 66*9880d681SAndroid Build Coastguard Worker# CHECK-EB: break 7 # encoding: [0x00,0x07,0x00,0x07] 67*9880d681SAndroid Build Coastguard Worker# CHECK-EB: break 7, 5 # encoding: [0x00,0x07,0x01,0x47] 68*9880d681SAndroid Build Coastguard Worker# CHECK-EB: syscall # encoding: [0x00,0x00,0x8b,0x7c] 69*9880d681SAndroid Build Coastguard Worker# CHECK-EB: syscall 396 # encoding: [0x01,0x8c,0x8b,0x7c] 70*9880d681SAndroid Build Coastguard Worker# CHECK-EB: eret # encoding: [0x00,0x00,0xf3,0x7c] 71*9880d681SAndroid Build Coastguard Worker# CHECK-EB: deret # encoding: [0x00,0x00,0xe3,0x7c] 72*9880d681SAndroid Build Coastguard Worker# CHECK-EB: di # encoding: [0x00,0x00,0x47,0x7c] 73*9880d681SAndroid Build Coastguard Worker# CHECK-EB: di # encoding: [0x00,0x00,0x47,0x7c] 74*9880d681SAndroid Build Coastguard Worker# CHECK-EB: di $10 # encoding: [0x00,0x0a,0x47,0x7c] 75*9880d681SAndroid Build Coastguard Worker# CHECK-EB: ei # encoding: [0x00,0x00,0x57,0x7c] 76*9880d681SAndroid Build Coastguard Worker# CHECK-EB: ei # encoding: [0x00,0x00,0x57,0x7c] 77*9880d681SAndroid Build Coastguard Worker# CHECK-EB: ei $10 # encoding: [0x00,0x0a,0x57,0x7c] 78*9880d681SAndroid Build Coastguard Worker# CHECK-EB: wait # encoding: [0x00,0x00,0x93,0x7c] 79*9880d681SAndroid Build Coastguard Worker# CHECK-EB: wait 17 # encoding: [0x00,0x11,0x93,0x7c] 80*9880d681SAndroid Build Coastguard Worker# CHECK-EB: tlbp # encoding: [0x00,0x00,0x03,0x7c] 81*9880d681SAndroid Build Coastguard Worker# CHECK-EB: tlbr # encoding: [0x00,0x00,0x13,0x7c] 82*9880d681SAndroid Build Coastguard Worker# CHECK-EB: tlbwi # encoding: [0x00,0x00,0x23,0x7c] 83*9880d681SAndroid Build Coastguard Worker# CHECK-EB: tlbwr # encoding: [0x00,0x00,0x33,0x7c] 84*9880d681SAndroid Build Coastguard Worker# CHECK-EB: prefe 1, 8($5) # encoding: [0x60,0x25,0xa4,0x08] 85*9880d681SAndroid Build Coastguard Worker# CHECK-EB: cachee 1, 8($5) # encoding: [0x60,0x25,0xa6,0x08] 86*9880d681SAndroid Build Coastguard Worker# CHECK-EB: prefx 1, $3($5) # encoding: [0x54,0x65,0x09,0xa0] 87*9880d681SAndroid Build Coastguard Worker# CHECK-EB: swre $24, 5($3) # encoding: [0x63,0x03,0xa2,0x05] 88*9880d681SAndroid Build Coastguard Worker# CHECK-EB: swle $24, 5($3) # encoding: [0x63,0x03,0xa0,0x05] 89*9880d681SAndroid Build Coastguard Worker# CHECK-EB: lwre $24, 5($3) # encoding: [0x63,0x03,0x66,0x05] 90*9880d681SAndroid Build Coastguard Worker# CHECK-EB: lwle $24, 2($4) # encoding: [0x63,0x04,0x64,0x02] 91*9880d681SAndroid Build Coastguard Worker# CHECK-EB: lle $2, 8($4) # encoding: [0x60,0x44,0x6c,0x08] 92*9880d681SAndroid Build Coastguard Worker# CHECK-EB: sce $2, 8($4) # encoding: [0x60,0x44,0xac,0x08] 93*9880d681SAndroid Build Coastguard Worker 94*9880d681SAndroid Build Coastguard Worker sdbbp 95*9880d681SAndroid Build Coastguard Worker sdbbp 34 96*9880d681SAndroid Build Coastguard Worker rdhwr $5, $29 97*9880d681SAndroid Build Coastguard Worker cache 1, 8($5) 98*9880d681SAndroid Build Coastguard Worker pref 1, 8($5) 99*9880d681SAndroid Build Coastguard Worker ssnop 100*9880d681SAndroid Build Coastguard Worker ehb 101*9880d681SAndroid Build Coastguard Worker pause 102*9880d681SAndroid Build Coastguard Worker break 103*9880d681SAndroid Build Coastguard Worker break 7 104*9880d681SAndroid Build Coastguard Worker break 7,5 105*9880d681SAndroid Build Coastguard Worker syscall 106*9880d681SAndroid Build Coastguard Worker syscall 0x18c 107*9880d681SAndroid Build Coastguard Worker eret 108*9880d681SAndroid Build Coastguard Worker deret 109*9880d681SAndroid Build Coastguard Worker di 110*9880d681SAndroid Build Coastguard Worker di $0 111*9880d681SAndroid Build Coastguard Worker di $10 112*9880d681SAndroid Build Coastguard Worker ei 113*9880d681SAndroid Build Coastguard Worker ei $0 114*9880d681SAndroid Build Coastguard Worker ei $10 115*9880d681SAndroid Build Coastguard Worker wait 116*9880d681SAndroid Build Coastguard Worker wait 17 117*9880d681SAndroid Build Coastguard Worker tlbp 118*9880d681SAndroid Build Coastguard Worker tlbr 119*9880d681SAndroid Build Coastguard Worker tlbwi 120*9880d681SAndroid Build Coastguard Worker tlbwr 121*9880d681SAndroid Build Coastguard Worker prefe 1, 8($5) 122*9880d681SAndroid Build Coastguard Worker cachee 1, 8($5) 123*9880d681SAndroid Build Coastguard Worker prefx 1, $3($5) 124*9880d681SAndroid Build Coastguard Worker swre $24, 5($3) 125*9880d681SAndroid Build Coastguard Worker swle $24, 5($3) 126*9880d681SAndroid Build Coastguard Worker lwre $24, 5($3) 127*9880d681SAndroid Build Coastguard Worker lwle $24, 2($4) 128*9880d681SAndroid Build Coastguard Worker lle $2, 8($4) 129*9880d681SAndroid Build Coastguard Worker sce $2, 8($4) 130