forked from OSchip/llvm-project
226 lines
5.4 KiB
Fortran
226 lines
5.4 KiB
Fortran
! RUN: bbc %s -o "-" -emit-fir | FileCheck %s
|
|
|
|
! CHECK-LABEL: func @_QPsub() {
|
|
subroutine sub()
|
|
! CHECK: }
|
|
end subroutine
|
|
|
|
! CHECK-LABEL: func @_QPasubroutine() {
|
|
subroutine AsUbRoUtInE()
|
|
! CHECK: }
|
|
end subroutine
|
|
|
|
! CHECK-LABEL: func @_QPfoo() -> f32 {
|
|
function foo()
|
|
real(4) :: foo
|
|
real :: pi = 3.14159
|
|
! CHECK: }
|
|
end function
|
|
|
|
|
|
! CHECK-LABEL: func @_QPfunctn() -> f32 {
|
|
function functn
|
|
real, parameter :: pi = 3.14
|
|
! CHECK: }
|
|
end function
|
|
|
|
|
|
module testMod
|
|
contains
|
|
! CHECK-LABEL: func @_QMtestmodPsub() {
|
|
subroutine sub()
|
|
! CHECK: }
|
|
end subroutine
|
|
|
|
! CHECK-LABEL: func @_QMtestmodPfoo() -> f32 {
|
|
function foo()
|
|
real(4) :: foo
|
|
! CHECK: }
|
|
end function
|
|
end module
|
|
|
|
|
|
! CHECK-LABEL: func @_QPfoo2()
|
|
function foo2()
|
|
real(4) :: foo2
|
|
contains
|
|
! CHECK-LABEL: func @_QFfoo2Psub() {
|
|
subroutine sub()
|
|
! CHECK: }
|
|
end subroutine
|
|
|
|
! CHECK-LABEL: func @_QFfoo2Pfoo() {
|
|
subroutine foo()
|
|
! CHECK: }
|
|
end subroutine
|
|
end function
|
|
|
|
! CHECK-LABEL: func @_QPsub2()
|
|
subroutine sUb2()
|
|
contains
|
|
! CHECK-LABEL: func @_QFsub2Psub() {
|
|
subroutine sub()
|
|
! CHECK: }
|
|
end subroutine
|
|
|
|
! CHECK-LABEL: func @_QFsub2Pfoo() {
|
|
subroutine Foo()
|
|
! CHECK: }
|
|
end subroutine
|
|
end subroutine
|
|
|
|
module testMod2
|
|
contains
|
|
! CHECK-LABEL: func @_QMtestmod2Psub()
|
|
subroutine sub()
|
|
contains
|
|
! CHECK-LABEL: func @_QMtestmod2FsubPsubsub() {
|
|
subroutine subSub()
|
|
! CHECK: }
|
|
end subroutine
|
|
end subroutine
|
|
end module
|
|
|
|
|
|
module color_points
|
|
interface
|
|
module subroutine draw()
|
|
end subroutine
|
|
module function erase()
|
|
integer(4) :: erase
|
|
end function
|
|
end interface
|
|
end module color_points
|
|
|
|
! We don't handle lowering of submodules yet. The following tests are
|
|
! commented out and "CHECK" is changed to "xHECK" to not trigger FileCheck.
|
|
!submodule (color_points) color_points_a
|
|
!contains
|
|
! ! xHECK-LABEL: func @_QMcolor_pointsScolor_points_aPsub() {
|
|
! subroutine sub
|
|
! end subroutine
|
|
! ! xHECK: }
|
|
!end submodule
|
|
!
|
|
!submodule (color_points:color_points_a) impl
|
|
!contains
|
|
! ! xHECK-LABEL: func @_QMcolor_pointsScolor_points_aSimplPfoo()
|
|
! subroutine foo
|
|
! contains
|
|
! ! xHECK-LABEL: func @_QMcolor_pointsScolor_points_aSimplFfooPbar() {
|
|
! subroutine bar
|
|
! ! xHECK: }
|
|
! end subroutine
|
|
! end subroutine
|
|
! ! xHECK-LABEL: func @_QMcolor_pointsPdraw() {
|
|
! module subroutine draw()
|
|
! end subroutine
|
|
! !FIXME func @_QMcolor_pointsPerase() -> i32 {
|
|
! module procedure erase
|
|
! ! xHECK: }
|
|
! end procedure
|
|
!end submodule
|
|
|
|
! CHECK-LABEL: func @_QPshould_not_collide() {
|
|
subroutine should_not_collide()
|
|
! CHECK: }
|
|
end subroutine
|
|
|
|
! CHECK-LABEL: func @_QQmain() {
|
|
program test
|
|
! CHECK: }
|
|
contains
|
|
! CHECK-LABEL: func @_QFPshould_not_collide() {
|
|
subroutine should_not_collide()
|
|
! CHECK: }
|
|
end subroutine
|
|
end program
|
|
|
|
! CHECK-LABEL: func @omp_get_num_threads() -> f32 attributes {fir.bindc_name = "omp_get_num_threads"} {
|
|
function omp_get_num_threads() bind(c)
|
|
! CHECK: }
|
|
end function
|
|
|
|
! CHECK-LABEL: func @get_threads() -> f32 attributes {fir.bindc_name = "get_threads"} {
|
|
function omp_get_num_threads_1() bind(c, name ="get_threads")
|
|
! CHECK: }
|
|
end function
|
|
|
|
! CHECK-LABEL: func @bEtA() -> f32 attributes {fir.bindc_name = "bEtA"} {
|
|
function alpha() bind(c, name =" bEtA ")
|
|
! CHECK: }
|
|
end function
|
|
|
|
! CHECK-LABEL: func @bc1() attributes {fir.bindc_name = "bc1"} {
|
|
subroutine bind_c_s() Bind(C,Name='bc1')
|
|
! CHECK: return
|
|
end subroutine bind_c_s
|
|
|
|
! CHECK-LABEL: func @_QPbind_c_s() {
|
|
subroutine bind_c_s()
|
|
! CHECK: fir.call @_QPbind_c_q() : () -> ()
|
|
! CHECK: return
|
|
call bind_c_q
|
|
end
|
|
|
|
! CHECK-LABEL: func @_QPbind_c_q() {
|
|
subroutine bind_c_q()
|
|
interface
|
|
subroutine bind_c_s() Bind(C, name='bc1')
|
|
end
|
|
end interface
|
|
! CHECK: fir.call @bc1() : () -> ()
|
|
! CHECK: return
|
|
call bind_c_s
|
|
end
|
|
|
|
! Test that BIND(C) label is taken into account for ENTRY symbols.
|
|
! CHECK-LABEL: func @_QPsub_with_entries() {
|
|
subroutine sub_with_entries
|
|
! CHECK-LABEL: func @bar() attributes {fir.bindc_name = "bar"} {
|
|
entry some_entry() bind(c, name="bar")
|
|
! CHECK-LABEL: func @_QPnormal_entry() {
|
|
entry normal_entry()
|
|
! CHECK-LABEL: func @some_other_entry() attributes {fir.bindc_name = "some_other_entry"} {
|
|
entry some_other_entry() bind(c)
|
|
end subroutine
|
|
|
|
! Test that semantics constructs binding labels with local name resolution
|
|
module testMod3
|
|
character*(*), parameter :: foo = "bad!!"
|
|
character*(*), parameter :: ok = "ok"
|
|
interface
|
|
real function f1() bind(c,name=ok//'1')
|
|
import ok
|
|
end function
|
|
subroutine s1() bind(c,name=ok//'2')
|
|
import ok
|
|
end subroutine
|
|
end interface
|
|
contains
|
|
! CHECK-LABEL: func @ok3() -> f32 attributes {fir.bindc_name = "ok3"} {
|
|
real function f2() bind(c,name=foo//'3')
|
|
character*(*), parameter :: foo = ok
|
|
! CHECK: fir.call @ok1() : () -> f32
|
|
! CHECK-LABEL: func @ok4() -> f32 attributes {fir.bindc_name = "ok4"} {
|
|
entry f3() bind(c,name=foo//'4')
|
|
! CHECK: fir.call @ok1() : () -> f32
|
|
f2 = f1()
|
|
end function
|
|
! CHECK-LABEL: func @ok5() attributes {fir.bindc_name = "ok5"} {
|
|
subroutine s2() bind(c,name=foo//'5')
|
|
character*(*), parameter :: foo = ok
|
|
! CHECK: fir.call @ok2() : () -> ()
|
|
! CHECK-LABEL: func @ok6() attributes {fir.bindc_name = "ok6"} {
|
|
entry s3() bind(c,name=foo//'6')
|
|
! CHECK: fir.call @ok2() : () -> ()
|
|
continue ! force end of specification part
|
|
! CHECK-LABEL: func @ok7() attributes {fir.bindc_name = "ok7"} {
|
|
entry s4() bind(c,name=foo//'7')
|
|
! CHECK: fir.call @ok2() : () -> ()
|
|
call s1
|
|
end subroutine
|
|
end module
|
|
|
|
! CHECK-LABEL: fir.global internal @_QFfooEpi : f32 {
|