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
6 # Check that the assembler can handle the expressions as operands.
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: lui $1, %hi(foo+(%lo(8))) # encoding: [A,A,0x01,0x3c]
14 # 32R2-EL: # fixup A - offset: 0, value: %hi(foo+(%lo(8))), kind: fixup_Mips_HI16
15 # 32R2-EL: addu $1, $1, $4 # encoding: [0x21,0x08,0x24,0x00]
16 # 32R2-EL: lw $4, %lo(foo+(%lo(8)))($1) # encoding: [A,A,0x24,0x8c]
17 # 32R2-EL: # fixup A - offset: 0, value: %lo(foo+(%lo(8))), kind: fixup_Mips_LO16
18 # 32R2-EL: lw $4, %lo(12+foo)($4) # encoding: [A,A,0x84,0x8c]
19 # 32R2-EL: # fixup A - offset: 0, value: %lo(12+foo), kind: fixup_Mips_LO16
20 # 32R2-EL: lw $4, %lo(16+foo)($4) # encoding: [A,A,0x84,0x8c]
21 # 32R2-EL: # fixup A - offset: 0, value: %lo(16+foo), kind: fixup_Mips_LO16
22 # 32R2-EL: lw $4, 10($4) # encoding: [0x0a,0x00,0x84,0x8c]
23 # 32R2-EL: lw $4, 15($4) # encoding: [0x0f,0x00,0x84,0x8c]
24 # 32R2-EL: lw $4, 21($4) # encoding: [0x15,0x00,0x84,0x8c]
25 # 32R2-EL: lw $4, 28($4) # encoding: [0x1c,0x00,0x84,0x8c]
26 # 32R2-EL: lw $4, 6($4) # encoding: [0x06,0x00,0x84,0x8c]
30 # MM-32R2-EL: .globl foo
32 # MM-32R2-EL: lw $4, %lo(foo)($4) # encoding: [0x84'A',0xfc'A',0x00,0x00]
33 # MM-32R2-EL: # fixup A - offset: 0, value: %lo(foo), kind: fixup_MICROMIPS_LO16
34 # MM-32R2-EL: lw $4, 56($4) # encoding: [0x84,0xfc,0x38,0x00]
35 # MM-32R2-EL: lui $1, %hi(foo+(%lo(8))) # encoding: [0xa1'A',0x41'A',0x00,0x00]
36 # MM-32R2-EL: # fixup A - offset: 0, value: %hi(foo+(%lo(8))), kind: fixup_MICROMIPS_HI16
37 # MM-32R2-EL: addu $1, $1, $4 # encoding: [0x81,0x00,0x50,0x09]
38 # MM-32R2-EL: lw $4, %lo(foo+(%lo(8)))($1) # encoding: [0x81'A',0xfc'A',0x00,0x00]
39 # MM-32R2-EL: # fixup A - offset: 0, value: %lo(foo+(%lo(8))), kind: fixup_MICROMIPS_LO16
40 # MM-32R2-EL: lw $4, %lo(12+foo)($4) # encoding: [0x84'A',0xfc'A',0x00,0x00]
41 # MM-32R2-EL: # fixup A - offset: 0, value: %lo(12+foo), kind: fixup_MICROMIPS_LO16
42 # MM-32R2-EL: lw $4, %lo(16+foo)($4) # encoding: [0x84'A',0xfc'A',0x00,0x00]
43 # MM-32R2-EL: # fixup A - offset: 0, value: %lo(16+foo), kind: fixup_MICROMIPS_LO16
44 # MM-32R2-EL: lw $4, 10($4) # encoding: [0x84,0xfc,0x0a,0x00]
45 # MM-32R2-EL: lw $4, 15($4) # encoding: [0x84,0xfc,0x0f,0x00]
46 # MM-32R2-EL: lw $4, 21($4) # encoding: [0x84,0xfc,0x15,0x00]
47 # MM-32R2-EL: lw $4, 28($4) # encoding: [0x84,0xfc,0x1c,0x00]
48 # MM-32R2-EL: lw $4, 6($4) # encoding: [0x84,0xfc,0x06,0x00]
49 # MM-32R2-EL: .space 64
55 lw $
4,((10 + 4) * 4)($
4)
56 lw $
4,%lo
(2 * 4) + foo
($
4)
57 lw $
4,%lo
((3 * 4) + foo
)($
4)
58 lw $
4,(((%lo
((4 * 4) + foo
))))($
4)
59 lw $
4, (((1+2)+3)+4)($
4)
60 lw $
4, ((((1+2)+3)+4)+5)($
4)
61 lw $
4, (((((1+2)+3)+4)+5)+6)($
4)
62 lw $
4, ((((((1+2)+3)+4)+5)+6)+7)($
4)
63 lw $
4, (%lo
((1+2)+65536)+3)($
4)