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: 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] 27# 32R2-EL: .space 64 28 29# MM-32R2-EL: .text 30# MM-32R2-EL: .globl foo 31# MM-32R2-EL: 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 50 51 .globl foo 52 .ent foo 53foo: 54 lw $4,%lo(foo)($4) 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) 64 .space 64 65 .end foo 66