blob: cb9e00f637afa6298d037f2b7440293ae5ac7cc2 [file] [log] [blame]
! 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 {