blob: 95dd58f513cc7535351939bf6b0590c7ded7b109 [file] [log] [blame]
Ehsan Amiria538b0f2016-08-03 18:17:35 +00001; RUN: llc -verify-machineinstrs %s -mtriple=powerpc64-unknown-linux-gnu -O2 -o - -optimize-regalloc=false -regalloc=fast | FileCheck %s
Chuang-Yu Cheng35c61812016-04-01 02:05:29 +00002
3declare void @func(i8*, i64, i64)
4
5define void @test(i8* %context, i32** %elementArrayPtr, i32 %value) {
6entry:
7 %cmp = icmp eq i32 %value, 0
8 br i1 %cmp, label %lreturn, label %lnext
9
10lnext:
11 %elementArray = load i32*, i32** %elementArrayPtr, align 8
12; CHECK: lwz [[LDREG:[0-9]+]], 124(1) # 4-byte Folded Reload
Puyan Lotfi43e94b12018-01-31 22:04:26 +000013; CHECK: # implicit-def: $x[[TEMPREG:[0-9]+]]
Chuang-Yu Cheng35c61812016-04-01 02:05:29 +000014 %element = load i32, i32* %elementArray, align 4
15; CHECK: mr [[TEMPREG]], [[LDREG]]
16; CHECK: clrldi 4, [[TEMPREG]], 32
17 %element.ext = zext i32 %element to i64
18 %value.ext = zext i32 %value to i64
19 call void @func(i8* %context, i64 %value.ext, i64 %element.ext)
20 br label %lreturn
21
22lreturn:
23 ret void
24}