| ! RUN: bbc %s -o - | tco | FileCheck %s --check-prefixes=CHECK%if target=x86_64{{.*}} %{,CHECK-KIND10%}%if flang-supports-f128-math %{,CHECK-KIND16%} |
| |
| ! CHECK-LABEL: define void {{.*}}test_reals |
| subroutine test_reals(x2, x3, x4, x8, c2, c3, c4, c8) |
| character(10) :: in = 'NaN NaN' |
| |
| real(kind=2) :: x2 |
| real(kind=3) :: x3 |
| real(kind=4) :: x4 |
| real(kind=8) :: x8 |
| |
| complex(kind=2) :: c2 |
| complex(kind=3) :: c3 |
| complex(kind=4) :: c4 |
| complex(kind=8) :: c8 |
| |
| read(in,*) x2 |
| ! CHECK: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 2, i32 {{[0-9]*}}, i8 0, i8 25, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z4)", x2 |
| |
| read(in,*) x3 |
| ! CHECK: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 2, i32 {{[0-9]*}}, i8 0, i8 26, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z4)", x3 |
| |
| read(in,*) x4 |
| ! CHECK: call i1 @_FortranAioOutputReal32(ptr %{{[0-9]*}}, float %{{[0-9]*}}) |
| print "(z8)", x4 |
| |
| read(in,*) x8 |
| ! CHECK: call i1 @_FortranAioOutputReal64(ptr %{{[0-9]*}}, double %{{[0-9]*}}) |
| print "(z16)", x8 |
| |
| read(in,*) c2 |
| ! CHECK: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 4, i32 {{[0-9]*}}, i8 0, i8 32, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z4,' ',z4)", c2 |
| |
| read(in,*) c3 |
| ! CHECK: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 4, i32 {{[0-9]*}}, i8 0, i8 33, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z4,' ',z4)", c3 |
| |
| read(in,*) c4 |
| ! CHECK: call i1 @_FortranAioOutputComplex32(ptr %{{[0-9]*}}, float %{{[0-9]*}}, float %{{[0-9]*}}) |
| print "(z8,' ',z8)", c4 |
| |
| read(in,*) c8 |
| ! CHECK: call i1 @_FortranAioOutputComplex64(ptr %{{[0-9]*}}, double %{{[0-9]*}}, double %{{[0-9]*}}) |
| print "(z16,' ',z16)", c8 |
| |
| end |
| |
| ! CHECK-KIND16-LABEL: test_kind10 |
| subroutine test_kind10(x10, c10) |
| integer, parameter :: kind10 = merge(10, 4, selected_real_kind(p=18).eq.10) |
| character(10) :: in = 'NaN NaN' |
| real(kind=kind10) :: x10 |
| complex(kind=kind10) :: c10 |
| |
| read(in,*) x10 |
| ! CHECK-KIND10: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 16, i32 {{[0-9]*}}, i8 0, i8 29, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK-KIND10: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z20)", x10 |
| |
| read(in,*) c10 |
| ! CHECK-KIND10: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 32, i32 {{[0-9]*}}, i8 0, i8 36, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK-KIND10: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z20,' ',z20)", c10 |
| end subroutine |
| |
| ! CHECK-KIND16-LABEL: test_kind16 |
| subroutine test_kind16(x16, c16) |
| integer, parameter :: kind16 = merge(16, 4, selected_real_kind(p=33).eq.16) |
| character(10) :: in = 'NaN NaN' |
| real(kind=kind16) :: x16 |
| complex(kind=kind16) :: c16 |
| |
| read(in,*) x16 |
| ! CHECK-KIND16: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 16, i32 {{[0-9]*}}, i8 0, i8 31, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK-KIND16: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z32)", x16 |
| |
| read(in,*) c16 |
| ! CHECK-KIND16: insertvalue { ptr, i64, i32, i8, i8, i8, i8 } { ptr undef, i64 32, i32 {{[0-9]*}}, i8 0, i8 38, i8 0, i8 0 }, ptr %{{[0-9]*}}, 0 |
| ! CHECK-KIND16: call i1 @_FortranAioOutputDescriptor(ptr %{{[0-9]*}}, ptr %{{[0-9]*}}) |
| print "(z32,' ',z32)", c16 |
| end subroutine |