blob: d5a2541eb7763505cdb66c51f62339ad707b5354 [file] [log] [blame]
Peter Collingbourne020ce3f2019-01-23 22:39:11 +00001; RUN: opt -S -hwasan -hwasan-allow-ifunc < %s | FileCheck %s
Peter Collingbourne87f477b2019-01-04 19:27:04 +00002
Peter Collingbourne020ce3f2019-01-23 22:39:11 +00003target triple = "aarch64--linux-android"
Peter Collingbourne87f477b2019-01-04 19:27:04 +00004
Peter Collingbourne1a8acfb2019-01-25 02:08:46 +00005declare i32 @bar([16 x i32]* %p)
Peter Collingbourne87f477b2019-01-04 19:27:04 +00006
Peter Collingbourne020ce3f2019-01-23 22:39:11 +00007define void @alloca() sanitize_hwaddress "hwasan-abi"="interceptor" {
Peter Collingbourne1a8acfb2019-01-25 02:08:46 +00008 ; CHECK: alloca [16 x i32]
Peter Collingbourne020ce3f2019-01-23 22:39:11 +00009 ; CHECK: [[A:%[^ ]*]] = call i8* @llvm.thread.pointer()
10 ; CHECK: [[B:%[^ ]*]] = getelementptr i8, i8* [[A]], i32 48
11 ; CHECK: [[C:%[^ ]*]] = bitcast i8* [[B]] to i64*
12 ; CHECK: [[LOAD:%[^ ]*]] = load i64, i64* [[C]]
Peter Collingbourne87f477b2019-01-04 19:27:04 +000013 ; CHECK: [[ICMP:%[^ ]*]] = icmp eq i64 [[LOAD]], 0
14 ; CHECK: br i1 [[ICMP]], label %[[INIT:[^,]*]], label %[[CONT:[^,]*]], !prof [[PROF:![0-9]+]]
15
16 ; CHECK: [[INIT]]:
17 ; CHECK: call void @__hwasan_thread_enter()
Peter Collingbourne020ce3f2019-01-23 22:39:11 +000018 ; CHECK: [[RELOAD:%[^ ]*]] = load i64, i64* [[C]]
Peter Collingbourne87f477b2019-01-04 19:27:04 +000019 ; CHECK: br label %[[CONT]]
20
21 ; CHECK: [[CONT]]:
22 ; CHECK: phi i64 [ [[LOAD]], %0 ], [ [[RELOAD]], %[[INIT]] ]
Peter Collingbourne1a8acfb2019-01-25 02:08:46 +000023 ; CHECK: alloca i8
Peter Collingbourne87f477b2019-01-04 19:27:04 +000024
25 %p = alloca [16 x i32]
Peter Collingbourne1a8acfb2019-01-25 02:08:46 +000026 %size = call i32 @bar([16 x i32]* %p)
27 %q = alloca i8, i32 %size
Peter Collingbourne87f477b2019-01-04 19:27:04 +000028 ret void
29}
30
Peter Collingbourne020ce3f2019-01-23 22:39:11 +000031define i32 @load(i32* %p) sanitize_hwaddress "hwasan-abi"="interceptor" {
32 ; CHECK: [[SHADOW:%[^ ]*]] = call i8* asm "", "=r,0"([0 x i8]* @__hwasan_shadow)
33 ; CHECK-NOT: icmp
34 ; CHECK: call void @llvm.hwasan.check.memaccess(i8* [[SHADOW]],
35 %v = load i32, i32* %p
36 ret i32 %v
37}
38
Peter Collingbourne87f477b2019-01-04 19:27:04 +000039; CHECK: [[PROF]] = !{!"branch_weights", i32 1, i32 100000}