Home | History | Annotate | Download | only in Mips
      1 # RUN: llvm-mc  %s -triple=mipsel-unknown-linux -mcpu=mips32r2 -show-encoding | \
      2 # RUN:   FileCheck %s --check-prefix=32R2-EL
      3 # RUN: llvm-mc  %s -triple=mipsel-unknown-linux -mcpu=mips32r2 -mattr=micromips -show-encoding | \
      4 # RUN:   FileCheck %s --check-prefix=MM-32R2-EL
      5 
      6 # Check that the assembler can handle the expressions as operands.
      7 # 32R2-EL: .text
      8 # 32R2-EL: .globl  foo
      9 # 32R2-EL: foo:
     10 # 32R2-EL: lw   $4, %lo(foo)($4)       # encoding: [A,A,0x84,0x8c]
     11 # 32R2-EL:                             #   fixup A - offset: 0, value: %lo(foo), kind: fixup_Mips_LO16
     12 # 32R2-EL: lw   $4, 56($4)             # encoding: [0x38,0x00,0x84,0x8c]
     13 # 32R2-EL: lw   $4, %lo(8+foo)($4)     # encoding: [A,A,0x84,0x8c]
     14 # 32R2-EL:                             #   fixup A - offset: 0, value: %lo(8+foo), kind: fixup_Mips_LO16
     15 # 32R2-EL: lw   $4, %lo(8+foo)($4)     # encoding: [A,A,0x84,0x8c]
     16 # 32R2-EL:                             #   fixup A - offset: 0, value: %lo(8+foo), kind: fixup_Mips_LO16
     17 # 32R2-EL: lw   $4, %lo(8+foo)($4)     # encoding: [A,A,0x84,0x8c]
     18 # 32R2-EL:                             #   fixup A - offset: 0, value: %lo(8+foo), kind: fixup_Mips_LO16
     19 # 32R2-EL: lw   $4, 10($4)             # encoding: [0x0a,0x00,0x84,0x8c]
     20 # 32R2-EL: lw   $4, 15($4)             # encoding: [0x0f,0x00,0x84,0x8c]
     21 # 32R2-EL: lw   $4, 21($4)             # encoding: [0x15,0x00,0x84,0x8c]
     22 # 32R2-EL: lw   $4, 28($4)             # encoding: [0x1c,0x00,0x84,0x8c]
     23 # 32R2-EL: lw   $4, %lo(65542)($4)     # encoding: [0x06,0x00,0x84,0x8c]
     24 # 32R2-EL: .space  64
     25 
     26 # MM-32R2-EL: .text
     27 # MM-32R2-EL: .globl  foo
     28 # MM-32R2-EL: foo:
     29 # MM-32R2-EL: lw   $4, %lo(foo)($4)     # encoding: [0x84'A',0xfc'A',0x00,0x00]
     30 # MM-32R2-EL:                           #   fixup A - offset: 0, value: %lo(foo), kind: fixup_MICROMIPS_LO16
     31 # MM-32R2-EL: lw   $4, 56($4)           # encoding: [0x84,0xfc,0x38,0x00]
     32 # MM-32R2-EL: lw   $4, %lo(8+foo)($4)   # encoding: [0x84'A',0xfc'A',0x00,0x00]
     33 # MM-32R2-EL:                           #   fixup A - offset: 0, value: %lo(8+foo), kind: fixup_MICROMIPS_LO16
     34 # MM-32R2-EL: lw   $4, %lo(8+foo)($4)   # encoding: [0x84'A',0xfc'A',0x00,0x00]
     35 # MM-32R2-EL:                           #   fixup A - offset: 0, value: %lo(8+foo), kind: fixup_MICROMIPS_LO16
     36 # MM-32R2-EL: lw   $4, %lo(8+foo)($4)   # encoding: [0x84'A',0xfc'A',0x00,0x00]
     37 # MM-32R2-EL:                           #   fixup A - offset: 0, value: %lo(8+foo), kind: fixup_MICROMIPS_LO16
     38 # MM-32R2-EL: lw   $4, 10($4)           # encoding: [0x84,0xfc,0x0a,0x00]
     39 # MM-32R2-EL: lw   $4, 15($4)           # encoding: [0x84,0xfc,0x0f,0x00]
     40 # MM-32R2-EL: lw   $4, 21($4)           # encoding: [0x84,0xfc,0x15,0x00]
     41 # MM-32R2-EL: lw   $4, 28($4)           # encoding: [0x84,0xfc,0x1c,0x00]
     42 # MM-32R2-EL: lw   $4, %lo(65542)($4)   # encoding: [0x84,0xfc,0x06,0x00]
     43 # MM-32R2-EL: .space  64
     44 
     45   .globl  foo
     46   .ent  foo
     47 foo:
     48   lw  $4,%lo(foo)($4)
     49   lw  $4,((10 + 4) * 4)($4)
     50   lw  $4,%lo (2 * 4) + foo($4)
     51   lw  $4,%lo((2 * 4) + foo)($4)
     52   lw  $4,(((%lo ((2 * 4) + foo))))($4)
     53   lw  $4, (((1+2)+3)+4)($4)
     54   lw  $4, ((((1+2)+3)+4)+5)($4)
     55   lw  $4, (((((1+2)+3)+4)+5)+6)($4)
     56   lw  $4, ((((((1+2)+3)+4)+5)+6)+7)($4)
     57   lw  $4, (%lo((1+2)+65536)+3)($4)
     58   .space  64
     59   .end  foo
     60