; NOTE: Assertions have been autogenerated by utils/update_test_checks.py ; RUN: opt -S -passes='require,function(codegenprepare)' < %s | FileCheck %s target triple = "riscv64-unknown-unknown" ; Check that despeculating count-zeros intrinsics doesn't crash when those ; intrinsics use scalable types. define @cttz_nxv4i64( %x) { ; CHECK-LABEL: @cttz_nxv4i64( ; CHECK-NEXT: [[Z:%.*]] = call @llvm.cttz.nxv4i64( [[X:%.*]], i1 false) ; CHECK-NEXT: ret [[Z]] ; %z = call @llvm.cttz.nxv4i64( %x, i1 false) ret %z } define @ctlz_nxv4i64( %x) { ; CHECK-LABEL: @ctlz_nxv4i64( ; CHECK-NEXT: [[Z:%.*]] = call @llvm.ctlz.nxv4i64( [[X:%.*]], i1 false) ; CHECK-NEXT: ret [[Z]] ; %z = call @llvm.ctlz.nxv4i64( %x, i1 false) ret %z } declare @llvm.cttz.nxv4i64(, i1) declare @llvm.ctlz.nxv4i64(, i1)