diff options
Diffstat (limited to 'test/CodeGen/Mips/tls.ll')
-rw-r--r-- | test/CodeGen/Mips/tls.ll | 32 |
1 files changed, 17 insertions, 15 deletions
diff --git a/test/CodeGen/Mips/tls.ll b/test/CodeGen/Mips/tls.ll index b86d25e..d83edfd 100644 --- a/test/CodeGen/Mips/tls.ll +++ b/test/CodeGen/Mips/tls.ll @@ -13,14 +13,14 @@ entry: %tmp = load i32* @t1, align 4 ret i32 %tmp -; CHECK: f1: - -; PIC: addu $[[R0:[a-z0-9]+]], $2, $25 -; PIC: lw $25, %call16(__tls_get_addr)($[[R0]]) -; PIC: addiu $4, $[[R0]], %tlsgd(t1) -; PIC: jalr $25 -; PIC: lw $2, 0($2) - +; PIC: f1: +; PIC-DAG: addu $[[R0:[a-z0-9]+]], $2, $25 +; PIC-DAG: lw $25, %call16(__tls_get_addr)($[[R0]]) +; PIC-DAG: addiu $4, $[[R0]], %tlsgd(t1) +; PIC-DAG: jalr $25 +; PIC-DAG: lw $2, 0($2) + +; STATIC: f1: ; STATIC: lui $[[R0:[0-9]+]], %tprel_hi(t1) ; STATIC: addiu $[[R1:[0-9]+]], $[[R0]], %tprel_lo(t1) ; STATIC: rdhwr $3, $29 @@ -36,17 +36,19 @@ entry: %tmp = load i32* @t2, align 4 ret i32 %tmp -; CHECK: f2: - -; PIC: addu $[[R0:[a-z0-9]+]], $2, $25 -; PIC: lw $25, %call16(__tls_get_addr)($[[R0]]) -; PIC: addiu $4, $[[R0]], %tlsgd(t2) -; PIC: jalr $25 -; PIC: lw $2, 0($2) +; PIC: f2: +; PIC-DAG: addu $[[R0:[a-z0-9]+]], $2, $25 +; PIC-DAG: lw $25, %call16(__tls_get_addr)($[[R0]]) +; PIC-DAG: addiu $4, $[[R0]], %tlsgd(t2) +; PIC-DAG: jalr $25 +; PIC-DAG: lw $2, 0($2) +; STATICGP: f2: ; STATICGP: lui $[[R0:[0-9]+]], %hi(__gnu_local_gp) ; STATICGP: addiu $[[GP:[0-9]+]], $[[R0]], %lo(__gnu_local_gp) ; STATICGP: lw ${{[0-9]+}}, %gottprel(t2)($[[GP]]) + +; STATIC: f2: ; STATIC: lui $[[R0:[0-9]+]], %hi(__gnu_local_gp) ; STATIC: addiu $[[GP:[0-9]+]], $[[R0]], %lo(__gnu_local_gp) ; STATIC: rdhwr $3, $29 |