Home | History | Annotate | Download | only in Mips
      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