; RUN: llc -mtriple=arm64--- -stop-after=finalize-isel -o - %s | FileCheck %s ; Check that we ignore the zeroext attribute on the return type of the tail ; call, since the return value is unused. This happens during CodeGenPrepare in ; dupRetToEnableTailCallOpts, which calls attributesPermitTailCall to check if ; the attributes of the caller and the callee match. declare zeroext i1 @zcallee() define void @zcaller() { ; CHECK-LABEL: name: zcaller entry: br i1 undef, label %calllabel, label %retlabel calllabel: ; CHECK: bb.1.calllabel: ; CHECK-NOT: BL @zcallee ; CHECK-NEXT: TCRETURNdi @zcallee %unused_result = tail call zeroext i1 @zcallee() br label %retlabel retlabel: ret void } declare signext i1 @scallee() define void @scaller() { ; CHECK-LABEL: name: scaller entry: br i1 undef, label %calllabel, label %retlabel calllabel: ; CHECK: bb.1.calllabel: ; CHECK-NOT: BL @scallee ; CHECK-NEXT: TCRETURNdi @scallee %unused_result = tail call signext i1 @scallee() br label %retlabel retlabel: ret void }