148 lines
4.4 KiB
C
148 lines
4.4 KiB
C
// 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;
|
|
}
|