// RUN: %clang_cc1 -triple s390x-linux-gnu -O2 -emit-llvm \ // RUN: -o - %s 2>&1 | FileCheck %s // REQUIRES: systemz-registered-target long *A; long Idx; unsigned long Addr; unsigned long fun_BD12_Q() { // CHECK-LABEL: define{{.*}} i64 @fun_BD12_Q() // CHECK: call i64 asm "lay $0, $1", "=r,^ZQ"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZQ" (&A[100])); return Addr; } unsigned long fun_BD12_R() { // CHECK-LABEL: define{{.*}} i64 @fun_BD12_R() // CHECK: call i64 asm "lay $0, $1", "=r,^ZR"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZR" (&A[100])); return Addr; } unsigned long fun_BD12_S() { // CHECK-LABEL: define{{.*}} i64 @fun_BD12_S() // CHECK: call i64 asm "lay $0, $1", "=r,^ZS"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZS" (&A[100])); return Addr; } unsigned long fun_BD12_T() { // CHECK-LABEL: define{{.*}} i64 @fun_BD12_T() // CHECK: call i64 asm "lay $0, $1", "=r,^ZT"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZT" (&A[100])); return Addr; } unsigned long fun_BD12_p() { // CHECK-LABEL: define{{.*}} i64 @fun_BD12_p() // CHECK: call i64 asm "lay $0, $1", "=r,p"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "p" (&A[100])); return Addr; } unsigned long fun_BDX12_Q() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX12_Q() // CHECK: call i64 asm "lay $0, $1", "=r,^ZQ"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZQ" (&A[Idx + 100])); return Addr; } unsigned long fun_BDX12_R() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX12_R() // CHECK: call i64 asm "lay $0, $1", "=r,^ZR"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZR" (&A[Idx + 100])); return Addr; } unsigned long fun_BDX12_S() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX12_S() // CHECK: call i64 asm "lay $0, $1", "=r,^ZS"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZS" (&A[Idx + 100])); return Addr; } unsigned long fun_BDX12_T() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX12_T() // CHECK: call i64 asm "lay $0, $1", "=r,^ZT"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZT" (&A[Idx + 100])); return Addr; } unsigned long fun_BDX12_p() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX12_p() // CHECK: call i64 asm "lay $0, $1", "=r,p"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "p" (&A[Idx + 100])); return Addr; } unsigned long fun_BD20_Q() { // CHECK-LABEL: define{{.*}} i64 @fun_BD20_Q() // CHECK: call i64 asm "lay $0, $1", "=r,^ZQ"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZQ" (&A[1000])); return Addr; } unsigned long fun_BD20_R() { // CHECK-LABEL: define{{.*}} i64 @fun_BD20_R() // CHECK: call i64 asm "lay $0, $1", "=r,^ZR"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZR" (&A[1000])); return Addr; } unsigned long fun_BD20_S() { // CHECK-LABEL: define{{.*}} i64 @fun_BD20_S() // CHECK: call i64 asm "lay $0, $1", "=r,^ZS"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZS" (&A[1000])); return Addr; } unsigned long fun_BD20_T() { // CHECK-LABEL: define{{.*}} i64 @fun_BD20_T() // CHECK: call i64 asm "lay $0, $1", "=r,^ZT"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZT" (&A[1000])); return Addr; } unsigned long fun_BD20_p() { // CHECK-LABEL: define{{.*}} i64 @fun_BD20_p() // CHECK: call i64 asm "lay $0, $1", "=r,p"(ptr nonnull %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "p" (&A[1000])); return Addr; } unsigned long fun_BDX20_Q() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX20_Q() // CHECK: call i64 asm "lay $0, $1", "=r,^ZQ"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZQ" (&A[Idx + 1000])); return Addr; } unsigned long fun_BDX20_R() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX20_R() // CHECK: call i64 asm "lay $0, $1", "=r,^ZR"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZR" (&A[Idx + 1000])); return Addr; } unsigned long fun_BDX20_S() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX20_S() // CHECK: call i64 asm "lay $0, $1", "=r,^ZS"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZS" (&A[Idx + 1000])); return Addr; } unsigned long fun_BDX20_T() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX20_T() // CHECK: call i64 asm "lay $0, $1", "=r,^ZT"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "ZT" (&A[Idx + 1000])); return Addr; } unsigned long fun_BDX20_p() { // CHECK-LABEL: define{{.*}} i64 @fun_BDX20_p() // CHECK: call i64 asm "lay $0, $1", "=r,p"(ptr %arrayidx) asm("lay %0, %1" : "=r" (Addr) : "p" (&A[Idx + 1000])); return Addr; }