Hal Finkel | bcc0608 | 2014-09-07 22:58:14 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -triple x86_64-unknown-unknown -emit-llvm -o - %s | FileCheck %s |
| 2 | |
| 3 | // CHECK-LABEL: @test1 |
| 4 | int test1(int *a) { |
NAKAMURA Takumi | 4b04c11 | 2014-09-08 01:12:55 +0000 | [diff] [blame^] | 5 | // CHECK: [[PTRINT1:%.+]] = ptrtoint |
| 6 | // CHECK: [[MASKEDPTR1:%.+]] = and i64 [[PTRINT1]], 31 |
| 7 | // CHECK: [[MASKCOND1:%.+]] = icmp eq i64 [[MASKEDPTR1]], 0 |
| 8 | // CHECK: call void @llvm.assume(i1 [[MASKCOND1]]) |
Hal Finkel | bcc0608 | 2014-09-07 22:58:14 +0000 | [diff] [blame] | 9 | a = __builtin_assume_aligned(a, 32, 0ull); |
| 10 | return a[0]; |
| 11 | } |
| 12 | |
| 13 | // CHECK-LABEL: @test2 |
| 14 | int test2(int *a) { |
NAKAMURA Takumi | 4b04c11 | 2014-09-08 01:12:55 +0000 | [diff] [blame^] | 15 | // CHECK: [[PTRINT2:%.+]] = ptrtoint |
| 16 | // CHECK: [[MASKEDPTR2:%.+]] = and i64 [[PTRINT2]], 31 |
| 17 | // CHECK: [[MASKCOND2:%.+]] = icmp eq i64 [[MASKEDPTR2]], 0 |
| 18 | // CHECK: call void @llvm.assume(i1 [[MASKCOND2]]) |
Hal Finkel | bcc0608 | 2014-09-07 22:58:14 +0000 | [diff] [blame] | 19 | a = __builtin_assume_aligned(a, 32, 0); |
| 20 | return a[0]; |
| 21 | } |
| 22 | |
| 23 | // CHECK-LABEL: @test3 |
| 24 | int test3(int *a) { |
NAKAMURA Takumi | 4b04c11 | 2014-09-08 01:12:55 +0000 | [diff] [blame^] | 25 | // CHECK: [[PTRINT3:%.+]] = ptrtoint |
| 26 | // CHECK: [[MASKEDPTR3:%.+]] = and i64 [[PTRINT3]], 31 |
| 27 | // CHECK: [[MASKCOND3:%.+]] = icmp eq i64 [[MASKEDPTR3]], 0 |
| 28 | // CHECK: call void @llvm.assume(i1 [[MASKCOND3]]) |
Hal Finkel | bcc0608 | 2014-09-07 22:58:14 +0000 | [diff] [blame] | 29 | a = __builtin_assume_aligned(a, 32); |
| 30 | return a[0]; |
| 31 | } |
| 32 | |
| 33 | // CHECK-LABEL: @test4 |
| 34 | int test4(int *a, int b) { |
NAKAMURA Takumi | 4b04c11 | 2014-09-08 01:12:55 +0000 | [diff] [blame^] | 35 | // CHECK-DAG: [[PTRINT4:%.+]] = ptrtoint |
| 36 | // CHECK-DAG: [[CONV4:%.+]] = sext i32 |
| 37 | // CHECK: [[OFFSETPTR4:%.+]] = sub i64 [[PTRINT4]], [[CONV4]] |
| 38 | // CHECK: [[MASKEDPTR4:%.+]] = and i64 [[OFFSETPTR4]], 31 |
| 39 | // CHECK: [[MASKCOND4:%.+]] = icmp eq i64 [[MASKEDPTR4]], 0 |
| 40 | // CHECK: call void @llvm.assume(i1 [[MASKCOND4]]) |
Hal Finkel | bcc0608 | 2014-09-07 22:58:14 +0000 | [diff] [blame] | 41 | a = __builtin_assume_aligned(a, 32, b); |
| 42 | return a[0]; |
| 43 | } |
| 44 | |