llvm/llvm/test/Transforms/InstCombine/RISCV/memcmp.ll

; RUN: opt %s -passes=instcombine -mtriple=riscv64-unknown-linux-gnu -S | FileCheck %s

declare signext i32 @memcmp(ptr, ptr, i64)

; Make sure we use signext attribute for the bcmp result.
define signext i32 @test_bcmp(ptr %mem1, ptr %mem2, i64 %size) {
; CHECK-LABEL: define {{[^@]+}}@test_bcmp(
; CHECK-NEXT:    [[BCMP:%.*]] = call i32 @bcmp(ptr [[MEM1:%.*]], ptr [[MEM2:%.*]], i64 [[SIZE:%.*]])
; CHECK-NEXT:    [[CMP:%.*]] = icmp eq i32 [[BCMP]], 0
; CHECK-NEXT:    [[ZEXT:%.*]] = zext i1 [[CMP]] to i32
; CHECK-NEXT:    ret i32 [[ZEXT]]
;
  %call = call signext i32 @memcmp(ptr %mem1, ptr %mem2, i64 %size)
  %cmp = icmp eq i32 %call, 0
  %zext = zext i1 %cmp to i32
  ret i32 %zext
}

; CHECK: declare signext i32 @bcmp(ptr nocapture, ptr nocapture, i64)