Files
clang-p2996/llvm/test/CodeGen/SystemZ/llxa-01.ll
Ulrich Weigand 80267f8148 Support z17 processor name and scheduler description (#135254)
The recently announced IBM z17 processor implements the architecture
already supported as "arch15" in LLVM. This patch adds support for "z17"
as an alternate architecture name for arch15.

This patch also add the scheduler description for the z17 processor,
provided by Jonas Paulsson.
2025-04-11 00:20:58 +02:00

99 lines
2.8 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
; Test use of LOAD LOGICAL INDEXED ADDRESS byte instructions.
;
; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z17 | FileCheck %s
; DO NOT USE: LLXAB with base and index.
define dso_local ptr @f0(ptr %ptr, i32 %idx) {
; CHECK-LABEL: f0:
; CHECK: # %bb.0:
; CHECK-NEXT: algfr %r2, %r3
; CHECK-NEXT: br %r14
%idxprom = zext i32 %idx to i64
%arrayidx = getelementptr inbounds i8, ptr %ptr, i64 %idxprom
ret ptr %arrayidx
}
; DO NOT USE: LLXAB with base and index (implied extension).
define dso_local ptr @f1(ptr %ptr, i32 zeroext %idx) {
; CHECK-LABEL: f1:
; CHECK: # %bb.0:
; CHECK-NEXT: agr %r2, %r3
; CHECK-NEXT: br %r14
%idxprom = zext i32 %idx to i64
%arrayidx = getelementptr inbounds i8, ptr %ptr, i64 %idxprom
ret ptr %arrayidx
}
; LLXAB with base and index and max displacement.
define dso_local ptr @f2(ptr %ptr, i32 %idx) {
; CHECK-LABEL: f2:
; CHECK: # %bb.0:
; CHECK-NEXT: llxab %r2, 524287(%r3,%r2)
; CHECK-NEXT: br %r14
%idxoff = add i32 %idx, 524287
%idxprom = zext i32 %idxoff to i64
%arrayidx = getelementptr inbounds i8, ptr %ptr, i64 %idxprom
ret ptr %arrayidx
}
; LLXAB with base and index and min displacement.
define dso_local ptr @f3(ptr %ptr, i32 %idx) {
; CHECK-LABEL: f3:
; CHECK: # %bb.0:
; CHECK-NEXT: llxab %r2, -524288(%r3,%r2)
; CHECK-NEXT: br %r14
%idxoff = add i32 %idx, -524288
%idxprom = zext i32 %idxoff to i64
%arrayidx = getelementptr inbounds i8, ptr %ptr, i64 %idxprom
ret ptr %arrayidx
}
; DO NOT USE: LLXAB with base and index and max displacement overflow.
define dso_local ptr @f4(ptr %ptr, i32 %idx) {
; CHECK-LABEL: f4:
; CHECK: # %bb.0:
; CHECK-NEXT: afi %r3, 524288
; CHECK-NEXT: algfr %r2, %r3
; CHECK-NEXT: br %r14
%idxoff = add i32 %idx, 524288
%idxprom = zext i32 %idxoff to i64
%arrayidx = getelementptr inbounds i8, ptr %ptr, i64 %idxprom
ret ptr %arrayidx
}
; DO NOT USE: LLXAB with base and index and min displacement overflow.
define dso_local ptr @f5(ptr %ptr, i32 %idx) {
; CHECK-LABEL: f5:
; CHECK: # %bb.0:
; CHECK-NEXT: afi %r3, -524289
; CHECK-NEXT: algfr %r2, %r3
; CHECK-NEXT: br %r14
%idxoff = add i32 %idx, -524289
%idxprom = zext i32 %idxoff to i64
%arrayidx = getelementptr inbounds i8, ptr %ptr, i64 %idxprom
ret ptr %arrayidx
}
; DO NOT USE: LLXAB with index.
define dso_local i64 @f6(i32 %idx) {
; CHECK-LABEL: f6:
; CHECK: # %bb.0:
; CHECK-NEXT: llgfr %r2, %r2
; CHECK-NEXT: br %r14
%idxprom = zext i32 %idx to i64
ret i64 %idxprom
}
; LLXAB with index and displacement.
define dso_local i64 @f7(i32 %idx) {
; CHECK-LABEL: f7:
; CHECK: # %bb.0:
; CHECK-NEXT: llxab %r2, 1(%r2,0)
; CHECK-NEXT: br %r14
%idxoff = add i32 %idx, 1
%idxprom = zext i32 %idxoff to i64
ret i64 %idxprom
}