blob: 79c36b07e4908d19ab45dc5c47ee2b9884278f5e [file] [log] [blame]
Justin Hibbitsa88b6052014-11-12 15:16:30 +00001; RUN: llc < %s -mtriple=powerpc-unknown-linux-gnu -relocation-model=pic | FileCheck -check-prefix=SMALL-BSS %s
2@bar = common global i32 0, align 4
Hal Finkel3ee2af72014-07-18 23:29:49 +00003
Justin Hibbits654346e2015-01-10 01:57:21 +00004declare i32 @call_foo(i32, ...)
5
Hal Finkel3ee2af72014-07-18 23:29:49 +00006define i32 @foo() {
7entry:
David Blaikiea79ac142015-02-27 21:17:42 +00008 %0 = load i32, i32* @bar, align 4
David Blaikie23af6482015-04-16 23:24:18 +00009 %call = call i32 (i32, ...) @call_foo(i32 %0, i32 0, i32 1, i32 2, i32 4, i32 8, i32 16, i32 32, i32 64)
Justin Hibbits654346e2015-01-10 01:57:21 +000010 ret i32 0
Hal Finkel3ee2af72014-07-18 23:29:49 +000011}
12
Justin Hibbitsa88b6052014-11-12 15:16:30 +000013!llvm.module.flags = !{!0}
Duncan P. N. Exon Smithbe7ea192014-12-15 19:07:53 +000014!0 = !{i32 1, !"PIC Level", i32 1}
Justin Hibbitsa88b6052014-11-12 15:16:30 +000015; SMALL-BSS-LABEL:foo:
Justin Hibbits654346e2015-01-10 01:57:21 +000016; SMALL-BSS: stwu 1, -32(1)
Krzysztof Parzyszek020ec292016-09-06 12:30:00 +000017; SMALL-BSS: stw 30, 24(1)
Justin Hibbitsa88b6052014-11-12 15:16:30 +000018; SMALL-BSS: bl _GLOBAL_OFFSET_TABLE_@local-4
19; SMALL-BSS: mflr 30
Justin Hibbits654346e2015-01-10 01:57:21 +000020; SMALL-BSS-DAG: stw {{[0-9]+}}, 8(1)
21; SMALL-BSS-DAG: lwz [[VREG:[0-9]+]], bar@GOT(30)
Justin Hibbits98a532d2015-01-08 15:47:19 +000022; SMALL-BSS-DAG: lwz {{[0-9]+}}, 0([[VREG]])
Justin Hibbits654346e2015-01-10 01:57:21 +000023; SMALL-BSS: bl call_foo@PLT
Krzysztof Parzyszekb66efb82016-09-22 17:22:43 +000024; SMALL-BSS: lwz 30, 24(1)