annotate llvm/test/Transforms/CodeGenPrepare/X86/sink-addrspacecast.ll @ 173:0572611fdcc8 llvm10 llvm12

reorgnization done
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 11:55:54 +0900
parents 1d019706d866
children 1f2b6ac9f198
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 ; RUN: opt -S -codegenprepare < %s | FileCheck %s -check-prefix=CHECK -check-prefix=GEP
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 target datalayout =
anatofuz
parents:
diff changeset
4 "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
anatofuz
parents:
diff changeset
5 target triple = "x86_64-unknown-linux-gnu"
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 ; CHECK-LABEL: @load_cast_gep
anatofuz
parents:
diff changeset
8 ; GEP: [[CAST:%[0-9]+]] = addrspacecast i64* %base to i8 addrspace(1)*
anatofuz
parents:
diff changeset
9 ; GEP: getelementptr inbounds i8, i8 addrspace(1)* [[CAST]], i64 40
anatofuz
parents:
diff changeset
10 define void @load_cast_gep(i1 %cond, i64* %base) {
anatofuz
parents:
diff changeset
11 entry:
anatofuz
parents:
diff changeset
12 %addr = getelementptr inbounds i64, i64* %base, i64 5
anatofuz
parents:
diff changeset
13 %casted = addrspacecast i64* %addr to i32 addrspace(1)*
anatofuz
parents:
diff changeset
14 br i1 %cond, label %if.then, label %fallthrough
anatofuz
parents:
diff changeset
15
anatofuz
parents:
diff changeset
16 if.then:
anatofuz
parents:
diff changeset
17 %v = load i32, i32 addrspace(1)* %casted, align 4
anatofuz
parents:
diff changeset
18 br label %fallthrough
anatofuz
parents:
diff changeset
19
anatofuz
parents:
diff changeset
20 fallthrough:
anatofuz
parents:
diff changeset
21 ret void
anatofuz
parents:
diff changeset
22 }
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 ; CHECK-LABEL: @store_gep_cast
anatofuz
parents:
diff changeset
25 ; GEP: [[CAST:%[0-9]+]] = addrspacecast i64* %base to i8 addrspace(1)*
anatofuz
parents:
diff changeset
26 ; GEP: getelementptr inbounds i8, i8 addrspace(1)* [[CAST]], i64 20
anatofuz
parents:
diff changeset
27 define void @store_gep_cast(i1 %cond, i64* %base) {
anatofuz
parents:
diff changeset
28 entry:
anatofuz
parents:
diff changeset
29 %casted = addrspacecast i64* %base to i32 addrspace(1)*
anatofuz
parents:
diff changeset
30 %addr = getelementptr inbounds i32, i32 addrspace(1)* %casted, i64 5
anatofuz
parents:
diff changeset
31 br i1 %cond, label %if.then, label %fallthrough
anatofuz
parents:
diff changeset
32
anatofuz
parents:
diff changeset
33 if.then:
anatofuz
parents:
diff changeset
34 store i32 0, i32 addrspace(1)* %addr, align 4
anatofuz
parents:
diff changeset
35 br label %fallthrough
anatofuz
parents:
diff changeset
36
anatofuz
parents:
diff changeset
37 fallthrough:
anatofuz
parents:
diff changeset
38 ret void
anatofuz
parents:
diff changeset
39 }