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