| ; 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) |