Elad Cohen | b107a22 | 2016-09-28 11:59:09 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -ffreestanding -triple x86_64-unknown-unknown -emit-llvm -o - %s | FileCheck %s |
Michael Zuckerman | e54093f | 2016-06-01 12:21:00 +0000 | [diff] [blame] | 2 | |
Zvi Rackover | 064f000 | 2017-07-10 07:13:56 +0000 | [diff] [blame] | 3 | // PR33722 |
| 4 | // RUN: %clang_cc1 -ffreestanding -triple x86_64-unknown-unknown -D_MSC_VER -emit-llvm -o - %s | FileCheck %s |
| 5 | |
Michael Zuckerman | e54093f | 2016-06-01 12:21:00 +0000 | [diff] [blame] | 6 | #include <immintrin.h> |
| 7 | |
| 8 | int test_bit_scan_forward(int a) { |
| 9 | return _bit_scan_forward(a); |
| 10 | // CHECK: @test_bit_scan_forward |
David Majnemer | d423574 | 2016-06-13 17:26:16 +0000 | [diff] [blame] | 11 | // CHECK: %[[call:.*]] = call i32 @llvm.cttz.i32( |
| 12 | // CHECK: ret i32 %[[call]] |
Michael Zuckerman | e54093f | 2016-06-01 12:21:00 +0000 | [diff] [blame] | 13 | } |
| 14 | |
| 15 | int test_bit_scan_reverse(int a) { |
| 16 | return _bit_scan_reverse(a); |
David Majnemer | d423574 | 2016-06-13 17:26:16 +0000 | [diff] [blame] | 17 | // CHECK: %[[call:.*]] = call i32 @llvm.ctlz.i32( |
Artem Belevich | 6530a3e | 2016-06-13 18:44:22 +0000 | [diff] [blame] | 18 | // CHECK: %[[sub:.*]] = sub nsw i32 31, %[[call]] |
David Majnemer | d423574 | 2016-06-13 17:26:16 +0000 | [diff] [blame] | 19 | // CHECK: ret i32 %[[sub]] |
Michael Zuckerman | e54093f | 2016-06-01 12:21:00 +0000 | [diff] [blame] | 20 | } |