-
-
Notifications
You must be signed in to change notification settings - Fork 58
/
issue-422-send-get.F90
92 lines (78 loc) · 3.37 KB
/
issue-422-send-get.F90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
! BSD 3-Clause License
!
! Copyright (c) 2016, Sourcery Institute
! All rights reserved.
!
! Redistribution and use in source and binary forms, with or without
! modification, are permitted provided that the following conditions are met:
!
! * Redistributions of source code must retain the above copyright notice, this
! list of conditions and the following disclaimer.
!
! * Redistributions in binary form must reproduce the above copyright notice,
! this list of conditions and the following disclaimer in the documentation
! and/or other materials provided with the distribution.
!
! * Neither the name of the copyright holder nor the names of its
! contributors may be used to endorse or promote products derived from
! this software without specific prior written permission.
!
! THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
! AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
! IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
! DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
! FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
! DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
! SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
! CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
! OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
! OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
program main
!! author: Damian Rouson
!! date: 2017-08-01
!! category: regression
!! Test whether assigning an allocatable coarray component to an allocatable
!! coarray component works.
!! OpenCoarrays issue #422
use iso_fortran_env, only : error_unit
implicit none
type foo
!! A derived type is required to demonstrate issue #422
integer, allocatable :: bar(:)[:]
end type
type(foo) :: foobar
enum, bind(C)
enumerator :: recipient=1, provider, getter_putter
!! provider=2, getter_putter=3
end enum
integer, parameter :: bar_size=2, required_images=3
associate( me=>this_image(), N_images=>num_images() )
verify_num_images: if (N_images<required_images) then
write(error_unit,*) "issue-422-send-get.f90 requires at least ",required_images," images"
error stop
end if verify_num_images
allocate(foobar%bar(bar_size)[*],source=me)
!! Assign each image's identifier to each element of foobar%bar
#ifndef GCC_GE_7
sync all
!! Issue #243 not backported to GCC < 7: implicit sync happens
!! after allocataion but before assignment
#endif
get_put_component: if (me==getter_putter) then
foobar%bar(:)[recipient] = foobar%bar(:)[provider]
!! Get bar from provider image and put bar on recipient image
sync images(recipient)
!! Signal recipient that get and put have completed
end if get_put_component
wait_and_verify: if (me==recipient) then
sync images(getter_putter)
!! Wait for signal from getter-putter
verify_result: if (any(foobar%bar/=provider)) then
write(error_unit,*) "Recipient image ",recipient," received ",foobar%bar," but expected ",provider
error stop
end if verify_result
print *,"Test passed."
!! Report success
end if wait_and_verify
end associate
end program