annotate llvm/test/Transforms/GlobalOpt/naked_functions.ll @ 252:1f2b6ac9f198 llvm-original

LLVM16-1
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 18 Aug 2023 09:04:13 +0900
parents c4bab56944e8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
c4bab56944e8 LLVM 16
kono
parents: 150
diff changeset
1 ; RUN: opt < %s -passes=globalopt -S | FileCheck %s
150
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 ; Check that naked functions don't get marked with fast calling conventions
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 @g = common global i32 0, align 4
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 define i32 @bar() {
anatofuz
parents:
diff changeset
8 entry:
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
9 %call = call i32 @foo(ptr @g)
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
10 ; CHECK: %call = call i32 @foo(ptr @g)
150
anatofuz
parents:
diff changeset
11 ret i32 %call
anatofuz
parents:
diff changeset
12 }
anatofuz
parents:
diff changeset
13
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
14 define internal i32 @foo(ptr) #0 {
150
anatofuz
parents:
diff changeset
15 entry:
anatofuz
parents:
diff changeset
16 %retval = alloca i32, align 4
anatofuz
parents:
diff changeset
17 call void asm sideeffect "ldr r0, [r0] \0Abx lr \0A", ""()
anatofuz
parents:
diff changeset
18 unreachable
anatofuz
parents:
diff changeset
19 }
anatofuz
parents:
diff changeset
20
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
21 ; CHECK: define internal i32 @foo(ptr %0)
150
anatofuz
parents:
diff changeset
22
anatofuz
parents:
diff changeset
23 attributes #0 = { naked }