blob: c57a9d6b3378affa6e63321fdf27838cc01f3056 [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z16 | FileCheck %s
;
; Test passing vector arguments per the ABI for z16 (with vector support).
; The function names codify the element type and the size of the vector in
; bytes, just like in the clang test systemz-abi-vector.c
@global_char_1 = global <1 x i8> zeroinitializer, align 2
@global_char_8 = global <8 x i8> zeroinitializer, align 8
@global_char_16 = global <16 x i8> zeroinitializer, align 8
@global_char_32 = global <32 x i8> zeroinitializer, align 8
@global_short_2 = global <1 x i16> zeroinitializer, align 2
@global_short_8 = global <4 x i16> zeroinitializer, align 8
@global_short_16 = global <8 x i16> zeroinitializer, align 8
@global_int_4 = global <1 x i32> zeroinitializer, align 4
@global_int_8 = global <2 x i32> zeroinitializer, align 8
@global_int_16 = global <4 x i32> zeroinitializer, align 8
@global_int_32 = global <8 x i32> zeroinitializer, align 8
@global_long_8 = global <1 x i64> zeroinitializer, align 8
@global_long_16 = global <2 x i64> zeroinitializer, align 8
@global___int128_16 = global <1 x i128> zeroinitializer, align 8
@global___int128_32 = global <2 x i128> zeroinitializer, align 8
@global__Float16_2 = global <1 x half> zeroinitializer, align 2
@global__Float16_8 = global <4 x half> zeroinitializer, align 8
@global__Float16_16 = global <8 x half> zeroinitializer, align 8
@global__Float16_32 = global <16 x half> zeroinitializer, align 8
@global_float_4 = global <1 x float> zeroinitializer, align 4
@global_float_8 = global <2 x float> zeroinitializer, align 8
@global_float_16 = global <4 x float> zeroinitializer, align 8
@global_double_8 = global <1 x double> zeroinitializer, align 8
@global_double_16 = global <2 x double> zeroinitializer, align 8
@global_double_32 = global <4 x double> zeroinitializer, align 8
@global_long_double_16 = global <1 x fp128> zeroinitializer, align 8
@global_long_double_32 = global <2 x fp128> zeroinitializer, align 8
define void @takeAndStore_char_1(<1 x i8> noundef %x) {
; CHECK-LABEL: takeAndStore_char_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_1@GOT
; CHECK-NEXT: vsteb %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <1 x i8> %x, ptr @global_char_1, align 2
ret void
}
define void @takeAndStore_char_8(<8 x i8> noundef %x) {
; CHECK-LABEL: takeAndStore_char_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <8 x i8> %x, ptr @global_char_8, align 8
ret void
}
define void @takeAndStore_char_16(<16 x i8> noundef %x) {
; CHECK-LABEL: takeAndStore_char_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <16 x i8> %x, ptr @global_char_16, align 8
ret void
}
define void @takeAndStore_char_32(ptr noundef readonly captures(none) dead_on_return %0) {
; CHECK-LABEL: takeAndStore_char_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: vl %v0, 0(%r2), 3
; CHECK-NEXT: vl %v1, 16(%r2), 3
; CHECK-NEXT: lgrl %r1, global_char_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%x = load <32 x i8>, ptr %0, align 8
store <32 x i8> %x, ptr @global_char_32, align 8
ret void
}
define void @takeAndStore_short_2(<1 x i16> noundef %x) {
; CHECK-LABEL: takeAndStore_short_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_2@GOT
; CHECK-NEXT: vsteh %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <1 x i16> %x, ptr @global_short_2, align 2
ret void
}
define void @takeAndStore_short_8(<4 x i16> noundef %x) {
; CHECK-LABEL: takeAndStore_short_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <4 x i16> %x, ptr @global_short_8, align 8
ret void
}
define void @takeAndStore_short_16(<8 x i16> noundef %x) {
; CHECK-LABEL: takeAndStore_short_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <8 x i16> %x, ptr @global_short_16, align 8
ret void
}
define void @takeAndStore_int_4(<1 x i32> noundef %x) {
; CHECK-LABEL: takeAndStore_int_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_4@GOT
; CHECK-NEXT: vstef %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <1 x i32> %x, ptr @global_int_4, align 4
ret void
}
define void @takeAndStore_int_8(<2 x i32> noundef %x) {
; CHECK-LABEL: takeAndStore_int_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <2 x i32> %x, ptr @global_int_8, align 8
ret void
}
define void @takeAndStore_int_16(<4 x i32> noundef %x) {
; CHECK-LABEL: takeAndStore_int_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <4 x i32> %x, ptr @global_int_16, align 8
ret void
}
define void @takeAndStore_int_32(ptr noundef readonly captures(none) dead_on_return %0) {
; CHECK-LABEL: takeAndStore_int_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: vl %v0, 0(%r2), 3
; CHECK-NEXT: vl %v1, 16(%r2), 3
; CHECK-NEXT: lgrl %r1, global_int_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%x = load <8 x i32>, ptr %0, align 8
store <8 x i32> %x, ptr @global_int_32, align 8
ret void
}
define void @takeAndStore_long_8(<1 x i64> noundef %x) {
; CHECK-LABEL: takeAndStore_long_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <1 x i64> %x, ptr @global_long_8, align 8
ret void
}
define void @takeAndStore_long_16(<2 x i64> noundef %x) {
; CHECK-LABEL: takeAndStore_long_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <2 x i64> %x, ptr @global_long_16, align 8
ret void
}
define void @takeAndStore___int128_16(<1 x i128> noundef %x) {
; CHECK-LABEL: takeAndStore___int128_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global___int128_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <1 x i128> %x, ptr @global___int128_16, align 8
ret void
}
define void @takeAndStore___int128_32(ptr noundef readonly captures(none) dead_on_return %0) {
; CHECK-LABEL: takeAndStore___int128_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: vl %v0, 0(%r2), 3
; CHECK-NEXT: vl %v1, 16(%r2), 3
; CHECK-NEXT: lgrl %r1, global___int128_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%x = load <2 x i128>, ptr %0, align 8
store <2 x i128> %x, ptr @global___int128_32, align 8
ret void
}
define void @takeAndStore__Float16_2(<1 x half> noundef %x) {
; CHECK-LABEL: takeAndStore__Float16_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_2@GOT
; CHECK-NEXT: vsteh %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <1 x half> %x, ptr @global__Float16_2, align 2
ret void
}
define void @takeAndStore__Float16_8(<4 x half> noundef %x) {
; CHECK-LABEL: takeAndStore__Float16_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_8@GOT
; CHECK-NEXT: vsteh %v24, 6(%r1), 3
; CHECK-NEXT: vsteh %v24, 4(%r1), 2
; CHECK-NEXT: vsteh %v24, 2(%r1), 1
; CHECK-NEXT: vsteh %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <4 x half> %x, ptr @global__Float16_8, align 8
ret void
}
define void @takeAndStore__Float16_16(<8 x half> noundef %x) {
; CHECK-LABEL: takeAndStore__Float16_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <8 x half> %x, ptr @global__Float16_16, align 8
ret void
}
define void @takeAndStore__Float16_32(ptr noundef readonly captures(none) dead_on_return %0) {
; CHECK-LABEL: takeAndStore__Float16_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: vl %v0, 0(%r2), 3
; CHECK-NEXT: vl %v1, 16(%r2), 3
; CHECK-NEXT: lgrl %r1, global__Float16_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%x = load <16 x half>, ptr %0, align 8
store <16 x half> %x, ptr @global__Float16_32, align 8
ret void
}
define void @takeAndStore_float_4(<1 x float> noundef %x) {
; CHECK-LABEL: takeAndStore_float_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_4@GOT
; CHECK-NEXT: vstef %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <1 x float> %x, ptr @global_float_4, align 4
ret void
}
define void @takeAndStore_float_8(<2 x float> noundef %x) {
; CHECK-LABEL: takeAndStore_float_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <2 x float> %x, ptr @global_float_8, align 8
ret void
}
define void @takeAndStore_float_16(<4 x float> noundef %x) {
; CHECK-LABEL: takeAndStore_float_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <4 x float> %x, ptr @global_float_16, align 8
ret void
}
define void @takeAndStore_double_8(<1 x double> noundef %x) {
; CHECK-LABEL: takeAndStore_double_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_double_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: br %r14
entry:
store <1 x double> %x, ptr @global_double_8, align 8
ret void
}
define void @takeAndStore_double_16(<2 x double> noundef %x) {
; CHECK-LABEL: takeAndStore_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_double_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <2 x double> %x, ptr @global_double_16, align 8
ret void
}
define void @takeAndStore_double_32(ptr noundef readonly captures(none) dead_on_return %0) {
; CHECK-LABEL: takeAndStore_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: vl %v0, 0(%r2), 3
; CHECK-NEXT: vl %v1, 16(%r2), 3
; CHECK-NEXT: lgrl %r1, global_double_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%x = load <4 x double>, ptr %0, align 8
store <4 x double> %x, ptr @global_double_32, align 8
ret void
}
define void @takeAndStore_long_double_16(<1 x fp128> noundef %x) {
; CHECK-LABEL: takeAndStore_long_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_double_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
store <1 x fp128> %x, ptr @global_long_double_16, align 8
ret void
}
define void @takeAndStore_long_double_32(ptr noundef readonly captures(none) dead_on_return %0) {
; CHECK-LABEL: takeAndStore_long_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: vl %v0, 0(%r2), 3
; CHECK-NEXT: vl %v1, 16(%r2), 3
; CHECK-NEXT: lgrl %r1, global_long_double_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%x = load <2 x fp128>, ptr %0, align 8
store <2 x fp128> %x, ptr @global_long_double_32, align 8
ret void
}
define <1 x i8> @loadAndReturn_char_1() {
; CHECK-LABEL: loadAndReturn_char_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_1@GOT
; CHECK-NEXT: vlrepb %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x i8>, ptr @global_char_1, align 2
ret <1 x i8> %0
}
define <8 x i8> @loadAndReturn_char_8() {
; CHECK-LABEL: loadAndReturn_char_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <8 x i8>, ptr @global_char_8, align 8
ret <8 x i8> %0
}
define <16 x i8> @loadAndReturn_char_16() {
; CHECK-LABEL: loadAndReturn_char_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <16 x i8>, ptr @global_char_16, align 8
ret <16 x i8> %0
}
define void @loadAndReturn_char_32(ptr dead_on_unwind noalias writable writeonly sret(<32 x i8>) align 8 captures(none) initializes((0, 32)) %agg.result) {
; CHECK-LABEL: loadAndReturn_char_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: vst %v1, 16(%r2), 3
; CHECK-NEXT: vst %v0, 0(%r2), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <32 x i8>, ptr @global_char_32, align 8
store <32 x i8> %0, ptr %agg.result, align 8
ret void
}
define <1 x i16> @loadAndReturn_short_2() {
; CHECK-LABEL: loadAndReturn_short_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_2@GOT
; CHECK-NEXT: vlreph %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x i16>, ptr @global_short_2, align 2
ret <1 x i16> %0
}
define <4 x i16> @loadAndReturn_short_8() {
; CHECK-LABEL: loadAndReturn_short_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <4 x i16>, ptr @global_short_8, align 8
ret <4 x i16> %0
}
define <8 x i16> @loadAndReturn_short_16() {
; CHECK-LABEL: loadAndReturn_short_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <8 x i16>, ptr @global_short_16, align 8
ret <8 x i16> %0
}
define <1 x i32> @loadAndReturn_int_4() {
; CHECK-LABEL: loadAndReturn_int_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_4@GOT
; CHECK-NEXT: vlrepf %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x i32>, ptr @global_int_4, align 4
ret <1 x i32> %0
}
define <2 x i32> @loadAndReturn_int_8() {
; CHECK-LABEL: loadAndReturn_int_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <2 x i32>, ptr @global_int_8, align 8
ret <2 x i32> %0
}
define <4 x i32> @loadAndReturn_int_16() {
; CHECK-LABEL: loadAndReturn_int_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <4 x i32>, ptr @global_int_16, align 8
ret <4 x i32> %0
}
define void @loadAndReturn_int_32(ptr dead_on_unwind noalias writable writeonly sret(<8 x i32>) align 8 captures(none) initializes((0, 32)) %agg.result) {
; CHECK-LABEL: loadAndReturn_int_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: vst %v1, 16(%r2), 3
; CHECK-NEXT: vst %v0, 0(%r2), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <8 x i32>, ptr @global_int_32, align 8
store <8 x i32> %0, ptr %agg.result, align 8
ret void
}
define <1 x i64> @loadAndReturn_long_8() {
; CHECK-LABEL: loadAndReturn_long_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x i64>, ptr @global_long_8, align 8
ret <1 x i64> %0
}
define <2 x i64> @loadAndReturn_long_16() {
; CHECK-LABEL: loadAndReturn_long_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <2 x i64>, ptr @global_long_16, align 8
ret <2 x i64> %0
}
define <1 x i128> @loadAndReturn___int128_16() {
; CHECK-LABEL: loadAndReturn___int128_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global___int128_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x i128>, ptr @global___int128_16, align 8
ret <1 x i128> %0
}
define void @loadAndReturn___int128_32(ptr dead_on_unwind noalias writable writeonly sret(<2 x i128>) align 8 captures(none) initializes((0, 32)) %agg.result) {
; CHECK-LABEL: loadAndReturn___int128_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global___int128_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: vst %v1, 16(%r2), 3
; CHECK-NEXT: vst %v0, 0(%r2), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <2 x i128>, ptr @global___int128_32, align 8
store <2 x i128> %0, ptr %agg.result, align 8
ret void
}
define <1 x half> @loadAndReturn__Float16_2() {
; CHECK-LABEL: loadAndReturn__Float16_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_2@GOT
; CHECK-NEXT: vlreph %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x half>, ptr @global__Float16_2, align 2
ret <1 x half> %0
}
define <4 x half> @loadAndReturn__Float16_8() {
; CHECK-LABEL: loadAndReturn__Float16_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_8@GOT
; CHECK-NEXT: vlreph %v0, 0(%r1)
; CHECK-NEXT: vlreph %v1, 2(%r1)
; CHECK-NEXT: vlreph %v2, 4(%r1)
; CHECK-NEXT: vlreph %v3, 6(%r1)
; CHECK-NEXT: vmrhh %v2, %v2, %v3
; CHECK-NEXT: vmrhh %v0, %v0, %v1
; CHECK-NEXT: vmrhf %v0, %v0, %v2
; CHECK-NEXT: vmrhg %v24, %v0, %v0
; CHECK-NEXT: br %r14
entry:
%0 = load <4 x half>, ptr @global__Float16_8, align 8
ret <4 x half> %0
}
define <8 x half> @loadAndReturn__Float16_16() {
; CHECK-LABEL: loadAndReturn__Float16_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <8 x half>, ptr @global__Float16_16, align 8
ret <8 x half> %0
}
define void @loadAndReturn__Float16_32(ptr dead_on_unwind noalias writable writeonly sret(<16 x half>) align 8 captures(none) initializes((0, 32)) %agg.result) {
; CHECK-LABEL: loadAndReturn__Float16_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: vst %v1, 16(%r2), 3
; CHECK-NEXT: vst %v0, 0(%r2), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <16 x half>, ptr @global__Float16_32, align 8
store <16 x half> %0, ptr %agg.result, align 8
ret void
}
define <1 x float> @loadAndReturn_float_4() {
; CHECK-LABEL: loadAndReturn_float_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_4@GOT
; CHECK-NEXT: vlrepf %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x float>, ptr @global_float_4, align 4
ret <1 x float> %0
}
define <2 x float> @loadAndReturn_float_8() {
; CHECK-LABEL: loadAndReturn_float_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <2 x float>, ptr @global_float_8, align 8
ret <2 x float> %0
}
define <4 x float> @loadAndReturn_float_16() {
; CHECK-LABEL: loadAndReturn_float_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <4 x float>, ptr @global_float_16, align 8
ret <4 x float> %0
}
define <1 x double> @loadAndReturn_double_8() {
; CHECK-LABEL: loadAndReturn_double_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_double_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x double>, ptr @global_double_8, align 8
ret <1 x double> %0
}
define <2 x double> @loadAndReturn_double_16() {
; CHECK-LABEL: loadAndReturn_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_double_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <2 x double>, ptr @global_double_16, align 8
ret <2 x double> %0
}
define void @loadAndReturn_double_32(ptr dead_on_unwind noalias writable writeonly sret(<4 x double>) align 8 captures(none) initializes((0, 32)) %agg.result) {
; CHECK-LABEL: loadAndReturn_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_double_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: vst %v1, 16(%r2), 3
; CHECK-NEXT: vst %v0, 0(%r2), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <4 x double>, ptr @global_double_32, align 8
store <4 x double> %0, ptr %agg.result, align 8
ret void
}
define <1 x fp128> @loadAndReturn_long_double_16() {
; CHECK-LABEL: loadAndReturn_long_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_double_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: br %r14
entry:
%0 = load <1 x fp128>, ptr @global_long_double_16, align 8
ret <1 x fp128> %0
}
define void @loadAndReturn_long_double_32(ptr dead_on_unwind noalias writable writeonly sret(<2 x fp128>) align 8 captures(none) initializes((0, 32)) %agg.result) {
; CHECK-LABEL: loadAndReturn_long_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_double_32@GOT
; CHECK-NEXT: mvc 16(16,%r2), 16(%r1)
; CHECK-NEXT: mvc 0(16,%r2), 0(%r1)
; CHECK-NEXT: br %r14
entry:
%0 = load <2 x fp128>, ptr @global_long_double_32, align 8
store <2 x fp128> %0, ptr %agg.result, align 8
ret void
}
define void @loadAndPass_char_1() {
; CHECK-LABEL: loadAndPass_char_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_1@GOT
; CHECK-NEXT: vlrepb %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_char_1@PLT
entry:
%0 = load <1 x i8>, ptr @global_char_1, align 2
tail call void @passCallee_char_1(<1 x i8> noundef %0)
ret void
}
declare void @passCallee_char_1(<1 x i8> noundef)
define void @loadAndPass_char_8() {
; CHECK-LABEL: loadAndPass_char_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_char_8@PLT
entry:
%0 = load <8 x i8>, ptr @global_char_8, align 8
tail call void @passCallee_char_8(<8 x i8> noundef %0)
ret void
}
declare void @passCallee_char_8(<8 x i8> noundef)
define void @loadAndPass_char_16() {
; CHECK-LABEL: loadAndPass_char_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_char_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee_char_16@PLT
entry:
%0 = load <16 x i8>, ptr @global_char_16, align 8
tail call void @passCallee_char_16(<16 x i8> noundef %0)
ret void
}
declare void @passCallee_char_16(<16 x i8> noundef)
define void @loadAndPass_char_32() {
; CHECK-LABEL: loadAndPass_char_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: lgrl %r1, global_char_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: vst %v1, 176(%r15), 3
; CHECK-NEXT: vst %v0, 160(%r15), 3
; CHECK-NEXT: brasl %r14, passCallee_char_32@PLT
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%byval-temp = alloca <32 x i8>, align 8
%0 = load <32 x i8>, ptr @global_char_32, align 8
store <32 x i8> %0, ptr %byval-temp, align 8
call void @passCallee_char_32(ptr noundef nonnull dead_on_return %byval-temp)
ret void
}
declare void @passCallee_char_32(ptr noundef dead_on_return)
define void @loadAndPass_short_2() {
; CHECK-LABEL: loadAndPass_short_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_2@GOT
; CHECK-NEXT: vlreph %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_short_2@PLT
entry:
%0 = load <1 x i16>, ptr @global_short_2, align 2
tail call void @passCallee_short_2(<1 x i16> noundef %0)
ret void
}
declare void @passCallee_short_2(<1 x i16> noundef)
define void @loadAndPass_short_8() {
; CHECK-LABEL: loadAndPass_short_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_short_8@PLT
entry:
%0 = load <4 x i16>, ptr @global_short_8, align 8
tail call void @passCallee_short_8(<4 x i16> noundef %0)
ret void
}
declare void @passCallee_short_8(<4 x i16> noundef)
define void @loadAndPass_short_16() {
; CHECK-LABEL: loadAndPass_short_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_short_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee_short_16@PLT
entry:
%0 = load <8 x i16>, ptr @global_short_16, align 8
tail call void @passCallee_short_16(<8 x i16> noundef %0)
ret void
}
declare void @passCallee_short_16(<8 x i16> noundef)
define void @loadAndPass_int_4() {
; CHECK-LABEL: loadAndPass_int_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_4@GOT
; CHECK-NEXT: vlrepf %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_int_4@PLT
entry:
%0 = load <1 x i32>, ptr @global_int_4, align 4
tail call void @passCallee_int_4(<1 x i32> noundef %0)
ret void
}
declare void @passCallee_int_4(<1 x i32> noundef)
define void @loadAndPass_int_8() {
; CHECK-LABEL: loadAndPass_int_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_int_8@PLT
entry:
%0 = load <2 x i32>, ptr @global_int_8, align 8
tail call void @passCallee_int_8(<2 x i32> noundef %0)
ret void
}
declare void @passCallee_int_8(<2 x i32> noundef)
define void @loadAndPass_int_16() {
; CHECK-LABEL: loadAndPass_int_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_int_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee_int_16@PLT
entry:
%0 = load <4 x i32>, ptr @global_int_16, align 8
tail call void @passCallee_int_16(<4 x i32> noundef %0)
ret void
}
declare void @passCallee_int_16(<4 x i32> noundef)
define void @loadAndPass_int_32() {
; CHECK-LABEL: loadAndPass_int_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: lgrl %r1, global_int_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: vst %v1, 176(%r15), 3
; CHECK-NEXT: vst %v0, 160(%r15), 3
; CHECK-NEXT: brasl %r14, passCallee_int_32@PLT
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%byval-temp = alloca <8 x i32>, align 8
%0 = load <8 x i32>, ptr @global_int_32, align 8
store <8 x i32> %0, ptr %byval-temp, align 8
call void @passCallee_int_32(ptr noundef nonnull dead_on_return %byval-temp)
ret void
}
declare void @passCallee_int_32(ptr noundef dead_on_return)
define void @loadAndPass_long_8() {
; CHECK-LABEL: loadAndPass_long_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_long_8@PLT
entry:
%0 = load <1 x i64>, ptr @global_long_8, align 8
tail call void @passCallee_long_8(<1 x i64> noundef %0)
ret void
}
declare void @passCallee_long_8(<1 x i64> noundef)
define void @loadAndPass_long_16() {
; CHECK-LABEL: loadAndPass_long_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee_long_16@PLT
entry:
%0 = load <2 x i64>, ptr @global_long_16, align 8
tail call void @passCallee_long_16(<2 x i64> noundef %0)
ret void
}
declare void @passCallee_long_16(<2 x i64> noundef)
define void @loadAndPass___int128_16() {
; CHECK-LABEL: loadAndPass___int128_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global___int128_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee___int128_16@PLT
entry:
%0 = load <1 x i128>, ptr @global___int128_16, align 8
tail call void @passCallee___int128_16(<1 x i128> noundef %0)
ret void
}
declare void @passCallee___int128_16(<1 x i128> noundef)
define void @loadAndPass___int128_32() {
; CHECK-LABEL: loadAndPass___int128_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: lgrl %r1, global___int128_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: vst %v1, 176(%r15), 3
; CHECK-NEXT: vst %v0, 160(%r15), 3
; CHECK-NEXT: brasl %r14, passCallee___int128_32@PLT
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%byval-temp = alloca <2 x i128>, align 8
%0 = load <2 x i128>, ptr @global___int128_32, align 8
store <2 x i128> %0, ptr %byval-temp, align 8
call void @passCallee___int128_32(ptr noundef nonnull dead_on_return %byval-temp)
ret void
}
declare void @passCallee___int128_32(ptr noundef dead_on_return)
define void @loadAndPass__Float16_2() {
; CHECK-LABEL: loadAndPass__Float16_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_2@GOT
; CHECK-NEXT: vlreph %v24, 0(%r1)
; CHECK-NEXT: jg passCallee__Float16_2@PLT
entry:
%0 = load <1 x half>, ptr @global__Float16_2, align 2
tail call void @passCallee__Float16_2(<1 x half> noundef %0)
ret void
}
declare void @passCallee__Float16_2(<1 x half> noundef)
define void @loadAndPass__Float16_8() {
; CHECK-LABEL: loadAndPass__Float16_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_8@GOT
; CHECK-NEXT: vlreph %v0, 0(%r1)
; CHECK-NEXT: vlreph %v1, 2(%r1)
; CHECK-NEXT: vlreph %v2, 4(%r1)
; CHECK-NEXT: vlreph %v3, 6(%r1)
; CHECK-NEXT: vmrhh %v2, %v2, %v3
; CHECK-NEXT: vmrhh %v0, %v0, %v1
; CHECK-NEXT: vmrhf %v0, %v0, %v2
; CHECK-NEXT: vmrhg %v24, %v0, %v0
; CHECK-NEXT: jg passCallee__Float16_8@PLT
entry:
%0 = load <4 x half>, ptr @global__Float16_8, align 8
tail call void @passCallee__Float16_8(<4 x half> noundef %0)
ret void
}
declare void @passCallee__Float16_8(<4 x half> noundef)
define void @loadAndPass__Float16_16() {
; CHECK-LABEL: loadAndPass__Float16_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global__Float16_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee__Float16_16@PLT
entry:
%0 = load <8 x half>, ptr @global__Float16_16, align 8
tail call void @passCallee__Float16_16(<8 x half> noundef %0)
ret void
}
declare void @passCallee__Float16_16(<8 x half> noundef)
define void @loadAndPass__Float16_32() {
; CHECK-LABEL: loadAndPass__Float16_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: lgrl %r1, global__Float16_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: vst %v1, 176(%r15), 3
; CHECK-NEXT: vst %v0, 160(%r15), 3
; CHECK-NEXT: brasl %r14, passCallee__Float16_32@PLT
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%byval-temp = alloca <16 x half>, align 8
%0 = load <16 x half>, ptr @global__Float16_32, align 8
store <16 x half> %0, ptr %byval-temp, align 8
call void @passCallee__Float16_32(ptr noundef nonnull dead_on_return %byval-temp)
ret void
}
declare void @passCallee__Float16_32(ptr noundef dead_on_return)
define void @loadAndPass_float_4() {
; CHECK-LABEL: loadAndPass_float_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_4@GOT
; CHECK-NEXT: vlrepf %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_float_4@PLT
entry:
%0 = load <1 x float>, ptr @global_float_4, align 4
tail call void @passCallee_float_4(<1 x float> noundef %0)
ret void
}
declare void @passCallee_float_4(<1 x float> noundef)
define void @loadAndPass_float_8() {
; CHECK-LABEL: loadAndPass_float_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_float_8@PLT
entry:
%0 = load <2 x float>, ptr @global_float_8, align 8
tail call void @passCallee_float_8(<2 x float> noundef %0)
ret void
}
declare void @passCallee_float_8(<2 x float> noundef)
define void @loadAndPass_float_16() {
; CHECK-LABEL: loadAndPass_float_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_float_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee_float_16@PLT
entry:
%0 = load <4 x float>, ptr @global_float_16, align 8
tail call void @passCallee_float_16(<4 x float> noundef %0)
ret void
}
declare void @passCallee_float_16(<4 x float> noundef)
define void @loadAndPass_double_8() {
; CHECK-LABEL: loadAndPass_double_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_double_8@GOT
; CHECK-NEXT: vlrepg %v24, 0(%r1)
; CHECK-NEXT: jg passCallee_double_8@PLT
entry:
%0 = load <1 x double>, ptr @global_double_8, align 8
tail call void @passCallee_double_8(<1 x double> noundef %0)
ret void
}
declare void @passCallee_double_8(<1 x double> noundef)
define void @loadAndPass_double_16() {
; CHECK-LABEL: loadAndPass_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_double_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee_double_16@PLT
entry:
%0 = load <2 x double>, ptr @global_double_16, align 8
tail call void @passCallee_double_16(<2 x double> noundef %0)
ret void
}
declare void @passCallee_double_16(<2 x double> noundef)
define void @loadAndPass_double_32() {
; CHECK-LABEL: loadAndPass_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: lgrl %r1, global_double_32@GOT
; CHECK-NEXT: vl %v0, 0(%r1), 3
; CHECK-NEXT: vl %v1, 16(%r1), 3
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: vst %v1, 176(%r15), 3
; CHECK-NEXT: vst %v0, 160(%r15), 3
; CHECK-NEXT: brasl %r14, passCallee_double_32@PLT
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%byval-temp = alloca <4 x double>, align 8
%0 = load <4 x double>, ptr @global_double_32, align 8
store <4 x double> %0, ptr %byval-temp, align 8
call void @passCallee_double_32(ptr noundef nonnull dead_on_return %byval-temp)
ret void
}
declare void @passCallee_double_32(ptr noundef dead_on_return)
define void @loadAndPass_long_double_16() {
; CHECK-LABEL: loadAndPass_long_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: lgrl %r1, global_long_double_16@GOT
; CHECK-NEXT: vl %v24, 0(%r1), 3
; CHECK-NEXT: jg passCallee_long_double_16@PLT
entry:
%0 = load <1 x fp128>, ptr @global_long_double_16, align 8
tail call void @passCallee_long_double_16(<1 x fp128> noundef %0)
ret void
}
declare void @passCallee_long_double_16(<1 x fp128> noundef)
define void @loadAndPass_long_double_32() {
; CHECK-LABEL: loadAndPass_long_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: lgrl %r1, global_long_double_32@GOT
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: mvc 176(16,%r15), 16(%r1)
; CHECK-NEXT: mvc 160(16,%r15), 0(%r1)
; CHECK-NEXT: brasl %r14, passCallee_long_double_32@PLT
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%byval-temp = alloca <2 x fp128>, align 8
%0 = load <2 x fp128>, ptr @global_long_double_32, align 8
store <2 x fp128> %0, ptr %byval-temp, align 8
call void @passCallee_long_double_32(ptr noundef nonnull dead_on_return %byval-temp)
ret void
}
declare void @passCallee_long_double_32(ptr noundef dead_on_return)
define void @receiveAndStore_char_1() {
; CHECK-LABEL: receiveAndStore_char_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_char_1@PLT
; CHECK-NEXT: lgrl %r1, global_char_1@GOT
; CHECK-NEXT: vsteb %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x i8> @retCallee_char_1()
store <1 x i8> %call, ptr @global_char_1, align 2
ret void
}
declare <1 x i8> @retCallee_char_1()
define void @receiveAndStore_char_8() {
; CHECK-LABEL: receiveAndStore_char_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_char_8@PLT
; CHECK-NEXT: lgrl %r1, global_char_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <8 x i8> @retCallee_char_8()
store <8 x i8> %call, ptr @global_char_8, align 8
ret void
}
declare <8 x i8> @retCallee_char_8()
define void @receiveAndStore_char_16() {
; CHECK-LABEL: receiveAndStore_char_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_char_16@PLT
; CHECK-NEXT: lgrl %r1, global_char_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <16 x i8> @retCallee_char_16()
store <16 x i8> %call, ptr @global_char_16, align 8
ret void
}
declare <16 x i8> @retCallee_char_16()
define void @receiveAndStore_char_32() {
; CHECK-LABEL: receiveAndStore_char_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: brasl %r14, retCallee_char_32@PLT
; CHECK-NEXT: vl %v0, 160(%r15), 3
; CHECK-NEXT: vl %v1, 176(%r15), 3
; CHECK-NEXT: lgrl %r1, global_char_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%tmp = alloca <32 x i8>, align 8
call void @retCallee_char_32(ptr dead_on_unwind nonnull writable sret(<32 x i8>) align 8 %tmp)
%0 = load <32 x i8>, ptr %tmp, align 8
store <32 x i8> %0, ptr @global_char_32, align 8
ret void
}
declare void @retCallee_char_32(ptr dead_on_unwind writable sret(<32 x i8>) align 8)
define void @receiveAndStore_short_2() {
; CHECK-LABEL: receiveAndStore_short_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_short_2@PLT
; CHECK-NEXT: lgrl %r1, global_short_2@GOT
; CHECK-NEXT: vsteh %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x i16> @retCallee_short_2()
store <1 x i16> %call, ptr @global_short_2, align 2
ret void
}
declare <1 x i16> @retCallee_short_2()
define void @receiveAndStore_short_8() {
; CHECK-LABEL: receiveAndStore_short_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_short_8@PLT
; CHECK-NEXT: lgrl %r1, global_short_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <4 x i16> @retCallee_short_8()
store <4 x i16> %call, ptr @global_short_8, align 8
ret void
}
declare <4 x i16> @retCallee_short_8()
define void @receiveAndStore_short_16() {
; CHECK-LABEL: receiveAndStore_short_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_short_16@PLT
; CHECK-NEXT: lgrl %r1, global_short_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <8 x i16> @retCallee_short_16()
store <8 x i16> %call, ptr @global_short_16, align 8
ret void
}
declare <8 x i16> @retCallee_short_16()
define void @receiveAndStore_int_4() {
; CHECK-LABEL: receiveAndStore_int_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_int_4@PLT
; CHECK-NEXT: lgrl %r1, global_int_4@GOT
; CHECK-NEXT: vstef %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x i32> @retCallee_int_4()
store <1 x i32> %call, ptr @global_int_4, align 4
ret void
}
declare <1 x i32> @retCallee_int_4()
define void @receiveAndStore_int_8() {
; CHECK-LABEL: receiveAndStore_int_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_int_8@PLT
; CHECK-NEXT: lgrl %r1, global_int_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <2 x i32> @retCallee_int_8()
store <2 x i32> %call, ptr @global_int_8, align 8
ret void
}
declare <2 x i32> @retCallee_int_8()
define void @receiveAndStore_int_16() {
; CHECK-LABEL: receiveAndStore_int_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_int_16@PLT
; CHECK-NEXT: lgrl %r1, global_int_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <4 x i32> @retCallee_int_16()
store <4 x i32> %call, ptr @global_int_16, align 8
ret void
}
declare <4 x i32> @retCallee_int_16()
define void @receiveAndStore_int_32() {
; CHECK-LABEL: receiveAndStore_int_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: brasl %r14, retCallee_int_32@PLT
; CHECK-NEXT: vl %v0, 160(%r15), 3
; CHECK-NEXT: vl %v1, 176(%r15), 3
; CHECK-NEXT: lgrl %r1, global_int_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%tmp = alloca <8 x i32>, align 8
call void @retCallee_int_32(ptr dead_on_unwind nonnull writable sret(<8 x i32>) align 8 %tmp)
%0 = load <8 x i32>, ptr %tmp, align 8
store <8 x i32> %0, ptr @global_int_32, align 8
ret void
}
declare void @retCallee_int_32(ptr dead_on_unwind writable sret(<8 x i32>) align 8)
define void @receiveAndStore_long_8() {
; CHECK-LABEL: receiveAndStore_long_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_long_8@PLT
; CHECK-NEXT: lgrl %r1, global_long_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x i64> @retCallee_long_8()
store <1 x i64> %call, ptr @global_long_8, align 8
ret void
}
declare <1 x i64> @retCallee_long_8()
define void @receiveAndStore_long_16() {
; CHECK-LABEL: receiveAndStore_long_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_long_16@PLT
; CHECK-NEXT: lgrl %r1, global_long_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <2 x i64> @retCallee_long_16()
store <2 x i64> %call, ptr @global_long_16, align 8
ret void
}
declare <2 x i64> @retCallee_long_16()
define void @receiveAndStore___int128_16() {
; CHECK-LABEL: receiveAndStore___int128_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee___int128_16@PLT
; CHECK-NEXT: lgrl %r1, global___int128_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x i128> @retCallee___int128_16()
store <1 x i128> %call, ptr @global___int128_16, align 8
ret void
}
declare <1 x i128> @retCallee___int128_16()
define void @receiveAndStore___int128_32() {
; CHECK-LABEL: receiveAndStore___int128_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: brasl %r14, retCallee___int128_32@PLT
; CHECK-NEXT: vl %v0, 160(%r15), 3
; CHECK-NEXT: vl %v1, 176(%r15), 3
; CHECK-NEXT: lgrl %r1, global___int128_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%tmp = alloca <2 x i128>, align 8
call void @retCallee___int128_32(ptr dead_on_unwind nonnull writable sret(<2 x i128>) align 8 %tmp)
%0 = load <2 x i128>, ptr %tmp, align 8
store <2 x i128> %0, ptr @global___int128_32, align 8
ret void
}
declare void @retCallee___int128_32(ptr dead_on_unwind writable sret(<2 x i128>) align 8)
define void @receiveAndStore__Float16_2() {
; CHECK-LABEL: receiveAndStore__Float16_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee__Float16_2@PLT
; CHECK-NEXT: lgrl %r1, global__Float16_2@GOT
; CHECK-NEXT: vsteh %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x half> @retCallee__Float16_2()
store <1 x half> %call, ptr @global__Float16_2, align 2
ret void
}
declare <1 x half> @retCallee__Float16_2()
define void @receiveAndStore__Float16_8() {
; CHECK-LABEL: receiveAndStore__Float16_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee__Float16_8@PLT
; CHECK-NEXT: lgrl %r1, global__Float16_8@GOT
; CHECK-NEXT: vsteh %v24, 6(%r1), 3
; CHECK-NEXT: vsteh %v24, 4(%r1), 2
; CHECK-NEXT: vsteh %v24, 2(%r1), 1
; CHECK-NEXT: vsteh %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <4 x half> @retCallee__Float16_8()
store <4 x half> %call, ptr @global__Float16_8, align 8
ret void
}
declare <4 x half> @retCallee__Float16_8()
define void @receiveAndStore__Float16_16() {
; CHECK-LABEL: receiveAndStore__Float16_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee__Float16_16@PLT
; CHECK-NEXT: lgrl %r1, global__Float16_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <8 x half> @retCallee__Float16_16()
store <8 x half> %call, ptr @global__Float16_16, align 8
ret void
}
declare <8 x half> @retCallee__Float16_16()
define void @receiveAndStore__Float16_32() {
; CHECK-LABEL: receiveAndStore__Float16_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: brasl %r14, retCallee__Float16_32@PLT
; CHECK-NEXT: vl %v0, 160(%r15), 3
; CHECK-NEXT: vl %v1, 176(%r15), 3
; CHECK-NEXT: lgrl %r1, global__Float16_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%tmp = alloca <16 x half>, align 8
call void @retCallee__Float16_32(ptr dead_on_unwind nonnull writable sret(<16 x half>) align 8 %tmp)
%0 = load <16 x half>, ptr %tmp, align 8
store <16 x half> %0, ptr @global__Float16_32, align 8
ret void
}
declare void @retCallee__Float16_32(ptr dead_on_unwind writable sret(<16 x half>) align 8)
define void @receiveAndStore_float_4() {
; CHECK-LABEL: receiveAndStore_float_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_float_4@PLT
; CHECK-NEXT: lgrl %r1, global_float_4@GOT
; CHECK-NEXT: vstef %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x float> @retCallee_float_4()
store <1 x float> %call, ptr @global_float_4, align 4
ret void
}
declare <1 x float> @retCallee_float_4()
define void @receiveAndStore_float_8() {
; CHECK-LABEL: receiveAndStore_float_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_float_8@PLT
; CHECK-NEXT: lgrl %r1, global_float_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <2 x float> @retCallee_float_8()
store <2 x float> %call, ptr @global_float_8, align 8
ret void
}
declare <2 x float> @retCallee_float_8()
define void @receiveAndStore_float_16() {
; CHECK-LABEL: receiveAndStore_float_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_float_16@PLT
; CHECK-NEXT: lgrl %r1, global_float_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <4 x float> @retCallee_float_16()
store <4 x float> %call, ptr @global_float_16, align 8
ret void
}
declare <4 x float> @retCallee_float_16()
define void @receiveAndStore_double_8() {
; CHECK-LABEL: receiveAndStore_double_8:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_double_8@PLT
; CHECK-NEXT: lgrl %r1, global_double_8@GOT
; CHECK-NEXT: vsteg %v24, 0(%r1), 0
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x double> @retCallee_double_8()
store <1 x double> %call, ptr @global_double_8, align 8
ret void
}
declare <1 x double> @retCallee_double_8()
define void @receiveAndStore_double_16() {
; CHECK-LABEL: receiveAndStore_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_double_16@PLT
; CHECK-NEXT: lgrl %r1, global_double_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <2 x double> @retCallee_double_16()
store <2 x double> %call, ptr @global_double_16, align 8
ret void
}
declare <2 x double> @retCallee_double_16()
define void @receiveAndStore_double_32() {
; CHECK-LABEL: receiveAndStore_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: brasl %r14, retCallee_double_32@PLT
; CHECK-NEXT: vl %v0, 160(%r15), 3
; CHECK-NEXT: vl %v1, 176(%r15), 3
; CHECK-NEXT: lgrl %r1, global_double_32@GOT
; CHECK-NEXT: vst %v1, 16(%r1), 3
; CHECK-NEXT: vst %v0, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%tmp = alloca <4 x double>, align 8
call void @retCallee_double_32(ptr dead_on_unwind nonnull writable sret(<4 x double>) align 8 %tmp)
%0 = load <4 x double>, ptr %tmp, align 8
store <4 x double> %0, ptr @global_double_32, align 8
ret void
}
declare void @retCallee_double_32(ptr dead_on_unwind writable sret(<4 x double>) align 8)
define void @receiveAndStore_long_double_16() {
; CHECK-LABEL: receiveAndStore_long_double_16:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -160
; CHECK-NEXT: .cfi_def_cfa_offset 320
; CHECK-NEXT: brasl %r14, retCallee_long_double_16@PLT
; CHECK-NEXT: lgrl %r1, global_long_double_16@GOT
; CHECK-NEXT: vst %v24, 0(%r1), 3
; CHECK-NEXT: lmg %r14, %r15, 272(%r15)
; CHECK-NEXT: br %r14
entry:
%call = tail call <1 x fp128> @retCallee_long_double_16()
store <1 x fp128> %call, ptr @global_long_double_16, align 8
ret void
}
declare <1 x fp128> @retCallee_long_double_16()
define void @receiveAndStore_long_double_32() {
; CHECK-LABEL: receiveAndStore_long_double_32:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r14, %r15, 112(%r15)
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -192
; CHECK-NEXT: .cfi_def_cfa_offset 352
; CHECK-NEXT: la %r2, 160(%r15)
; CHECK-NEXT: brasl %r14, retCallee_long_double_32@PLT
; CHECK-NEXT: lgrl %r1, global_long_double_32@GOT
; CHECK-NEXT: mvc 16(16,%r1), 176(%r15)
; CHECK-NEXT: mvc 0(16,%r1), 160(%r15)
; CHECK-NEXT: lmg %r14, %r15, 304(%r15)
; CHECK-NEXT: br %r14
entry:
%tmp = alloca <2 x fp128>, align 8
call void @retCallee_long_double_32(ptr dead_on_unwind nonnull writable sret(<2 x fp128>) align 8 %tmp)
%0 = load <2 x fp128>, ptr %tmp, align 8
store <2 x fp128> %0, ptr @global_long_double_32, align 8
ret void
}
declare void @retCallee_long_double_32(ptr dead_on_unwind writable sret(<2 x fp128>) align 8)