| ; Test strcmp using CLST, i32 version. |
| ; |
| ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s |
| |
| declare signext i32 @strcmp(i8 *%src1, i8 *%src2) |
| |
| ; Check a case where the result is used as an integer. |
| define i32 @f1(i8 *%src1, i8 *%src2) { |
| ; CHECK-LABEL: f1: |
| ; CHECK: lhi %r0, 0 |
| ; CHECK: [[LABEL:\.[^:]*]]: |
| ; CHECK: clst %r2, %r3 |
| ; CHECK-NEXT: jo [[LABEL]] |
| ; CHECK-NEXT: %bb.{{[0-9]+}} |
| ; CHECK-NEXT: ipm [[REG:%r[0-5]]] |
| ; CHECK: srl [[REG]], 28 |
| ; CHECK: rll %r2, [[REG]], 31 |
| ; CHECK: br %r14 |
| %res = call i32 @strcmp(i8 *%src1, i8 *%src2) |
| ret i32 %res |
| } |
| |
| ; Check a case where the result is tested for equality. |
| define void @f2(i8 *%src1, i8 *%src2, i32 *%dest) { |
| ; CHECK-LABEL: f2: |
| ; CHECK: lhi %r0, 0 |
| ; CHECK: [[LABEL:\.[^:]*]]: |
| ; CHECK: clst %r2, %r3 |
| ; CHECK-NEXT: jo [[LABEL]] |
| ; CHECK-NEXT: %bb.{{[0-9]+}} |
| ; CHECK-NEXT: ber %r14 |
| ; CHECK: br %r14 |
| %res = call i32 @strcmp(i8 *%src1, i8 *%src2) |
| %cmp = icmp eq i32 %res, 0 |
| br i1 %cmp, label %exit, label %store |
| |
| store: |
| store i32 0, i32 *%dest |
| br label %exit |
| |
| exit: |
| ret void |
| } |
| |
| ; Test a case where the result is used both as an integer and for |
| ; branching. |
| define i32 @f3(i8 *%src1, i8 *%src2, i32 *%dest) { |
| ; CHECK-LABEL: f3: |
| ; CHECK: lhi %r0, 0 |
| ; CHECK: [[LABEL:\.[^:]*]]: |
| ; CHECK: clst %r2, %r3 |
| ; CHECK-NEXT: jo [[LABEL]] |
| ; CHECK-NEXT: %bb.{{[0-9]+}} |
| ; CHECK-NEXT: ipm [[REG:%r[0-5]]] |
| ; CHECK: srl [[REG]], 28 |
| ; CHECK: rll %r2, [[REG]], 31 |
| ; CHECK: blr %r14 |
| ; CHECK: br %r14 |
| entry: |
| %res = call i32 @strcmp(i8 *%src1, i8 *%src2) |
| %cmp = icmp slt i32 %res, 0 |
| br i1 %cmp, label %exit, label %store |
| |
| store: |
| store i32 0, i32 *%dest |
| br label %exit |
| |
| exit: |
| ret i32 %res |
| } |