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