public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
* Re: [Testsuite Fortran, Patch] Add coarray/ directory for coarray compile and run-time tests
  2011-04-30 21:15 [Testsuite Fortran, Patch] Add coarray/ directory for coarray compile and run-time tests Tobias Burnus
@ 2011-04-30 21:15 ` Tobias Burnus
  2011-05-05 14:05   ` Rainer Orth
  0 siblings, 1 reply; 3+ messages in thread
From: Tobias Burnus @ 2011-04-30 21:15 UTC (permalink / raw)
  To: gcc patches, gfortran, Rainer Orth, Mike Stump, Ralf Wildenhues

[-- Attachment #1: Type: text/plain, Size: 1161 bytes --]

Now with the .exp file - for those with broken crystal balls ...

Sorry for the initial omission,

Tobias

Tobias Burnus wrote:
> The patch adds the directory
>   gcc/testsuite/gfortran.dg/coarray/
>
> All files in this directory are compiled/linked/run with 
> "-fcoarray=single" and "-fcoarray=lib -lcaf_single". The compilation 
> is only done with -O2 - instead of cycling through all optimization 
> options; however, one could change that.
>
> The coarray_16.f90 "dg-do run" test is -fcoarray=lib proof and can be 
> moved into that directory.
>
> Questions:
>
> a) Is run-time testing with -O2 sufficient - or should all 
> DG_TORTURE_OPTIONS be used?
>
> b) Is the way of adding "-lcaf_single" acceptable?
>
> c) What's the best way to add support for -lcaf_mpi? I think, the user 
> needs to specify both compile/link options, e.g.
>    GCC_CAF_FLAGS="`mpif90 -showme` -lcaf_mpi"
> or
>    GCC_CAF_FFLAGS=`mpif90 -showme:compile`
>    GCC_CAF_LDFLAGS="`mpif90 -showme:link` -lcaf_mpi"
> and a run command, e.g.
>   GCC_CAF_RUN="mpiexec -n 2"
> either directly or via site.exp - which defaults to unset.
>
> Is the patch OK for the trunk?
>
> Tobias
>


[-- Attachment #2: caf.exp --]
[-- Type: text/plain, Size: 2364 bytes --]

# Copyright (C) 2011 Free Software Foundation, Inc.

# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with GCC; see the file COPYING3.  If not see
# <http://www.gnu.org/licenses/>.
#
# Contributed by Tobias Burnus <burnus@net-b.de>


# Test coarray support.
#
# For the compilation tests, all files are compiles with the
# option -fcoarray=single and with -fcoarray=lib
#
# For the link and execution tests, for -fcoarray=lib the
# libcaf_single library is linked. Additionally, with the
# required settings another CAF library is used.

# Load procedures from common libraries. 
load_lib gfortran-dg.exp

# If a testcase doesn't have special options, use these.
global DEFAULT_FFLAGS
if ![info exists DEFAULT_FFLAGS] then {
    set DEFAULT_FFLAGS " -pedantic-errors"
}

dg-init

global runtests
global DG_TORTURE_OPTIONS torture_with_loops

torture-init
set-torture-options $DG_TORTURE_OPTIONS

# Main loop.
foreach test [lsort [glob -nocomplain $srcdir/$subdir/*.\[fF\]{,90,95,03,08} ]] {
    # If we're only testing specific files and this isn't one of them, skip it.
    if ![runtest_file_p $runtests $test] then {
	continue
    }

# Enable if you want to test several options:
#    # look if this is dg-do-run test, in which case
#    # we cycle through the option list, otherwise we don't
#    if [expr [search_for $test "dg-do run"]] {
#	set option_list $torture_with_loops
#    } else {
#	set option_list [list { -O } ]
#    }
    set option_list [list { -O2 } ]

    set nshort [file tail [file dirname $test]]/[file tail $test]

    foreach flags $option_list {
	verbose "Testing $nshort (single), $flags" 1
	dg-test $test "-fcoarray=single $flags" "" 
    }

    foreach flags $option_list {
	verbose "Testing $nshort (libcaf_single), $flags" 1
	dg-test $test "-fcoarray=lib $flags -lcaf_single" ""
    }
}
torture-finish
dg-finish

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [Testsuite Fortran, Patch] Add coarray/ directory for coarray compile and run-time tests
@ 2011-04-30 21:15 Tobias Burnus
  2011-04-30 21:15 ` Tobias Burnus
  0 siblings, 1 reply; 3+ messages in thread
From: Tobias Burnus @ 2011-04-30 21:15 UTC (permalink / raw)
  To: gcc patches, gfortran, Rainer Orth, Mike Stump, Ralf Wildenhues

The patch adds the directory
   gcc/testsuite/gfortran.dg/coarray/

All files in this directory are compiled/linked/run with 
"-fcoarray=single" and "-fcoarray=lib -lcaf_single". The compilation is 
only done with -O2 - instead of cycling through all optimization 
options; however, one could change that.

The coarray_16.f90 "dg-do run" test is -fcoarray=lib proof and can be 
moved into that directory.

Questions:

a) Is run-time testing with -O2 sufficient - or should all 
DG_TORTURE_OPTIONS be used?

b) Is the way of adding "-lcaf_single" acceptable?

c) What's the best way to add support for -lcaf_mpi? I think, the user 
needs to specify both compile/link options, e.g.
    GCC_CAF_FLAGS="`mpif90 -showme` -lcaf_mpi"
or
    GCC_CAF_FFLAGS=`mpif90 -showme:compile`
    GCC_CAF_LDFLAGS="`mpif90 -showme:link` -lcaf_mpi"
and a run command, e.g.
   GCC_CAF_RUN="mpiexec -n 2"
either directly or via site.exp - which defaults to unset.

Is the patch OK for the trunk?

Tobias

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [Testsuite Fortran, Patch] Add coarray/ directory for coarray compile and run-time tests
  2011-04-30 21:15 ` Tobias Burnus
@ 2011-05-05 14:05   ` Rainer Orth
  0 siblings, 0 replies; 3+ messages in thread
From: Rainer Orth @ 2011-05-05 14:05 UTC (permalink / raw)
  To: Tobias Burnus; +Cc: gcc patches, gfortran, Mike Stump, Ralf Wildenhues

Tobias,

I know Mike already approved that patch.  Just a few nits.

> # Test coarray support.
> #
> # For the compilation tests, all files are compiles with the
                                                    ^ d
> # option -fcoarray=single and with -fcoarray=lib
                                                  ^ .

> # Enable if you want to test several options:
> #    # look if this is dg-do-run test, in which case
> #    # we cycle through the option list, otherwise we don't
> #    if [expr [search_for $test "dg-do run"]] {
> #	set option_list $torture_with_loops
> #    } else {
> #	set option_list [list { -O } ]
> #    }

I think we prefer not to have #if 0 (or equivalent) code in the tree.

Thanks.
	Rainer

-- 
-----------------------------------------------------------------------------
Rainer Orth, Center for Biotechnology, Bielefeld University

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2011-05-05 14:02 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2011-04-30 21:15 [Testsuite Fortran, Patch] Add coarray/ directory for coarray compile and run-time tests Tobias Burnus
2011-04-30 21:15 ` Tobias Burnus
2011-05-05 14:05   ` Rainer Orth

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).