-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathINSTALL
51 lines (38 loc) · 2.49 KB
/
INSTALL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
This file describes how to build and install GPTL. For information on using
the library, see the web pages in the doc/ directory or at the GPTL home page
at github (https://jmrosinski.github.io/GPTL/), and also the man pages which
are provided with the distribution.
The build procedure is basic autoconf:
% ./configure; make; make check; make install.
Usually you'll want to specify C and Fortran compilers with
environment variables. To enable MPI support, use the wrappers, e.g.
% env CC=mpicc FC=mpif90 ./configure --prefix=</installation/directory>
The "configure" script automatically tests for MPI functionality and includes
it if it proves functional. "configure" also automatically tests for OpenMP
functionality (unless --disable-openmp is specified), and includes support if
OpenMP tests succeed.
Other switches to "configure" you may want to consider setting include:
--enable-pmpi: Enables MPI auto-profiling with the PMPI layer provided by most
MPI distros. Requires MPI-capable C compiler or wrapper, such as mpicc.
--enable-papi: Enables PAPI (Performance API) support for hardware performance
counters (https://icl.utk.edu/papi/). The PAPI lib must be installed in order
for this option to work. Use environment variables $CPPFLAGS and $LDFLAGS to
point to the installation if it is not in a standard place.
--enable-nestedomp: Enables support for OpenMP apps utilizing nested OMP
constructs. Use this only if you really need it. It adds significant overhead.
--disable-shared: Build only a static library. Standard autoconf behavior for
libraries is to build shared libraries (.so files).
--disable-libunwind: Disables use of libunwind for discovering the name of
auto-profiled user functions. Otherwise the "configure" script will check for
availability and usability of the backtrace() function which does not require
linking with any additional libraries. Libunwind is preferred though, as it
is more modern, and from empirical observation seems to do a more accurate job
unwinding the call stack. Note that in each case (libunwind and backtrace),
adding "-rdynamic" to link flags is often very helpful to being able to
determine function name. Applications using auto-profiling also should be
linked with "-g" to ensure their symbol names are included.
There are other options (see ./configure --help), but these are the main ones
folks generally use.
The "make install" step installs the built library, man page documentation,
and also gptl.pc for optional use by applications which can make use of
pkg-config.