summaryrefslogtreecommitdiff
path: root/test/MC/Mips/micromips-expressions.s
blob: 509e98072bb456c05ca6a6d77131a9247da48480 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# RUN: llvm-mc  %s -triple=mipsel-unknown-linux -show-encoding \
# RUN: -mcpu=mips32r2 -mattr=micromips | FileCheck %s
# Check that the assembler can handle the expressions as operands.
# CHECK:  .text
# CHECK:  .globl  foo
# CHECK:  foo:
# CHECK:  lw   $4, %lo(foo)($4)    # encoding: [0x84'A',0xfc'A',0x00,0x00]
# CHECK:                           # fixup A - offset: 0,
# CHECK:                             value: foo@ABS_LO,
# CHECK:                             kind: fixup_MICROMIPS_LO16
# CHECK:  lw   $4, 56($4)          # encoding: [0x84,0xfc,0x38,0x00]
# CHECK:  lw   $4, %lo(foo+8)($4)  # encoding: [0x84'A',0xfc'A',0x08,0x00]
# CHECK:                           # fixup A - offset: 0,
# CHECK:                             value: foo@ABS_LO,
# CHECK:                             kind: fixup_MICROMIPS_LO16
# CHECK:  lw   $4, %lo(foo+8)($4)  # encoding: [0x84'A',0xfc'A',0x08,0x00]
# CHECK:                           # fixup A - offset: 0,
# CHECK:                             value: foo@ABS_LO,
# CHECK:                             kind: fixup_MICROMIPS_LO16
# CHECK:  lw   $4, %lo(foo+8)($4)  # encoding: [0x84'A',0xfc'A',0x08,0x00]
# CHECK:                           # fixup A - offset: 0,
# CHECK:                             value: foo@ABS_LO,
# CHECK:                             kind: fixup_MICROMIPS_LO16
# CHECK:  .space  64

  .globl  foo
  .ent  foo
foo:
  lw  $4,%lo(foo)($4)
  lw  $4,((10 + 4) * 4)($4)
  lw  $4,%lo (2 * 4) + foo($4)
  lw  $4,%lo((2 * 4) + foo)($4)
  lw  $4,(((%lo ((2 * 4) + foo))))($4)
  .space  64
  .end  foo