| ; RUN: opt < %s -mtriple=arm-unknown-linux-gnu -S -inline | FileCheck %s |
| ; RUN: opt < %s -mtriple=arm-unknown-linux-gnu -S -passes='cgscc(inline)' | FileCheck %s |
| ; Check that we only inline when we have compatible target attributes. |
| ; ARM has implemented a target attribute that will verify that the attribute |
| ; sets are compatible. |
| |
| define i32 @foo() #0 { |
| entry: |
| %call = call i32 (...) @baz() |
| ret i32 %call |
| ; CHECK-LABEL: foo |
| ; CHECK: call i32 (...) @baz() |
| } |
| declare i32 @baz(...) #0 |
| |
| define i32 @bar() #1 { |
| entry: |
| %call = call i32 @foo() |
| ret i32 %call |
| ; CHECK-LABEL: bar |
| ; CHECK: call i32 (...) @baz() |
| } |
| |
| define i32 @qux() #0 { |
| entry: |
| %call = call i32 @bar() |
| ret i32 %call |
| ; CHECK-LABEL: qux |
| ; CHECK: call i32 @bar() |
| } |
| |
| define i32 @thumb_fn() #2 { |
| entry: |
| %call = call i32 @foo() |
| ret i32 %call |
| ; CHECK-LABEL: thumb_fn |
| ; CHECK: call i32 @foo |
| } |
| |
| define i32 @strict_align() #3 { |
| entry: |
| %call = call i32 @foo() |
| ret i32 %call |
| ; CHECK-LABEL: strict_align |
| ; CHECK: call i32 (...) @baz() |
| } |
| |
| define i32 @soft_float_fn() #4 { |
| entry: |
| %call = call i32 @foo() |
| ret i32 %call |
| ; CHECK-LABEL: soft_float_fn |
| ; CHECK: call i32 @foo |
| } |
| |
| attributes #0 = { "target-cpu"="generic" "target-features"="+dsp,+neon" } |
| attributes #1 = { "target-cpu"="generic" "target-features"="+dsp,+neon,+fp16" } |
| attributes #2 = { "target-cpu"="generic" "target-features"="+dsp,+neon,+fp16,+thumb-mode" } |
| attributes #3 = { "target-cpu"="generic" "target-features"="+dsp,+neon,+strict-align" } |
| attributes #4 = { "target-cpu"="generic" "target-features"="+dsp,+neon,+fp16,+soft-float" } |