Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Default Open MPI 4.0.0 does not provide functions deprecated in MPI-2.0 #6114

Closed
bertwesarg opened this issue Nov 26, 2018 · 16 comments
Closed

Comments

@bertwesarg
Copy link
Member

Background information

What version of Open MPI are you using? (e.g., v1.10.3, v2.1.0, git branch name and hash, etc.)

Open MPI 4.0.0

Describe how Open MPI was installed (e.g., from a source/distribution tarball, from a git clone, from an operating system distribution package, etc.)

$ tar xf openmpi-4.0.0.tar.bz2
$ cd openmpi-4.0.0
$ mkdir _build
$ cd _build
$ ../configure --prefix=…

Please describe the system on which you are running

  • Operating system/version: Ubuntu 18.04..1
  • Computer hardware: ThinkPad X480s
  • Network type: N.A

Details of the problem

libmpi.so.40.20.0 misses the following symbols, which are deprecated in MPI-2.0 (see Chapter 15, page 599 pp.)

  • MPI_Keyval_create
  • MPI_Keyval_free
  • MPI_Attr_put
  • MPI_Attr_get
  • MPI_Attr_delete
$ nm ./ompi/.libs/libmpi.so.40.20.0 | grep '\(MPI_Keyval_create\|MPI_Keyval_free\|MPI_Attr_put\|MPI_Attr_get\|MPI_Attr_delete\)'
$

The worst part is, that there are prototypes in mpi.h:

cat >declcheck-depr-mpi-2.0.c <<EOF
#include <mpi.h>

void test()
{
    int ret = MPI_Keyval_create(NULL, NULL, NULL, NULL);
    ret = MPI_Keyval_free(NULL);
    ret = MPI_Attr_put(MPI_COMM_WORLD, 0, NULL);
    ret = MPI_Attr_get(MPI_COMM_WORLD, 0, NULL, NULL);
    ret = MPI_Attr_delete(MPI_COMM_WORLD, 0);
}
EOF
$ gcc -Iompi/include -c declcheck-depr-mpi-2.0.c

declcheck-depr-mpi-2.0.c: In function ‘test’:
declcheck-depr-mpi-2.0.c:5:5: warning: ‘MPI_Keyval_create’ is deprecated: MPI_Keyval_create was deprecated in MPI-2.0; use MPI_Comm_create_keyval instead. [-Wdeprecated-declarations]
     int ret = MPI_Keyval_create(NULL, NULL, NULL, NULL);
     ^~~
In file included from declcheck-depr-mpi-2.0.c:1:0:
ompi/include/mpi.h:2625:20: note: declared here
 OMPI_DECLSPEC  int MPI_Keyval_create(MPI_Copy_function *copy_fn,
                    ^~~~~~~~~~~~~~~~~
declcheck-depr-mpi-2.0.c:6:5: warning: ‘MPI_Keyval_free’ is deprecated: MPI_Keyval_free was deprecated in MPI-2.0; MPI_Comm_free_keyval instead. [-Wdeprecated-declarations]
     ret = MPI_Keyval_free(NULL);
     ^~~
In file included from declcheck-depr-mpi-2.0.c:1:0:
ompi/include/mpi.h:2633:20: note: declared here
 OMPI_DECLSPEC  int MPI_Keyval_free(int *keyval)
                    ^~~~~~~~~~~~~~~
declcheck-depr-mpi-2.0.c:7:5: warning: ‘MPI_Attr_put’ is deprecated: MPI_Attr_put was deprecated in MPI-2.0; use MPI_Comm_set_attr instead [-Wdeprecated-declarations]
     ret = MPI_Attr_put(MPI_COMM_WORLD, 0, NULL);
     ^~~
In file included from declcheck-depr-mpi-2.0.c:1:0:
ompi/include/mpi.h:2609:20: note: declared here
 OMPI_DECLSPEC  int MPI_Attr_put(MPI_Comm comm, int keyval, void *attribute_val)
                    ^~~~~~~~~~~~
declcheck-depr-mpi-2.0.c:8:5: warning: ‘MPI_Attr_get’ is deprecated: MPI_Attr_get was deprecated in MPI-2.0; use MPI_Comm_get_attr instead [-Wdeprecated-declarations]
     ret = MPI_Attr_get(MPI_COMM_WORLD, 0, NULL, NULL);
     ^~~
In file included from declcheck-depr-mpi-2.0.c:1:0:
ompi/include/mpi.h:2605:20: note: declared here
 OMPI_DECLSPEC  int MPI_Attr_get(MPI_Comm comm, int keyval, void *attribute_val, int *flag)
                    ^~~~~~~~~~~~
declcheck-depr-mpi-2.0.c:9:5: warning: ‘MPI_Attr_delete’ is deprecated: MPI_Attr_delete was deprecated in MPI-2.0; use MPI_Comm_delete_attr instead [-Wdeprecated-declarations]
     ret = MPI_Attr_delete(MPI_COMM_WORLD, 0);
     ^~~
In file included from declcheck-depr-mpi-2.0.c:1:0:
ompi/include/mpi.h:2601:20: note: declared here
 OMPI_DECLSPEC  int MPI_Attr_delete(MPI_Comm comm, int keyval)
                    ^~~~~~~~~~~~~~~
bertwesarg added a commit to bertwesarg/ompi that referenced this issue Nov 26, 2018
See open-mpi#6114

Signed-off-by: Bert Wesarg <bert.wesarg@tu-dresden.de>
@bosilca
Copy link
Member

bosilca commented Nov 26, 2018

The prototypes are there just so that the compiler can give you a nice warnings about the use of deprecated symbols.

@bertwesarg
Copy link
Member Author

The prototypes are there just so that the compiler can give you a nice warnings about the use of deprecated symbols.

"deprecated" is not the same as "removed". So what do you want me to tell with your comment?

@bosilca
Copy link
Member

bosilca commented Nov 26, 2018

Nothing more than these symbols should not be used. It's been years MPI libraries issue warnings about deprecated symbols, and still some software developers chose to ignore them. The warnings suggest what functions should be used instead, updating software packages should be easy.

@bertwesarg
Copy link
Member Author

Sorry, you just explained "deprecated" to me. But what Open MPI did, was to "remove" these functions without removing the declaration.

@jsquyres
Copy link
Member

jsquyres commented Nov 26, 2018

Shoot. I know we intended to fix this before v4.0.0 went out the door -- and I see that #6018 was the attempt to do that. But it looks like #6018 fixed mpi.h, but did not fix Makefile.am. 😦

@jsquyres
Copy link
Member

Actually, @hjelmn @bertwesarg, was #6118 enough? I.e., shouldn't all the .c files in ompi/mpi/c always be in the library? I.e., the --enable-mpi-compatibility flag should only affect whether declarations are in mpi.h, right?

@hjelmn
Copy link
Member

hjelmn commented Nov 26, 2018

#6118 was enough for master. Need one more for v4.0.x

@hjelmn hjelmn closed this as completed Nov 26, 2018
@hjelmn hjelmn reopened this Nov 26, 2018
@hjelmn
Copy link
Member

hjelmn commented Nov 26, 2018

Really hate that close and comment button.......

gpaulsen pushed a commit to gpaulsen/ompi that referenced this issue Nov 26, 2018
See open-mpi#6114

Signed-off-by: Bert Wesarg <bert.wesarg@tu-dresden.de>
@bertwesarg
Copy link
Member Author

Actually, @hjelmn @bertwesarg, was #6118 enough? I.e., shouldn't all the .c files in ompi/mpi/c always be in the library? I.e., the --enable-mpi-compatibility flag should only affect whether declarations are in mpi.h, right?

I tend to agree. The slides from the BOF [1] are pretty clear here:

NOT PROTOYPED IN v4.0.x mpi.h BY DEFAULT

I.e., this can be changed!

The symbols are in libmpi, however (so ABI is preserved)

I.e., this is always the case!

[1] https://www.open-mpi.org/papers/sc-2018/Open-MPI-SC18-BOF.pdf

@jsquyres
Copy link
Member

@bertwesarg Yeah, this is definitely exactly what I had in mind when I made those slides (i.e., the symbols are always there -- but the prototypes may not be).

@bertwesarg
Copy link
Member Author

BTW, I tried the ABI compience checker on this issue, and it did not detected it!
ompi-3.1.3.mpi.abi.gz
ompi-4.0.0.mpi.abi.gz

It only reported these symbols as removed:

OMPI_C_MPI_DUP_FN
OMPI_C_MPI_NULL_COPY_FN
OMPI_C_MPI_NULL_DELETE_FN
ompi_request_persistent_proc_null_free
ompi_orte_tracker_t_class

@bertwesarg
Copy link
Member Author

May I suggest that someone add the 'State: Awaiting merge to release branches' label to this issue. Thanks.

gpaulsen pushed a commit to gpaulsen/ompi that referenced this issue Nov 29, 2018
See open-mpi#6114

Signed-off-by: Bert Wesarg <bert.wesarg@tu-dresden.de>
(cherry picked from commit b3f3281)
bosilca pushed a commit to bosilca/ompi that referenced this issue Dec 3, 2018
See open-mpi#6114

Signed-off-by: Bert Wesarg <bert.wesarg@tu-dresden.de>
gpaulsen pushed a commit to gpaulsen/ompi that referenced this issue Dec 11, 2018
See open-mpi#6114

Signed-off-by: Bert Wesarg <bert.wesarg@tu-dresden.de>
(cherry picked from commit b3f3281)
@apjanke
Copy link
Contributor

apjanke commented Dec 11, 2018

Hi folks,

I'm getting a build failure when trying to build scalapack 2.0.2 against Open-MPI 4.0.0, where it worked against Open-MPI 3.1.3. This is on macOS 10.13.6.

The build error is a link problem that looks like it includes some of these deprecated symbols:

[ 62%] Linking Fortran shared library lib/libscalapack.dylib
/usr/local/Cellar/cmake/3.13.1/bin/cmake -E cmake_link_script CMakeFiles/scalapack.dir/link.txt --verbose=1
/usr/local/bin/mpif90 -O2 -DNDEBUG -O2 -dynamiclib -Wl,-headerpad_max_install_names  -o lib/libscalapack.dylib -install_name /tmp/scalapack-20181211-63099-14r05qx/scalapack-2.0.2/build/lib/libscalapack.dylib CMakeFiles/scalapack.dir/BLACS/SRC/igesd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgesd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgesd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgesd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgesd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrsd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strsd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrsd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrsd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrsd2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igerv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgerv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgerv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgerv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgerv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrrv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strrv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrrv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrrv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrrv2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igebs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgebs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgebs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgebs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgebs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igebr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgebr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgebr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgebr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgebr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrbs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strbs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrbs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrbs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrbs2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrbr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strbr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrbr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrbr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrbr2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igsum2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgsum2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgsum2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgsum2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgsum2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igamx2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgamx2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgamx2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgamx2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgamx2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igamn2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgamn2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgamn2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgamn2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgamn2d_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_setup_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_set_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_get_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_abort_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_exit_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_pnum_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_pcoord_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ksendid_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/krecvid_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/kbsid_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/kbrid_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dcputime00_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dwalltime00_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_pinfo_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_init_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_map_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_free_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_grid_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_info_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_barr_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sys2blacs_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs2sys_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/free_handle_.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igesd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgesd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgesd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgesd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgesd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrsd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strsd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrsd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrsd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrsd2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igerv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgerv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgerv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgerv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgerv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrrv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strrv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrrv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrrv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrrv2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igebs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgebs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgebs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgebs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgebs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igebr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgebr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgebr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgebr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgebr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrbs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strbs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrbs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrbs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrbs2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/itrbr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/strbr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dtrbr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ctrbr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ztrbr2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igsum2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgsum2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgsum2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgsum2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgsum2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igamx2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgamx2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgamx2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgamx2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgamx2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/igamn2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sgamn2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dgamn2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/cgamn2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/zgamn2d_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_setup_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_set_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_get_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_abort_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_exit_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_pnum_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_pcoord_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/ksendid_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/krecvid_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/kbsid_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/kbrid_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dcputime00_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/dwalltime00_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_pinfo_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_init_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_map_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_free_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_grid_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_info_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs_barr_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/sys2blacs_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/blacs2sys_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/free_handle_-C.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_HypBS.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_HypBR.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_IdringBS.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_IdringBR.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_MpathBS.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_MpathBR.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_SringBS.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_SringBR.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_TreeBS.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_TreeBR.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_Ssend.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_Rsend.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_Srecv.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_Asend.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_Arecv.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_TreeComb.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_BeComb.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_MringComb.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ArgCheck.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_TransDist.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_GetBuff.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_UpdateBuffs.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_EmergencyBuff.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_BlacsErr.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_BlacsWarn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_BlacsAbort.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_BuffIsFree.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_imvcopy.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_smvcopy.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dmvcopy.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ivmcopy.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_svmcopy.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dvmcopy.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_Pack.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_Unpack.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_GetMpiGeType.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_GetMpiTrType.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ivvsum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_svvsum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dvvsum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cvvsum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zvvsum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ivvamx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_svvamx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dvvamx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cvvamx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zvvamx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ivvamx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_svvamx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dvvamx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cvvamx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zvvamx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ivvamn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_svvamn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dvvamn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cvvamn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zvvamn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ivvamn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_svvamn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dvvamn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cvvamn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zvvamn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_iMPI_amx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_sMPI_amx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dMPI_amx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cMPI_amx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zMPI_amx.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_iMPI_amx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_sMPI_amx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dMPI_amx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cMPI_amx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zMPI_amx2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_iMPI_amn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_sMPI_amn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dMPI_amn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cMPI_amn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zMPI_amn.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_iMPI_amn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_sMPI_amn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_dMPI_amn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cMPI_amn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zMPI_amn2.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_cMPI_sum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_zMPI_sum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_ContxtNum.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_GlobalVars.c.o CMakeFiles/scalapack.dir/BLACS/SRC/BI_TransUserComm.c.o CMakeFiles/scalapack.dir/TOOLS/iceil.f.o CMakeFiles/scalapack.dir/TOOLS/ilacpy.f.o CMakeFiles/scalapack.dir/TOOLS/ilcm.f.o CMakeFiles/scalapack.dir/TOOLS/indxg2p.f.o CMakeFiles/scalapack.dir/TOOLS/indxg2l.f.o CMakeFiles/scalapack.dir/TOOLS/indxl2g.f.o CMakeFiles/scalapack.dir/TOOLS/infog1l.f.o CMakeFiles/scalapack.dir/TOOLS/infog2l.f.o CMakeFiles/scalapack.dir/TOOLS/npreroc.f.o CMakeFiles/scalapack.dir/TOOLS/numroc.f.o CMakeFiles/scalapack.dir/TOOLS/chk1mat.f.o CMakeFiles/scalapack.dir/TOOLS/pchkxmat.f.o CMakeFiles/scalapack.dir/TOOLS/sltimer.f.o CMakeFiles/scalapack.dir/TOOLS/desc_convert.f.o CMakeFiles/scalapack.dir/TOOLS/descinit.f.o CMakeFiles/scalapack.dir/TOOLS/descset.f.o CMakeFiles/scalapack.dir/TOOLS/SL_init.f.o CMakeFiles/scalapack.dir/TOOLS/picol2row.f.o CMakeFiles/scalapack.dir/TOOLS/pirow2col.f.o CMakeFiles/scalapack.dir/TOOLS/pilaprnt.f.o CMakeFiles/scalapack.dir/TOOLS/pitreecomb.f.o CMakeFiles/scalapack.dir/TOOLS/pifillpad.f.o CMakeFiles/scalapack.dir/TOOLS/pichekpad.f.o CMakeFiles/scalapack.dir/TOOLS/pielset.f.o CMakeFiles/scalapack.dir/TOOLS/pielset2.f.o CMakeFiles/scalapack.dir/TOOLS/pielget.f.o CMakeFiles/scalapack.dir/TOOLS/dsnrm2.f.o CMakeFiles/scalapack.dir/TOOLS/dsasum.f.o CMakeFiles/scalapack.dir/TOOLS/slatcpy.f.o CMakeFiles/scalapack.dir/TOOLS/ssdot.f.o CMakeFiles/scalapack.dir/TOOLS/smatadd.f.o CMakeFiles/scalapack.dir/TOOLS/psmatadd.f.o CMakeFiles/scalapack.dir/TOOLS/pscol2row.f.o CMakeFiles/scalapack.dir/TOOLS/psrow2col.f.o CMakeFiles/scalapack.dir/TOOLS/pslaprnt.f.o CMakeFiles/scalapack.dir/TOOLS/pstreecomb.f.o CMakeFiles/scalapack.dir/TOOLS/psfillpad.f.o CMakeFiles/scalapack.dir/TOOLS/pschekpad.f.o CMakeFiles/scalapack.dir/TOOLS/pselset.f.o CMakeFiles/scalapack.dir/TOOLS/pselset2.f.o CMakeFiles/scalapack.dir/TOOLS/pselget.f.o CMakeFiles/scalapack.dir/TOOLS/pslaread.f.o CMakeFiles/scalapack.dir/TOOLS/pslawrite.f.o CMakeFiles/scalapack.dir/TOOLS/dddot.f.o CMakeFiles/scalapack.dir/TOOLS/dlatcpy.f.o CMakeFiles/scalapack.dir/TOOLS/dmatadd.f.o CMakeFiles/scalapack.dir/TOOLS/pdmatadd.f.o CMakeFiles/scalapack.dir/TOOLS/pdcol2row.f.o CMakeFiles/scalapack.dir/TOOLS/pdrow2col.f.o CMakeFiles/scalapack.dir/TOOLS/pdlaprnt.f.o CMakeFiles/scalapack.dir/TOOLS/pdtreecomb.f.o CMakeFiles/scalapack.dir/TOOLS/pdfillpad.f.o CMakeFiles/scalapack.dir/TOOLS/pdchekpad.f.o CMakeFiles/scalapack.dir/TOOLS/pdelset.f.o CMakeFiles/scalapack.dir/TOOLS/pdelset2.f.o CMakeFiles/scalapack.dir/TOOLS/pdelget.f.o CMakeFiles/scalapack.dir/TOOLS/pdlaread.f.o CMakeFiles/scalapack.dir/TOOLS/pdlawrite.f.o CMakeFiles/scalapack.dir/TOOLS/dscnrm2.f.o CMakeFiles/scalapack.dir/TOOLS/dscasum.f.o CMakeFiles/scalapack.dir/TOOLS/ccdotu.f.o CMakeFiles/scalapack.dir/TOOLS/ccdotc.f.o CMakeFiles/scalapack.dir/TOOLS/clatcpy.f.o CMakeFiles/scalapack.dir/TOOLS/cmatadd.f.o CMakeFiles/scalapack.dir/TOOLS/pcmatadd.f.o CMakeFiles/scalapack.dir/TOOLS/pccol2row.f.o CMakeFiles/scalapack.dir/TOOLS/pcrow2col.f.o CMakeFiles/scalapack.dir/TOOLS/pclaprnt.f.o CMakeFiles/scalapack.dir/TOOLS/pctreecomb.f.o CMakeFiles/scalapack.dir/TOOLS/pcfillpad.f.o CMakeFiles/scalapack.dir/TOOLS/pcchekpad.f.o CMakeFiles/scalapack.dir/TOOLS/pcelset.f.o CMakeFiles/scalapack.dir/TOOLS/pcelset2.f.o CMakeFiles/scalapack.dir/TOOLS/pcelget.f.o CMakeFiles/scalapack.dir/TOOLS/pclaread.f.o CMakeFiles/scalapack.dir/TOOLS/pclawrite.f.o CMakeFiles/scalapack.dir/TOOLS/zzdotu.f.o CMakeFiles/scalapack.dir/TOOLS/zzdotc.f.o CMakeFiles/scalapack.dir/TOOLS/zlatcpy.f.o CMakeFiles/scalapack.dir/TOOLS/zmatadd.f.o CMakeFiles/scalapack.dir/TOOLS/pzmatadd.f.o CMakeFiles/scalapack.dir/TOOLS/pzcol2row.f.o CMakeFiles/scalapack.dir/TOOLS/pzrow2col.f.o CMakeFiles/scalapack.dir/TOOLS/pzlaprnt.f.o CMakeFiles/scalapack.dir/TOOLS/pztreecomb.f.o CMakeFiles/scalapack.dir/TOOLS/pzfillpad.f.o CMakeFiles/scalapack.dir/TOOLS/pzchekpad.f.o CMakeFiles/scalapack.dir/TOOLS/pzelset.f.o CMakeFiles/scalapack.dir/TOOLS/pzelset2.f.o CMakeFiles/scalapack.dir/TOOLS/pzelget.f.o CMakeFiles/scalapack.dir/TOOLS/pzlaread.f.o CMakeFiles/scalapack.dir/TOOLS/pzlawrite.f.o CMakeFiles/scalapack.dir/TOOLS/reshape.c.o CMakeFiles/scalapack.dir/TOOLS/SL_gridreshape.c.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/icopy.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/slatm1.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/slaran.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/slarnd.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/slatms.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/slagge.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/slagsy.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/slarot.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/clarnv.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/clatm1.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/clatms.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/clagge.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/claghe.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/clagsy.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/clarot.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/clarnd.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/dlatm1.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/dlaran.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/dlarnd.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/dlatms.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/dlagge.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/dlagsy.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/dlarot.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlarnv.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlatm1.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlatms.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlagge.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlaghe.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlagsy.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlarot.f.o CMakeFiles/scalapack.dir/TOOLS/LAPACK/zlarnd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/picopy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psswap_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psscal_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pscopy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psaxpy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psdot_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psnrm2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psasum_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psamax_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcswap_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcscal_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcsscal_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pccopy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcaxpy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcdotu_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcdotc_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pscnrm2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pscasum_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcamax_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdswap_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdscal_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdcopy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdaxpy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pddot_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdnrm2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdasum_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdamax_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzswap_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzscal_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzdscal_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzcopy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzaxpy_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzdotu_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzdotc_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdznrm2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdzasum_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzamax_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psgemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psger_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pssymv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pssyr_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pssyr2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pstrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pstrsv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psagemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psasymv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psatrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcgemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcgerc_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcgeru_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pchemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcher_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcher2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pctrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pctrsv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcagemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcahemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcatrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdgemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdger_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdsymv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdsyr_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdsyr2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdtrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdtrsv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdagemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdasymv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdatrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzgemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzgerc_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzgeru_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzhemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzher_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzher2_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pztrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pztrsv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzagemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzahemv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzatrmv_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psgeadd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/psgemm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pssymm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pssyr2k_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pssyrk_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pstradd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pstran_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pstrmm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pstrsm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcgeadd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcgemm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pchemm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcher2k_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcherk_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcsymm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcsyr2k_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pcsyrk_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pctradd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pctranc_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pctranu_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pctrmm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pctrsm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdgeadd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdgemm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdsymm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdsyr2k_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdsyrk_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdtradd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdtran_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdtrmm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pdtrsm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzgeadd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzgemm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzhemm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzher2k_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzherk_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzsymm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzsyr2k_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pzsyrk_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pztradd_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pztranc_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pztranu_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pztrmm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pztrsm_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/pilaenv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/pxerbla.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/immadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/immdda.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/immtadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/immddat.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/svasum.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/sset.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/scshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/srshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/svvdot.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmtadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmtcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmdda.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmddac.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmddat.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/smmddact.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/stzpad.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/stzpadcpy.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/stzscal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/sagemv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/sasymv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/satrmv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/sasqrtb.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/sascal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/scvasum.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cset.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ccshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/crshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cvvdotu.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cvvdotc.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmtadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmtcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmdda.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmddac.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmddat.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cmmddact.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ctzpad.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ctzpadcpy.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/chescal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ctzscal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ctzcnjg.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cagemv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/cahemv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/catrmv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/casymv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/csymv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/csyr.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/csyr2.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dvasum.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dset.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dcshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/drshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dvvdot.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmtadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmtcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmdda.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmddac.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmddat.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dmmddact.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dtzpad.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dtzpadcpy.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dtzscal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dagemv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dasymv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/datrmv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dasqrtb.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dascal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/dzvasum.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zset.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zcshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zrshft.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zvvdotu.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zvvdotc.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmtadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmtcadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmdda.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmddac.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmddat.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zmmddact.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ztzpad.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ztzpadcpy.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zhescal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ztzscal.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/ztzcnjg.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zagemv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zahemv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zatrmv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zasymv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zsymv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zsyr.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTZBLAS/zsyr2.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CGatherV.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CInV.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CInV2.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CInOutV.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CInOutV2.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_COutV.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CScatterV.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CVMinit.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CVMloc.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CVMnpq.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CVMpack.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CVMswp.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CVMupdate.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CVMcontig.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cabort.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cainfog2l.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cbinfo.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cchkmat.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cchkvec.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cconjg.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cgetbuf.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cinfog2l.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Citypeset.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cgcd.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Clcm.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cmalloc.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cnumroc.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cg2lrem.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cindxg2p.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cnnxtroc.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cnpreroc.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpswapNN.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpswapND.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpdot11.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpdotNN.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpdotND.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpaxpbyNN.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpaxpbyND.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpaxpbyDN.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpaxpby.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpgemmBC.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpgemmAC.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpgemmAB.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cplaprnt.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cplapad.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cplapd2.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cplascal.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cplasca2.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cplacnjg.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpsym.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpsymmAB.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpsymmBC.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpsyr.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpsyrkA.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CpsyrkAC.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpsyr2.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpsyr2kA.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpsyr2kAC.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cptrm.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cpgeadd.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cptradd.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cptran.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CptrmmAB.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CptrmmB.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cptrsm.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CptrsmAB.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CptrsmAB0.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CptrsmAB1.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CptrsmB.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cptrsv.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctop.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzahemv.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzasymv.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzatrmv.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzhemm.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzhemv.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzher.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzherk.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzher2.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzher2k.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzsymm.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzsymv.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzsyr.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzsyrk.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzsyr2.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctzsyr2k.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctztrmm.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Ctztrmv.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cwarn.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_freebuf_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_topget_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_topset_.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cdescset.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cdescribe.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_CargFtoC.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cfirstnb.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Clastnb.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cspan.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cstypeset.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cdtypeset.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cctypeset.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PTOOLS/PB_Cztypeset.c.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbstran.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbsmatadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbstrsrt.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbstrget.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbstrnv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbsvecadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbstrst1.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbctran.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbcmatadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbctrsrt.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbctrget.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbctrnv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbcvecadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbctrst1.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbdtran.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbdmatadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbdtrsrt.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbdtrget.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbdtrnv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbdvecadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbdtrst1.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbztran.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbzmatadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbztrsrt.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbztrget.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbztrnv.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbzvecadd.f.o CMakeFiles/scalapack.dir/PBLAS/SRC/PBBLAS/pbztrst1.f.o CMakeFiles/scalapack.dir/REDIST/SRC/pgemraux.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pigemr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pigemr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pitrmr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pitrmr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/psgemr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/psgemr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pstrmr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pstrmr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pcgemr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pcgemr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pctrmr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pctrmr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pdgemr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pdgemr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pdtrmr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pdtrmr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pzgemr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pzgemr2.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pztrmr.c.o CMakeFiles/scalapack.dir/REDIST/SRC/pztrmr2.c.o CMakeFiles/scalapack.dir/SRC/pjlaenv.f.o CMakeFiles/scalapack.dir/SRC/pilaenvx.f.o CMakeFiles/scalapack.dir/SRC/piparmq.f.o CMakeFiles/scalapack.dir/SRC/pilaver.f.o CMakeFiles/scalapack.dir/SRC/pmpim2.f.o CMakeFiles/scalapack.dir/SRC/pmpcol.f.o CMakeFiles/scalapack.dir/SRC/pslabad.f.o CMakeFiles/scalapack.dir/SRC/pslaed0.f.o CMakeFiles/scalapack.dir/SRC/pslaed1.f.o CMakeFiles/scalapack.dir/SRC/pslaed2.f.o CMakeFiles/scalapack.dir/SRC/pslaed3.f.o CMakeFiles/scalapack.dir/SRC/pslaedz.f.o CMakeFiles/scalapack.dir/SRC/pslamch.f.o CMakeFiles/scalapack.dir/SRC/pslared1d.f.o CMakeFiles/scalapack.dir/SRC/pslasrt.f.o CMakeFiles/scalapack.dir/SRC/psstebz.f.o CMakeFiles/scalapack.dir/SRC/psstedc.f.o CMakeFiles/scalapack.dir/SRC/slapst.f.o CMakeFiles/scalapack.dir/SRC/slasrt2.f.o CMakeFiles/scalapack.dir/SRC/sstein2.f.o CMakeFiles/scalapack.dir/SRC/slar1va.f.o CMakeFiles/scalapack.dir/SRC/slarrb2.f.o CMakeFiles/scalapack.dir/SRC/slarrd2.f.o CMakeFiles/scalapack.dir/SRC/slarre2.f.o CMakeFiles/scalapack.dir/SRC/slarre2a.f.o CMakeFiles/scalapack.dir/SRC/slarrf2.f.o CMakeFiles/scalapack.dir/SRC/slarrv2.f.o CMakeFiles/scalapack.dir/SRC/sstegr2.f.o CMakeFiles/scalapack.dir/SRC/sstegr2a.f.o CMakeFiles/scalapack.dir/SRC/sstegr2b.f.o CMakeFiles/scalapack.dir/SRC/pdlabad.f.o CMakeFiles/scalapack.dir/SRC/pdlaed0.f.o CMakeFiles/scalapack.dir/SRC/pdlaed1.f.o CMakeFiles/scalapack.dir/SRC/pdlaed2.f.o CMakeFiles/scalapack.dir/SRC/pdlaed3.f.o CMakeFiles/scalapack.dir/SRC/pdlaedz.f.o CMakeFiles/scalapack.dir/SRC/pdlamch.f.o CMakeFiles/scalapack.dir/SRC/pdlared1d.f.o CMakeFiles/scalapack.dir/SRC/pdlasrt.f.o CMakeFiles/scalapack.dir/SRC/pdstebz.f.o CMakeFiles/scalapack.dir/SRC/pdstedc.f.o CMakeFiles/scalapack.dir/SRC/dlapst.f.o CMakeFiles/scalapack.dir/SRC/dlasrt2.f.o CMakeFiles/scalapack.dir/SRC/dstein2.f.o CMakeFiles/scalapack.dir/SRC/dlar1va.f.o CMakeFiles/scalapack.dir/SRC/dlarrb2.f.o CMakeFiles/scalapack.dir/SRC/dlarrd2.f.o CMakeFiles/scalapack.dir/SRC/dlarre2.f.o CMakeFiles/scalapack.dir/SRC/dlarre2a.f.o CMakeFiles/scalapack.dir/SRC/dlarrf2.f.o CMakeFiles/scalapack.dir/SRC/dlarrv2.f.o CMakeFiles/scalapack.dir/SRC/dstegr2.f.o CMakeFiles/scalapack.dir/SRC/dstegr2a.f.o CMakeFiles/scalapack.dir/SRC/dstegr2b.f.o CMakeFiles/scalapack.dir/SRC/psdbsv.f.o CMakeFiles/scalapack.dir/SRC/psdbtrf.f.o CMakeFiles/scalapack.dir/SRC/psdbtrs.f.o CMakeFiles/scalapack.dir/SRC/psdbtrsv.f.o CMakeFiles/scalapack.dir/SRC/psdtsv.f.o CMakeFiles/scalapack.dir/SRC/psdttrf.f.o CMakeFiles/scalapack.dir/SRC/psdttrs.f.o CMakeFiles/scalapack.dir/SRC/psdttrsv.f.o CMakeFiles/scalapack.dir/SRC/psgbsv.f.o CMakeFiles/scalapack.dir/SRC/psgbtrf.f.o CMakeFiles/scalapack.dir/SRC/psgbtrs.f.o CMakeFiles/scalapack.dir/SRC/psgebd2.f.o CMakeFiles/scalapack.dir/SRC/psgebrd.f.o CMakeFiles/scalapack.dir/SRC/psgecon.f.o CMakeFiles/scalapack.dir/SRC/psgeequ.f.o CMakeFiles/scalapack.dir/SRC/psgehd2.f.o CMakeFiles/scalapack.dir/SRC/psgehrd.f.o CMakeFiles/scalapack.dir/SRC/psgelq2.f.o CMakeFiles/scalapack.dir/SRC/psgelqf.f.o CMakeFiles/scalapack.dir/SRC/psgels.f.o CMakeFiles/scalapack.dir/SRC/psgeql2.f.o CMakeFiles/scalapack.dir/SRC/psgeqlf.f.o CMakeFiles/scalapack.dir/SRC/psgeqpf.f.o CMakeFiles/scalapack.dir/SRC/psgeqr2.f.o CMakeFiles/scalapack.dir/SRC/psgeqrf.f.o CMakeFiles/scalapack.dir/SRC/psgerfs.f.o CMakeFiles/scalapack.dir/SRC/psgerq2.f.o CMakeFiles/scalapack.dir/SRC/psgerqf.f.o CMakeFiles/scalapack.dir/SRC/psgesv.f.o CMakeFiles/scalapack.dir/SRC/psgesvd.f.o CMakeFiles/scalapack.dir/SRC/psgesvx.f.o CMakeFiles/scalapack.dir/SRC/psgetf2.f.o CMakeFiles/scalapack.dir/SRC/psgetrf.f.o CMakeFiles/scalapack.dir/SRC/psgetri.f.o CMakeFiles/scalapack.dir/SRC/psgetrs.f.o CMakeFiles/scalapack.dir/SRC/psggqrf.f.o CMakeFiles/scalapack.dir/SRC/psggrqf.f.o CMakeFiles/scalapack.dir/SRC/pslabrd.f.o CMakeFiles/scalapack.dir/SRC/pslacon.f.o CMakeFiles/scalapack.dir/SRC/pslacp2.f.o CMakeFiles/scalapack.dir/SRC/pslacpy.f.o CMakeFiles/scalapack.dir/SRC/pslahrd.f.o CMakeFiles/scalapack.dir/SRC/pslange.f.o CMakeFiles/scalapack.dir/SRC/pslanhs.f.o CMakeFiles/scalapack.dir/SRC/pslansy.f.o CMakeFiles/scalapack.dir/SRC/pslantr.f.o CMakeFiles/scalapack.dir/SRC/pslapiv.f.o CMakeFiles/scalapack.dir/SRC/pslapv2.f.o CMakeFiles/scalapack.dir/SRC/pslaqge.f.o CMakeFiles/scalapack.dir/SRC/pslaqsy.f.o CMakeFiles/scalapack.dir/SRC/pslarf.f.o CMakeFiles/scalapack.dir/SRC/pslarfb.f.o CMakeFiles/scalapack.dir/SRC/pslarfg.f.o CMakeFiles/scalapack.dir/SRC/pslarft.f.o CMakeFiles/scalapack.dir/SRC/pslase2.f.o CMakeFiles/scalapack.dir/SRC/pslaset.f.o CMakeFiles/scalapack.dir/SRC/pslascl.f.o CMakeFiles/scalapack.dir/SRC/pslassq.f.o CMakeFiles/scalapack.dir/SRC/pslaswp.f.o CMakeFiles/scalapack.dir/SRC/pslatra.f.o CMakeFiles/scalapack.dir/SRC/pslatrd.f.o CMakeFiles/scalapack.dir/SRC/pslatrs.f.o CMakeFiles/scalapack.dir/SRC/pslauu2.f.o CMakeFiles/scalapack.dir/SRC/pslauum.f.o CMakeFiles/scalapack.dir/SRC/psorg2l.f.o CMakeFiles/scalapack.dir/SRC/psorg2r.f.o CMakeFiles/scalapack.dir/SRC/psorgl2.f.o CMakeFiles/scalapack.dir/SRC/psorglq.f.o CMakeFiles/scalapack.dir/SRC/psorgql.f.o CMakeFiles/scalapack.dir/SRC/psorgqr.f.o CMakeFiles/scalapack.dir/SRC/psorgr2.f.o CMakeFiles/scalapack.dir/SRC/psorgrq.f.o CMakeFiles/scalapack.dir/SRC/psorm2l.f.o CMakeFiles/scalapack.dir/SRC/psorm2r.f.o CMakeFiles/scalapack.dir/SRC/psormbr.f.o CMakeFiles/scalapack.dir/SRC/psormhr.f.o CMakeFiles/scalapack.dir/SRC/psorml2.f.o CMakeFiles/scalapack.dir/SRC/psormlq.f.o CMakeFiles/scalapack.dir/SRC/psormql.f.o CMakeFiles/scalapack.dir/SRC/psormqr.f.o CMakeFiles/scalapack.dir/SRC/psormr2.f.o CMakeFiles/scalapack.dir/SRC/psormrq.f.o CMakeFiles/scalapack.dir/SRC/psormtr.f.o CMakeFiles/scalapack.dir/SRC/pspocon.f.o CMakeFiles/scalapack.dir/SRC/pspbsv.f.o CMakeFiles/scalapack.dir/SRC/pspbtrf.f.o CMakeFiles/scalapack.dir/SRC/pspbtrs.f.o CMakeFiles/scalapack.dir/SRC/pspbtrsv.f.o CMakeFiles/scalapack.dir/SRC/psptsv.f.o CMakeFiles/scalapack.dir/SRC/pspttrf.f.o CMakeFiles/scalapack.dir/SRC/pspttrs.f.o CMakeFiles/scalapack.dir/SRC/pspttrsv.f.o CMakeFiles/scalapack.dir/SRC/pspoequ.f.o CMakeFiles/scalapack.dir/SRC/psporfs.f.o CMakeFiles/scalapack.dir/SRC/psposv.f.o CMakeFiles/scalapack.dir/SRC/psposvx.f.o CMakeFiles/scalapack.dir/SRC/pspotf2.f.o CMakeFiles/scalapack.dir/SRC/pspotrf.f.o CMakeFiles/scalapack.dir/SRC/pspotri.f.o CMakeFiles/scalapack.dir/SRC/pspotrs.f.o CMakeFiles/scalapack.dir/SRC/psrscl.f.o CMakeFiles/scalapack.dir/SRC/psstein.f.o CMakeFiles/scalapack.dir/SRC/pssyev.f.o CMakeFiles/scalapack.dir/SRC/pssyevd.f.o CMakeFiles/scalapack.dir/SRC/pssyevx.f.o CMakeFiles/scalapack.dir/SRC/pssygs2.f.o CMakeFiles/scalapack.dir/SRC/pssygst.f.o CMakeFiles/scalapack.dir/SRC/pssygvx.f.o CMakeFiles/scalapack.dir/SRC/pssyngst.f.o CMakeFiles/scalapack.dir/SRC/pssyntrd.f.o CMakeFiles/scalapack.dir/SRC/pssyttrd.f.o CMakeFiles/scalapack.dir/SRC/pssytd2.f.o CMakeFiles/scalapack.dir/SRC/pssytrd.f.o CMakeFiles/scalapack.dir/SRC/pstrti2.f.o CMakeFiles/scalapack.dir/SRC/pstrtri.f.o CMakeFiles/scalapack.dir/SRC/pstrtrs.f.o CMakeFiles/scalapack.dir/SRC/pslaevswp.f.o CMakeFiles/scalapack.dir/SRC/pslarzb.f.o CMakeFiles/scalapack.dir/SRC/pslarzt.f.o CMakeFiles/scalapack.dir/SRC/pslarz.f.o CMakeFiles/scalapack.dir/SRC/pslatrz.f.o CMakeFiles/scalapack.dir/SRC/pstzrzf.f.o CMakeFiles/scalapack.dir/SRC/psormr3.f.o CMakeFiles/scalapack.dir/SRC/psormrz.f.o CMakeFiles/scalapack.dir/SRC/pslahqr.f.o CMakeFiles/scalapack.dir/SRC/pslaconsb.f.o CMakeFiles/scalapack.dir/SRC/pslacp3.f.o CMakeFiles/scalapack.dir/SRC/pslawil.f.o CMakeFiles/scalapack.dir/SRC/pslasmsub.f.o CMakeFiles/scalapack.dir/SRC/pslared2d.f.o CMakeFiles/scalapack.dir/SRC/pslamr1d.f.o CMakeFiles/scalapack.dir/SRC/slaref.f.o CMakeFiles/scalapack.dir/SRC/slamsh.f.o CMakeFiles/scalapack.dir/SRC/slasorte.f.o CMakeFiles/scalapack.dir/SRC/ssteqr2.f.o CMakeFiles/scalapack.dir/SRC/sdbtf2.f.o CMakeFiles/scalapack.dir/SRC/sdbtrf.f.o CMakeFiles/scalapack.dir/SRC/sdttrf.f.o CMakeFiles/scalapack.dir/SRC/sdttrsv.f.o CMakeFiles/scalapack.dir/SRC/spttrsv.f.o CMakeFiles/scalapack.dir/SRC/strmvt.f.o CMakeFiles/scalapack.dir/SRC/pssyevr.f.o CMakeFiles/scalapack.dir/SRC/bslaapp.f.o CMakeFiles/scalapack.dir/SRC/bslaexc.f.o CMakeFiles/scalapack.dir/SRC/bstrexc.f.o CMakeFiles/scalapack.dir/SRC/pstrord.f.o CMakeFiles/scalapack.dir/SRC/pstrsen.f.o CMakeFiles/scalapack.dir/SRC/psgebal.f.o CMakeFiles/scalapack.dir/SRC/pshseqr.f.o CMakeFiles/scalapack.dir/SRC/pslamve.f.o CMakeFiles/scalapack.dir/SRC/pslaqr0.f.o CMakeFiles/scalapack.dir/SRC/pslaqr1.f.o CMakeFiles/scalapack.dir/SRC/pslaqr2.f.o CMakeFiles/scalapack.dir/SRC/pslaqr3.f.o CMakeFiles/scalapack.dir/SRC/pslaqr4.f.o CMakeFiles/scalapack.dir/SRC/pslaqr5.f.o CMakeFiles/scalapack.dir/SRC/psrot.f.o CMakeFiles/scalapack.dir/SRC/slaqr6.f.o CMakeFiles/scalapack.dir/SRC/pcdbsv.f.o CMakeFiles/scalapack.dir/SRC/pcdbtrf.f.o CMakeFiles/scalapack.dir/SRC/pcdbtrs.f.o CMakeFiles/scalapack.dir/SRC/pcdbtrsv.f.o CMakeFiles/scalapack.dir/SRC/pcdtsv.f.o CMakeFiles/scalapack.dir/SRC/pcdttrf.f.o CMakeFiles/scalapack.dir/SRC/pcdttrs.f.o CMakeFiles/scalapack.dir/SRC/pcdttrsv.f.o CMakeFiles/scalapack.dir/SRC/pcgbsv.f.o CMakeFiles/scalapack.dir/SRC/pcgbtrf.f.o CMakeFiles/scalapack.dir/SRC/pcgbtrs.f.o CMakeFiles/scalapack.dir/SRC/pcgebd2.f.o CMakeFiles/scalapack.dir/SRC/pcgebrd.f.o CMakeFiles/scalapack.dir/SRC/pcgecon.f.o CMakeFiles/scalapack.dir/SRC/pcgeequ.f.o CMakeFiles/scalapack.dir/SRC/pcgehd2.f.o CMakeFiles/scalapack.dir/SRC/pcgehrd.f.o CMakeFiles/scalapack.dir/SRC/pcgelq2.f.o CMakeFiles/scalapack.dir/SRC/pcgelqf.f.o CMakeFiles/scalapack.dir/SRC/pcgels.f.o CMakeFiles/scalapack.dir/SRC/pcgeql2.f.o CMakeFiles/scalapack.dir/SRC/pcgeqlf.f.o CMakeFiles/scalapack.dir/SRC/pcgeqpf.f.o CMakeFiles/scalapack.dir/SRC/pcgeqr2.f.o CMakeFiles/scalapack.dir/SRC/pcgeqrf.f.o CMakeFiles/scalapack.dir/SRC/pcgerfs.f.o CMakeFiles/scalapack.dir/SRC/pcgerq2.f.o CMakeFiles/scalapack.dir/SRC/pcgerqf.f.o CMakeFiles/scalapack.dir/SRC/pcgesv.f.o CMakeFiles/scalapack.dir/SRC/pcgesvd.f.o CMakeFiles/scalapack.dir/SRC/pcgesvx.f.o CMakeFiles/scalapack.dir/SRC/pcgetf2.f.o CMakeFiles/scalapack.dir/SRC/pcgetrf.f.o CMakeFiles/scalapack.dir/SRC/pcgetri.f.o CMakeFiles/scalapack.dir/SRC/pcgetrs.f.o CMakeFiles/scalapack.dir/SRC/pcggqrf.f.o CMakeFiles/scalapack.dir/SRC/pcggrqf.f.o CMakeFiles/scalapack.dir/SRC/pcheev.f.o CMakeFiles/scalapack.dir/SRC/pcheevd.f.o CMakeFiles/scalapack.dir/SRC/pcheevx.f.o CMakeFiles/scalapack.dir/SRC/pchegs2.f.o CMakeFiles/scalapack.dir/SRC/pchegst.f.o CMakeFiles/scalapack.dir/SRC/pchegvx.f.o CMakeFiles/scalapack.dir/SRC/pchengst.f.o CMakeFiles/scalapack.dir/SRC/pchentrd.f.o CMakeFiles/scalapack.dir/SRC/pchettrd.f.o CMakeFiles/scalapack.dir/SRC/pchetd2.f.o CMakeFiles/scalapack.dir/SRC/pchetrd.f.o CMakeFiles/scalapack.dir/SRC/pclabrd.f.o CMakeFiles/scalapack.dir/SRC/pclacon.f.o CMakeFiles/scalapack.dir/SRC/pclacgv.f.o CMakeFiles/scalapack.dir/SRC/pclacp2.f.o CMakeFiles/scalapack.dir/SRC/pclacpy.f.o CMakeFiles/scalapack.dir/SRC/pclahrd.f.o CMakeFiles/scalapack.dir/SRC/pclahqr.f.o CMakeFiles/scalapack.dir/SRC/pclaconsb.f.o CMakeFiles/scalapack.dir/SRC/pclasmsub.f.o CMakeFiles/scalapack.dir/SRC/pclacp3.f.o CMakeFiles/scalapack.dir/SRC/pclawil.f.o CMakeFiles/scalapack.dir/SRC/pclange.f.o CMakeFiles/scalapack.dir/SRC/pclanhe.f.o CMakeFiles/scalapack.dir/SRC/pclanhs.f.o CMakeFiles/scalapack.dir/SRC/pclansy.f.o CMakeFiles/scalapack.dir/SRC/pclantr.f.o CMakeFiles/scalapack.dir/SRC/pclapiv.f.o CMakeFiles/scalapack.dir/SRC/pclapv2.f.o CMakeFiles/scalapack.dir/SRC/pclaqge.f.o CMakeFiles/scalapack.dir/SRC/pclaqsy.f.o CMakeFiles/scalapack.dir/SRC/pclarf.f.o CMakeFiles/scalapack.dir/SRC/pclarfb.f.o CMakeFiles/scalapack.dir/SRC/pclarfc.f.o CMakeFiles/scalapack.dir/SRC/pclarfg.f.o CMakeFiles/scalapack.dir/SRC/pclarft.f.o CMakeFiles/scalapack.dir/SRC/pclascl.f.o CMakeFiles/scalapack.dir/SRC/pclase2.f.o CMakeFiles/scalapack.dir/SRC/pclaset.f.o CMakeFiles/scalapack.dir/SRC/pclassq.f.o CMakeFiles/scalapack.dir/SRC/pclaswp.f.o CMakeFiles/scalapack.dir/SRC/pclatra.f.o CMakeFiles/scalapack.dir/SRC/pclatrd.f.o CMakeFiles/scalapack.dir/SRC/pclatrs.f.o CMakeFiles/scalapack.dir/SRC/pclauu2.f.o CMakeFiles/scalapack.dir/SRC/pclauum.f.o CMakeFiles/scalapack.dir/SRC/pcpocon.f.o CMakeFiles/scalapack.dir/SRC/pcpoequ.f.o CMakeFiles/scalapack.dir/SRC/pcporfs.f.o CMakeFiles/scalapack.dir/SRC/pcposv.f.o CMakeFiles/scalapack.dir/SRC/pcpbsv.f.o CMakeFiles/scalapack.dir/SRC/pcpbtrf.f.o CMakeFiles/scalapack.dir/SRC/pcpbtrs.f.o CMakeFiles/scalapack.dir/SRC/pcpbtrsv.f.o CMakeFiles/scalapack.dir/SRC/pcptsv.f.o CMakeFiles/scalapack.dir/SRC/pcpttrf.f.o CMakeFiles/scalapack.dir/SRC/pcpttrs.f.o CMakeFiles/scalapack.dir/SRC/pcpttrsv.f.o CMakeFiles/scalapack.dir/SRC/pcposvx.f.o CMakeFiles/scalapack.dir/SRC/pcpotf2.f.o CMakeFiles/scalapack.dir/SRC/pcpotrf.f.o CMakeFiles/scalapack.dir/SRC/pcpotri.f.o CMakeFiles/scalapack.dir/SRC/pcpotrs.f.o CMakeFiles/scalapack.dir/SRC/pcsrscl.f.o CMakeFiles/scalapack.dir/SRC/pcstein.f.o CMakeFiles/scalapack.dir/SRC/pctrevc.f.o CMakeFiles/scalapack.dir/SRC/pctrti2.f.o CMakeFiles/scalapack.dir/SRC/pctrtri.f.o CMakeFiles/scalapack.dir/SRC/pctrtrs.f.o CMakeFiles/scalapack.dir/SRC/pcung2l.f.o CMakeFiles/scalapack.dir/SRC/pcung2r.f.o CMakeFiles/scalapack.dir/SRC/pcungl2.f.o CMakeFiles/scalapack.dir/SRC/pcunglq.f.o CMakeFiles/scalapack.dir/SRC/pcungql.f.o CMakeFiles/scalapack.dir/SRC/pcungqr.f.o CMakeFiles/scalapack.dir/SRC/pcungr2.f.o CMakeFiles/scalapack.dir/SRC/pcungrq.f.o CMakeFiles/scalapack.dir/SRC/pcunm2l.f.o CMakeFiles/scalapack.dir/SRC/pcunm2r.f.o CMakeFiles/scalapack.dir/SRC/pcunmbr.f.o CMakeFiles/scalapack.dir/SRC/pcunmhr.f.o CMakeFiles/scalapack.dir/SRC/pcunml2.f.o CMakeFiles/scalapack.dir/SRC/pcunmlq.f.o CMakeFiles/scalapack.dir/SRC/pcunmql.f.o CMakeFiles/scalapack.dir/SRC/pcunmqr.f.o CMakeFiles/scalapack.dir/SRC/pcunmr2.f.o CMakeFiles/scalapack.dir/SRC/pcunmrq.f.o CMakeFiles/scalapack.dir/SRC/pcunmtr.f.o CMakeFiles/scalapack.dir/SRC/pclaevswp.f.o CMakeFiles/scalapack.dir/SRC/pclarzb.f.o CMakeFiles/scalapack.dir/SRC/pclarzt.f.o CMakeFiles/scalapack.dir/SRC/pclarz.f.o CMakeFiles/scalapack.dir/SRC/pclarzc.f.o CMakeFiles/scalapack.dir/SRC/pclatrz.f.o CMakeFiles/scalapack.dir/SRC/pctzrzf.f.o CMakeFiles/scalapack.dir/SRC/pclattrs.f.o CMakeFiles/scalapack.dir/SRC/pcunmr3.f.o CMakeFiles/scalapack.dir/SRC/pcunmrz.f.o CMakeFiles/scalapack.dir/SRC/pcmax1.f.o CMakeFiles/scalapack.dir/SRC/pscsum1.f.o CMakeFiles/scalapack.dir/SRC/pclamr1d.f.o CMakeFiles/scalapack.dir/SRC/cdbtf2.f.o CMakeFiles/scalapack.dir/SRC/cdbtrf.f.o CMakeFiles/scalapack.dir/SRC/cdttrf.f.o CMakeFiles/scalapack.dir/SRC/cdttrsv.f.o CMakeFiles/scalapack.dir/SRC/cpttrsv.f.o CMakeFiles/scalapack.dir/SRC/csteqr2.f.o CMakeFiles/scalapack.dir/SRC/ctrmvt.f.o CMakeFiles/scalapack.dir/SRC/clamsh.f.o CMakeFiles/scalapack.dir/SRC/claref.f.o CMakeFiles/scalapack.dir/SRC/clanv2.f.o CMakeFiles/scalapack.dir/SRC/clahqr2.f.o CMakeFiles/scalapack.dir/SRC/pcheevr.f.o CMakeFiles/scalapack.dir/SRC/pddbsv.f.o CMakeFiles/scalapack.dir/SRC/pddbtrf.f.o CMakeFiles/scalapack.dir/SRC/pddbtrs.f.o CMakeFiles/scalapack.dir/SRC/pddbtrsv.f.o CMakeFiles/scalapack.dir/SRC/pddtsv.f.o CMakeFiles/scalapack.dir/SRC/pddttrf.f.o CMakeFiles/scalapack.dir/SRC/pddttrs.f.o CMakeFiles/scalapack.dir/SRC/pddttrsv.f.o CMakeFiles/scalapack.dir/SRC/pdgbsv.f.o CMakeFiles/scalapack.dir/SRC/pdgbtrf.f.o CMakeFiles/scalapack.dir/SRC/pdgbtrs.f.o CMakeFiles/scalapack.dir/SRC/pdgebd2.f.o CMakeFiles/scalapack.dir/SRC/pdgebrd.f.o CMakeFiles/scalapack.dir/SRC/pdgecon.f.o CMakeFiles/scalapack.dir/SRC/pdgeequ.f.o CMakeFiles/scalapack.dir/SRC/pdgehd2.f.o CMakeFiles/scalapack.dir/SRC/pdgehrd.f.o CMakeFiles/scalapack.dir/SRC/pdgelq2.f.o CMakeFiles/scalapack.dir/SRC/pdgelqf.f.o CMakeFiles/scalapack.dir/SRC/pdgels.f.o CMakeFiles/scalapack.dir/SRC/pdgeql2.f.o CMakeFiles/scalapack.dir/SRC/pdgeqlf.f.o CMakeFiles/scalapack.dir/SRC/pdgeqpf.f.o CMakeFiles/scalapack.dir/SRC/pdgeqr2.f.o CMakeFiles/scalapack.dir/SRC/pdgeqrf.f.o CMakeFiles/scalapack.dir/SRC/pdgerfs.f.o CMakeFiles/scalapack.dir/SRC/pdgerq2.f.o CMakeFiles/scalapack.dir/SRC/pdgerqf.f.o CMakeFiles/scalapack.dir/SRC/pdgesv.f.o CMakeFiles/scalapack.dir/SRC/pdgesvd.f.o CMakeFiles/scalapack.dir/SRC/pdgesvx.f.o CMakeFiles/scalapack.dir/SRC/pdgetf2.f.o CMakeFiles/scalapack.dir/SRC/pdgetrf.f.o CMakeFiles/scalapack.dir/SRC/pdgetri.f.o CMakeFiles/scalapack.dir/SRC/pdgetrs.f.o CMakeFiles/scalapack.dir/SRC/pdggqrf.f.o CMakeFiles/scalapack.dir/SRC/pdggrqf.f.o CMakeFiles/scalapack.dir/SRC/pdlabrd.f.o CMakeFiles/scalapack.dir/SRC/pdlacon.f.o CMakeFiles/scalapack.dir/SRC/pdlacp2.f.o CMakeFiles/scalapack.dir/SRC/pdlacpy.f.o CMakeFiles/scalapack.dir/SRC/pdlahrd.f.o CMakeFiles/scalapack.dir/SRC/pdlange.f.o CMakeFiles/scalapack.dir/SRC/pdlanhs.f.o CMakeFiles/scalapack.dir/SRC/pdlansy.f.o CMakeFiles/scalapack.dir/SRC/pdlantr.f.o CMakeFiles/scalapack.dir/SRC/pdlapiv.f.o CMakeFiles/scalapack.dir/SRC/pdlapv2.f.o CMakeFiles/scalapack.dir/SRC/pdlaqge.f.o CMakeFiles/scalapack.dir/SRC/pdlaqsy.f.o CMakeFiles/scalapack.dir/SRC/pdlarf.f.o CMakeFiles/scalapack.dir/SRC/pdlarfb.f.o CMakeFiles/scalapack.dir/SRC/pdlarfg.f.o CMakeFiles/scalapack.dir/SRC/pdlarft.f.o CMakeFiles/scalapack.dir/SRC/pdlase2.f.o CMakeFiles/scalapack.dir/SRC/pdlaset.f.o CMakeFiles/scalapack.dir/SRC/pdlascl.f.o CMakeFiles/scalapack.dir/SRC/pdlassq.f.o CMakeFiles/scalapack.dir/SRC/pdlaswp.f.o CMakeFiles/scalapack.dir/SRC/pdlatra.f.o CMakeFiles/scalapack.dir/SRC/pdlatrd.f.o CMakeFiles/scalapack.dir/SRC/pdlatrs.f.o CMakeFiles/scalapack.dir/SRC/pdlauu2.f.o CMakeFiles/scalapack.dir/SRC/pdlauum.f.o CMakeFiles/scalapack.dir/SRC/pdorg2l.f.o CMakeFiles/scalapack.dir/SRC/pdorg2r.f.o CMakeFiles/scalapack.dir/SRC/pdorgl2.f.o CMakeFiles/scalapack.dir/SRC/pdorglq.f.o CMakeFiles/scalapack.dir/SRC/pdorgql.f.o CMakeFiles/scalapack.dir/SRC/pdorgqr.f.o CMakeFiles/scalapack.dir/SRC/pdorgr2.f.o CMakeFiles/scalapack.dir/SRC/pdorgrq.f.o CMakeFiles/scalapack.dir/SRC/pdorm2l.f.o CMakeFiles/scalapack.dir/SRC/pdorm2r.f.o CMakeFiles/scalapack.dir/SRC/pdormbr.f.o CMakeFiles/scalapack.dir/SRC/pdormhr.f.o CMakeFiles/scalapack.dir/SRC/pdorml2.f.o CMakeFiles/scalapack.dir/SRC/pdormlq.f.o CMakeFiles/scalapack.dir/SRC/pdormql.f.o CMakeFiles/scalapack.dir/SRC/pdormqr.f.o CMakeFiles/scalapack.dir/SRC/pdormr2.f.o CMakeFiles/scalapack.dir/SRC/pdormrq.f.o CMakeFiles/scalapack.dir/SRC/pdormtr.f.o CMakeFiles/scalapack.dir/SRC/pdpocon.f.o CMakeFiles/scalapack.dir/SRC/pdpbsv.f.o CMakeFiles/scalapack.dir/SRC/pdpbtrf.f.o CMakeFiles/scalapack.dir/SRC/pdpbtrs.f.o CMakeFiles/scalapack.dir/SRC/pdpbtrsv.f.o CMakeFiles/scalapack.dir/SRC/pdptsv.f.o CMakeFiles/scalapack.dir/SRC/pdpttrf.f.o CMakeFiles/scalapack.dir/SRC/pdpttrs.f.o CMakeFiles/scalapack.dir/SRC/pdpttrsv.f.o CMakeFiles/scalapack.dir/SRC/pdpoequ.f.o CMakeFiles/scalapack.dir/SRC/pdporfs.f.o CMakeFiles/scalapack.dir/SRC/pdposv.f.o CMakeFiles/scalapack.dir/SRC/pdposvx.f.o CMakeFiles/scalapack.dir/SRC/pdpotf2.f.o CMakeFiles/scalapack.dir/SRC/pdpotrf.f.o CMakeFiles/scalapack.dir/SRC/pdpotri.f.o CMakeFiles/scalapack.dir/SRC/pdpotrs.f.o CMakeFiles/scalapack.dir/SRC/pdrscl.f.o CMakeFiles/scalapack.dir/SRC/pdstein.f.o CMakeFiles/scalapack.dir/SRC/pdsyev.f.o CMakeFiles/scalapack.dir/SRC/pdsyevd.f.o CMakeFiles/scalapack.dir/SRC/pdsyevx.f.o CMakeFiles/scalapack.dir/SRC/pdsygs2.f.o CMakeFiles/scalapack.dir/SRC/pdsygst.f.o CMakeFiles/scalapack.dir/SRC/pdsygvx.f.o CMakeFiles/scalapack.dir/SRC/pdsyngst.f.o CMakeFiles/scalapack.dir/SRC/pdsyntrd.f.o CMakeFiles/scalapack.dir/SRC/pdsyttrd.f.o CMakeFiles/scalapack.dir/SRC/pdsytd2.f.o CMakeFiles/scalapack.dir/SRC/pdsytrd.f.o CMakeFiles/scalapack.dir/SRC/pdtrti2.f.o CMakeFiles/scalapack.dir/SRC/pdtrtri.f.o CMakeFiles/scalapack.dir/SRC/pdtrtrs.f.o CMakeFiles/scalapack.dir/SRC/pdlaevswp.f.o CMakeFiles/scalapack.dir/SRC/pdlarzb.f.o CMakeFiles/scalapack.dir/SRC/pdlarzt.f.o CMakeFiles/scalapack.dir/SRC/pdlarz.f.o CMakeFiles/scalapack.dir/SRC/pdlatrz.f.o CMakeFiles/scalapack.dir/SRC/pdtzrzf.f.o CMakeFiles/scalapack.dir/SRC/pdormr3.f.o CMakeFiles/scalapack.dir/SRC/pdormrz.f.o CMakeFiles/scalapack.dir/SRC/pdlahqr.f.o CMakeFiles/scalapack.dir/SRC/pdlaconsb.f.o CMakeFiles/scalapack.dir/SRC/pdlacp3.f.o CMakeFiles/scalapack.dir/SRC/pdlawil.f.o CMakeFiles/scalapack.dir/SRC/pdlasmsub.f.o CMakeFiles/scalapack.dir/SRC/pdlared2d.f.o CMakeFiles/scalapack.dir/SRC/pdlamr1d.f.o CMakeFiles/scalapack.dir/SRC/dlaref.f.o CMakeFiles/scalapack.dir/SRC/dlamsh.f.o CMakeFiles/scalapack.dir/SRC/dlasorte.f.o CMakeFiles/scalapack.dir/SRC/dsteqr2.f.o CMakeFiles/scalapack.dir/SRC/ddbtf2.f.o CMakeFiles/scalapack.dir/SRC/ddbtrf.f.o CMakeFiles/scalapack.dir/SRC/ddttrf.f.o CMakeFiles/scalapack.dir/SRC/ddttrsv.f.o CMakeFiles/scalapack.dir/SRC/dpttrsv.f.o CMakeFiles/scalapack.dir/SRC/dtrmvt.f.o CMakeFiles/scalapack.dir/SRC/pdsyevr.f.o CMakeFiles/scalapack.dir/SRC/bdlaapp.f.o CMakeFiles/scalapack.dir/SRC/bdlaexc.f.o CMakeFiles/scalapack.dir/SRC/bdtrexc.f.o CMakeFiles/scalapack.dir/SRC/dlaqr6.f.o CMakeFiles/scalapack.dir/SRC/pdtrord.f.o CMakeFiles/scalapack.dir/SRC/pdtrsen.f.o CMakeFiles/scalapack.dir/SRC/pdgebal.f.o CMakeFiles/scalapack.dir/SRC/pdhseqr.f.o CMakeFiles/scalapack.dir/SRC/pdlamve.f.o CMakeFiles/scalapack.dir/SRC/pdlaqr0.f.o CMakeFiles/scalapack.dir/SRC/pdlaqr1.f.o CMakeFiles/scalapack.dir/SRC/pdlaqr2.f.o CMakeFiles/scalapack.dir/SRC/pdlaqr3.f.o CMakeFiles/scalapack.dir/SRC/pdlaqr4.f.o CMakeFiles/scalapack.dir/SRC/pdlaqr5.f.o CMakeFiles/scalapack.dir/SRC/pdrot.f.o CMakeFiles/scalapack.dir/SRC/pzdbsv.f.o CMakeFiles/scalapack.dir/SRC/pzdbtrf.f.o CMakeFiles/scalapack.dir/SRC/pzdbtrs.f.o CMakeFiles/scalapack.dir/SRC/pzdbtrsv.f.o CMakeFiles/scalapack.dir/SRC/pzdtsv.f.o CMakeFiles/scalapack.dir/SRC/pzdttrf.f.o CMakeFiles/scalapack.dir/SRC/pzdttrs.f.o CMakeFiles/scalapack.dir/SRC/pzdttrsv.f.o CMakeFiles/scalapack.dir/SRC/pzgbsv.f.o CMakeFiles/scalapack.dir/SRC/pzgbtrf.f.o CMakeFiles/scalapack.dir/SRC/pzgbtrs.f.o CMakeFiles/scalapack.dir/SRC/pzgebd2.f.o CMakeFiles/scalapack.dir/SRC/pzgebrd.f.o CMakeFiles/scalapack.dir/SRC/pzgecon.f.o CMakeFiles/scalapack.dir/SRC/pzgeequ.f.o CMakeFiles/scalapack.dir/SRC/pzgehd2.f.o CMakeFiles/scalapack.dir/SRC/pzgehrd.f.o CMakeFiles/scalapack.dir/SRC/pzgelq2.f.o CMakeFiles/scalapack.dir/SRC/pzgelqf.f.o CMakeFiles/scalapack.dir/SRC/pzgels.f.o CMakeFiles/scalapack.dir/SRC/pzgeql2.f.o CMakeFiles/scalapack.dir/SRC/pzgeqlf.f.o CMakeFiles/scalapack.dir/SRC/pzgeqpf.f.o CMakeFiles/scalapack.dir/SRC/pzgeqr2.f.o CMakeFiles/scalapack.dir/SRC/pzgeqrf.f.o CMakeFiles/scalapack.dir/SRC/pzgerfs.f.o CMakeFiles/scalapack.dir/SRC/pzgerq2.f.o CMakeFiles/scalapack.dir/SRC/pzgerqf.f.o CMakeFiles/scalapack.dir/SRC/pzgesv.f.o CMakeFiles/scalapack.dir/SRC/pzgesvd.f.o CMakeFiles/scalapack.dir/SRC/pzgesvx.f.o CMakeFiles/scalapack.dir/SRC/pzgetf2.f.o CMakeFiles/scalapack.dir/SRC/pzgetrf.f.o CMakeFiles/scalapack.dir/SRC/pzgetri.f.o CMakeFiles/scalapack.dir/SRC/pzgetrs.f.o CMakeFiles/scalapack.dir/SRC/pzggqrf.f.o CMakeFiles/scalapack.dir/SRC/pzggrqf.f.o CMakeFiles/scalapack.dir/SRC/pzheev.f.o CMakeFiles/scalapack.dir/SRC/pzheevd.f.o CMakeFiles/scalapack.dir/SRC/pzheevx.f.o CMakeFiles/scalapack.dir/SRC/pzhegs2.f.o CMakeFiles/scalapack.dir/SRC/pzhegst.f.o CMakeFiles/scalapack.dir/SRC/pzhegvx.f.o CMakeFiles/scalapack.dir/SRC/pzhengst.f.o CMakeFiles/scalapack.dir/SRC/pzhentrd.f.o CMakeFiles/scalapack.dir/SRC/pzhettrd.f.o CMakeFiles/scalapack.dir/SRC/pzhetd2.f.o CMakeFiles/scalapack.dir/SRC/pzhetrd.f.o CMakeFiles/scalapack.dir/SRC/pzlabrd.f.o CMakeFiles/scalapack.dir/SRC/pzlacon.f.o CMakeFiles/scalapack.dir/SRC/pzlacgv.f.o CMakeFiles/scalapack.dir/SRC/pzlacp2.f.o CMakeFiles/scalapack.dir/SRC/pzlacpy.f.o CMakeFiles/scalapack.dir/SRC/pzlahrd.f.o CMakeFiles/scalapack.dir/SRC/pzlahqr.f.o CMakeFiles/scalapack.dir/SRC/pzlaconsb.f.o CMakeFiles/scalapack.dir/SRC/pzlasmsub.f.o CMakeFiles/scalapack.dir/SRC/pzlacp3.f.o CMakeFiles/scalapack.dir/SRC/pzlawil.f.o CMakeFiles/scalapack.dir/SRC/pzlange.f.o CMakeFiles/scalapack.dir/SRC/pzlanhe.f.o CMakeFiles/scalapack.dir/SRC/pzlanhs.f.o CMakeFiles/scalapack.dir/SRC/pzlansy.f.o CMakeFiles/scalapack.dir/SRC/pzlantr.f.o CMakeFiles/scalapack.dir/SRC/pzlapiv.f.o CMakeFiles/scalapack.dir/SRC/pzlapv2.f.o CMakeFiles/scalapack.dir/SRC/pzlaqge.f.o CMakeFiles/scalapack.dir/SRC/pzlaqsy.f.o CMakeFiles/scalapack.dir/SRC/pzlarf.f.o CMakeFiles/scalapack.dir/SRC/pzlarfb.f.o CMakeFiles/scalapack.dir/SRC/pzlarfc.f.o CMakeFiles/scalapack.dir/SRC/pzlarfg.f.o CMakeFiles/scalapack.dir/SRC/pzlarft.f.o CMakeFiles/scalapack.dir/SRC/pzlascl.f.o CMakeFiles/scalapack.dir/SRC/pzlase2.f.o CMakeFiles/scalapack.dir/SRC/pzlaset.f.o CMakeFiles/scalapack.dir/SRC/pzlassq.f.o CMakeFiles/scalapack.dir/SRC/pzlaswp.f.o CMakeFiles/scalapack.dir/SRC/pzlatra.f.o CMakeFiles/scalapack.dir/SRC/pzlatrd.f.o CMakeFiles/scalapack.dir/SRC/pzlattrs.f.o CMakeFiles/scalapack.dir/SRC/pzlatrs.f.o CMakeFiles/scalapack.dir/SRC/pzlauu2.f.o CMakeFiles/scalapack.dir/SRC/pzlauum.f.o CMakeFiles/scalapack.dir/SRC/pzpocon.f.o CMakeFiles/scalapack.dir/SRC/pzpoequ.f.o CMakeFiles/scalapack.dir/SRC/pzporfs.f.o CMakeFiles/scalapack.dir/SRC/pzposv.f.o CMakeFiles/scalapack.dir/SRC/pzpbsv.f.o CMakeFiles/scalapack.dir/SRC/pzpbtrf.f.o CMakeFiles/scalapack.dir/SRC/pzpbtrs.f.o CMakeFiles/scalapack.dir/SRC/pzpbtrsv.f.o CMakeFiles/scalapack.dir/SRC/pzptsv.f.o CMakeFiles/scalapack.dir/SRC/pzpttrf.f.o CMakeFiles/scalapack.dir/SRC/pzpttrs.f.o CMakeFiles/scalapack.dir/SRC/pzpttrsv.f.o CMakeFiles/scalapack.dir/SRC/pzposvx.f.o CMakeFiles/scalapack.dir/SRC/pzpotf2.f.o CMakeFiles/scalapack.dir/SRC/pzpotrf.f.o CMakeFiles/scalapack.dir/SRC/pzpotri.f.o CMakeFiles/scalapack.dir/SRC/pzpotrs.f.o CMakeFiles/scalapack.dir/SRC/pzdrscl.f.o CMakeFiles/scalapack.dir/SRC/pzstein.f.o CMakeFiles/scalapack.dir/SRC/pztrevc.f.o CMakeFiles/scalapack.dir/SRC/pztrti2.f.o CMakeFiles/scalapack.dir/SRC/pztrtri.f.o CMakeFiles/scalapack.dir/SRC/pztrtrs.f.o CMakeFiles/scalapack.dir/SRC/pzung2l.f.o CMakeFiles/scalapack.dir/SRC/pzung2r.f.o CMakeFiles/scalapack.dir/SRC/pzungl2.f.o CMakeFiles/scalapack.dir/SRC/pzunglq.f.o CMakeFiles/scalapack.dir/SRC/pzungql.f.o CMakeFiles/scalapack.dir/SRC/pzungqr.f.o CMakeFiles/scalapack.dir/SRC/pzungr2.f.o CMakeFiles/scalapack.dir/SRC/pzungrq.f.o CMakeFiles/scalapack.dir/SRC/pzunm2l.f.o CMakeFiles/scalapack.dir/SRC/pzunm2r.f.o CMakeFiles/scalapack.dir/SRC/pzunmbr.f.o CMakeFiles/scalapack.dir/SRC/pzunmhr.f.o CMakeFiles/scalapack.dir/SRC/pzunml2.f.o CMakeFiles/scalapack.dir/SRC/pzunmlq.f.o CMakeFiles/scalapack.dir/SRC/pzunmql.f.o CMakeFiles/scalapack.dir/SRC/pzunmqr.f.o CMakeFiles/scalapack.dir/SRC/pzunmr2.f.o CMakeFiles/scalapack.dir/SRC/pzunmrq.f.o CMakeFiles/scalapack.dir/SRC/pzunmtr.f.o CMakeFiles/scalapack.dir/SRC/pzlaevswp.f.o CMakeFiles/scalapack.dir/SRC/pzlarzb.f.o CMakeFiles/scalapack.dir/SRC/pzlarzt.f.o CMakeFiles/scalapack.dir/SRC/pzlarz.f.o CMakeFiles/scalapack.dir/SRC/pzlarzc.f.o CMakeFiles/scalapack.dir/SRC/pzlatrz.f.o CMakeFiles/scalapack.dir/SRC/pztzrzf.f.o CMakeFiles/scalapack.dir/SRC/pzunmr3.f.o CMakeFiles/scalapack.dir/SRC/pzunmrz.f.o CMakeFiles/scalapack.dir/SRC/pzmax1.f.o CMakeFiles/scalapack.dir/SRC/pdzsum1.f.o CMakeFiles/scalapack.dir/SRC/pzlamr1d.f.o CMakeFiles/scalapack.dir/SRC/zdbtf2.f.o CMakeFiles/scalapack.dir/SRC/zdbtrf.f.o CMakeFiles/scalapack.dir/SRC/zdttrf.f.o CMakeFiles/scalapack.dir/SRC/zdttrsv.f.o CMakeFiles/scalapack.dir/SRC/zpttrsv.f.o CMakeFiles/scalapack.dir/SRC/zsteqr2.f.o CMakeFiles/scalapack.dir/SRC/ztrmvt.f.o CMakeFiles/scalapack.dir/SRC/zlamsh.f.o CMakeFiles/scalapack.dir/SRC/zlaref.f.o CMakeFiles/scalapack.dir/SRC/zlanv2.f.o CMakeFiles/scalapack.dir/SRC/zlahqr2.f.o CMakeFiles/scalapack.dir/SRC/pzheevr.f.o CMakeFiles/scalapack.dir/SRC/pbchkvect.c.o CMakeFiles/scalapack.dir/SRC/getpbbuf.c.o CMakeFiles/scalapack.dir/SRC/pcrot.c.o CMakeFiles/scalapack.dir/SRC/pslaiect.c.o CMakeFiles/scalapack.dir/SRC/pdlaiect.c.o CMakeFiles/scalapack.dir/SRC/pzrot.c.o CMakeFiles/scalapack.dir/SRC/slamov.c.o CMakeFiles/scalapack.dir/SRC/clamov.c.o CMakeFiles/scalapack.dir/SRC/dlamov.c.o CMakeFiles/scalapack.dir/SRC/zlamov.c.o -L/usr/local/opt/veclibfort/lib -lvecLibFort -L/usr/local/opt/veclibfort/lib -lvecLibFort 
Undefined symbols for architecture x86_64:
  "_MPI_Attr_get", referenced from:
      _blacs_get_ in blacs_get_.c.o
      _Cblacs_get in blacs_get_-C.c.o
  "_MPI_Type_struct", referenced from:
      _igamx2d_ in igamx2d_.c.o
      _sgamx2d_ in sgamx2d_.c.o
      _dgamx2d_ in dgamx2d_.c.o
      _cgamx2d_ in cgamx2d_.c.o
      _zgamx2d_ in zgamx2d_.c.o
      _igamn2d_ in igamn2d_.c.o
      _sgamn2d_ in sgamn2d_.c.o
      ...
ld: symbol(s) not found for architecture x86_64
collect2: error: ld returned 1 exit status
make[2]: *** [lib/libscalapack.dylib] Error 1
make[1]: *** [CMakeFiles/scalapack.dir/all] Error 2
make: *** [all] Error 2

Does that look like the bug described in this issue report? If so, is that link intended to still work against Open-MPI 4.x, or would scalapack need to be updated to not call deprecated functions?

@jsquyres
Copy link
Member

Yes, this is exactly this issue.

Optimially, Scalapack should be updated to use neither deprecated nor deleted functions (MPI_Attr_get is deprecated, but MPI_Type_struct is deleted). For the moment, you need to configure Open MPI with --enable-mpi1-compatibility. PR #6120 will re-add the deprecated symbols and take care of some other housework, but it won't restore MPI_Type_struct() to mpi.h by default (i.e., you'll still need --enable-mpi1-compatibility for that).

Please email the Scalapack developers and add your voice to the list of people asking that they update. Thanks!

@apjanke
Copy link
Contributor

apjanke commented Dec 11, 2018

Thanks! I've emailed the Scalapack developers. (Registration on the lapack forum seems to be broken.)

The --enable-mpi1-compatibility switch worked for me and got scalapack building again. We may use that for the time being.

@gpaulsen
Copy link
Member

Merged to v4.0.x. Generating v4.0.1rc1 today. Please give that a try.

simonLeary42 pushed a commit to UMass-RC/spack that referenced this issue Feb 8, 2023
import itertools
import os
import re
import sys

import llnl.util.tty as tty

from spack.package import *

PMI_DEV_DIR="/usr/include/slurm"
PMI_LIB_DIR="/usr/lib/x86_64-linux-gnu"

class Openmpi(AutotoolsPackage, CudaPackage):
    """An open source Message Passing Interface implementation.

    The Open MPI Project is an open source Message Passing Interface
    implementation that is developed and maintained by a consortium
    of academic, research, and industry partners. Open MPI is
    therefore able to combine the expertise, technologies, and
    resources from all across the High Performance Computing
    community in order to build the best MPI library available.
    Open MPI offers advantages for system and software vendors,
    application developers and computer science researchers.
    """

    homepage = "https://www.open-mpi.org"
    url = "https://download.open-mpi.org/release/open-mpi/v4.1/openmpi-4.1.0.tar.bz2"
    list_url = "https://www.open-mpi.org/software/ompi/"
    git = "https://github.com/open-mpi/ompi.git"

    maintainers = ["hppritcha", "naughtont3"]

    executables = ["^ompi_info$"]

    tags = ["e4s"]

    version("main", branch="main", submodules=True)

    # Current
    version(
        "4.1.4", sha256="92912e175fd1234368c8730c03f4996fe5942e7479bb1d10059405e7f2b3930d"
    )  # libmpi.so.40.30.4

    # Still supported
    version(
        "4.1.3", sha256="3d81d04c54efb55d3871a465ffb098d8d72c1f48ff1cbaf2580eb058567c0a3b"
    )  # libmpi.so.40.30.3
    version(
        "4.1.2", sha256="9b78c7cf7fc32131c5cf43dd2ab9740149d9d87cadb2e2189f02685749a6b527"
    )  # libmpi.so.40.30.2
    version(
        "4.1.1", sha256="e24f7a778bd11a71ad0c14587a7f5b00e68a71aa5623e2157bafee3d44c07cda"
    )  # libmpi.so.40.30.1
    version(
        "4.1.0", sha256="73866fb77090819b6a8c85cb8539638d37d6877455825b74e289d647a39fd5b5"
    )  # libmpi.so.40.30.0
    version(
        "4.0.7", sha256="7d3ecc8389161eb721982c855f89c25dca289001577a01a439ae97ce872be997"
    )  # libmpi.so.40.20.7
    version(
        "4.0.6", sha256="94b7b59ae9860f3bd7b5f378a698713e7b957070fdff2c43453b6cbf8edb410c"
    )  # libmpi.so.40.20.6
    version(
        "4.0.5", sha256="c58f3863b61d944231077f344fe6b4b8fbb83f3d1bc93ab74640bf3e5acac009"
    )  # libmpi.so.40.20.5
    version(
        "4.0.4", sha256="47e24eb2223fe5d24438658958a313b6b7a55bb281563542e1afc9dec4a31ac4"
    )  # libmpi.so.40.20.4
    version(
        "4.0.3", sha256="1402feced8c3847b3ab8252165b90f7d1fa28c23b6b2ca4632b6e4971267fd03"
    )  # libmpi.so.40.20.3
    version(
        "4.0.2", sha256="900bf751be72eccf06de9d186f7b1c4b5c2fa9fa66458e53b77778dffdfe4057"
    )  # libmpi.so.40.20.2
    version(
        "4.0.1", sha256="cce7b6d20522849301727f81282201d609553103ac0b09162cf28d102efb9709"
    )  # libmpi.so.40.20.1
    version(
        "4.0.0", sha256="2f0b8a36cfeb7354b45dda3c5425ef8393c9b04115570b615213faaa3f97366b"
    )  # libmpi.so.40.20.0

    # Retired
    version(
        "3.1.6", sha256="50131d982ec2a516564d74d5616383178361c2f08fdd7d1202b80bdf66a0d279"
    )  # libmpi.so.40.10.4
    version(
        "3.1.5", sha256="fbf0075b4579685eec8d56d34d4d9c963e6667825548554f5bf308610af72133"
    )  # libmpi.so.40.10.4
    version(
        "3.1.4", sha256="17a69e0054db530c7dc119f75bd07d079efa147cf94bf27e590905864fe379d6"
    )  # libmpi.so.40.10.4
    version(
        "3.1.3", sha256="8be04307c00f51401d3fb9d837321781ea7c79f2a5a4a2e5d4eaedc874087ab6"
    )  # libmpi.so.40.10.3
    version(
        "3.1.2", sha256="c654ed847f34a278c52a15c98add40402b4a90f0c540779f1ae6c489af8a76c5"
    )  # libmpi.so.40.10.2
    version(
        "3.1.1", sha256="3f11b648dd18a8b878d057e9777f2c43bf78297751ad77ae2cef6db0fe80c77c"
    )  # libmpi.so.40.10.1
    version(
        "3.1.0", sha256="b25c044124cc859c0b4e6e825574f9439a51683af1950f6acda1951f5ccdf06c"
    )  # libmpi.so.40.10.0
    version(
        "3.0.5", sha256="f8976b95f305efc435aa70f906b82d50e335e34cffdbf5d78118a507b1c6efe8"
    )  # libmpi.so.40.00.5
    version(
        "3.0.4", sha256="2ff4db1d3e1860785295ab95b03a2c0f23420cda7c1ae845c419401508a3c7b5"
    )  # libmpi.so.40.00.5
    version(
        "3.0.3", sha256="fb228e42893fe6a912841a94cd8a0c06c517701ae505b73072409218a12cf066"
    )  # libmpi.so.40.00.4
    version(
        "3.0.2", sha256="d2eea2af48c1076c53cabac0a1f12272d7470729c4e1cb8b9c2ccd1985b2fb06"
    )  # libmpi.so.40.00.2
    version(
        "3.0.1", sha256="663450d1ee7838b03644507e8a76edfb1fba23e601e9e0b5b2a738e54acd785d"
    )  # libmpi.so.40.00.1
    version(
        "3.0.0", sha256="f699bff21db0125d8cccfe79518b77641cd83628725a1e1ed3e45633496a82d7"
    )  # libmpi.so.40.00.0

    version(
        "2.1.6", sha256="98b8e1b8597bbec586a0da79fcd54a405388190247aa04d48e8c40944d4ca86e"
    )  # libmpi.so.20.10.3
    version(
        "2.1.5", sha256="b807ccab801f27c3159a5edf29051cd3331d3792648919f9c4cee48e987e7794"
    )  # libmpi.so.20.10.3
    version(
        "2.1.4", sha256="3e03695ca8bd663bc2d89eda343c92bb3d4fc79126b178f5ddcb68a8796b24e2"
    )  # libmpi.so.20.10.3
    version(
        "2.1.3", sha256="285b3e2a69ed670415524474496043ecc61498f2c63feb48575f8469354d79e8"
    )  # libmpi.so.20.10.2
    version(
        "2.1.2", sha256="3cc5804984c5329bdf88effc44f2971ed244a29b256e0011b8deda02178dd635"
    )  # libmpi.so.20.10.2
    version(
        "2.1.1", sha256="bd7badd4ff3afa448c0d7f3ca0ee6ce003b957e9954aa87d8e4435759b5e4d16"
    )  # libmpi.so.20.10.1
    version(
        "2.1.0", sha256="b169e15f5af81bf3572db764417670f508c0df37ce86ff50deb56bd3acb43957"
    )  # libmpi.so.20.10.0

    version(
        "2.0.4", sha256="4f82d5f7f294becbd737319f74801206b08378188a95b70abe706fdc77a0c20b"
    )  # libmpi.so.20.0.4
    version(
        "2.0.3", sha256="b52c0204c0e5954c9c57d383bb22b4181c09934f97783292927394d29f2a808a"
    )  # libmpi.so.20.0.3
    version(
        "2.0.2", sha256="cae396e643f9f91f0a795f8d8694adf7bacfb16f967c22fb39e9e28d477730d3"
    )  # libmpi.so.20.0.2
    version(
        "2.0.1", sha256="fed74f4ae619b7ebcc18150bb5bdb65e273e14a8c094e78a3fea0df59b9ff8ff"
    )  # libmpi.so.20.0.1
    version(
        "2.0.0", sha256="08b64cf8e3e5f50a50b4e5655f2b83b54653787bd549b72607d9312be44c18e0"
    )  # libmpi.so.20.0.0

    # Ancient
    version(
        "1.10.7", sha256="a089ece151fec974905caa35b0a59039b227bdea4e7933069e94bee4ed0e5a90"
    )  # libmpi.so.12.0.7
    version(
        "1.10.6", sha256="65606184a084a0eda6102b01e5a36a8f02d3195d15e91eabbb63e898bd110354"
    )  # libmpi.so.12.0.6
    version(
        "1.10.5", sha256="a95fa355ed3a905c7c187bc452529a9578e2d6bae2559d8197544ab4227b759e"
    )  # libmpi.so.12.0.5
    version(
        "1.10.4", sha256="fb3c0c4c77896185013b6091b306d29ba592eb40d8395533da5c8bc300d922db"
    )  # libmpi.so.12.0.4
    version(
        "1.10.3", sha256="7484bb664312082fd12edc2445b42362089b53b17fb5fce12efd4fe452cc254d"
    )  # libmpi.so.12.0.3
    version(
        "1.10.2", sha256="8846e7e69a203db8f50af90fa037f0ba47e3f32e4c9ccdae2db22898fd4d1f59"
    )  # libmpi.so.12.0.2
    version(
        "1.10.1", sha256="7919ecde15962bab2e26d01d5f5f4ead6696bbcacb504b8560f2e3a152bfe492"
    )  # libmpi.so.12.0.1
    version(
        "1.10.0", sha256="26b432ce8dcbad250a9787402f2c999ecb6c25695b00c9c6ee05a306c78b6490"
    )  # libmpi.so.12.0.0

    version(
        "1.8.8", sha256="a28382d1e6a36f4073412dc00836ff2524e42b674da9caf6ca7377baad790b94"
    )  # libmpi.so.1.6.3
    version(
        "1.8.7", sha256="da629e9bd820a379cfafe15f842ee9b628d7451856085ccc23ee75ab3e1b48c7"
    )  # libmpi.so.1.6.2
    version(
        "1.8.6", sha256="b9fe3bdfb86bd42cc53448e17f11278531b989b05ff9513bc88ba1a523f14e87"
    )  # libmpi.so.1.6.1
    version(
        "1.8.5", sha256="4cea06a9eddfa718b09b8240d934b14ca71670c2dc6e6251a585ce948a93fbc4"
    )  # libmpi.so.1.6.0
    version(
        "1.8.4", sha256="23158d916e92c80e2924016b746a93913ba7fae9fff51bf68d5c2a0ae39a2f8a"
    )  # libmpi.so.1.6.0
    version(
        "1.8.3", sha256="2ef02dab61febeb74714ff80d508c00b05defc635b391ed2c8dcc1791fbc88b3"
    )  # libmpi.so.1.6.0
    version(
        "1.8.2", sha256="ab70770faf1bac15ef44301fe2186b02f857646545492dd7331404e364a7d131"
    )  # libmpi.so.1.5.2
    version(
        "1.8.1", sha256="171427ebc007943265f33265ec32e15e786763952e2bfa2eac95e3e192c1e18f"
    )  # libmpi.so.1.5.0
    version(
        "1.8", sha256="35d5db86f49c0c64573b2eaf6d51c94ed8a06a9bb23dda475e602288f05e4ecf"
    )  # libmpi.so.1.5.0

    version(
        "1.7.5", sha256="cb3eef6880537d341d5d098511d390ec853716a6ec94007c03a0d1491b2ac8f2"
    )  # libmpi.so.1.4.0
    version(
        "1.7.4", sha256="ff8e31046c5bacfc6202d67f2479731ccd8542cdd628583ae75874000975f45c"
    )  # libmpi.so.1.3.0
    version(
        "1.7.3", sha256="438d96c178dbf5a1bc92fa1d238a8225d87b64af26ce2a07789faaf312117e45"
    )  # libmpi.so.1.2.0
    version(
        "1.7.2", sha256="82a1c477dcadad2032ab24d9be9e39c1042865965841911f072c49aa3544fd85"
    )  # libmpi.so.1.1.2
    version(
        "1.7.1", sha256="554583008fa34ecdfaca22e46917cc3457a69cba08c29ebbf53eef4f4b8be171"
    )  # libmpi.so.1.1.1
    version(
        "1.7", sha256="542e44aaef6546798c0d39c0fd849e9fbcd04a762f0ab100638499643253a513"
    )  # libmpi.so.1.1.0

    version(
        "1.6.5", sha256="fe37bab89b5ef234e0ac82dc798282c2ab08900bf564a1ec27239d3f1ad1fc85"
    )  # libmpi.so.1.0.8
    version(
        "1.6.4", sha256="40cb113a27d76e1e915897661579f413564c032dc6e703073e6a03faba8093fa"
    )  # libmpi.so.1.0.7
    version(
        "1.6.3", sha256="0c30cfec0e420870630fdc101ffd82f7eccc90276bc4e182f8282a2448668798"
    )  # libmpi.so.1.0.6
    version(
        "1.6.2", sha256="5cc7744c6cc4ec2c04bc76c8b12717c4011822a2bd7236f2ea511f09579a714a"
    )  # libmpi.so.1.0.3
    version(
        "1.6.1", sha256="077240dd1ab10f0caf26931e585db73848e9815c7119b993f91d269da5901e3a"
    )  # libmpi.so.1.0.3
    version(
        "1.6", sha256="6e0d8b336543fb9ab78c97d364484923167857d30b266dfde1ccf60f356b9e0e"
    )  # libmpi.so.1.0.3

    version(
        "1.5.5", sha256="660e6e49315185f88a87b6eae3d292b81774eab7b29a9b058b10eb35d892ff23"
    )  # libmpi.so.1.0.3
    version(
        "1.5.4", sha256="81126a95a51b8af4bb0ad28790f852c30d22d989713ec30ad22e9e0a79587ef6"
    )  # libmpi.so.1.0.2
    version(
        "1.5.3", sha256="70745806cdbe9b945d47d9fa058f99e072328e41e40c0ced6dd75220885c5263"
    )  # libmpi.so.1.0.1
    version(
        "1.5.2", sha256="7123b781a9fd21cc79870e7fe01e9c0d3f36935c444922661e24af523b116ab1"
    )  # libmpi.so.1.0.1
    version(
        "1.5.1", sha256="c28bb0bd367ceeec08f739d815988fca54fc4818762e6abcaa6cfedd6fd52274"
    )  # libmpi.so.1.0.0
    version(
        "1.5", sha256="1882b1414a94917ec26b3733bf59da6b6db82bf65b5affd7f0fcbd96efaca506"
    )  # libmpi.so.1.0.0

    version(
        "1.4.5", sha256="a3857bc69b7d5258cf7fc1ed1581d9ac69110f5c17976b949cb7ec789aae462d"
    )  # libmpi.so.0.0.4
    version(
        "1.4.4", sha256="9ad125304a89232d5b04da251f463fdbd8dcd997450084ba4227e7f7a095c3ed"
    )  # libmpi.so.0.0.3
    version(
        "1.4.3", sha256="220b72b1c7ee35469ff74b4cfdbec457158ac6894635143a33e9178aa3981015"
    )  # libmpi.so.0.0.2
    version(
        "1.4.2", sha256="19129e3d51860ad0a7497ede11563908ba99c76b3a51a4d0b8801f7e2db6cd80"
    )  # libmpi.so.0.0.2
    version(
        "1.4.1", sha256="d4d71d7c670d710d2d283ea60af50d6c315318a4c35ec576bedfd0f3b7b8c218"
    )  # libmpi.so.0.0.1
    version(
        "1.4", sha256="fa55edef1bd8af256e459d4d9782516c6998b9d4698eda097d5df33ae499858e"
    )  # libmpi.so.0.0.1

    version(
        "1.3.4", sha256="fbfe4b99b0c98f81a4d871d02f874f84ea66efcbb098f6ad84ebd19353b681fc"
    )  # libmpi.so.0.0.1
    version(
        "1.3.3", sha256="e1425853282da9237f5b41330207e54da1dc803a2e19a93dacc3eca1d083e422"
    )  # libmpi.so.0.0.0
    version(
        "1.3.2", sha256="c93ed90962d879a2923bed17171ed9217036ee1279ffab0925ea7eead26105d8"
    )  # libmpi.so.0.0.0
    version(
        "1.3.1", sha256="22d18919ddc5f49d55d7d63e2abfcdac34aa0234427e861e296a630c6c11632c"
    )  # libmpi.so.0.0.0
    version(
        "1.3", sha256="864706d88d28b586a045461a828962c108f5912671071bc3ef0ca187f115e47b"
    )  # libmpi.so.0.0.0

    version(
        "1.2.9", sha256="0eb36abe09ba7bf6f7a70255974e5d0a273f7f32d0e23419862c6dcc986f1dff"
    )  # libmpi.so.0.0.0
    version(
        "1.2.8", sha256="75b286cb3b1bf6528a7e64ee019369e0601b8acb5c3c167a987f755d1e41c95c"
    )  # libmpi.so.0.0.0
    version(
        "1.2.7", sha256="d66c7f0bb11494023451651d0e61afaef9d2199ed9a91ed08f0dedeb51541c36"
    )  # libmpi.so.0.0.0
    version(
        "1.2.6", sha256="e5b27af5a153a257b1562a97bbf7164629161033934558cefd8e1e644a9f73d3"
    )  # libmpi.so.0.0.0
    version(
        "1.2.5", sha256="3c3aed872c17165131c77bd7a12fe8aec776cb23da946b7d12840db93ab79322"
    )  # libmpi.so.0.0.0
    version(
        "1.2.4", sha256="594a3a0af69cc7895e0d8f9add776a44bf9ed389794323d0b1b45e181a97e538"
    )  # libmpi.so.0.0.0
    version(
        "1.2.3", sha256="f936ca3a197e5b2d1a233b7d546adf07898127683b03c4b37cf31ae22a6f69bb"
    )  # libmpi.so.0.0.0
    version(
        "1.2.2", sha256="aa763e0e6a6f5fdff8f9d3fc988a4ba0ed902132d292c85aef392cc65bb524e6"
    )  # libmpi.so.0.0.0
    version(
        "1.2.1", sha256="a94731d84fb998df33960e0b57ea5661d35e7c7cd9d03d900f0b6a5a72e4546c"
    )  # libmpi.so.0.0.0
    version(
        "1.2", sha256="ba0bfa3dec2ead38a3ed682ca36a0448617b8e29191ab3f48c9d0d24d87d14c0"
    )  # libmpi.so.0.0.0

    version(
        "1.1.5", sha256="913deaedf3498bd5d06299238ec4d048eb7af9c3afd8e32c12f4257c8b698a91"
    )  # libmpi.so.0.0.0
    version(
        "1.1.4", sha256="21c37f85df7e959f17cc7cb5571d8db2a94ed2763e3e96e5d052aff2725c1d18"
    )  # libmpi.so.0.0.0
    version(
        "1.1.3", sha256="c33f8f5e65cfe872173616cca27ae8dc6d93ea66e0708118b9229128aecc174f"
    )  # libmpi.so.0.0.0
    version(
        "1.1.2", sha256="3bd8d9fe40b356be7f9c3d336013d3865f8ca6a79b3c6e7ef28784f6c3a2b8e6"
    )  # libmpi.so.0.0.0
    version(
        "1.1.1", sha256="dc31aaec986c4ce436dbf31e73275ed1a9391432dcad7609de8d0d3a78d2c700"
    )  # libmpi.so.0.0.0
    version(
        "1.1", sha256="ebe14801d2caeeaf47b0e437b43f73668b711f4d3fcff50a0d665d4bd4ea9531"
    )  # libmpi.so.0.0.0

    version(
        "1.0.2", sha256="ccd1074d7dd9566b73812d9882c84e446a8f4c77b6f471d386d3e3b9467767b8"
    )  # libmpi.so.0.0.0
    version(
        "1.0.1", sha256="f801b7c8ea6c485ac0709a628a479aeafa718a205ed6bc0cf2c684bc0cc73253"
    )  # libmpi.so.0.0.0
    version(
        "1.0", sha256="cf75e56852caebe90231d295806ac3441f37dc6d9ad17b1381791ebb78e21564"
    )  # libmpi.so.0.0.0

    patch("ad_lustre_rwcontig_open_source.patch", when="@1.6.5")
    patch("llnl-platforms.patch", when="@1.6.5")
    patch("configure.patch", when="@1.10.1")
    patch("fix_multidef_pmi_class.patch", when="@2.0.0:2.0.1")
    patch("fix-ucx-1.7.0-api-instability.patch", when="@4.0.0:4.0.2")

    # Vader Bug: https://github.com/open-mpi/ompi/issues/5375
    # Haven't release fix for 2.1.x
    patch("btl_vader.patch", when="@2.1.3:2.1.5")

    # Fixed in 3.0.3 and 3.1.3
    patch("btl_vader.patch", when="@3.0.1:3.0.2")
    patch("btl_vader.patch", when="@3.1.0:3.1.2")

    # Make NAG compiler pass the -pthread option to the linker:
    # https://github.com/open-mpi/ompi/pull/6378
    # We support only versions based on Libtool 2.4.6.
    patch("nag_pthread/2.1.4_2.1.999_3.0.1_4.patch", when="@2.1.4:2.1,3.0.1:4%nag")
    patch("nag_pthread/2.1.2_2.1.3_3.0.0.patch", when="@2.1.2:2.1.3,3.0.0%nag")
    patch("nag_pthread/2.0.0_2.1.1.patch", when="@2.0.0:2.1.1%nag")
    patch("nag_pthread/1.10.4_1.10.999.patch", when="@1.10.4:1.10%nag")

    # Fix MPI_Sizeof() in the "mpi" Fortran module for compilers that do not
    # support "IGNORE TKR" functionality (e.g. NAG).
    # The issue has been resolved upstream in two steps:
    #   1) https://github.com/open-mpi/ompi/pull/2294
    #   2) https://github.com/open-mpi/ompi/pull/5099
    # The first one was applied starting version v3.0.0 and backported to
    # v1.10. A subset with relevant modifications is applicable starting
    # version 1.8.4.
    patch("use_mpi_tkr_sizeof/step_1.patch", when="@1.8.4:1.10.6,2.0:2")
    # The second patch was applied starting version v4.0.0 and backported to
    # v2.x, v3.0.x, and v3.1.x.
    patch("use_mpi_tkr_sizeof/step_2.patch", when="@1.8.4:2.1.3,3:3.0.1")
    # To fix performance regressions introduced while fixing a bug in older
    # gcc versions on x86_64, Refs. open-mpi/ompi#8603
    patch("opal_assembly_arch.patch", when="@4.0.0:4.0.5,4.1.0")

    variant(
        "fabrics",
        values=disjoint_sets(
            ("auto",),
            (
                "psm",
                "psm2",
                "verbs",
                "mxm",
                "ucx",
                "ofi",
                "fca",
                "hcoll",
                "xpmem",
                "cma",
                "knem",
            ),  # shared memory transports
        ).with_non_feature_values("auto", "none"),
        description="List of fabrics that are enabled; " "'auto' lets openmpi determine",
    )

    variant(
        "schedulers",
        values=disjoint_sets(
            ("auto",), ("alps", "lsf", "tm", "slurm", "sge", "loadleveler")
        ).with_non_feature_values("auto", "none"),
        description="List of schedulers for which support is enabled; "
        "'auto' lets openmpi determine",
    )

    # Additional support options
    variant("atomics", default=False, description="Enable built-in atomics")
    variant("java", default=False, when="@1.7.4:", description="Build Java support")
    variant("static", default=True, description="Build static libraries")
    variant("sqlite3", default=False, when="@1.7.3:1", description="Build SQLite3 support")
    variant("vt", default=True, description="Build VampirTrace support")
    variant(
        "thread_multiple",
        default=False,
        when="@1.5.4:2",
        description="Enable MPI_THREAD_MULTIPLE support",
    )
    variant(
        "pmi", default=False, when="@1.5.5:4 schedulers=slurm", description="Enable PMI support"
    )
    variant(
        "wrapper-rpath",
        default=True,
        when="@1.7.4:",
        description="Enable rpath support in the wrappers",
    )
    variant("cxx", default=False, when="@:4", description="Enable deprecated C++ MPI bindings")
    variant(
        "cxx_exceptions",
        default=False,
        when="@:4",
        description="Enable deprecated C++ exception support",
    )
    variant("gpfs", default=False, description="Enable GPFS support")
    variant(
        "singularity",
        default=False,
        when="@:4",
        description="Build deprecated support for the Singularity container",
    )
    variant("lustre", default=False, description="Lustre filesystem library support")
    variant("romio", default=True, description="Enable ROMIO support")
    variant("rsh", default=True, description="Enable rsh (openssh) process lifecycle management")
    # Adding support to build a debug version of OpenMPI that activates
    # Memchecker, as described here:
    #
    # https://www.open-mpi.org/faq/?category=debugging#memchecker_what
    #
    # This option degrades run-time support, and thus is disabled by default
    variant(
        "memchecker",
        default=False,
        description="Memchecker support for debugging [degrades performance]",
    )

    variant(
        "legacylaunchers",
        default=False,
        description="Do not remove mpirun/mpiexec when building with slurm",
    )
    # Variants to use internal packages
    variant("internal-hwloc", default=False, description="Use internal hwloc")

    provides("mpi")
    provides("mpi@:2.2", when="@1.6.5")
    provides("mpi@:3.0", when="@1.7.5:")
    provides("mpi@:3.1", when="@2.0.0:")

    if sys.platform != "darwin":
        depends_on("numactl")

    depends_on("autoconf @2.69:", type="build", when="@main")
    depends_on("automake @1.13.4:", type="build", when="@main")
    depends_on("libtool @2.4.2:", type="build", when="@main")
    depends_on("m4", type="build", when="@main")

    depends_on("perl", type="build")
    depends_on("pkgconfig", type="build")

    depends_on("hwloc@2:", when="@4: ~internal-hwloc")
    # ompi@:3.0.0 doesn't support newer hwloc releases:
    # "configure: error: OMPI does not currently support hwloc v2 API"
    # Future ompi releases may support it, needs to be verified.
    # See #7483 for context.
    depends_on("hwloc@:1", when="@:3 ~internal-hwloc")

    depends_on("hwloc +cuda", when="+cuda ~internal-hwloc")
    depends_on("java", when="+java")
    depends_on("sqlite", when="+sqlite3")
    depends_on("zlib", when="@3:")
    depends_on("valgrind~mpi", when="+memchecker")
    # Singularity release 3 works better
    depends_on("singularity@3:", when="+singularity")
    depends_on("lustre", when="+lustre")

    depends_on("opa-psm2", when="fabrics=psm2")
    depends_on("rdma-core", when="fabrics=verbs")
    depends_on("mxm", when="fabrics=mxm")
    depends_on("binutils+libiberty", when="fabrics=mxm")
    with when("fabrics=ucx"):
        depends_on("ucx")
        depends_on("ucx +thread_multiple", when="+thread_multiple")
        depends_on("ucx +thread_multiple", when="@3.0.0:")
        depends_on("ucx@1.9.0:", when="@4.0.6:4.0")
        depends_on("ucx@1.9.0:", when="@4.1.1:4.1")
        depends_on("ucx@1.9.0:", when="@5.0.0:")
    depends_on("libfabric", when="fabrics=ofi")
    depends_on("fca", when="fabrics=fca")
    depends_on("hcoll", when="fabrics=hcoll")
    depends_on("xpmem", when="fabrics=xpmem")
    depends_on("knem", when="fabrics=knem")

    depends_on("lsf", when="schedulers=lsf")
    depends_on("pbs", when="schedulers=tm")
    depends_on("slurm", when="schedulers=slurm")

    # PMIx is unavailable for @1, and required for @2:
    # OpenMPI @2: includes a vendored version:
    # depends_on('pmix@1.1.2', when='@2.1.6')
    # depends_on('pmix@3.2.3', when='@4.1.2')
    depends_on("pmix@1.0:1", when="@2.0:2")
    depends_on("pmix@3.1:", when="@4.0:4")
    depends_on("pmix@5:", when="@5.0:5")

    # Libevent is required when *vendored* PMIx is used
    depends_on("libevent@2:", when="@main")

    depends_on("openssh", type="run", when="+rsh")

    conflicts("+cxx_exceptions", when="%nvhpc", msg="nvc does not ignore -fexceptions, but errors")

    # CUDA support was added in 1.7, and since the variant is part of the
    # parent package we must express as a conflict rather than a conditional
    # variant.
    conflicts("+cuda", when="@:1.6")
    # PSM2 support was added in 1.10.0
    conflicts("fabrics=psm2", when="@:1.8")
    # MXM support was added in 1.5.4
    conflicts("fabrics=mxm", when="@:1.5.3")
    # libfabric (OFI) support was added in 1.10.0
    conflicts("fabrics=ofi", when="@:1.8")
    # fca support was added in 1.5.0 and removed in 5.0.0
    conflicts("fabrics=fca", when="@:1.4,5:")
    # hcoll support was added in 1.7.3:
    conflicts("fabrics=hcoll", when="@:1.7.2")
    # xpmem support was added in 1.7
    conflicts("fabrics=xpmem", when="@:1.6")
    # cma support was added in 1.7
    conflicts("fabrics=cma", when="@:1.6")
    # knem support was added in 1.5
    conflicts("fabrics=knem", when="@:1.4")

    conflicts(
        "schedulers=slurm ~pmi",
        when="@1.5.4",
        msg="+pmi is required for openmpi to work with SLURM.",
    )
    conflicts(
        "schedulers=loadleveler",
        when="@3:",
        msg="The loadleveler scheduler is not supported with " "openmpi(>=3).",
    )

    # According to this comment on github:
    #
    # https://github.com/open-mpi/ompi/issues/4338#issuecomment-383982008
    #
    # adding --enable-static silently disables slurm support via pmi/pmi2
    # for versions older than 3.0.3,3.1.3,4.0.0
    # Presumably future versions after 11/2018 should support slurm+static
    conflicts("+static", when="schedulers=slurm @:3.0.2,3.1:3.1.2,4.0.0")

    filter_compiler_wrappers("openmpi/*-wrapper-data*", relative_root="share")

    extra_install_tests = "examples"

    @classmethod
    def determine_version(cls, exe):
        output = Executable(exe)(output=str, error=str)
        match = re.search(r"Open MPI: (\S+)", output)
        return Version(match.group(1)) if match else None

    @classmethod
    def determine_variants(cls, exes, version):
        results = []
        for exe in exes:
            variants = []
            output = Executable(exe)("-a", output=str, error=str)
            # Some of these options we have to find by hoping the
            # configure string is in the ompi_info output. While this
            # is usually true, it's not guaranteed.  For anything that
            # begins with --, we want to use the defaults as provided
            # by the openmpi package in the absense of any other info.

            # atomics
            if re.search(r"--enable-builtin-atomics", output):
                variants.append("+atomics")

            # java
            if version in spack.version.ver("1.7.4:"):
                match = re.search(r"\bJava bindings: (\S+)", output)
                if match and is_enabled(match.group(1)):
                    variants.append("+java")
                else:
                    variants.append("~java")

            # static
            if re.search(r"--enable-static", output):
                variants.append("+static")
            elif re.search(r"--disable-static", output):
                variants.append("~static")
            elif re.search(r"\bMCA (?:coll|oca|pml): monitoring", output):
                # Built multiple variants of openmpi and ran diff.
                # This seems to be the distinguishing feature.
                variants.append("~static")

            # sqlite
            if version in spack.version.ver("1.7.3:1"):
                if re.search(r"\bMCA db: sqlite", output):
                    variants.append("+sqlite3")
                else:
                    variants.append("~sqlite3")

            # vt
            if re.search(r"--enable-contrib-no-build=vt", output):
                variants.append("+vt")

            # thread_multiple
            if version in spack.version.ver("1.5.4:2"):
                match = re.search(r"MPI_THREAD_MULTIPLE: (\S+?),?", output)
                if match and is_enabled(match.group(1)):
                    variants.append("+thread_multiple")
                else:
                    variants.append("~thread_multiple")

            # cuda
            match = re.search(
                r'parameter "mpi_built_with_cuda_support" ' + r'\(current value: "(\S+)"', output
            )
            if match and is_enabled(match.group(1)):
                variants.append("+cuda")
            else:
                variants.append("~cuda")

            # wrapper-rpath
            if version in spack.version.ver("1.7.4:"):
                match = re.search(r"\bWrapper compiler rpath: (\S+)", output)
                if match and is_enabled(match.group(1)):
                    variants.append("+wrapper-rpath")
                else:
                    variants.append("~wrapper-rpath")

            # cxx
            if version in spack.version.ver(":4"):
                match = re.search(r"\bC\+\+ bindings: (\S+)", output)
                if match and match.group(1) == "yes":
                    variants.append("+cxx")
                else:
                    variants.append("~cxx")

            # cxx_exceptions
            if version in spack.version.ver(":4"):
                match = re.search(r"\bC\+\+ exceptions: (\S+)", output)
                if match and match.group(1) == "yes":
                    variants.append("+cxx_exceptions")
                else:
                    variants.append("~cxx_exceptions")

            # singularity
            if version in spack.version.ver(":4"):
                if re.search(r"--with-singularity", output):
                    variants.append("+singularity")

            # lustre
            if re.search(r"--with-lustre", output):
                variants.append("+lustre")

            # memchecker
            match = re.search(r"Memory debugging support: (\S+)", output)
            if match and is_enabled(match.group(1)):
                variants.append("+memchecker")
            else:
                variants.append("~memchecker")

            # pmi
            if version in spack.version.ver("1.5.5:4"):
                if re.search(r"\bMCA (?:ess|prrte): pmi", output):
                    variants.append("+pmi")
                else:
                    variants.append("~pmi")

            # fabrics
            fabrics = get_options_from_variant(cls, "fabrics")
            used_fabrics = []
            for fabric in fabrics:
                match = re.search(r"\bMCA (?:mtl|btl|pml): %s\b" % fabric, output)
                if match:
                    used_fabrics.append(fabric)
            if used_fabrics:
                variants.append("fabrics=" + ",".join(used_fabrics))

            # schedulers
            schedulers = get_options_from_variant(cls, "schedulers")
            used_schedulers = []
            for scheduler in schedulers:
                match = re.search(r"\bMCA (?:prrte|ras): %s\b" % scheduler, output)
                if match:
                    used_schedulers.append(scheduler)
            if used_schedulers:
                variants.append("schedulers=" + ",".join(used_schedulers))

            # Get the appropriate compiler
            match = re.search(r"\bC compiler absolute: (\S+)", output)
            if match:
                compiler = match.group(1)
                compiler_spec = get_spack_compiler_spec(compiler)
                if compiler_spec:
                    variants.append("%" + str(compiler_spec))
            results.append(" ".join(variants))
        return results

    def url_for_version(self, version):
        url = "https://download.open-mpi.org/release/open-mpi/v{0}/openmpi-{1}.tar.bz2"
        return url.format(version.up_to(2), version)

    @property
    def headers(self):
        hdrs = HeaderList(find(self.prefix.include, "mpi.h", recursive=False))
        if not hdrs:
            hdrs = HeaderList(find(self.prefix, "mpi.h", recursive=True))
        return hdrs or None

    @property
    def libs(self):
        query_parameters = self.spec.last_query.extra_parameters
        libraries = ["libmpi"]

        if "cxx" in query_parameters:
            libraries = ["libmpi_cxx"] + libraries

        return find_libraries(libraries, root=self.prefix, shared=True, recursive=True)

    def setup_run_environment(self, env):
        # Because MPI is both a runtime and a compiler, we have to setup the
        # compiler components as part of the run environment.
        env.set("MPICC", join_path(self.prefix.bin, "mpicc"))
        env.set("MPICXX", join_path(self.prefix.bin, "mpic++"))
        env.set("MPIF77", join_path(self.prefix.bin, "mpif77"))
        env.set("MPIF90", join_path(self.prefix.bin, "mpif90"))
        env.prepend_path("LD_LIBRARY_PATH", self.prefix.lib)

    def setup_dependent_build_environment(self, env, dependent_spec):
        self.setup_run_environment(env)

        # Use the spack compiler wrappers under MPI
        env.set("OMPI_CC", spack_cc)
        env.set("OMPI_CXX", spack_cxx)
        env.set("OMPI_FC", spack_fc)
        env.set("OMPI_F77", spack_f77)

        # See https://www.open-mpi.org/faq/?category=building#installdirs
        for suffix in [
            "PREFIX",
            "EXEC_PREFIX",
            "BINDIR",
            "SBINDIR",
            "LIBEXECDIR",
            "DATAROOTDIR",
            "DATADIR",
            "SYSCONFDIR",
            "SHAREDSTATEDIR",
            "LOCALSTATEDIR",
            "LIBDIR",
            "INCLUDEDIR",
            "INFODIR",
            "MANDIR",
            "PKGDATADIR",
            "PKGLIBDIR",
            "PKGINCLUDEDIR",
        ]:
            env.unset("OPAL_%s" % suffix)

    def setup_dependent_package(self, module, dependent_spec):
        self.spec.mpicc = join_path(self.prefix.bin, "mpicc")
        self.spec.mpicxx = join_path(self.prefix.bin, "mpic++")
        self.spec.mpifc = join_path(self.prefix.bin, "mpif90")
        self.spec.mpif77 = join_path(self.prefix.bin, "mpif77")
        self.spec.mpicxx_shared_libs = [
            join_path(self.prefix.lib, "libmpi_cxx.{0}".format(dso_suffix)),
            join_path(self.prefix.lib, "libmpi.{0}".format(dso_suffix)),
        ]

    # Most of the following with_or_without methods might seem redundant
    # because Spack compiler wrapper adds the required -I and -L flags, which
    # is enough for the configure script to find them. However, we also need
    # the flags in Libtool (lib/*.la) and pkg-config (lib/pkgconfig/*.pc).
    # Therefore, we pass the prefixes explicitly.

    def with_or_without_psm2(self, activated):
        if not activated:
            return "--without-psm2"
        return "--with-psm2={0}".format(self.spec["opa-psm2"].prefix)

    def with_or_without_verbs(self, activated):
        # Up through version 1.6, this option was named --with-openib.
        # In version 1.7, it was renamed to be --with-verbs.
        opt = "verbs" if self.spec.satisfies("@1.7:") else "openib"
        if not activated:
            return "--without-{0}".format(opt)
        return "--with-{0}={1}".format(opt, self.spec["rdma-core"].prefix)

    def with_or_without_mxm(self, activated):
        if not activated:
            return "--without-mxm"
        return "--with-mxm={0}".format(self.spec["mxm"].prefix)

    def with_or_without_ucx(self, activated):
        if not activated:
            return "--without-ucx"
        return "--with-ucx={0}".format(self.spec["ucx"].prefix)

    def with_or_without_ofi(self, activated):
        # Up through version 3.0.3 this option was name --with-libfabric.
        # In version 3.0.4, the old name was deprecated in favor of --with-ofi.
        opt = "ofi" if self.spec.satisfies("@3.0.4:") else "libfabric"
        if not activated:
            return "--without-{0}".format(opt)
        return "--with-{0}={1}".format(opt, self.spec["libfabric"].prefix)

    def with_or_without_fca(self, activated):
        if not activated:
            return "--without-fca"
        return "--with-fca={0}".format(self.spec["fca"].prefix)

    def with_or_without_hcoll(self, activated):
        if not activated:
            return "--without-hcoll"
        return "--with-hcoll={0}".format(self.spec["hcoll"].prefix)

    def with_or_without_xpmem(self, activated):
        if not activated:
            return "--without-xpmem"
        return "--with-xpmem={0}".format(self.spec["xpmem"].prefix)

    def with_or_without_knem(self, activated):
        if not activated:
            return "--without-knem"
        return "--with-knem={0}".format(self.spec["knem"].prefix)

    def with_or_without_lsf(self, activated):
        if not activated:
            return "--without-lsf"
        return "--with-lsf={0}".format(self.spec["lsf"].prefix)

    def with_or_without_tm(self, activated):
        if not activated:
            return "--without-tm"
        return "--with-tm={0}".format(self.spec["pbs"].prefix)

    @run_before("autoreconf")
    def die_without_fortran(self):
        # Until we can pass variants such as +fortran through virtual
        # dependencies depends_on('mpi'), require Fortran compiler to
        # avoid delayed build errors in dependents.
        if (self.compiler.f77 is None) or (self.compiler.fc is None):
            raise InstallError("OpenMPI requires both C and Fortran compilers!")

    @when("@main")
    def autoreconf(self, spec, prefix):
        perl = which("perl")
        perl("autogen.pl")

    def configure_args(self):
        spec = self.spec
        config_args = ["--enable-shared", "--disable-silent-rules"]

        # All rpath flags should be appended with self.compiler.cc_rpath_arg.
        # Later, we might need to update share/openmpi/mpic++-wrapper-data.txt
        # and mpifort-wrapper-data.txt (see filter_rpaths()).
        wrapper_ldflags = []

        config_args.extend(self.enable_or_disable("builtin-atomics", variant="atomics"))

        if spec.satisfies("+pmi"):
            #config_args.append("--with-pmi={0}".format(spec["slurm"].prefix))
            # system slurm pmi2.h parent directory
            config_args.append(f'--with-pmi={PMI_DEV_DIR}')
            config_args.append(f'--with-pmi-libdir={PMI_LIB_DIR}')
        else:
            config_args.extend(self.with_or_without("pmi"))

        config_args.extend(self.enable_or_disable("static"))

        if spec.satisfies("@4.0.0:4.0.2"):
            # uct btl doesn't work with some UCX versions so just disable
            config_args.append("--enable-mca-no-build=btl-uct")

        # Remove ssh/rsh pml
        if spec.satisfies("~rsh"):
            config_args.append("--enable-mca-no-build=plm-rsh")

        # some scientific packages ignore deprecated/remove symbols. Re-enable
        # them for now, for discussion see
        # https://github.com/open-mpi/ompi/issues/6114#issuecomment-446279495
        if spec.satisfies("@4.0.1:"):
            config_args.append("--enable-mpi1-compatibility")

        # Fabrics
        if "fabrics=auto" not in spec:
            config_args.extend(self.with_or_without("fabrics"))

        if spec.satisfies("@2.0.0:"):
            if "fabrics=xpmem platform=cray" in spec:
                config_args.append("--with-cray-xpmem")
            else:
                config_args.append("--without-cray-xpmem")

        # Schedulers
        if "schedulers=auto" not in spec:
            config_args.extend(self.with_or_without("schedulers"))

        config_args.extend(self.enable_or_disable("memchecker"))
        if spec.satisfies("+memchecker", strict=True):
            config_args.extend(
                [
                    "--enable-debug",
                ]
            )

        # Package dependencies
        for dep in ["libevent", "lustre", "pmix", "singularity", "valgrind", "zlib"]:
            if "^" + dep in spec:
                config_args.append("--with-{0}={1}".format(dep, spec[dep].prefix))

        # Hwloc support
        if "^hwloc" in spec:
            config_args.append("--with-hwloc=" + spec["hwloc"].prefix)
        # Java support
        if "+java" in spec:
            config_args.extend(
                ["--enable-java", "--enable-mpi-java", "--with-jdk-dir=" + spec["java"].home]
            )
        elif spec.satisfies("@1.7.4:"):
            config_args.extend(["--disable-java", "--disable-mpi-java"])

        if "~romio" in spec:
            config_args.append("--disable-io-romio")

        if "+gpfs" in spec:
            config_args.append("--with-gpfs")
        else:
            config_args.append("--with-gpfs=no")

        # SQLite3 support
        config_args.extend(self.with_or_without("sqlite3"))

        # VampirTrace support
        if spec.satisfies("@1.3:1"):
            if "~vt" in spec:
                config_args.append("--enable-contrib-no-build=vt")

        # Multithreading support
        config_args.extend(
            self.enable_or_disable("mpi-thread-multiple", variant="thread_multiple")
        )

        # CUDA support
        # See https://www.open-mpi.org/faq/?category=buildcuda
        if "+cuda" in spec:
            # OpenMPI dynamically loads libcuda.so, requires dlopen
            config_args.append("--enable-dlopen")
            # Searches for header files in DIR/include
            config_args.append("--with-cuda={0}".format(spec["cuda"].prefix))
            if spec.satisfies("@1.7:1.7.2"):
                # This option was removed from later versions
                config_args.append(
                    "--with-cuda-libdir={0}".format(spec["cuda"].libs.directories[0])
                )
            if spec.satisfies("@1.7.2"):
                # There was a bug in 1.7.2 when --enable-static is used
                config_args.append("--enable-mca-no-build=pml-bfo")
            if spec.satisfies("%pgi^cuda@7.0:7"):
                # OpenMPI has problems with CUDA 7 and PGI
                config_args.append("--with-wrapper-cflags=-D__LP64__ -ta:tesla")
                if spec.satisfies("%pgi@:15.8"):
                    # With PGI 15.9 and later compilers, the
                    # CFLAGS=-D__LP64__ is no longer needed.
                    config_args.append("CFLAGS=-D__LP64__")
        elif spec.satisfies("@1.7:"):
            config_args.append("--without-cuda")

        if spec.satisfies("%nvhpc@:20.11"):
            # Workaround compiler issues
            config_args.append("CFLAGS=-O1")

        if "+wrapper-rpath" in spec:
            config_args.append("--enable-wrapper-rpath")

            # Disable new dynamic tags in the wrapper (--disable-new-dtags)
            # In the newer versions this can be done with a configure option
            # (for older versions, we rely on filter_compiler_wrappers() and
            # filter_pc_files()):
            if spec.satisfies("@3.0.5:"):
                config_args.append("--disable-wrapper-runpath")

            # Add extra_rpaths and implicit_rpaths into the wrappers.
            wrapper_ldflags.extend(
                [
                    self.compiler.cc_rpath_arg + path
                    for path in itertools.chain(
                        self.compiler.extra_rpaths, self.compiler.implicit_rpaths()
                    )
                ]
            )
        else:
            config_args.append("--disable-wrapper-rpath")
            config_args.append("--disable-wrapper-runpath")

        config_args.extend(self.enable_or_disable("mpi-cxx", variant="cxx"))
        config_args.extend(self.enable_or_disable("cxx-exceptions", variant="cxx_exceptions"))

        if wrapper_ldflags:
            config_args.append("--with-wrapper-ldflags={0}".format(" ".join(wrapper_ldflags)))

        return config_args

    @run_after("install", when="+wrapper-rpath")
    def filter_rpaths(self):
        def filter_lang_rpaths(lang_tokens, rpath_arg):
            if self.compiler.cc_rpath_arg == rpath_arg:
                return

            files = find(
                self.spec.prefix.share.openmpi,
                ["*{0}-wrapper-data*".format(t) for t in lang_tokens],
            )
            files.extend(
                find(
                    self.spec.prefix.lib.pkgconfig, ["ompi-{0}.pc".format(t) for t in lang_tokens]
                )
            )

            x = FileFilter(*[f for f in files if not os.path.islink(f)])

            # Replace self.compiler.cc_rpath_arg, which have been added as
            # '--with-wrapper-ldflags', with rpath_arg in the respective
            # language-specific wrappers and pkg-config files.
            x.filter(self.compiler.cc_rpath_arg, rpath_arg, string=True, backup=False)

            if self.spec.satisfies("@:1.10.3,2:2.1.1"):
                # Replace Libtool-style RPATH prefixes '-Wl,-rpath -Wl,' with
                # rpath_arg for old version of OpenMPI, which assumed that CXX
                # and FC had the same prefixes as CC.
                x.filter("-Wl,-rpath -Wl,", rpath_arg, string=True, backup=False)

        filter_lang_rpaths(["c++", "CC", "cxx"], self.compiler.cxx_rpath_arg)
        filter_lang_rpaths(["fort", "f77", "f90"], self.compiler.fc_rpath_arg)

    @run_after("install", when="@:3.0.4+wrapper-rpath")
    def filter_pc_files(self):
        files = find(self.spec.prefix.lib.pkgconfig, "*.pc")
        x = FileFilter(*[f for f in files if not os.path.islink(f)])

        # Remove this linking flag if present (it turns RPATH into RUNPATH)
        x.filter(
            "{0}--enable-new-dtags".format(self.compiler.linker_arg), "", string=True, backup=False
        )

        # NAG compiler is usually mixed with GCC, which has a different
        # prefix for linker arguments.
        if self.compiler.name == "nag":
            x.filter("-Wl,--enable-new-dtags", "", string=True, backup=False)

    @run_after("install")
    def delete_mpirun_mpiexec(self):
        # The preferred way to run an application when Slurm is the
        # scheduler is to let Slurm manage process spawning via PMI.
        #
        # Deleting the links to orterun avoids users running their
        # applications via mpirun or mpiexec, and leaves srun as the
        # only sensible choice (orterun is still present, but normal
        # users don't know about that).
        if "@1.6: ~legacylaunchers schedulers=slurm" in self.spec:
            exe_list = [
                self.prefix.bin.mpirun,
                self.prefix.bin.mpiexec,
                self.prefix.bin.shmemrun,
                self.prefix.bin.oshrun,
            ]
            script_stub = join_path(os.path.dirname(__file__), "nolegacylaunchers.sh")
            for exe in exe_list:
                try:
                    os.remove(exe)
                except OSError:
                    tty.debug("File not present: " + exe)
                else:
                    copy(script_stub, exe)

    @run_after("install")
    def setup_install_tests(self):
        """
        Copy the example files after the package is installed to an
        install test subdirectory for use during `spack test run`.
        """
        self.cache_extra_test_sources(self.extra_install_tests)

    def _test_bin_ops(self):
        info = ([], ["Ident string: {0}".format(self.spec.version), "MCA"], 0)

        ls = (["-n", "1", "ls", ".."], ["openmpi-{0}".format(self.spec.version)], 0)

        checks = {
            "mpirun": ls,
            "ompi_info": info,
            "oshmem_info": info,
            "oshrun": ls,
            "shmemrun": ls,
        }

        for binary in checks:
            options, expected, status = checks[binary]
            exe = join_path(self.prefix.bin, binary)
            reason = "test: checking {0} output".format(binary)
            self.run_test(
                exe, options, expected, status, installed=True, purpose=reason, skip_missing=True
            )

    def _test_check_versions(self):
        comp_vers = str(self.spec.compiler.version)
        spec_vers = str(self.spec.version)
        checks = {
            # Binaries available in at least versions 2.0.0 through 4.0.3
            "mpiCC": comp_vers,
            "mpic++": comp_vers,
            "mpicc": comp_vers,
            "mpicxx": comp_vers,
            "mpiexec": spec_vers,
            "mpif77": comp_vers,
            "mpif90": comp_vers,
            "mpifort": comp_vers,
            "mpirun": spec_vers,
            "ompi_info": spec_vers,
            "ortecc": comp_vers,
            "orterun": spec_vers,
            # Binaries available in versions 2.0.0 through 2.1.6
            "ompi-submit": spec_vers,
            "orte-submit": spec_vers,
            # Binaries available in versions 2.0.0 through 3.1.5
            "ompi-dvm": spec_vers,
            "orte-dvm": spec_vers,
            "oshcc": comp_vers,
            "oshfort": comp_vers,
            "oshmem_info": spec_vers,
            "oshrun": spec_vers,
            "shmemcc": comp_vers,
            "shmemfort": comp_vers,
            "shmemrun": spec_vers,
            # Binary available in version 3.1.0 through 3.1.5
            "prun": spec_vers,
            # Binaries available in versions 3.0.0 through 3.1.5
            "oshCC": comp_vers,
            "oshc++": comp_vers,
            "oshcxx": comp_vers,
            "shmemCC": comp_vers,
            "shmemc++": comp_vers,
            "shmemcxx": comp_vers,
        }

        for binary in checks:
            expected = checks[binary]
            purpose = "test: ensuring version of {0} is {1}".format(binary, expected)
            exe = join_path(self.prefix.bin, binary)
            self.run_test(
                exe, "--version", expected, installed=True, purpose=purpose, skip_missing=True
            )

    @property
    def _cached_tests_work_dir(self):
        """The working directory for cached test sources."""
        return join_path(self.test_suite.current_test_cache_dir, self.extra_install_tests)

    def _test_examples(self):
        """Run test examples copied from source at build-time."""
        # Build the copied, cached test examples
        self.run_test(
            "make",
            ["all"],
            [],
            purpose="test: building cached test examples",
            work_dir=self._cached_tests_work_dir,
        )

        # Run examples with known, simple-to-verify results
        have_spml = self.spec.satisfies("@2:2.1.6")

        hello_world = (["Hello, world", "I am", "0 of", "1"], 0)

        max_red = (["0/1 dst = 0 1 2"], 0)

        missing_spml = (["No available spml components"], 1)

        no_out = ([""], 0)

        ring_out = (["1 processes in ring", "0 exiting"], 0)

        strided = (["not in valid range"], 255)

        checks = {
            "hello_c": hello_world,
            "hello_cxx": hello_world,
            "hello_mpifh": hello_world,
            "hello_oshmem": hello_world if have_spml else missing_spml,
            "hello_oshmemcxx": hello_world if have_spml else missing_spml,
            "hello_oshmemfh": hello_world if have_spml else missing_spml,
            "hello_usempi": hello_world,
            "hello_usempif08": hello_world,
            "oshmem_circular_shift": ring_out if have_spml else missing_spml,
            "oshmem_max_reduction": max_red if have_spml else missing_spml,
            "oshmem_shmalloc": no_out if have_spml else missing_spml,
            "oshmem_strided_puts": strided if have_spml else missing_spml,
            "oshmem_symmetric_data": no_out if have_spml else missing_spml,
            "ring_c": ring_out,
            "ring_cxx": ring_out,
            "ring_mpifh": ring_out,
            "ring_oshmem": ring_out if have_spml else missing_spml,
            "ring_oshmemfh": ring_out if have_spml else missing_spml,
            "ring_usempi": ring_out,
            "ring_usempif08": ring_out,
        }

        for exe in checks:
            expected, status = checks[exe]
            reason = "test: checking {0} example output and status ({1})".format(exe, status)
            self.run_test(
                exe,
                [],
                expected,
                status,
                installed=False,
                purpose=reason,
                skip_missing=True,
                work_dir=self._cached_tests_work_dir,
            )

    def test(self):
        """Perform stand-alone/smoke tests on the installed package."""
        # Simple version check tests on selected installed binaries
        self._test_check_versions()

        # Test the operation of selected executables
        self._test_bin_ops()

        # Test example programs pulled from the build
        self._test_examples()

    def flag_handler(self, name, flags):
        wrapper_flags = None

        if name == 'cflags':
            wrapper_flags = [f'-I{PMI_DEV_DIR}']

        return (wrapper_flags, None, flags)

def get_spack_compiler_spec(compiler):
    spack_compilers = spack.compilers.find_compilers([os.path.dirname(compiler)])
    actual_compiler = None
    # check if the compiler actually matches the one we want
    for spack_compiler in spack_compilers:
        if spack_compiler.cc and spack_compiler.cc == compiler:
            actual_compiler = spack_compiler
            break
    return actual_compiler.spec if actual_compiler else None

def is_enabled(text):
    if text in set(["t", "true", "enabled", "yes", "1"]):
        return True
    return False

def get_options_from_variant(self, name):
    values = self.variants[name][0].values
    if getattr(values, "feature_values", None):
        values = values.feature_values
    return values
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants