1*cfbb71dfSDaniel Sanders // RUN: %clang_cc1 %s -triple mips-unknown-linux-gnu -emit-llvm -o - | FileCheck %s 2*cfbb71dfSDaniel Sanders // 3*cfbb71dfSDaniel Sanders // Test that the ctlz and cttz builtins are defined for zero. 4*cfbb71dfSDaniel Sanders // Based on count-builtin.c 5*cfbb71dfSDaniel Sanders 6*cfbb71dfSDaniel Sanders int leading, trailing, pop; 7*cfbb71dfSDaniel Sanders test_i16(short P)8*cfbb71dfSDaniel Sandersvoid test_i16(short P) { 9*cfbb71dfSDaniel Sanders leading = __builtin_clzs(P); 10*cfbb71dfSDaniel Sanders trailing = __builtin_ctzs(P); 11*cfbb71dfSDaniel Sanders 12*cfbb71dfSDaniel Sanders // CHECK: @test_i16 13*cfbb71dfSDaniel Sanders // CHECK: call i16 @llvm.ctlz.i16(i16 {{.*}}, i1 false) 14*cfbb71dfSDaniel Sanders // CHECK: call i16 @llvm.cttz.i16(i16 {{.*}}, i1 false) 15*cfbb71dfSDaniel Sanders } 16*cfbb71dfSDaniel Sanders test_i32(int P)17*cfbb71dfSDaniel Sandersvoid test_i32(int P) { 18*cfbb71dfSDaniel Sanders leading = __builtin_clz(P); 19*cfbb71dfSDaniel Sanders trailing = __builtin_ctz(P); 20*cfbb71dfSDaniel Sanders 21*cfbb71dfSDaniel Sanders // CHECK: @test_i32 22*cfbb71dfSDaniel Sanders // CHECK: call i32 @llvm.ctlz.i32(i32 {{.*}}, i1 false) 23*cfbb71dfSDaniel Sanders // CHECK: call i32 @llvm.cttz.i32(i32 {{.*}}, i1 false) 24*cfbb71dfSDaniel Sanders } 25*cfbb71dfSDaniel Sanders test_i64(float P)26*cfbb71dfSDaniel Sandersvoid test_i64(float P) { 27*cfbb71dfSDaniel Sanders leading = __builtin_clzll(P); 28*cfbb71dfSDaniel Sanders trailing = __builtin_ctzll(P); 29*cfbb71dfSDaniel Sanders // CHECK: @test_i64 30*cfbb71dfSDaniel Sanders // CHECK: call i64 @llvm.ctlz.i64(i64 {{.*}}, i1 false) 31*cfbb71dfSDaniel Sanders // CHECK: call i64 @llvm.cttz.i64(i64 {{.*}}, i1 false) 32*cfbb71dfSDaniel Sanders } 33