| ; 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) |